1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-09 17:38:00 +00:00

pageant --foreground: close stdout after printing env setup.

This is a small refinement of my own to Marco Ricci's new mode
introduced by the previous commit. If Pageant is being run by a parent
process intending to make requests to it, then it's probably put a
pipe on Pageant's stdout, and will be reading from that pipe to
retrieve the environment setup commands. So it needs to know when it's
read enough.

Closing stdout immediately makes this as easy as possible, freeing the
parent process of the need to count lines of output (and also know how
many lines to expect): it can simply read until there's no more data.

This also means there's no need to make stdout line-buffered, of
course – the fclose will flush it anyway.
This commit is contained in:
Simon Tatham 2024-09-23 09:16:14 +01:00
parent 2b93417398
commit 10b5c1163c
2 changed files with 12 additions and 1 deletions

View File

@ -193,6 +193,15 @@ to standard input. This is useful if Pageant is spawned by a parent
process that controls or otherwise programmatically interfaces with process that controls or otherwise programmatically interfaces with
Pageant. Pageant.
\lcont{
After Pageant prints its environment setup commands, it closes its
standard output, so that the parent process can simply read until it
receives EOF, instead of having to know how many lines of output to
expect.
}
\S{pageant-manpage-client} CLIENT OPTIONS \S{pageant-manpage-client} CLIENT OPTIONS
The following options tell Pageant to operate in client mode, The following options tell Pageant to operate in client mode,

View File

@ -1224,8 +1224,10 @@ void run_agent(FILE *logfp, const char *symlink_path)
} else if (life == LIFE_PERM) { } else if (life == LIFE_PERM) {
pageant_fork_and_print_env(false); pageant_fork_and_print_env(false);
} else if (life == LIFE_FOREGROUND) { } else if (life == LIFE_FOREGROUND) {
setvbuf(stdout, NULL, _IOLBF, 0);
pageant_print_env(getpid()); pageant_print_env(getpid());
/* Close stdout, so that a parent process at the other end of a pipe
* can do the simple thing of reading up to EOF */
fclose(stdout);
} else if (life == LIFE_DEBUG) { } else if (life == LIFE_DEBUG) {
/* Force stdout to be line-buffered in preference to unbuffered, so /* Force stdout to be line-buffered in preference to unbuffered, so
* that if diagnostic output is being piped somewhere, it will arrive * that if diagnostic output is being piped somewhere, it will arrive