Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature request: Add support for pty fds in process #399

Open
leha-bot opened this issue Sep 9, 2024 · 3 comments
Open

Feature request: Add support for pty fds in process #399

leha-bot opened this issue Sep 9, 2024 · 3 comments

Comments

@leha-bot
Copy link

leha-bot commented Sep 9, 2024

The main use case is for batch run some apps which doesn't understand "non-tty" stdin.

Windows supports this from win10 , 1803 and requires the special HANDLEs created via CreatePseudoConsole
Linux creates these pty via openpty(3).

@klemens-morgenstern
Copy link
Collaborator

What do you have in mind here? An IO Object for the ability to set this for a subprocess?

@leha-bot
Copy link
Author

I thought about some kind of API like
(it's not exactly boost process API, just bikeshedding in bp v1 API style):

bp::pty pty;
bp::process child("/some/binary", bp::std_in > pty, bp::std_out < pty);

std::string process_output_line;
pty >> process_output_line; // read string from process (until first space , or use std::getline())
pty << 15; // write to child' stdin via pty

Currently, there is no portable way (at least I tried to (ab)use the posix file descriptors, but no luck, pipe helpers won't work with same pty fd and either copies them, or hangs)

@klemens-morgenstern
Copy link
Collaborator

I did some work here: https://github.com/boostorg/process/tree/pty

I don't think I'll finish it, the windows API is just too hostile and the posix one is straight forward enough to not need built-in support.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants