b64_encode_I8_a Subroutine

private pure subroutine b64_encode_I8_a(n, code)

Arguments

TypeIntentOptionalAttributesName
integer(kind=I8P), intent(in) :: n(1:)
character(len=:), intent(out), allocatable:: code

Calls

proc~~b64_encode_i8_a~3~~CallsGraph proc~b64_encode_i8_a~3 b64_encode_I8_a proc~encode_bits~3 encode_bits proc~b64_encode_i8_a~3->proc~encode_bits~3

Called by

proc~~b64_encode_i8_a~3~~CalledByGraph proc~b64_encode_i8_a~3 b64_encode_I8_a proc~b64_encode_up_a~3 b64_encode_up_a proc~b64_encode_up_a~3->proc~b64_encode_i8_a~3 interface~b64_encode~3 b64_encode interface~b64_encode~3->proc~b64_encode_i8_a~3 interface~b64_encode_up~3 b64_encode_up interface~b64_encode_up~3->proc~b64_encode_up_a~3 interface~b64_encode_up~3->proc~b64_encode_up_a~3 interface~b64_encode_up~3->interface~b64_encode_up~3 interface~b64_encode_up~3->interface~b64_encode_up~3

Contents

Source Code


Source Code

   pure subroutine b64_encode_I8_a(n, code)
   !< Encode array numbers to base64 (I8P).
   !<
   !<```fortran
   !< use befor64
   !< use penf
   !< character(len=:), allocatable :: code64
   !< call b64_encode(n=[23_I8P,324_I8P,25456656_I8P,2_I8P], code=code64)
   !< print "(A)", code64
   !<```
   !=> FwAAAAAAAABEAQAAAAAAABBwhAEAAAAAAgAAAAAAAAA= <<<
   integer(I8P),                  intent(in)  :: n(1:)   !< Array of numbers to be encoded.
   character(len=:), allocatable, intent(out) :: code    !< Encoded array.
   integer(I1P),     allocatable              :: nI1P(:) !< One byte integer array containing n.
   integer(I4P)                               :: padd    !< Number of padding characters ('=').
   integer(I8P)                               :: ns      !< Size of n.

   ns = size(n,dim=1)
   allocate(nI1P(1:((ns*BYI8P+2)/3)*3)) ; nI1P = 0_I1P
   code = repeat(' ',((ns*BYI8P+2)/3)*4)
   nI1P = transfer(n,nI1P)
   padd = mod((ns*BYI8P),3_I8P) ; if (padd>0_I4P) padd = 3_I4P - padd
   call encode_bits(bits=nI1P,padd=padd,code=code)
   endsubroutine b64_encode_I8_a