re PR libfortran/33672 (Additional runtime checks needed for namelist reads)
2007-10-14 Jerry DeLisle <jvdelisle@gcc.gnu.org> PR libfortran/33672 * gfortran.dg/namelist_40.f90: New test. From-SVN: r129310
This commit is contained in:
parent
45dfbe77d2
commit
5012f3e3c7
@ -1,3 +1,8 @@
|
||||
2007-10-14 Jerry DeLisle <jvdelisle@gcc.gnu.org>
|
||||
|
||||
PR libfortran/33672
|
||||
* gfortran.dg/namelist_40.f90: New test.
|
||||
|
||||
2007-10-14 Tobias Burnus <burnus@net-b.de>
|
||||
|
||||
PR fortran/33745
|
||||
|
54
gcc/testsuite/gfortran.dg/namelist_40.f90
Normal file
54
gcc/testsuite/gfortran.dg/namelist_40.f90
Normal file
@ -0,0 +1,54 @@
|
||||
! { dg-do run }
|
||||
! PR33672 Additional runtime checks needed for namelist reads
|
||||
! Submitted by Jerry DeLisle <jvdelisle@gcc.gnu.org>
|
||||
|
||||
module global
|
||||
type :: mt
|
||||
character(len=2) :: ch(2) = (/"aa","bb"/)
|
||||
end type mt
|
||||
type :: bt
|
||||
integer :: i(2) = (/1,2/)
|
||||
type(mt) :: m(2)
|
||||
end type bt
|
||||
end module global
|
||||
|
||||
program namelist_40
|
||||
use global
|
||||
type(bt) :: x(2)
|
||||
character(40) :: teststring
|
||||
namelist /mynml/ x
|
||||
|
||||
teststring = " x(2)%m%ch(:)(2:2) = 'z','z',"
|
||||
call writenml (teststring)
|
||||
teststring = " x(2)%m(2)%ch(:)(2) = 'z','z',"
|
||||
call writenml (teststring)
|
||||
teststring = " x(2)%m(2)%ch(:)(:3) = 'z','z',"
|
||||
call writenml (teststring)
|
||||
teststring = " x(2)%m(2)%ch(1:2)(k:) = 'z','z',"
|
||||
call writenml (teststring)
|
||||
|
||||
contains
|
||||
|
||||
subroutine writenml (astring)
|
||||
character(40), intent(in) :: astring
|
||||
character(300) :: errmessage
|
||||
integer :: ierror
|
||||
|
||||
open (10, status="scratch", delim='apostrophe')
|
||||
write (10, '(A)') "&MYNML"
|
||||
write (10, '(A)') astring
|
||||
write (10, '(A)') "/"
|
||||
rewind (10)
|
||||
read (10, nml = mynml, iostat=ierror, iomsg=errmessage)
|
||||
if (ierror == 0) call abort
|
||||
print '(a)', trim(errmessage)
|
||||
close (10)
|
||||
|
||||
end subroutine writenml
|
||||
|
||||
end program namelist_40
|
||||
! { dg-output "Multiple sub-objects with non-zero rank in namelist object x(\n|\r\n|\r)" }
|
||||
! { dg-output "Missing colon in substring qualifier for namelist variable x%m%ch(\n|\r\n|\r)" }
|
||||
! { dg-output "Substring out of range for namelist variable x%m%ch(\n|\r\n|\r)" }
|
||||
! { dg-output "Bad character in substring qualifier for namelist variable x%m%ch(\n|\r\n|\r)" }
|
||||
! { dg-final { cleanup-modules "global" } }
|
Loading…
Reference in New Issue
Block a user