diff options
Diffstat (limited to 'gcc/testsuite/gfortran.dg/assumed_charlen_in_main.f90')
-rw-r--r-- | gcc/testsuite/gfortran.dg/assumed_charlen_in_main.f90 | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/assumed_charlen_in_main.f90 b/gcc/testsuite/gfortran.dg/assumed_charlen_in_main.f90 new file mode 100644 index 000000000..f4bb70154 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/assumed_charlen_in_main.f90 @@ -0,0 +1,27 @@ +! { dg-do compile } +! Tests the fix for PR28771 in which an assumed character length variable with an initializer could +! survive in the main program without causing an error. +! +! Contributed by Martin Reinecke <martin@mpa-garching.mpg.de> +! Modified to test fix of regression reported by P.Schaffnit@access.rwth-aachen.de + +subroutine poobar () + ! The regression caused an ICE here + CHARACTER ( LEN = * ), PARAMETER :: Markers(5) = (/ "Error ", & + & "Fehler", & + & "Erreur", & + & "Stop ", & + & "Arret " /) + character(6) :: recepteur (5) + recepteur = Markers +end subroutine poobar + +! If the regression persisted, the compilation would stop before getting here +program test + character(len=*), parameter :: foo = 'test' ! Parameters must work. + character(len=4) :: bar = foo + character(len=*) :: foobar = 'This should fail' ! { dg-error "must be a dummy" } + print *, bar + call poobar () +end + |