! { dg-do run } ! Test the fix for PR47348, in which the substring length ! in the array constructor at line 19 would be missed and ! the length of q used instead. ! ! Contributed by Thomas Koenig ! program main implicit none character(len = *), parameter :: fmt='(2(A,"|"))' character(len = *), parameter :: test='xyc|aec|' integer :: i character(len = 4) :: q character(len = 8) :: buffer q = 'xy' i = 2 write (buffer, fmt) (/ trim(q), 'ae' /)//'c' if (buffer .ne. test) Call abort write (buffer, FMT) (/ q(1:i), 'ae' /)//'c' if (buffer .ne. test) Call abort end program main