character(len=:), allocatable :: s1
character (len=:), allocatable :: s2
character(len=:), allocatable :: w
integer :: i, j, k, tc
allocate (s2, mold=s1)
i = 1
j = 1
do
k = index (s1(i:), w)
if (k == 0) then
s2(j:j+len(s1)-i) = s1(i:)
s2 = s2(:j+len(s1)-i)
exit
else
tc = k - 1
if (tc > 0) s2(j:j+tc-1) = s1(i:i+tc-1)
i = i + tc + len(w)
j = j + tc
end if
end do
Because s2 can only be shorter than s1, it is allocated with the size of s1 and shortened to its actual length with the "s2 = s2(:j+len(s1)-i)" statement.