fix typo during interactive_mode check in gdb_has_a_terminal
authorJoel Brobecker <brobecker@gnat.com>
Mon, 31 Jan 2011 03:11:40 +0000 (03:11 +0000)
committerJoel Brobecker <brobecker@gnat.com>
Mon, 31 Jan 2011 03:11:40 +0000 (03:11 +0000)
Discovered by Pierre Muller.

gdb/ChangeLog:

        * inflow.c (gdb_has_a_terminal): Fix typo in interactive_mode
        value test.

gdb/testsuite/ChangeLog:

        * gdb.base/interact.exp: Add extra tests that verify that
        the value of the interactive-mode setting does not change
        after the script is sourced.

gdb/ChangeLog
gdb/inflow.c
gdb/testsuite/ChangeLog
gdb/testsuite/gdb.base/interact.exp

index 373ccfc094837006cc770f8e147e85c1fed4eb87..9c18a83e74032e0902fc81705cbfac2ed500274e 100644 (file)
@@ -1,3 +1,8 @@
+2011-01-31  Joel Brobecker  <brobecker@adacore.com>
+
+       * inflow.c (gdb_has_a_terminal): Fix typo in interactive_mode
+       value test.
+
 2011-01-31  Yao Qi  <yao@codesourcery.com>
 
        * arm-linux-nat.c: Update calls to regcache_register_status
index 859c74e0274d4ba11793671cd26bd9688c6bba37..99759049746f8aa630062d72bc090afdc5bc1696 100644 (file)
@@ -165,7 +165,7 @@ int
 gdb_has_a_terminal (void)
 {
   if (interactive_mode != AUTO_BOOLEAN_AUTO)
-    return interactive_mode = AUTO_BOOLEAN_TRUE;
+    return interactive_mode == AUTO_BOOLEAN_TRUE;
 
   switch (gdb_has_a_terminal_flag)
     {
index 1b63bff51ab641255ac165e87235ba1ea9899332..d05b6e6956de4022be37aaaca22edf3080143b73 100644 (file)
@@ -1,3 +1,9 @@
+2011-01-31  Joel Brobecker  <brobecker@adacore.com>
+
+       * gdb.base/interact.exp: Add extra tests that verify that
+       the value of the interactive-mode setting does not change
+       after the script is sourced.
+
 2011-01-29  Jan Kratochvil  <jan.kratochvil@redhat.com>
 
        * gdb.cp/noparam.exp: New file.
index 1f15fd862ed16943f6525b1ad6a373da6a569c9a..59caf1b81506560e7472481a89c6eb657a7cb9e8 100644 (file)
@@ -28,21 +28,36 @@ set script_output "\\$\[0-9\]+ = 1\[\r\n\]+\\$\[0-9\]+ = 2.*"
 gdb_exit
 gdb_start
 
-# Test sourcing of the script with interactive mode `auto'
+# Test sourcing of the script with interactive mode `auto'.
+# Verify that evaluating the script does not cause an unexpected
+# change of the interactive-mode setting.
 gdb_test_no_output "set interactive-mode auto"
 gdb_test "source zzz-gdbscript" "$script_output" \
          "source script with interactive-mode auto"
 gdb_test "print 3" "= 3" "sanity check with interactive-mode auto"
+gdb_test "show interactive-mode" \
+         "Debugger's interactive mode is auto \\(currently .*\\)\\." \
+         "show interactive-mode (auto)"
 
-# Test sourcing of the script with interactive mode `on'
+# Test sourcing of the script with interactive mode `on'.
+# Verify that evaluating the script does not cause an unexpected
+# change of the interactive-mode setting.
 gdb_test_no_output "set interactive-mode on"
 gdb_test "source zzz-gdbscript" "$script_output" \
          "source script with interactive-mode on"
 gdb_test "print 4" "= 4" "sanity check with interactive-mode on"
+gdb_test "show interactive-mode" \
+         "Debugger's interactive mode is on\\." \
+         "show interactive-mode (on)"
 
-# Test sourcing of the script with interactive mode `of'
+# Test sourcing of the script with interactive mode `off'.
+# Verify that evaluating the script does not cause an unexpected
+# change of the interactive-mode setting.
 gdb_test_no_output "set interactive-mode off"
 gdb_test "source zzz-gdbscript" "$script_output" \
          "source script with interactive-mode off"
 gdb_test "print 5" "= 5" "sanity check with interactive-mode off"
+gdb_test "show interactive-mode" \
+         "Debugger's interactive mode is off\\." \
+         "show interactive-mode (off)"