#command-output #pty #tty #process #terminal #logging #exec

app faketty

Wrapper to exec a command in a pty, even if redirecting the output

19 stable releases

1.0.18 Aug 11, 2024
1.0.17 May 25, 2024
1.0.16 Feb 29, 2024
1.0.14 Dec 21, 2023
1.0.1 Sep 21, 2020

#49 in Command line utilities

Download history 69/week @ 2024-09-18 109/week @ 2024-09-25 33/week @ 2024-10-02 34/week @ 2024-10-09 26/week @ 2024-10-16 27/week @ 2024-10-23 38/week @ 2024-10-30 32/week @ 2024-11-06 24/week @ 2024-11-13 26/week @ 2024-11-20 30/week @ 2024-11-27 41/week @ 2024-12-04 64/week @ 2024-12-11 19/week @ 2024-12-18 11/week @ 2024-12-25 201/week @ 2025-01-01

319 downloads per month

MIT/Apache

12KB
174 lines

faketty

github crates.io build status

A wrapper binary to exec a command in a pty, even if redirecting the output.

This allows logging the stdout and stderr (separately) of a process, without the output being different from what you'd see in the terminal if you weren't logging anything.

$ cargo install faketty
$ faketty bazel build :target >log/out 2>log/err
          ~~~~~~~~~~~~~~~~~~~ command to run

Background

When redirecting stdout/err to a pipe or file, a process may detect the output is no longer going to a tty (because it has no width/height, baud rate, etc) and may change its behavior accordingly. For example many programs that involve a progress bar or colored text in a terminal disable those things when the output is not going to a terminal.

There is a script(1) command which makes it possible to redirect a command's terminal-style output by executing it inside a pseudoterminal (pty) – a bidirectional pipe that also has width, height, etc and tricks the process into thinking it is talking to a real terminal. However, script only uses a single pty, which makes it impossible to demultiplex stdout and stderr to different places.

The faketty command in this repo is similar to script --quiet --return --command '...' /dev/null except that it preserves distinct stdout and stderr streams.


License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this program by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~3.5MB
~66K SLoC