diff options
author | Paul Brook <paul@codesourcery.com> | 2004-08-31 23:43:21 +0000 |
---|---|---|
committer | Paul Brook <pbrook@gcc.gnu.org> | 2004-08-31 23:43:21 +0000 |
commit | 244fada7d093f23e27bbb8af97d99bb9a876e9b0 (patch) | |
tree | ac565ec762faca9922dc3c698e1b3b01925bef82 | |
parent | a0ca8e0c48cbda3a4f82d32b0d6659f0f82085e9 (diff) | |
download | gcc-244fada7d093f23e27bbb8af97d99bb9a876e9b0.zip gcc-244fada7d093f23e27bbb8af97d99bb9a876e9b0.tar.gz gcc-244fada7d093f23e27bbb8af97d99bb9a876e9b0.tar.bz2 |
error.c (generate_error): Set both iostat and library_return.
* runtime/error.c (generate_error): Set both iostat and
library_return.
testsuite/
* gfortran.dg/eof_2.f90: New test.
From-SVN: r86852
-rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/eof_2.f90 | 13 | ||||
-rw-r--r-- | libgfortran/ChangeLog | 5 | ||||
-rw-r--r-- | libgfortran/runtime/error.c | 13 |
4 files changed, 29 insertions, 6 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index a71d3aa..3dae964 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2004-09-01 Paul Brook <paul@codesourcery.com> + + * gfortran.dg/eof_2.f90: New test. + 2004-08-31 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de> PR fortran/16579 diff --git a/gcc/testsuite/gfortran.dg/eof_2.f90 b/gcc/testsuite/gfortran.dg/eof_2.f90 new file mode 100644 index 0000000..b7c2c91 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/eof_2.f90 @@ -0,0 +1,13 @@ +! { dg-do run } +! Check that end= and iostat= specifiers are honoured when both are used +program eof_2 + integer ierr, i + + open (11, status="SCRATCH") + ierr = 0 + read (11, *, end=10, iostat=ierr) i + call abort +10 continue + if (ierr .ge. 0) call abort +end program + diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index 50ad7a6..891c74e 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,8 @@ +2004-09-01 Paul Brook <paul@codesourcery.com> + + * runtime/error.c (generate_error): Set both iostat and + library_return. + 2004-08-31 Paul Brook <paul@codesourcery.com> PR libfortran/16805 diff --git a/libgfortran/runtime/error.c b/libgfortran/runtime/error.c index 74670b5..5eb5b0b 100644 --- a/libgfortran/runtime/error.c +++ b/libgfortran/runtime/error.c @@ -445,13 +445,11 @@ translate_error (int code) void generate_error (int family, const char *message) { - + /* Set the error status. */ if (ioparm.iostat != NULL) - { - *ioparm.iostat = family; - return; - } + *ioparm.iostat = family; + /* Report status back to the compiler. */ switch (family) { case ERROR_EOR: @@ -468,10 +466,13 @@ generate_error (int family, const char *message) default: ioparm.library_return = LIBRARY_ERROR; + if (ioparm.err != 0) + return; break; } - if (ioparm.err != 0) + /* Return if the user supplied an iostat variable. */ + if (ioparm.iostat != NULL) return; /* Terminate the program */ |