re PR fortran/15750 (IOLENGTH form of INQUIRE statement not implemented)
authorTobias Schlüter <tobias.schlueter@physik.uni-muenchen.de>
Mon, 20 Sep 2004 11:09:47 +0000 (13:09 +0200)
committerTobias Schlüter <tobi@gcc.gnu.org>
Mon, 20 Sep 2004 11:09:47 +0000 (13:09 +0200)
PR fortran/15750
* gfortran.fortran-torture/execute/iolength_2.f90: New test.

From-SVN: r87752

gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.fortran-torture/execute/iolength_2.f90 [new file with mode: 0644]

index 422f3c99932a6ec817c7839c2028095ef9bb9c1d..8a2968859a5f0bdc3135e466d301d27a01e66b15 100644 (file)
@@ -1,3 +1,8 @@
+2004-09-20  Tobias Schlueter  <tobias.schlueter@physik.uni-muenchen.de>
+
+       PR fortran/15750
+       * gfortran.fortran-torture/execute/iolength_2.f90: New test.    
+
 2004-09-20  Ira Rosen  <irar@il.ibm.com>
 
        * gcc.dg/vect/vect-13.c: Added xfail for non ppc platforms.
diff --git a/gcc/testsuite/gfortran.fortran-torture/execute/iolength_2.f90 b/gcc/testsuite/gfortran.fortran-torture/execute/iolength_2.f90
new file mode 100644 (file)
index 0000000..ac65778
--- /dev/null
@@ -0,0 +1,24 @@
+! Test that IOLENGTH works for derived types containing arrays
+module iolength_2_mod
+  integer, parameter ::  &
+       ! 32 bit, i.e. 4 byte integer (every gcc architecture should have this?)
+       int32 = selected_int_kind(9), &
+       ! IEEE double precision, i.e. 8 bytes
+       dp = selected_real_kind(15, 307)
+  type foo
+     ! This type should take up 5*4+4+8=32 bytes
+     integer(int32) :: a(5), b
+     real(dp) :: c
+  end type foo
+end module iolength_2_mod
+
+program iolength_2
+  use iolength_2_mod
+  implicit none
+  integer :: iol
+  type(foo) :: d
+  inquire (iolength = iol) d
+  if ( 32 /= iol) then
+     call abort
+  end if
+end program iolength_2