! { dg-do run { target fd_truncate } } module nml_47 type :: mt character(len=2) :: c012345678901234567890123456789012345678901234567890123456789h(2) = (/"aa","bb"/) end type mt type :: bt integer :: i(2) = (/1,2/) type(mt) :: m(2) end type bt end module nml_47 program namelist_47 use nml_47 type(bt) :: x(2) character(140) :: teststring namelist /mynml/ x teststring = " x(2)%m%c012345678901234567890123456789012345678901234567890123456789h(:)(2:2) = 'z','z'," call writenml (teststring) teststring = " x(2)%m(2)%c012345678901234567890123456789012345678901234567890123456789h(:)(2) = 'z','z'," call writenml (teststring) teststring = " x(2)%m(2)%c012345678901234567890123456789012345678901234567890123456789h(:)(:3) = 'z','z'," call writenml (teststring) teststring = " x(2)%m(2)%c012345678901234567890123456789012345678901234567890123456789h(1:2)(k:) = 'z','z'," call writenml (teststring) contains subroutine writenml (astring) character(140), intent(in) :: astring character(300) :: errmessage integer :: ierror open (10, status="scratch", delim='apostrophe') write (10, '(A)') "&MYNML" write (10, '(A)') astring write (10, '(A)') "/" rewind (10) read (10, nml = mynml, iostat=ierror, iomsg=errmessage) if (ierror == 0) call abort print '(a)', trim(errmessage) close (10) end subroutine writenml end program namelist_47 ! { dg-output "Multiple sub-objects with non-zero rank in namelist object x(\n|\r\n|\r)" } ! { dg-output "Missing colon in substring qualifier for namelist variable x%m%c012345678901234567890123456789012345678901234567890123456789h(\n|\r\n|\r)" } ! { dg-output "Substring out of range for namelist variable x%m%c012345678901234567890123456789012345678901234567890123456789h(\n|\r\n|\r)" } ! { dg-output "Bad character in substring qualifier for namelist variable x%m%c012345678901234567890123456789012345678901234567890123456789h(\n|\r\n|\r)" } ! { dg-final { cleanup-modules "nml_47" } }