diff options
Diffstat (limited to 'gcc/testsuite/gfortran.dg/char_result_10.f90')
-rw-r--r-- | gcc/testsuite/gfortran.dg/char_result_10.f90 | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/char_result_10.f90 b/gcc/testsuite/gfortran.dg/char_result_10.f90 new file mode 100644 index 000000000..d14fd3815 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/char_result_10.f90 @@ -0,0 +1,36 @@ +! { dg-do compile } +! PR 18883: Fake result variables of non-constant length, with ENTRY +function s_to_c(chars) + character, pointer :: chars(:) + character(len=len(chars)) :: s_to_c, s_to_c_2 + s_to_c = 'a' + return +entry s_to_c_2(chars) + s_to_c_2 = 'b' + return +end function s_to_c + +program huj + + implicit none + interface + function s_to_c(chars) + character, pointer :: chars(:) + character(len=len(chars)) :: s_to_c + end function s_to_c + + function s_to_c_2(chars) + character, pointer :: chars(:) + character(len=len(chars)) :: s_to_c_2 + end function s_to_c_2 + end interface + + character, pointer :: c(:) + character(3) :: s + + allocate(c(5)) + c = (/"a", "b", "c" /) + s = s_to_c(c) + s = s_to_c_2(c) + +end program huj |