diff options
author | Jerry DeLisle <jvdelisle@gcc.gnu.org> | 2006-03-01 06:14:32 +0000 |
---|---|---|
committer | Jerry DeLisle <jvdelisle@gcc.gnu.org> | 2006-03-01 06:14:32 +0000 |
commit | c1fa1ae9be95a9d02b0f584387cbfb646f7383cd (patch) | |
tree | 471fc3a2d6c10e8787cea9e77e9d8ee7ffe19c13 | |
parent | c9f15d9c0efac092136e6a02da3aafb5b38e3480 (diff) | |
download | gcc-c1fa1ae9be95a9d02b0f584387cbfb646f7383cd.zip gcc-c1fa1ae9be95a9d02b0f584387cbfb646f7383cd.tar.gz gcc-c1fa1ae9be95a9d02b0f584387cbfb646f7383cd.tar.bz2 |
re PR libfortran/26136 (List directed input with underfilled (logicals) array read incorrectly)
2006-02-28 Jerry DeLisle <jvdelisle@gcc.gnu.org>
PR libgfortran/26136
* gfortran.dg/namelist_23.f90: New test.
From-SVN: r111598
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/namelist_23.f90 | 53 |
2 files changed, 58 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5b2507c..0b27651 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-02-28 Jerry DeLisle <jvdelisle@gcc.gnu.org> + + PR libgfortran/26136 + * gfortran.dg/namelist_23.f90: New test. + 2006-02-28 Roger Sayle <roger@eyesopen.com> PR middle-end/14752 diff --git a/gcc/testsuite/gfortran.dg/namelist_23.f90 b/gcc/testsuite/gfortran.dg/namelist_23.f90 new file mode 100644 index 0000000..70a0080 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/namelist_23.f90 @@ -0,0 +1,53 @@ +!{ dg-do run } +! PR26136 Filling logical variables from namelist read when object list is not +! complete. Test case derived from PR. +! Contributed by Jerry DeLisle <jvdelisle@gcc.gnu.org> +program read_logical + implicit none + logical, dimension(4) :: truely + integer, dimension(4) :: truely_a_very_long_variable_name + namelist /mynml/ truely + namelist /mynml/ truely_a_very_long_variable_name + + truely = .false. + truely_a_very_long_variable_name = 0 + + open(10, status="scratch") + write(10,*) "&mynml" + write(10,*) "truely = trouble, traffic .true" + write(10,*) "truely_a_very_long_variable_name = 4, 4, 4" + write(10,*) "/" + rewind(10) + read (10, nml=mynml, err = 1000) + if (.not.all(truely(1:3))) call abort() + if (.not.all(truely_a_very_long_variable_name(1:3).eq.4)) call abort() + + truely = .false. + truely_a_very_long_variable_name = 0 + + rewind(10) + write(10,*) "&mynml" + write(10,*) "truely = .true., .true.," + write(10,*) "truely_a_very_long_variable_name = 4, 4, 4" + write(10,*) "/" + rewind(10) + read (10, nml=mynml, err = 1000) + if (.not.all(truely(1:2))) call abort() + if (.not.all(truely_a_very_long_variable_name(1:3).eq.4)) call abort() + + truely = .true. + truely_a_very_long_variable_name = 0 + + rewind(10) + write(10,*) "&mynml" + write(10,*) "truely = .false., .false.," + write(10,*) "truely_a_very_long_variable_name = 4, 4, 4" + write(10,*) "/" + rewind(10) + read (10, nml=mynml, err = 1000) + if (all(truely(1:2))) call abort() + if (.not.all(truely_a_very_long_variable_name(1:3).eq.4)) call abort() + close(10) + stop +1000 call abort() +end program read_logical |