Index: gdb/mi/mi-console.c |
diff --git a/gdb/mi/mi-console.c b/gdb/mi/mi-console.c |
index 6b4601b224b135ce097790c7cbd321df4e57114e..b04e65cc447374a58fe0d4c8de6e828f6585432f 100644 |
--- a/gdb/mi/mi-console.c |
+++ b/gdb/mi/mi-console.c |
@@ -19,12 +19,15 @@ |
You should have received a copy of the GNU General Public License |
along with this program. If not, see <http://www.gnu.org/licenses/>. */ |
+/* An MI console is a kind of ui_file stream that sends output to |
+ stdout, but encapsulated and prefixed with a distinctive string; |
+ for instance, error output is normally identified by a leading |
+ "&". */ |
+ |
#include "defs.h" |
#include "mi-console.h" |
#include "gdb_string.h" |
-/* MI-console: send output to std-out but correcty encapsulated */ |
- |
static ui_file_fputs_ftype mi_console_file_fputs; |
static ui_file_flush_ftype mi_console_file_flush; |
static ui_file_delete_ftype mi_console_file_delete; |
@@ -38,11 +41,15 @@ struct mi_console_file |
char quote; |
}; |
-int mi_console_file_magic; |
+/* Use the address of this otherwise-unused global as a magic number |
+ identifying this class of ui_file objects. */ |
+static int mi_console_file_magic; |
+ |
+/* Create a console that wraps the given output stream RAW with the |
+ string PREFIX and quoting it with QUOTE. */ |
struct ui_file * |
-mi_console_file_new (struct ui_file *raw, |
- const char *prefix, char quote) |
+mi_console_file_new (struct ui_file *raw, const char *prefix, char quote) |
{ |
struct ui_file *ui_file = ui_file_new (); |
struct mi_console_file *mi_console = XMALLOC (struct mi_console_file); |
@@ -55,6 +62,7 @@ mi_console_file_new (struct ui_file *raw, |
set_ui_file_fputs (ui_file, mi_console_file_fputs); |
set_ui_file_flush (ui_file, mi_console_file_flush); |
set_ui_file_data (ui_file, mi_console, mi_console_file_delete); |
+ |
return ui_file; |
} |
@@ -66,36 +74,36 @@ mi_console_file_delete (struct ui_file *file) |
if (mi_console->magic != &mi_console_file_magic) |
internal_error (__FILE__, __LINE__, |
_("mi_console_file_delete: bad magic number")); |
+ |
xfree (mi_console); |
} |
static void |
-mi_console_file_fputs (const char *buf, |
- struct ui_file *file) |
+mi_console_file_fputs (const char *buf, struct ui_file *file) |
{ |
struct mi_console_file *mi_console = ui_file_data (file); |
if (mi_console->magic != &mi_console_file_magic) |
internal_error (__FILE__, __LINE__, |
"mi_console_file_fputs: bad magic number"); |
- /* Append the text to our internal buffer */ |
+ |
+ /* Append the text to our internal buffer. */ |
fputs_unfiltered (buf, mi_console->buffer); |
- /* Flush when an embedded \n */ |
+ /* Flush when an embedded newline is present anywhere in the buffer. */ |
if (strchr (buf, '\n') != NULL) |
gdb_flush (file); |
} |
-/* Transform a byte sequence into a console output packet. */ |
+/* Transform a byte sequence into a console output packet. */ |
+ |
static void |
-mi_console_raw_packet (void *data, |
- const char *buf, |
- long length_buf) |
+mi_console_raw_packet (void *data, const char *buf, long length_buf) |
{ |
struct mi_console_file *mi_console = data; |
if (mi_console->magic != &mi_console_file_magic) |
internal_error (__FILE__, __LINE__, |
- _("mi_console_file_transform: bad magic number")); |
+ _("mi_console_raw_packet: bad magic number")); |
if (length_buf > 0) |
{ |
@@ -124,6 +132,24 @@ mi_console_file_flush (struct ui_file *file) |
if (mi_console->magic != &mi_console_file_magic) |
internal_error (__FILE__, __LINE__, |
_("mi_console_file_flush: bad magic number")); |
+ |
ui_file_put (mi_console->buffer, mi_console_raw_packet, mi_console); |
ui_file_rewind (mi_console->buffer); |
+ |
+} |
+ |
+/* Change the underlying stream of the console directly; this is |
+ useful as a minimum-impact way to reflect external changes like |
+ logging enable/disable. */ |
+ |
+void |
+mi_console_set_raw (struct ui_file *file, struct ui_file *raw) |
+{ |
+ struct mi_console_file *mi_console = ui_file_data (file); |
+ |
+ if (mi_console->magic != &mi_console_file_magic) |
+ internal_error (__FILE__, __LINE__, |
+ _("mi_console_file_set_raw: bad magic number")); |
+ |
+ mi_console->raw = raw; |
} |