diff options
author | Daniel Jacobowitz <drow@false.org> | 2002-03-30 23:47:18 +0000 |
---|---|---|
committer | Daniel Jacobowitz <drow@false.org> | 2002-03-30 23:47:18 +0000 |
commit | 1e50cda1d1dcced52bba66fbb9343b05a9d65666 (patch) | |
tree | 448f4bc009f935c374f20c0b3d190e2b649a1ecb /gdb/testsuite/gdb.base/dbx.exp | |
parent | 24015922ffbd541dfb49ea2e60bdae8b3d84b371 (diff) | |
download | gdb-1e50cda1d1dcced52bba66fbb9343b05a9d65666.zip gdb-1e50cda1d1dcced52bba66fbb9343b05a9d65666.tar.gz gdb-1e50cda1d1dcced52bba66fbb9343b05a9d65666.tar.bz2 |
2002-03-30 Daniel Jacobowitz <drow@mvista.com>
Fix PR gdb/452
* gdb.base/dbx.exp: Restore old definition of gdb_file_cmd
when finished. Make gdb_file_cmd send "exec-file" when
appropriate.
Diffstat (limited to 'gdb/testsuite/gdb.base/dbx.exp')
-rw-r--r-- | gdb/testsuite/gdb.base/dbx.exp | 28 |
1 files changed, 13 insertions, 15 deletions
diff --git a/gdb/testsuite/gdb.base/dbx.exp b/gdb/testsuite/gdb.base/dbx.exp index 9df3bda..161333c 100644 --- a/gdb/testsuite/gdb.base/dbx.exp +++ b/gdb/testsuite/gdb.base/dbx.exp @@ -168,6 +168,11 @@ proc dbx_reinitialize_dir { subdir } { # file into gdb for a dbx session. So why not just override gdb_file_cmd with the # right sequence of events, allowing gdb_load to do its normal thing? This way # remotes and simulators will work, too. +# +# [drow 2002-03-30]: We can restore the old gdb_file_cmd afterwards, though. +set old_gdb_file_cmd_args [info args gdb_file_cmd] +set old_gdb_file_cmd_body [info body gdb_file_cmd] + proc gdb_file_cmd {arg} { global verbose global loadpath @@ -206,6 +211,11 @@ proc gdb_file_cmd {arg} { verbose "\t\tLoaded $arg into the $GDB" send_gdb "exec-file $arg\n" gdb_expect { + -re "A program is being debugged already.*Kill it.*y or n. $" { + send_gdb "y\n" + verbose "\t\tKilling previous program being debugged" + exp_continue + } -re ".*$gdb_prompt $" { verbose "\t\tLoaded $arg with new symbol table into $GDB" return 0 @@ -221,23 +231,9 @@ proc gdb_file_cmd {arg} { perror "$arg wasn't compiled with \"-g\"" return -1 } - -re "A program is being debugged already.*Kill it.*y or n. $" { - send_gdb "y\n" - verbose "\t\tKilling previous program being debugged" - exp_continue - } -re "Load new symbol table from \".*\".*y or n. $" { send_gdb "y\n" - gdb_expect { - -re "Reading symbols from.*done.*$gdb_prompt $" { - verbose "\t\tLoaded $arg with new symbol table into $GDB" - return 0 - } - timeout { - perror "(timeout) Couldn't load $arg, other program already loaded." - return -1 - } - } + exp_continue } -re ".*No such file or directory.*$gdb_prompt $" { perror "($arg) No such file or directory\n" @@ -339,4 +335,6 @@ test_func gdb_exit set GDBFLAGS $saved_gdbflags +eval proc gdb_file_cmd {$old_gdb_file_cmd_args} {$old_gdb_file_cmd_body} + return 0 |