From 15c46491c2ae1e2a5a9168f78e05c76bc3eb31a8 Mon Sep 17 00:00:00 2001 From: Wu Zhou Date: Feb 24 2006 07:29:42 +0000 Subject: * gdb.fortran/derived-type.f90: New file. * gdb.fortran/derived-type.exp: New testcase. --- diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index aa36f61..d271dd5 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-02-24 Wu Zhou + + * gdb.fortran/derived-type.f90: New file. + * gdb.fortran/derived-type.exp: New testcase. + 2006-02-23 Daniel Jacobowitz * gdb.base/default.exp: Allow ';' as a directory separator. diff --git a/gdb/testsuite/gdb.fortran/derived-type.exp b/gdb/testsuite/gdb.fortran/derived-type.exp new file mode 100644 index 0000000..06c4839 --- /dev/null +++ b/gdb/testsuite/gdb.fortran/derived-type.exp @@ -0,0 +1,65 @@ +# Copyright 2005 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +# This file was written by Wu Zhou. (woodzltc@cn.ibm.com) + +# This file is part of the gdb testsuite. It contains tests for type-printing +# and value-printing Fortran derived types. + +if $tracelevel then { + strace $tracelevel +} + +set testfile "derived-type" +set srcfile ${testfile}.f90 +set binfile ${objdir}/${subdir}/${testfile} + +if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug f77 quiet}] != "" } { + untested "Couldn't compile ${srcfile}" + return -1 +} + +gdb_exit +gdb_start +gdb_reinitialize_dir $srcdir/$subdir +gdb_load ${binfile} + +if ![runto MAIN__] then { + perror "couldn't run to breakpoint MAIN__" + continue +} + +gdb_test "ptype p" \ + "type = Type bar.*int4.*\:\: c.*real.*\:\: d.*End Type bar" \ + "ptype p" +gdb_test "ptype q" \ + "type = Type foo.*real.*\:\: a.*Type bar.*int4.*\:\: c.*real.*\:\: d.*End Type bar \:\: x.*character.*\\(7\\) \:\: b.*End Type foo" \ + "type-printing for derived type" + +gdb_breakpoint [gdb_get_line_number "print"] +gdb_continue_to_breakpoint "print" + +gdb_test "print p" "\\$\[0-9\]+ = \\{ 1, 2.375\\}" +gdb_test "print p%c" "\\$\[0-9\]+ = 1" +gdb_test "print p%d" "\\$\[0-9\]+ = 2.375" +gdb_test "print q%a" "\\$\[0-9\]+ = 3.125" +gdb_test "print q%b" "\\$\[0-9\]+ = \\(.*a.*b.*c.*d.*e.*f.*g.*\\)" +gdb_test "print q%x%c" "\\$\[0-9\]+ = 1" +gdb_test "print q%x%d" "\\$\[0-9\]+ = 2.375" +gdb_test "print q" \ + "\\$\[0-9\]+ = \\{ 3.125, \\{ 1, 2.375\\}, \\(.*a.*b.*c.*d.*e.*f.*g.*\\)\\}" \ + "print q" + diff --git a/gdb/testsuite/gdb.fortran/derived-type.f90 b/gdb/testsuite/gdb.fortran/derived-type.f90 new file mode 100644 index 0000000..eb1ae8a --- /dev/null +++ b/gdb/testsuite/gdb.fortran/derived-type.f90 @@ -0,0 +1,41 @@ +! Copyright 2006 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +! +! Ihis file is the Fortran source file for derived-type.exp. It was written +! by Wu Zhou. (woodzltc@cn.ibm.com) + +program main + + type bar + integer :: c + real :: d + end type + type foo + real :: a + type(bar) :: x + character*7 :: b + end type foo + type(foo) :: q + type(bar) :: p + + p = bar(1, 2.375) + q%a = 3.125 + q%b = "abcdefg" + q%x%c = 1 + q%x%d = 2.375 + print *,p,q + +end program main