io/process: emit read for data remaining in buffer on exit

This commit is contained in:
outfoxxed 2025-05-24 02:39:01 -07:00
parent 89e796cb21
commit c4a7d16478
Signed by untrusted user: outfoxxed
GPG key ID: 4C88A185FB89301E
3 changed files with 8 additions and 0 deletions

View file

@ -98,6 +98,10 @@ void SplitParser::parseBytes(QByteArray& incoming, QByteArray& buffer) {
}
}
void SplitParser::streamEnded(QByteArray& buffer) {
if (!buffer.isEmpty()) emit this->read(QString(buffer));
}
QString SplitParser::splitMarker() const { return this->mSplitMarker; }
void SplitParser::setSplitMarker(QString marker) {

View file

@ -54,6 +54,7 @@ public:
// the buffer will be sent in both slots if there is data remaining from a previous parser
virtual void parseBytes(QByteArray& incoming, QByteArray& buffer) = 0;
virtual void streamEnded(QByteArray& /*buffer*/) {};
signals:
/// Emitted when data is read from the stream.
@ -75,6 +76,7 @@ public:
explicit SplitParser(QObject* parent = nullptr): DataStreamParser(parent) {}
void parseBytes(QByteArray& incoming, QByteArray& buffer) override;
void streamEnded(QByteArray& buffer) override;
[[nodiscard]] QString splitMarker() const;
void setSplitMarker(QString marker);

View file

@ -254,6 +254,8 @@ void Process::onStarted() {
void Process::onFinished(qint32 exitCode, QProcess::ExitStatus exitStatus) {
this->process->deleteLater();
this->process = nullptr;
if (this->mStdoutParser) this->mStdoutParser->streamEnded(this->stdoutBuffer);
if (this->mStderrParser) this->mStderrParser->streamEnded(this->stderrBuffer);
this->stdoutBuffer.clear();
this->stderrBuffer.clear();