* pr-6292.ch, pr-6292.exp, Makefile.in: New test case.
authorPer Bothner <per@bothner.com>
Sun, 12 Feb 1995 19:47:48 +0000 (19:47 +0000)
committerPer Bothner <per@bothner.com>
Sun, 12 Feb 1995 19:47:48 +0000 (19:47 +0000)
gdb/testsuite/gdb.chill/.Sanitize
gdb/testsuite/gdb.chill/ChangeLog
gdb/testsuite/gdb.chill/Makefile.in
gdb/testsuite/gdb.chill/pr-6292.ch [new file with mode: 0644]
gdb/testsuite/gdb.chill/pr-6292.exp [new file with mode: 0644]

index ca6e8ee258396453d4fbc073db49debdcd857e47..e5e380e86392e3dcd3892e2bed035cbb48d5b54a 100644 (file)
@@ -40,6 +40,8 @@ pr-5022.exp
 pr-5646.ch
 pr-5646-grt.ch
 pr-5646.exp
+pr-6292.ch
+pr-6292.exp
 result.ch
 result.exp
 tuples.ch
index 25ff307be15fe17e35969a42536e4df1f13f97d8..3ddad40fff64ecb833438909c5cc2fe206e24f37 100644 (file)
@@ -1,3 +1,7 @@
+Sun Feb 12 11:26:08 1995  Per Bothner  <bothner@kalessin.cygnus.com>
+
+       * pr-6292.ch, pr-6292.exp, Makefile.in:  New test case.
+
 Wed Feb  1 13:09:48 1995  Per Bothner  <bothner@kalessin.cygnus.com>
 
        * tuples.ch, tuples.exp, Makefile.in:  New test case.
index c8fe5fb7a2ae6deead227180f672711fbb0da874..2cd447b140b8eda8c750f22ff8925d82972350d9 100644 (file)
@@ -103,7 +103,8 @@ GDBFLAGS = -nx
 #### host, target, and site specific Makefile frags come in here.
 
 EXECUTABLES = chillvars.exe result.exe tuples.exe \
-  pr-4975.exe pr-5016.exe pr-5020.exe pr-5022.exe pr-5646.exe pr-5984.exe
+  pr-4975.exe pr-5016.exe pr-5020.exe pr-5022.exe pr-5646.exe pr-5984.exe \
+  pr-6292.exe
 
 all:   $(EXECUTABLES)
 
diff --git a/gdb/testsuite/gdb.chill/pr-6292.ch b/gdb/testsuite/gdb.chill/pr-6292.ch
new file mode 100644 (file)
index 0000000..c2ed953
--- /dev/null
@@ -0,0 +1,17 @@
+hack : module
+
+dcl i int;
+
+fred : proc (a int in, b int loc);
+  writetext(stdout, "a was '%C'; b was '%C'.%/", a, b);
+  b + := 1;
+end fred;
+
+klaus : proc ();
+  writetext(stdout, "here's klaus calling.%/");
+end klaus;
+
+i:=12;
+writetext(stdout, "done.%/");
+
+end hack;
diff --git a/gdb/testsuite/gdb.chill/pr-6292.exp b/gdb/testsuite/gdb.chill/pr-6292.exp
new file mode 100644 (file)
index 0000000..a01e08b
--- /dev/null
@@ -0,0 +1,59 @@
+# Copyright (C) 1995 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+# 
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+# 
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
+
+# Please email any bugs, comments, and/or additions to this file to:
+# bug-gdb@prep.ai.mit.edu
+
+# This file was written by Per Bothner. (bothner@cygnus.com)
+
+if $tracelevel then {
+       strace $tracelevel
+}
+
+proc do_tests {} {
+    global prms_id bug_id subdir objdir srcdir binfile prompt
+
+    set prms_id 0
+    set bug_id 0
+
+    # Start with a fresh gdb.
+
+    gdb_exit
+    gdb_start
+    gdb_reinitialize_dir $srcdir/$subdir
+    gdb_load $objdir/$subdir/$binfile
+
+    send "set language chill\n" ; 
+
+    send "break pr-6292.ch:15\n"; expect -re "$prompt $"
+    send "run\n"; expect -re "Breakpoint .*pr-6292.ch:15.*$prompt $"
+    gdb_test_exact "call klaus()" {here's klaus calling.}
+    gdb_test {set fred(10, i)} {a was '10'; b was '12'.}
+    test_print_accept "print i" {13} "print i after call"
+}
+
+# Check to see if we have an executable to test.  If not, then either we
+# haven't tried to compile one, or the compilation failed for some reason.
+# In either case, just notify the user and skip the tests in this file.
+
+set binfile "pr-6292.exe"
+set srcfile $binfile.ch
+
+if ![file exists $objdir/$subdir/$binfile] then {
+    warning "$binfile does not exist; tests suppressed."
+} else {
+    do_tests
+}