gdb_test_multiple: Fix user code argument processing
authorPedro Alves <palves@redhat.com>
Tue, 7 Apr 2015 17:19:30 +0000 (18:19 +0100)
committerPedro Alves <palves@redhat.com>
Tue, 7 Apr 2015 17:27:24 +0000 (18:27 +0100)
While teaching gdb_test_multiple to forward "-i" to gdb_expect, I
found that with:

      gdb_test_multiple (...) {
        -i $some_variable -re "..." {}
      }

$some_variable was not getting expanded in the gdb_test_multiple
caller's scope.  This is a bug inside gdb_test_multiple.  When
processing an argument in passed in user code, it was appending the
original argument literally, instead of appending the uplist'ed
argument.

gdb/testsuite/ChangeLog:
2015-04-07  Pedro Alves  <palves@redhat.com>

        * lib/gdb.exp (gdb_test_multiple): When processing an argument,
append the substituted item, not the original item.

gdb/testsuite/ChangeLog
gdb/testsuite/lib/gdb.exp

index 82544a0..694b1c8 100644 (file)
@@ -1,5 +1,10 @@
 2015-04-07  Pedro Alves  <palves@redhat.com>
 
+        * lib/gdb.exp (gdb_test_multiple): When processing an argument,
+       append the substituted item, not the original item.
+
+2015-04-07  Pedro Alves  <palves@redhat.com>
+
        * gdb.base/interrupt.exp: Use gdb_test_multiple instead of
        gdb_expect.
 
index e0a03ec..203b8cf 100644 (file)
@@ -730,7 +730,7 @@ proc gdb_test_multiple { command message user_code } {
        }
        if { $expecting_arg } {
            set expecting_arg 0
-           lappend processed_code $item
+           lappend processed_code $subst_item
            continue
        }
        if { $expecting_action } {