From: Tom Tromey Date: Tue, 2 Jun 2026 17:27:15 +0000 (-0600) Subject: Print command trace to gdb_stdlog X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=e4d214db01492b035874eaac2c3a022e6c3d5bc8;p=thirdparty%2Fbinutils-gdb.git Print command trace to gdb_stdlog I recently wanted to enable some gdb logging when running the internal AdaCore test suite. To do this nicely, I enable debug-redirect early in the test, so that the logging output does not affect the test results. I also wanted to the log the commands, to correlate what I see in the debug log with what I see in the ordinary test suite log file (which is basically like our own gdb.log). However, I found that "set trace-commands on" will log to stdout, not stdlog. This patch changes this to log to the log file instead. --- diff --git a/gdb/cli/cli-script.c b/gdb/cli/cli-script.c index b8312f431cb..0a1208845b4 100644 --- a/gdb/cli/cli-script.c +++ b/gdb/cli/cli-script.c @@ -486,8 +486,6 @@ ATTRIBUTE_PRINTF (1, 2) void print_command_trace (const char *fmt, ...) { - int i; - if (suppress_next_print_command_trace) { suppress_next_print_command_trace = false; @@ -497,15 +495,15 @@ print_command_trace (const char *fmt, ...) if (!source_verbose && !trace_commands) return; - for (i=0; i < command_nest_depth; i++) - gdb_printf ("+"); + for (int i = 0; i < command_nest_depth; ++i) + gdb_printf (gdb_stdlog, "+"); va_list args; va_start (args, fmt); - gdb_vprintf (fmt, args); + gdb_vprintf (gdb_stdlog, fmt, args); va_end (args); - gdb_puts ("\n"); + gdb_puts ("\n", gdb_stdlog); } /* Helper for execute_control_command. */ diff --git a/gdb/testsuite/gdb.base/ui-redirect.exp b/gdb/testsuite/gdb.base/ui-redirect.exp index 313843e3626..bed11bd2e87 100644 --- a/gdb/testsuite/gdb.base/ui-redirect.exp +++ b/gdb/testsuite/gdb.base/ui-redirect.exp @@ -135,6 +135,12 @@ with_test_prefix "redirect debugging" { "Copying output to /dev/null.*Redirecting debug output to /dev/null\\." gdb_test "continue" "Continuing.*((?!infrun).).*Breakpoint ${::decimal}, bar.*" gdb_test "set debug infrun 0" + + # The trace should be sent to the log, not stdout. + gdb_test_no_output "set trace-commands on" + gdb_test_no_output {printf ""} + gdb_test_no_output "set trace-commands off" + gdb_test "set logging enabled off" "Done logging to /dev/null\\." gdb_test "help" "List of classes of commands:.*" }