Skip to content

Commit 09224a3

Browse files
committed
Fix \watch's interaction with libedit on ^C.
When you hit ^C, the terminal driver in Unix-like systems echoes "^C" as well as sending an interrupt signal (depending on stty settings). At least libedit (but maybe also libreadline) is then confused about the current cursor location, and corrupts the display if you try to scroll back. Fix, by moving to a new line before the next prompt is displayed. Back-patch to all supported released. Author: Pavel Stehule <pavel.stehule@gmail.com> Reported-by: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://postgr.es/m/3278793.1626198638%40sss.pgh.pa.us
1 parent f02f0b8 commit 09224a3

File tree

1 file changed

+8
-0
lines changed

1 file changed

+8
-0
lines changed

src/bin/psql/command.c

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4675,6 +4675,14 @@ do_watch(PQExpBuffer query_buf, double sleep)
46754675
sigint_interrupt_enabled = false;
46764676
}
46774677

4678+
/*
4679+
* If the terminal driver echoed "^C", libedit/libreadline might be
4680+
* confused about the cursor position. Therefore, inject a newline
4681+
* before the next prompt is displayed.
4682+
*/
4683+
fprintf(stdout, "\n");
4684+
fflush(stdout);
4685+
46784686
pg_free(title);
46794687
return (res >= 0);
46804688
}

0 commit comments

Comments
 (0)