From: Lennart Poettering Date: Mon, 22 Dec 2014 19:33:45 +0000 (+0100) Subject: machinectl,nspawn: don't print extra final newline if pty terminal output was newline... X-Git-Tag: v219~881 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=c7b7d4493aa03e9ef5fb1e670b8969a48aa494dd machinectl,nspawn: don't print extra final newline if pty terminal output was newline-terinated anyway --- diff --git a/src/machine/machinectl.c b/src/machine/machinectl.c index 4eebcb771..f5b87a23d 100644 --- a/src/machine/machinectl.c +++ b/src/machine/machinectl.c @@ -1110,6 +1110,7 @@ static int login_machine(int argc, char *argv[], void *userdata) { pid_t leader; sigset_t mask; int r, ret = 0; + char last_char = 0; assert(bus); @@ -1186,9 +1187,12 @@ static int login_machine(int argc, char *argv[], void *userdata) { if (r < 0) return log_error_errno(r, "Failed to run event loop: %m"); + pty_forward_last_char(forward, &last_char); + forward = pty_forward_free(forward); - fputc('\n', stdout); + if (last_char != '\n') + fputc('\n', stdout); log_info("Connection to container %s terminated.", argv[1]); diff --git a/src/nspawn/nspawn.c b/src/nspawn/nspawn.c index f1f9b7828..01b8c3203 100644 --- a/src/nspawn/nspawn.c +++ b/src/nspawn/nspawn.c @@ -3462,6 +3462,7 @@ int main(int argc, char *argv[]) { if (barrier_place_and_sync(&barrier)) { _cleanup_event_unref_ sd_event *event = NULL; _cleanup_(pty_forward_freep) PTYForward *forward = NULL; + char last_char = 0; int ifi = 0; r = move_network_interfaces(pid); @@ -3531,9 +3532,11 @@ int main(int argc, char *argv[]) { goto finish; } + pty_forward_last_char(forward, &last_char); + forward = pty_forward_free(forward); - if (!arg_quiet) + if (!arg_quiet && last_char != '\n') putc('\n', stdout); /* Kill if it is not dead yet anyway */