b64_decode_R8_a Subroutine

private pure subroutine b64_decode_R8_a(code, n)

Arguments

TypeIntentOptionalAttributesName
character, intent(in) :: code
real(kind=R8P), intent(out) :: n(1:)

Calls

proc~~b64_decode_r8_a~4~~CallsGraph proc~b64_decode_r8_a~4 b64_decode_R8_a proc~decode_bits~4 decode_bits proc~b64_decode_r8_a~4->proc~decode_bits~4

Called by

proc~~b64_decode_r8_a~4~~CalledByGraph proc~b64_decode_r8_a~4 b64_decode_R8_a proc~b64_decode_up_a~4 b64_decode_up_a proc~b64_decode_up_a~4->proc~b64_decode_r8_a~4 interface~b64_decode~4 b64_decode interface~b64_decode~4->proc~b64_decode_r8_a~4 interface~b64_decode_up~4 b64_decode_up interface~b64_decode_up~4->proc~b64_decode_up_a~4 interface~b64_decode_up~4->proc~b64_decode_up_a~4 interface~b64_decode_up~4->interface~b64_decode_up~4 interface~b64_decode_up~4->interface~b64_decode_up~4

Contents

Source Code


Source Code

   pure subroutine b64_decode_R8_a(code, n)
   !< Decode a base64 code into an array numbers (R8P).
   !<
   !<```fortran
   !< use befor64
   !< use penf
   !< real(R8P) :: array_R8(1:2)
   !< call b64_decode(code='AAAAAAAA8D8AAAAAAAAAQA==',n=array_R8)
   !< print "(L1)", str(n=array_R8)==str(n=[1._R8P,2._R8P])
   !<```
   !=> T <<<
   character(*), intent(in)  :: code    !< Encoded array.
   real(R8P),    intent(out) :: n(1:)   !< Array of numbers to be decoded.
   integer(I1P), allocatable :: nI1P(:) !< One byte integer array containing n.

   allocate(nI1P(1:size(n,dim=1)*BYR8P)) ; nI1P = 0_I1P
   call decode_bits(code=code,bits=nI1P)
   n = transfer(nI1P,n)
   endsubroutine b64_decode_R8_a