summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/der_io_3.f90
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gfortran.dg/der_io_3.f90')
-rw-r--r--gcc/testsuite/gfortran.dg/der_io_3.f9045
1 files changed, 45 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/der_io_3.f90 b/gcc/testsuite/gfortran.dg/der_io_3.f90
new file mode 100644
index 000000000..1cb370ce1
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/der_io_3.f90
@@ -0,0 +1,45 @@
+! { dg-do compile }
+! { dg-options "-std=legacy" }
+!
+! PR23843
+! Make sure derived type I/O with PRIVATE components works where it's allowed
+module m1
+ type t1
+ integer i
+ end type t1
+end module m1
+
+module m2
+ use m1
+
+ type t2
+ private
+ type (t1) t
+ end type t2
+
+ type t3
+ private
+ integer i
+ end type t3
+
+contains
+ subroutine test
+ character*20 c
+ type(t2) :: a
+ type(t3) :: b
+
+ a % t % i = 31337
+ b % i = 255
+
+ write(c,*) a
+ if (trim(adjustl(c)) /= "31337") call abort
+ write(c,*) b
+ if (trim(adjustl(c)) /= "255") call abort
+ end subroutine test
+end module m2
+
+use m2
+call test
+end
+
+! { dg-final { cleanup-modules "m1 m2" } }