re PR fortran/55818 (Reading a REAL from a file which doesn't end in a new line fails)
2013-01-02 Jerry DeLisle <jvdelisle@gcc.gnu.org> PR fortran/55818 * gfortran.dg/eof_4.f90: New test. From-SVN: r194819
This commit is contained in:
parent
6a7da30fd7
commit
3fd005a689
@ -1,3 +1,8 @@
|
||||
2013-01-02 Jerry DeLisle <jvdelisle@gcc.gnu.org>
|
||||
|
||||
PR fortran/55818
|
||||
* gfortran.dg/eof_4.f90: New test.
|
||||
|
||||
2013-01-02 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* lib/c-compat.exp (compat-use-alt-compiler): Remove
|
||||
|
130
gcc/testsuite/gfortran.dg/eof_4.f90
Normal file
130
gcc/testsuite/gfortran.dg/eof_4.f90
Normal file
@ -0,0 +1,130 @@
|
||||
! { dg-do run }
|
||||
! PR55818 Reading a REAL from a file which doesn't end in a new line fails
|
||||
! Test case from PR reporter.
|
||||
implicit none
|
||||
integer :: stat
|
||||
!integer :: var ! << works
|
||||
real :: var ! << fails
|
||||
character(len=10) :: cvar ! << fails
|
||||
complex :: cval
|
||||
logical :: lvar
|
||||
|
||||
open(99, file="test.dat", access="stream", form="unformatted", status="new")
|
||||
write(99) "1", new_line("")
|
||||
write(99) "2", new_line("")
|
||||
write(99) "3"
|
||||
close(99)
|
||||
|
||||
! Test character kind
|
||||
open(99, file="test.dat")
|
||||
read (99,*, iostat=stat) cvar
|
||||
if (stat /= 0 .or. cvar /= "1") call abort()
|
||||
read (99,*, iostat=stat) cvar
|
||||
if (stat /= 0 .or. cvar /= "2") call abort()
|
||||
read (99,*, iostat=stat) cvar ! << FAILS: stat /= 0
|
||||
if (stat /= 0 .or. cvar /= "3") call abort() ! << aborts here
|
||||
|
||||
! Test real kind
|
||||
rewind(99)
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0 .or. var /= 1.0) call abort()
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0 .or. var /= 2.0) call abort()
|
||||
read (99,*, iostat=stat) var ! << FAILS: stat /= 0
|
||||
if (stat /= 0 .or. var /= 3.0) call abort()
|
||||
close(99, status="delete")
|
||||
|
||||
! Test real kind with exponents
|
||||
open(99, file="test.dat", access="stream", form="unformatted", status="new")
|
||||
write(99) "1.0e3", new_line("")
|
||||
write(99) "2.0e-03", new_line("")
|
||||
write(99) "3.0e2"
|
||||
close(99)
|
||||
|
||||
open(99, file="test.dat")
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0) call abort()
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0) call abort()
|
||||
read (99,*) var ! << FAILS: stat /= 0
|
||||
if (stat /= 0) call abort()
|
||||
close(99, status="delete")
|
||||
|
||||
! Test logical kind
|
||||
open(99, file="test.dat", access="stream", form="unformatted", status="new")
|
||||
write(99) "Tru", new_line("")
|
||||
write(99) "fal", new_line("")
|
||||
write(99) "t"
|
||||
close(99)
|
||||
|
||||
open(99, file="test.dat")
|
||||
read (99,*, iostat=stat) lvar
|
||||
if (stat /= 0 .or. (.not.lvar)) call abort()
|
||||
read (99,*, iostat=stat) lvar
|
||||
if (stat /= 0 .or. lvar) call abort()
|
||||
read (99,*) lvar ! << FAILS: stat /= 0
|
||||
if (stat /= 0 .or. (.not.lvar)) call abort()
|
||||
close(99, status="delete")
|
||||
|
||||
! Test combinations of Inf and Nan
|
||||
open(99, file="test.dat", access="stream", form="unformatted", status="new")
|
||||
write(99) "infinity", new_line("")
|
||||
write(99) "nan", new_line("")
|
||||
write(99) "infinity"
|
||||
close(99)
|
||||
|
||||
open(99, file="test.dat")
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0) call abort()
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0) call abort()
|
||||
read (99,*) var ! << FAILS: stat /= 0
|
||||
if (stat /= 0) call abort ! << aborts here
|
||||
close(99, status="delete")
|
||||
|
||||
open(99, file="test.dat", access="stream", form="unformatted", status="new")
|
||||
write(99) "infinity", new_line("")
|
||||
write(99) "inf", new_line("")
|
||||
write(99) "nan"
|
||||
close(99)
|
||||
|
||||
open(99, file="test.dat")
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0) call abort()
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0) call abort()
|
||||
read (99,*) var ! << FAILS: stat /= 0
|
||||
if (stat /= 0) call abort ! << aborts here
|
||||
close(99, status="delete")
|
||||
|
||||
open(99, file="test.dat", access="stream", form="unformatted", status="new")
|
||||
write(99) "infinity", new_line("")
|
||||
write(99) "nan", new_line("")
|
||||
write(99) "inf"
|
||||
close(99)
|
||||
|
||||
open(99, file="test.dat")
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0) call abort()
|
||||
read (99,*, iostat=stat) var
|
||||
if (stat /= 0) call abort()
|
||||
read (99,*) var ! << FAILS: stat /= 0
|
||||
if (stat /= 0) call abort ! << aborts here
|
||||
close(99, status="delete")
|
||||
|
||||
! Test complex kind
|
||||
open(99, file="test.dat", access="stream", form="unformatted", status="new")
|
||||
write(99) "(1,2)", new_line("")
|
||||
write(99) "(2,3)", new_line("")
|
||||
write(99) "(4,5)"
|
||||
close(99)
|
||||
|
||||
open(99, file="test.dat")
|
||||
read (99,*, iostat=stat) cval
|
||||
if (stat /= 0 .or. cval /= cmplx(1,2)) call abort()
|
||||
read (99,*, iostat=stat) cval
|
||||
if (stat /= 0 .or. cval /= cmplx(2,3)) call abort()
|
||||
read (99,*, iostat=stat) cval ! << FAILS: stat /= 0, value is okay
|
||||
if (stat /= 0 .or. cval /= cmplx(4,5)) call abort()
|
||||
close(99, status="delete")
|
||||
end
|
Loading…
Reference in New Issue
Block a user