summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/char_length_9.f90
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gfortran.dg/char_length_9.f90')
-rw-r--r--gcc/testsuite/gfortran.dg/char_length_9.f9022
1 files changed, 22 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/char_length_9.f90 b/gcc/testsuite/gfortran.dg/char_length_9.f90
new file mode 100644
index 000000000..dbec68cd8
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/char_length_9.f90
@@ -0,0 +1,22 @@
+! { dg-do compile }
+! Test the fix for a regression caused by the first fix of PR31879.
+! Reported by Tobias Burnus <burnus@gcc.gnu.org>
+!
+MODULE input_val_types
+ IMPLICIT NONE
+ INTEGER, PARAMETER :: default_string_length=80
+ TYPE val_type
+ CHARACTER(len=default_string_length), DIMENSION(:), POINTER :: c_val
+ END TYPE val_type
+CONTAINS
+ SUBROUTINE val_get (val, c_val)
+ TYPE(val_type), POINTER :: val
+ CHARACTER(LEN=*), INTENT(out) :: c_val
+ INTEGER :: i, l_out
+ i=1
+ c_val((i-1)*default_string_length+1:MIN (l_out, i*default_string_length)) = &
+ val%c_val(i)(1:MIN (80, l_out-(i-1)*default_string_length))
+ END SUBROUTINE val_get
+END MODULE input_val_types
+
+! { dg-final { cleanup-modules "input_val_types" } }