You have a length of 12 in the constructor, so it's best to use a length of 12.
Also use instead
character(len=12), dimension(5) :: models = [character(len=12) :: "feddes.swp", &
"jarvis89.swp", "jarvis10.swp", "pem.swp", "van.swp"]
Perhaps even better if you have compiler support,
character(len=*), dimension(*) :: ...
source
share