Cast string to integer (I8P).
use penf
type(string) :: astring
integer(I8P) :: integer_
logical :: test_passed(1)
astring = '127'
integer_ = astring%to_number(kind=1_I8P)
test_passed(1) = integer_==127_I8P
print '(L1)', all(test_passed)
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(string), | intent(in) | :: | self |
The string. |
||
integer(kind=I8P), | intent(in) | :: | kind |
Mold parameter for kind detection. |
The number into the string.
elemental function to_integer_I8P(self, kind) result(to_number) !< Cast string to integer (I8P). !< !<```fortran !< use penf !< type(string) :: astring !< integer(I8P) :: integer_ !< logical :: test_passed(1) !< astring = '127' !< integer_ = astring%to_number(kind=1_I8P) !< test_passed(1) = integer_==127_I8P !< print '(L1)', all(test_passed) !<``` !=> T <<< class(string), intent(in) :: self !< The string. integer(I8P), intent(in) :: kind !< Mold parameter for kind detection. integer(I8P) :: to_number !< The number into the string. if (allocated(self%raw)) then if (self%is_integer()) read(self%raw, *) to_number endif endfunction to_integer_I8P