b64_decode_string Subroutine

private elemental subroutine b64_decode_string(code, s)

Arguments

Type IntentOptional Attributes Name
character(len=*), intent(in) :: code
character(len=*), intent(out) :: s

Calls

proc~~b64_decode_string~~CallsGraph proc~b64_decode_string b64_decode_string interface~byte_size byte_size proc~b64_decode_string->interface~byte_size proc~decode_bits decode_bits proc~b64_decode_string->proc~decode_bits proc~byte_size_chr byte_size_chr interface~byte_size->proc~byte_size_chr proc~byte_size_i1p byte_size_I1P interface~byte_size->proc~byte_size_i1p proc~byte_size_i2p byte_size_I2P interface~byte_size->proc~byte_size_i2p proc~byte_size_i4p byte_size_I4P interface~byte_size->proc~byte_size_i4p proc~byte_size_i8p byte_size_I8P interface~byte_size->proc~byte_size_i8p proc~byte_size_r4p byte_size_R4P interface~byte_size->proc~byte_size_r4p proc~byte_size_r8p byte_size_R8P interface~byte_size->proc~byte_size_r8p

Called by

proc~~b64_decode_string~~CalledByGraph proc~b64_decode_string b64_decode_string interface~b64_decode b64_decode interface~b64_decode->proc~b64_decode_string proc~b64_decode_up b64_decode_up proc~b64_decode_up->proc~b64_decode_string proc~decode string%decode proc~decode->interface~b64_decode proc~decode~2 string%decode proc~decode~2->interface~b64_decode program~volatile_doctest~1012 volatile_doctest program~volatile_doctest~1012->interface~b64_decode program~volatile_doctest~1031 volatile_doctest program~volatile_doctest~1031->interface~b64_decode program~volatile_doctest~1037 volatile_doctest program~volatile_doctest~1037->interface~b64_decode program~volatile_doctest~1038 volatile_doctest program~volatile_doctest~1038->interface~b64_decode program~volatile_doctest~1050 volatile_doctest program~volatile_doctest~1050->interface~b64_decode program~volatile_doctest~107 volatile_doctest program~volatile_doctest~107->interface~b64_decode program~volatile_doctest~1156 volatile_doctest program~volatile_doctest~1156->interface~b64_decode program~volatile_doctest~1163 volatile_doctest program~volatile_doctest~1163->interface~b64_decode program~volatile_doctest~1171 volatile_doctest program~volatile_doctest~1171->interface~b64_decode program~volatile_doctest~1191 volatile_doctest program~volatile_doctest~1191->interface~b64_decode program~volatile_doctest~121 volatile_doctest program~volatile_doctest~121->interface~b64_decode program~volatile_doctest~124 volatile_doctest program~volatile_doctest~124->interface~b64_decode program~volatile_doctest~1246 volatile_doctest program~volatile_doctest~1246->interface~b64_decode program~volatile_doctest~1304 volatile_doctest program~volatile_doctest~1304->interface~b64_decode program~volatile_doctest~1344 volatile_doctest program~volatile_doctest~1344->interface~b64_decode program~volatile_doctest~1371 volatile_doctest program~volatile_doctest~1371->interface~b64_decode program~volatile_doctest~1392 volatile_doctest program~volatile_doctest~1392->interface~b64_decode program~volatile_doctest~1395 volatile_doctest program~volatile_doctest~1395->interface~b64_decode program~volatile_doctest~1478 volatile_doctest program~volatile_doctest~1478->interface~b64_decode program~volatile_doctest~148 volatile_doctest program~volatile_doctest~148->interface~b64_decode program~volatile_doctest~1506 volatile_doctest program~volatile_doctest~1506->interface~b64_decode program~volatile_doctest~1549 volatile_doctest program~volatile_doctest~1549->interface~b64_decode program~volatile_doctest~159 volatile_doctest program~volatile_doctest~159->interface~b64_decode program~volatile_doctest~1610 volatile_doctest program~volatile_doctest~1610->interface~b64_decode program~volatile_doctest~1615 volatile_doctest program~volatile_doctest~1615->interface~b64_decode program~volatile_doctest~1633 volatile_doctest program~volatile_doctest~1633->interface~b64_decode program~volatile_doctest~1647 volatile_doctest program~volatile_doctest~1647->interface~b64_decode program~volatile_doctest~1654 volatile_doctest program~volatile_doctest~1654->interface~b64_decode program~volatile_doctest~1658 volatile_doctest program~volatile_doctest~1658->interface~b64_decode program~volatile_doctest~1681 volatile_doctest program~volatile_doctest~1681->interface~b64_decode program~volatile_doctest~1728 volatile_doctest program~volatile_doctest~1728->interface~b64_decode program~volatile_doctest~1739 volatile_doctest program~volatile_doctest~1739->interface~b64_decode program~volatile_doctest~182 volatile_doctest program~volatile_doctest~182->interface~b64_decode program~volatile_doctest~1885 volatile_doctest program~volatile_doctest~1885->interface~b64_decode program~volatile_doctest~1907 volatile_doctest program~volatile_doctest~1907->interface~b64_decode program~volatile_doctest~1915 volatile_doctest program~volatile_doctest~1915->interface~b64_decode program~volatile_doctest~1916 volatile_doctest program~volatile_doctest~1916->interface~b64_decode program~volatile_doctest~1941 volatile_doctest program~volatile_doctest~1941->interface~b64_decode program~volatile_doctest~20 volatile_doctest program~volatile_doctest~20->interface~b64_decode program~volatile_doctest~242 volatile_doctest program~volatile_doctest~242->interface~b64_decode program~volatile_doctest~278 volatile_doctest program~volatile_doctest~278->interface~b64_decode program~volatile_doctest~3 volatile_doctest program~volatile_doctest~3->interface~b64_decode program~volatile_doctest~301 volatile_doctest program~volatile_doctest~301->interface~b64_decode program~volatile_doctest~317 volatile_doctest program~volatile_doctest~317->interface~b64_decode program~volatile_doctest~355 volatile_doctest program~volatile_doctest~355->interface~b64_decode program~volatile_doctest~359 volatile_doctest program~volatile_doctest~359->interface~b64_decode program~volatile_doctest~38 volatile_doctest program~volatile_doctest~38->interface~b64_decode program~volatile_doctest~391 volatile_doctest program~volatile_doctest~391->interface~b64_decode program~volatile_doctest~454 volatile_doctest program~volatile_doctest~454->interface~b64_decode program~volatile_doctest~538 volatile_doctest program~volatile_doctest~538->interface~b64_decode program~volatile_doctest~593 volatile_doctest program~volatile_doctest~593->interface~b64_decode program~volatile_doctest~613 volatile_doctest program~volatile_doctest~613->interface~b64_decode program~volatile_doctest~642 volatile_doctest program~volatile_doctest~642->interface~b64_decode program~volatile_doctest~677 volatile_doctest program~volatile_doctest~677->interface~b64_decode program~volatile_doctest~699 volatile_doctest program~volatile_doctest~699->interface~b64_decode program~volatile_doctest~700 volatile_doctest program~volatile_doctest~700->interface~b64_decode program~volatile_doctest~727 volatile_doctest program~volatile_doctest~727->interface~b64_decode program~volatile_doctest~753 volatile_doctest program~volatile_doctest~753->interface~b64_decode program~volatile_doctest~820 volatile_doctest program~volatile_doctest~820->interface~b64_decode program~volatile_doctest~838 volatile_doctest program~volatile_doctest~838->interface~b64_decode program~volatile_doctest~885 volatile_doctest program~volatile_doctest~885->interface~b64_decode program~volatile_doctest~958 volatile_doctest program~volatile_doctest~958->interface~b64_decode program~volatile_doctest~963 volatile_doctest program~volatile_doctest~963->interface~b64_decode program~volatile_doctest~979 volatile_doctest program~volatile_doctest~979->interface~b64_decode program~volatile_doctest~240 volatile_doctest program~volatile_doctest~240->proc~decode program~volatile_doctest~986 volatile_doctest program~volatile_doctest~986->proc~decode

Source Code

   elemental subroutine b64_decode_string(code, s)
   !< Decode a base64 code into a scalar string.
   !<
   !<```fortran
   !< use befor64
   !< use penf
   !< character(:), allocatable :: code64
   !< code64 = repeat(' ',5)
   !< call b64_decode(code='aGVsbG8=',s=code64)
   !< print "(L1)", code64=='hello'
   !<```
   !=> T <<<
   character(*), intent(in)  :: code    !< Encoded scalar.
   character(*), intent(out) :: s       !< String to be decoded.
   integer(I1P), allocatable :: nI1P(:) !< One byte integer array containing n.

   allocate(nI1P(1:byte_size(s))) ; nI1P = 0_I1P
   call decode_bits(code=code,bits=nI1P)
   s = transfer(nI1P,s)
   endsubroutine b64_decode_string