Implement System Input Handling for CLI Execution #384
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This commit implements a solution to handle system input within the Command-Line Interface (CLI), as in Issue #353.
Implemented changes:
SystemIO::setCLIInput(),
was added in thesystemio.h
file that sets the input stream toSTDIN
. This method is used only by the CLI, which doesn't support multi-thread execution and thus cannot rely on the same input handling methods as the GUI. The GUI has a dedicated thread for reading console input, while other threads manage the rest of the program.readFromFile()
method was updated to handleSTDIN
input differently. Whenfd == STDIN
, it now reads one byte at a time usingInputStream.read(1)
. This continues until the specified number of bytes (lengthRequested
) is reached or a newline ('\n'
) character is encountered.This change ensures that both the GUI and CLI can correctly handle
STDIN
input. Without reading one byte at a time, the CLI could not properly process inputs of a size different from the requested length, since there isn't a function likeputStdInData(const QByteArray &data)
in the CLI that pushes data into thestdin
buffer object.Ripes/src/syscall/systemio.h
Lines 458 to 463 in 290c0e6
For the GUI, STDIN is handled through the
QTextStream
object, which is linked in theConsoleWidget
:Ripes/src/consolewidget.cpp
Lines 23 to 25 in 290c0e6
To integrate the new input handling in the CLI, a call to
SystemIO::setCLIInput()
is added in theCLIRunner
constructor to set the input stream toSTDIN
:With these changes the
STDIN
input can be handled in both Ripes mode (GUI and CLI).