aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRob Savoye <rob@cygnus>1993-03-22 04:30:50 +0000
committerRob Savoye <rob@cygnus>1993-03-22 04:30:50 +0000
commita309ee82f3b098c37196d96ad6e8052b99f7f70d (patch)
treecbe2255aedf88aeb16c48d3cc359369543ee1008
parent3d0bd7d39ada4aa4d20e0c0d0e84af082d409982 (diff)
downloadgdb-a309ee82f3b098c37196d96ad6e8052b99f7f70d.zip
gdb-a309ee82f3b098c37196d96ad6e8052b99f7f70d.tar.gz
gdb-a309ee82f3b098c37196d96ad6e8052b99f7f70d.tar.bz2
Fixed a bunch of missing return codes, misc bugs.
-rw-r--r--gdb/testsuite/config/unix-gdb.exp120
1 files changed, 86 insertions, 34 deletions
diff --git a/gdb/testsuite/config/unix-gdb.exp b/gdb/testsuite/config/unix-gdb.exp
index 2e5a117..69cf6d1 100644
--- a/gdb/testsuite/config/unix-gdb.exp
+++ b/gdb/testsuite/config/unix-gdb.exp
@@ -15,7 +15,7 @@
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
# Please email any bugs, comments, and/or additions to this file to:
-# DejaGnu@cygnus.com
+# bug-dejagnu@prep.ai.mit.edu
# This file was written by Rob Savoye. (rob@cygnus.com)
@@ -91,37 +91,49 @@ proc gdb_load { arg } {
set loadpath [file dirname $arg]
send "file $arg\n"
expect {
- -re "Reading symbols from.*done.*$prompt $"\
- { if $verbose>1 then {
+ -re "Reading symbols from.*done.*$prompt $" {
+ if $verbose>1 then {
send_user "\t\tLoaded $arg into the $GDB\n"
}
}
-re "has no symbol-table.*$prompt $" {
- error "$arg wasn't compiled with \"-g\"\n"
+ error "$arg wasn't compiled with \"-g\""
return -1
}
- -re "A program is being debugged already..*Kill it\? \(y or n\) $"\
- { send "y\n"
+ -re "A program is being debugged already..*Kill it\? \(y or n\) $" {
+ send "y\n"
if $verbose>1 then {
send_user "\t\tKilling previous program being debugged\n"
}
continue -expect
}
- -re "Load new symbol table from.*\? \(y or n\) $"\
- { send "y\n"
+ -re "Load new symbol table from.*\? \(y or n\) $" {
+ send "y\n"
expect {
- -re "Reading symbols from.*done.*$prompt $"
- { if $verbose>1 then {
+ -re "Reading symbols from.*done.*$prompt $" {
+ if $verbose>1 then {
send_user "\t\tLoaded $arg with new symbol table into $GDB\n"
}
+ return 0
}
- timeout { error "(timeout) Couldn't load $arg, other program already loaded."; return -1 }
+ timeout {
+ error "(timeout) Couldn't load $arg, other program already loaded."
+ return -1
+ }
+ }
+ }
+ -re ".*No such file or directory.*$prompt $" {
+ error "($arg) No such file or directory\n"
+ return -1
+ }
+ -re "$prompt $" {
+ error "couldn't load $arg into $GDB."
+ return -1
}
+ timeout {
+ error "couldn't load $arg into $GDB (timed out)."
+ return -1
}
- -re ".*No such file or directory.*$prompt $"\
- { error "($arg) No such file or directory\n"; return -1 }
- -re "$prompt $" { error "couldn't load $arg into $GDB."; return -1 }
- timeout { error "couldn't load $arg into $GDB (timed out)."; return -1 }
}
}
@@ -138,10 +150,11 @@ proc gdb_exit {} {
send_user "Quitting $GDB $GDBFLAGS\n"
}
catch "send \"quit\n\"" result
- if [string match "write\(spawn_id=\[0-9\]+\): Bad file number" $result] then {
+ if [string match "write\(spawn_id=\[0-9\]+\):" $result] then {
catch "close"
- return 0
+ return -1
}
+ catch {
expect {
eof {
if $verbose>1 then {
@@ -154,14 +167,15 @@ proc gdb_exit {} {
}
close
}
- -re "The program is running. Quit anyway? (y or n) $"\
- { send "y\n"
+ -re "The program is running. Quit anyway? (y or n) $" {
+ send "y\n"
if $verbose>1 then {
send_user "\t\tKilling program being debugged\n"
}
close
}
}
+ }
catch "close"
if $verbose>1 then {
@@ -189,34 +203,66 @@ proc gdb_start {} {
if [ llength $GDBFLAGS ] then {
spawn $GDB $GDBFLAGS
} else {
+ if {[which $GDB] != 0} then {
spawn $GDB
+ } else {
+ error "Can't find $GDB"
+ }
}
expect {
- -re ".*$prompt $" { if $verbose>1 then {
- send_user "GDB initialized for native mode\n" }
+ -re ".*$prompt $" {
+ if $verbose>1 then {
+ send_user "GDB initialized for native mode\n"
+ }
+ }
+ -re "$prompt $" {
+ error "GDB never initialized."
+ return -1
+ }
+ timeout {
+ error "(timeout) GDB never initialized."
+ return -1
}
- -re "$prompt $" { error "GDB never initialized."; return -1 }
- timeout { error "(timeout) GDB never initialized."; return -1 }
}
set timeout $oldtimeout
# force the height to "unlimited", so no pagers get used
send "set height 0\n"
- expect -re ".*$prompt $" {}
+ expect {
+ -re ".*$prompt $" {
+ if $verbose>2 then {
+ send_user "Seting height to 0.\n"
+ }
+ }
+ timeout {
+ warning "Couldn't set the height to 0."
+ }
+ }
# force the width to "unlimited", so no wraparound occurs
send "set width 0\n"
- expect -re ".*$prompt $" {}
+ expect {
+ -re ".*$prompt $" {
+ if $verbose>2 then {
+ send_user "Seting width to 0.\n"
}
-
-expect_after {
- "<return>" { send "\n"; error "Window too small." }
- -re "\(y or n\) " { send "n\n"; error "Got interactive prompt." }
- buffer_full { error "internal buffer is full." }
- eof { error "eof -- pty is hosed." }
- timeout { error "timeout." }
- "virtual memory exhausted" { error "virtual memory exhausted." }
- "Undefined command" { error "send string probably wrong." }
+ }
+ timeout {
+ warning "Couldn't set the width to 0."
+}
+ }
}
+# These only need to be uncommented for debugging test cases. They exist
+# mainly to catch programming errors
+#expect_after {
+# "<return>" { send "\n"; error "Window too small." }
+# -re "\(y or n\) " { send "n\n"; error "Got interactive prompt." }
+# buffer_full { error "internal buffer is full." }
+# eof { error "eof -- there is no child process" ; alldone}
+# timeout { error "timeout." }
+# "virtual memory exhausted" { error "virtual memory exhausted." }
+# "Undefined command" { error "send string probably wrong." }
+#}
+
load_lib gdb.exp
set binpath /s1/users/rob/vxworks/bin/somewhere-bogus-that-needs-configuring
@@ -224,3 +270,9 @@ set bin $GDB
gdb_start
+
+
+
+
+
+