Make command-repeat work after gdb.execute
authorBenno Fünfstück <benno.fuenfstueck@gmail.com>
Wed, 21 Nov 2018 17:16:25 +0000 (17:16 +0000)
committerPedro Alves <palves@redhat.com>
Wed, 21 Nov 2018 17:16:25 +0000 (17:16 +0000)
Since commit

  56bcdbea2bed ("Let gdb.execute handle multi-line commands")

command repetition after using the `gdb.execute` Python function
fails (the previous command is not repeated anymore). This happens
because read_command_lines_1 sets dont_repeat, but the call to
prevent_dont_repeat in execute_gdb_command is later.

The fix is to move the call to prevent_dont_repeat to the beginning of
the function.

Tested on my laptop (ArchLinux-x86_64).

gdb/ChangeLog:

PR python/23714
* gdb/python/python.c (execute_gdb_command): Call
prevent_dont_repeat earlier to avoid affecting dont_repeat.

gdb/testuite/ChangeLog:

PR python/23714
* gdb.python/python.exp: Test command repetition after
gdb.execute.

gdb/ChangeLog
gdb/python/python.c
gdb/testsuite/ChangeLog
gdb/testsuite/gdb.python/python.exp

index 01fc8fa..22d9e77 100644 (file)
@@ -1,3 +1,9 @@
+2018-11-21  Benno Fünfstück  <benno.fuenfstueck@gmail.com>
+
+       PR python/23714
+       * gdb/python/python.c (execute_gdb_command): Call
+       prevent_dont_repeat earlier to avoid affecting dont_repeat.
+
 2018-11-08  Tom Tromey  <tom@tromey.com>
 
        PR gdb/23555:
index 55119cc..bc9f4e0 100644 (file)
@@ -584,6 +584,8 @@ execute_gdb_command (PyObject *self, PyObject *args, PyObject *kw)
 
   std::string to_string_res;
 
+  scoped_restore preventer = prevent_dont_repeat ();
+
   TRY
     {
       struct interp *interp;
@@ -611,7 +613,6 @@ execute_gdb_command (PyObject *self, PyObject *args, PyObject *kw)
       interp = interp_lookup (current_ui, "console");
       current_uiout = interp->interp_ui_out ();
 
-      scoped_restore preventer = prevent_dont_repeat ();
       if (to_string)
        to_string_res = execute_control_commands_to_string (lines.get (),
                                                            from_tty);
index 65557f4..a5e0a4f 100644 (file)
@@ -1,3 +1,9 @@
+2018-11-21  Benno Fünfstück  <benno.fuenfstueck@gmail.com>
+
+       PR python/23714
+       * gdb.python/python.exp: Test command repetition after
+       gdb.execute.
+
 2018-11-19  Pedro Alves  <palves@redhat.com>
 
        * gdb.base/warning.exp: Don't override INTERNAL_FLAGS.  Use
index a37113c..fca9ab0 100644 (file)
@@ -121,6 +121,7 @@ gdb_test "python print (x)" "23"
 
 gdb_test "python gdb.execute('echo 2\\necho 3\\\\n\\n')" "23" \
     "multi-line execute"
+gdb_test " " "23" "gdb.execute does not affect repeat history"
 
 # Test post_event.
 gdb_py_test_multiple "post event insertion" \