diff options
author | Janne Blomqvist <jb@gcc.gnu.org> | 2016-10-16 09:28:15 +0300 |
---|---|---|
committer | Janne Blomqvist <jb@gcc.gnu.org> | 2016-10-16 09:28:15 +0300 |
commit | 9937c1eb7288216e4b59303389d64ff1125516f0 (patch) | |
tree | a341f4354565e5e662dd7a014dc22f320f207565 /libgfortran | |
parent | 4698eb35ad78f3ed657e644218438fcab73c4ef1 (diff) | |
download | gcc-9937c1eb7288216e4b59303389d64ff1125516f0.tar.gz |
PR 48587 Newunit allocator, cleanup
Improve error message, and remove a redundant check, as the same check is
done a bit earlier due to the PR 48587 patch.
2016-10-16 Janne Blomqvist <jb@gcc.gnu.org>
PR libfortran/48587
* io/transfer.c (data_transfer_init): Improve error message,
remove redundant check.
Regtested on x86_64-pc-linux-gnu.
From-SVN: r241211
Diffstat (limited to 'libgfortran')
-rw-r--r-- | libgfortran/ChangeLog | 6 | ||||
-rw-r--r-- | libgfortran/io/transfer.c | 11 |
2 files changed, 8 insertions, 9 deletions
diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index bf7af2b4dbb..bfda86df86c 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,9 @@ +2016-10-16 Janne Blomqvist <jb@gcc.gnu.org> + + PR libfortran/48587 + * io/transfer.c (data_transfer_init): Improve error message, + remove redundant check. + 2016-10-15 Janne Blomqvist <jb@gcc.gnu.org> PR libfortran/48587 diff --git a/libgfortran/io/transfer.c b/libgfortran/io/transfer.c index 7696cca2306..2232417af6b 100644 --- a/libgfortran/io/transfer.c +++ b/libgfortran/io/transfer.c @@ -2606,7 +2606,8 @@ data_transfer_init (st_parameter_dt *dtp, int read_flag) /* This means we tried to access an external unit < 0 without having opened it first with NEWUNIT=. */ generate_error (&dtp->common, LIBERROR_BAD_OPTION, - "Invalid unit number in statement"); + "Unit number is negative and unit was not already " + "opened with OPEN(NEWUNIT=...)"); return; } else if (dtp->u.p.current_unit->s == NULL) @@ -2614,14 +2615,6 @@ data_transfer_init (st_parameter_dt *dtp, int read_flag) st_parameter_open opp; unit_convert conv; - if (dtp->common.unit < 0 && !is_internal_unit (dtp)) - { - close_unit (dtp->u.p.current_unit); - dtp->u.p.current_unit = NULL; - generate_error (&dtp->common, LIBERROR_BAD_OPTION, - "Bad unit number in statement"); - return; - } memset (&u_flags, '\0', sizeof (u_flags)); u_flags.access = ACCESS_SEQUENTIAL; u_flags.action = ACTION_READWRITE; |