* gdb.fortran/derived-type.f90: New file.
* gdb.fortran/derived-type.exp: New testcase.
This commit is contained in:
parent
2a5e440cb4
commit
15c46491c2
@ -1,3 +1,8 @@
|
||||
2006-02-24 Wu Zhou <woodzltc@cn.ibm.com>
|
||||
|
||||
* gdb.fortran/derived-type.f90: New file.
|
||||
* gdb.fortran/derived-type.exp: New testcase.
|
||||
|
||||
2006-02-23 Daniel Jacobowitz <dan@codesourcery.com>
|
||||
|
||||
* gdb.base/default.exp: Allow ';' as a directory separator.
|
||||
|
65
gdb/testsuite/gdb.fortran/derived-type.exp
Normal file
65
gdb/testsuite/gdb.fortran/derived-type.exp
Normal file
@ -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"
|
||||
|
41
gdb/testsuite/gdb.fortran/derived-type.f90
Normal file
41
gdb/testsuite/gdb.fortran/derived-type.f90
Normal file
@ -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
|
Loading…
x
Reference in New Issue
Block a user