diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index ba894d92ecf..b7a5f61d38e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-01-16 Bud Davis + + PR fortran/18778 + * gfortran.dg/endfile_2.f90: New test. + 2005-01-16 Steven G. Kargl PR 19168 diff --git a/gcc/testsuite/gfortran.dg/endfile_2.f90 b/gcc/testsuite/gfortran.dg/endfile_2.f90 new file mode 100644 index 00000000000..7f366f1e033 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/endfile_2.f90 @@ -0,0 +1,12 @@ +! { dg-do run } +! pr18778 abort on endfile without opening unit + program test + implicit none + integer i + endfile(8) + rewind(8) + read(8,end=0023)i + call abort ! should never get here + stop + 0023 continue + end diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index c0534b8ef44..d6bcb8d9cbb 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,9 @@ +2004-01-16 Bud Davis + + PR fortran/18778 + * io/transfer.c (us_read): no bytes available is not a + runtime error. + 2005-01-15 Bud Davis PR fortran/18983 diff --git a/libgfortran/io/transfer.c b/libgfortran/io/transfer.c index 54544079073..73ae853fc87 100644 --- a/libgfortran/io/transfer.c +++ b/libgfortran/io/transfer.c @@ -843,6 +843,9 @@ us_read (void) n = sizeof (gfc_offset); p = salloc_r (current_unit->s, &n); + if (n == 0) + return; /* end of file */ + if (p == NULL || n != sizeof (gfc_offset)) { generate_error (ERROR_BAD_US, NULL);