From: Tom Tromey Date: Mon, 13 Apr 2020 18:42:59 +0000 (-0600) Subject: Introduce and use flush_streams X-Git-Url: http://git.efficios.com/?a=commitdiff_plain;h=c1cd3163d99efe4f7cbe7f228859fd93f28e06bb;p=deliverable%2Fbinutils-gdb.git Introduce and use flush_streams Code in gdbsupport can't call gdb_flush, so this introduces a new "flush_streams" function that must be supplied by the client. Note that the similar gdb_flush_out_err exists, but it isn't defined in quite the same way, so it wasn't clear to me whether the two could be merged. gdb/ChangeLog 2020-04-13 Tom Tromey * utils.c (flush_streams): New function. * event-loop.c (gdb_wait_for_event): Call flush_streams. gdbsupport/ChangeLog 2020-04-13 Tom Tromey * errors.h (flush_streams): Declare. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index d4facee888..c0b3ae78d3 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2020-04-13 Tom Tromey + + * utils.c (flush_streams): New function. + * event-loop.c (gdb_wait_for_event): Call flush_streams. + 2020-04-13 Tom Tromey * event-loop.c (handle_file_event): Use warning, not diff --git a/gdb/event-loop.c b/gdb/event-loop.c index a5d2f6fa1c..4ce8899612 100644 --- a/gdb/event-loop.c +++ b/gdb/event-loop.c @@ -663,8 +663,7 @@ gdb_wait_for_event (int block) int num_found = 0; /* Make sure all output is done before getting another event. */ - gdb_stdout->flush (); - gdb_stderr->flush (); + flush_streams (); if (gdb_notifier.num_fds == 0) return -1; diff --git a/gdb/utils.c b/gdb/utils.c index f5b20331b1..2f2cd845c4 100644 --- a/gdb/utils.c +++ b/gdb/utils.c @@ -691,6 +691,15 @@ malloc_failure (long size) } } +/* See common/errors.h. */ + +void +flush_streams () +{ + gdb_stdout->flush (); + gdb_stderr->flush (); +} + /* My replacement for the read system call. Used like `read' but keeps going if `read' returns too soon. */ diff --git a/gdbsupport/ChangeLog b/gdbsupport/ChangeLog index 880a6ae765..a065a9abaf 100644 --- a/gdbsupport/ChangeLog +++ b/gdbsupport/ChangeLog @@ -1,3 +1,7 @@ +2020-04-13 Tom Tromey + + * errors.h (flush_streams): Declare. + 2020-04-13 Tom Tromey * gdb_select.h: Move from ../gdb/. diff --git a/gdbsupport/errors.h b/gdbsupport/errors.h index da13482798..f8f6c157f2 100644 --- a/gdbsupport/errors.h +++ b/gdbsupport/errors.h @@ -87,4 +87,8 @@ extern void perror_with_name (const char *string) ATTRIBUTE_NORETURN; extern void malloc_failure (long size) ATTRIBUTE_NORETURN; +/* Flush stdout and stderr. Must be provided by the client. */ + +extern void flush_streams (); + #endif /* COMMON_ERRORS_H */