http://gcc.gnu.org/bugzilla/show_bug.cgi?id=53296
--- Comment #2 from Tobias Burnus <burnus at gcc dot gnu.org> 2012-05-10 10:35:22 UTC --- Simplified program. * As is, it prints 128 * Without "txt", it prints 5 and segfaults * Without character(len=128) :: "txt", it prints 5 and works Thus, the extension to 128 characters does not properly work in the case of having no character literal. That matches what is in the code: character(kind=1) A.16[2][1:5]; vs. character(kind=1) A.15[3][1:128]; I have not looked through the source code, but the first place, where constructors string lengths are handled is array.c's gfc_resolve_character_array_constructor. I don't quickly see whether it does so correctly or not. If it does, the failure must be later. It might be that in that function, the "txt" is correctly extended and padded to len=128 - and that then everything is later handled correctly because the first element has the right size? program charArrErr implicit none call rou([character(len=128) :: "txt", uCase("abcde"),uCase("ghij_")]) contains subroutine rou(arr) implicit none character(*),intent(in) :: arr(:) print *, len(arr) end subroutine function uCase(str) implicit none character(*), intent(in) :: str character(len(str)) :: uCase uCase=str end function uCase end program charArrErr