diff options
author | Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> | 2014-06-06 19:57:51 +0000 |
---|---|---|
committer | François-Xavier Coudert <fxcoudert@gcc.gnu.org> | 2014-06-06 19:57:51 +0000 |
commit | 72b572cbb3a3d90cfbbaa0b6ee1bc13a0d42f9a4 (patch) | |
tree | 8b454b97eddbf10a2a219e8ffc857d06daa03131 /gcc | |
parent | 7b11cab795af9c578a20c0909f3f6edbb31c0879 (diff) | |
download | gcc-72b572cbb3a3d90cfbbaa0b6ee1bc13a0d42f9a4.zip gcc-72b572cbb3a3d90cfbbaa0b6ee1bc13a0d42f9a4.tar.gz gcc-72b572cbb3a3d90cfbbaa0b6ee1bc13a0d42f9a4.tar.bz2 |
io.c (resolve_tag): Warn on non-default kind for NUMBER...
* io.c (resolve_tag): Warn on non-default kind for NUMBER,
NEXTREC, RECL, NAMED, OPENED and PENDING I/O specifiers.
* gfortran.dg/io_constraints_11.f90: New file.
* gfortran.dg/io_constraints_12.f90: New file.
* gfortran.dg/io_constraints_13.f90: New file.
From-SVN: r211323
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/fortran/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/fortran/io.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/io_constraints_11.f90 | 36 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/io_constraints_12.f90 | 36 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/io_constraints_13.f90 | 35 |
6 files changed, 124 insertions, 3 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index a62e8a7..c292130 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,8 @@ +2014-06-06 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> + + * io.c (resolve_tag): Warn on non-default kind for NUMBER, + NEXTREC, RECL, NAMED, OPENED and PENDING I/O specifiers. + 2014-06-06 Jakub Jelinek <jakub@redhat.com> * dump-parse-tree.c (show_omp_namelist): Dump reduction diff --git a/gcc/fortran/io.c b/gcc/fortran/io.c index 84d0db8..731c6dc 100644 --- a/gcc/fortran/io.c +++ b/gcc/fortran/io.c @@ -1497,7 +1497,8 @@ resolve_tag (const io_tag *tag, gfc_expr *e) return false; } - if ((tag == &tag_iostat || tag == &tag_size || tag == &tag_iolength) + if ((tag == &tag_iostat || tag == &tag_size || tag == &tag_iolength + || tag == &tag_number || tag == &tag_nextrec || tag == &tag_s_recl) && e->ts.kind != gfc_default_integer_kind) { if (!gfc_notify_std (GFC_STD_F2003, "Fortran 95 requires default " @@ -1505,9 +1506,11 @@ resolve_tag (const io_tag *tag, gfc_expr *e) return false; } - if (tag == &tag_exist && e->ts.kind != gfc_default_logical_kind) + if (e->ts.kind != gfc_default_logical_kind && + (tag == &tag_exist || tag == &tag_named || tag == &tag_opened + || tag == &tag_pending)) { - if (!gfc_notify_std (GFC_STD_F2008, "Nondefault LOGICAL " + if (!gfc_notify_std (GFC_STD_F2008, "Non-default LOGICAL kind " "in %s tag at %L", tag->name, &e->where)) return false; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index eba01f0..d2e2a4b 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2014-06-06 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> + + * gfortran.dg/io_constraints_11.f90: New file. + * gfortran.dg/io_constraints_12.f90: New file. + * gfortran.dg/io_constraints_13.f90: New file. + 2014-06-06 Uros Bizjak <ubizjak@gmail.com> PR target/61423 diff --git a/gcc/testsuite/gfortran.dg/io_constraints_11.f90 b/gcc/testsuite/gfortran.dg/io_constraints_11.f90 new file mode 100644 index 0000000..911c866 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/io_constraints_11.f90 @@ -0,0 +1,36 @@ +! { dg-do compile } +! { dg-options "-std=f95" } +! +! Test our conformance to item 4.9 ("Kind type parameters of integer +! specifiers") of the Fortran 2003 status document at +! ftp://ftp.nag.co.uk/sc22wg5/N1551-N1600/N1579.pdf +! +! The non-default integer variables are allowed since Fortran 2003. +! The non-default logical variables are allowed since Fortran 2008. + + integer(kind=8) :: i, j, k, n + logical(kind=8) :: l1, l2, l3 + + open(10, status="scratch", iostat=i) ! { dg-error "requires default INTEGER" } + + backspace(10, iostat=i) ! { dg-error "requires default INTEGER" } + endfile(10, iostat=i) ! { dg-error "requires default INTEGER" } + rewind(10, iostat=i) ! { dg-error "requires default INTEGER" } + + read(*, '(I2)', iostat=i) k ! { dg-error "requires default INTEGER" } + read(*, '(I2)', advance='no', size=j) k ! { dg-error "requires default INTEGER" } + + inquire(iolength=i) "42" ! { dg-error "requires default INTEGER" } + inquire(10, iostat=i) ! { dg-error "requires default INTEGER" } + inquire(10, number=j) ! { dg-error "requires default INTEGER" } + inquire(10, recl=k) ! { dg-error "requires default INTEGER" } + inquire(10, nextrec=n) ! { dg-error "requires default INTEGER" } + + inquire(10, exist=l1) ! { dg-error "Non-default LOGICAL kind" } + inquire(10, named=l3) ! { dg-error "Non-default LOGICAL kind" } + inquire(10, opened=l2) ! { dg-error "Non-default LOGICAL kind" } + inquire(10, pending=l2) ! { dg-error "Non-default LOGICAL kind" } + + close(10, iostat=i) ! { dg-error "requires default INTEGER" } + +end diff --git a/gcc/testsuite/gfortran.dg/io_constraints_12.f90 b/gcc/testsuite/gfortran.dg/io_constraints_12.f90 new file mode 100644 index 0000000..78f11c5 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/io_constraints_12.f90 @@ -0,0 +1,36 @@ +! { dg-do compile } +! { dg-options "-std=f2003" } +! +! Test our conformance to item 4.9 ("Kind type parameters of integer +! specifiers") of the Fortran 2003 status document at +! ftp://ftp.nag.co.uk/sc22wg5/N1551-N1600/N1579.pdf +! +! The non-default integer variables are allowed since Fortran 2003. +! The non-default logical variables are allowed since Fortran 2008. + + integer(kind=8) :: i, j, k, n + logical(kind=8) :: l1, l2, l3 + + open(10, status="scratch", iostat=i) + + backspace(10, iostat=i) + endfile(10, iostat=i) + rewind(10, iostat=i) + + read(*, '(I2)', iostat=i) k + read(*, '(I2)', advance='no', size=j) k + + inquire(iolength=i) "42" + inquire(10, iostat=i) + inquire(10, number=j) + inquire(10, recl=k) + inquire(10, nextrec=n) + + inquire(10, exist=l1) ! { dg-error "Non-default LOGICAL kind" } + inquire(10, named=l3) ! { dg-error "Non-default LOGICAL kind" } + inquire(10, opened=l2) ! { dg-error "Non-default LOGICAL kind" } + inquire(10, pending=l2) ! { dg-error "Non-default LOGICAL kind" } + + close(10, iostat=i) + +end diff --git a/gcc/testsuite/gfortran.dg/io_constraints_13.f90 b/gcc/testsuite/gfortran.dg/io_constraints_13.f90 new file mode 100644 index 0000000..f57edf7 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/io_constraints_13.f90 @@ -0,0 +1,35 @@ +! { dg-do compile } +! +! Test our conformance to item 4.9 ("Kind type parameters of integer +! specifiers") of the Fortran 2003 status document at +! ftp://ftp.nag.co.uk/sc22wg5/N1551-N1600/N1579.pdf +! +! The non-default integer variables are allowed since Fortran 2003. +! The non-default logical variables are allowed since Fortran 2008. + + integer(kind=8) :: i, j, k, n + logical(kind=8) :: l1, l2, l3 + + open(10, status="scratch", iostat=i) + + backspace(10, iostat=i) + endfile(10, iostat=i) + rewind(10, iostat=i) + + read(*, '(I2)', iostat=i) k + read(*, '(I2)', advance='no', size=j) k + + inquire(iolength=i) "42" + inquire(10, iostat=i) + inquire(10, number=j) + inquire(10, recl=k) + inquire(10, nextrec=n) + + inquire(10, exist=l1) + inquire(10, named=l3) + inquire(10, opened=l2) + inquire(10, pending=l2) + + close(10, iostat=i) + +end |