julienne_formats_s.F90 Source File


This file depends on

sourcefile~~julienne_formats_s.f90~~EfferentGraph sourcefile~julienne_formats_s.f90 julienne_formats_s.F90 sourcefile~julienne_formats_m.f90 julienne_formats_m.F90 sourcefile~julienne_formats_s.f90->sourcefile~julienne_formats_m.f90

Source Code

! Copyright (c) 2024-2025, The Regents of the University of California and Sourcery Institute
! Terms of use are as specified in LICENSE.txt

submodule(julienne_formats_m) julienne_formats_s
  !! Construct separated-value formats 
  implicit none

contains

  module procedure separated_values
    character(len=*), parameter :: prefix = "(*(G0,:,'"
    character(len=*), parameter :: double_prefix = "(*(G25.20,:,'"
    character(len=*), parameter :: complex_prefix = "(*('(',G0,',',G0,')',:,'" 
    character(len=*), parameter :: suffix = "'))"

    select rank(mold)
      rank(1)
        select type(mold)
          type is(complex)
            format_string = complex_prefix // separator // suffix
          type is(double precision)
            format_string = double_prefix // separator // "'))"
          type is(real)
            format_string = prefix // separator // suffix
          type is(integer)
            format_string = prefix // separator // suffix
          type is(character(len=*))
            format_string = prefix // separator // suffix
          class default
             error stop "format_s separated_values: unsupported type"
        end select
      rank default
        error stop "formats_s separated_values: unsupported rank"
    end select
  end procedure

end submodule julienne_formats_s