b64_encode_R16 Subroutine

private pure subroutine b64_encode_R16(n, code)

Arguments

TypeIntentOptionalAttributesName
real(kind=R16P), intent(in) :: n
character(len=:), intent(out), allocatable:: code

Calls

proc~~b64_encode_r16~4~~CallsGraph proc~b64_encode_r16~4 b64_encode_R16 proc~encode_bits~4 encode_bits proc~b64_encode_r16~4->proc~encode_bits~4

Contents

Source Code


Source Code

   pure subroutine b64_encode_R16(n, code)
   !< Encode scalar number to base64 (R16P).
   !<
   !<```fortran
   !< use befor64
   !< use penf
   !< character(len=:), allocatable :: code64
   !< call b64_encode(n=134.231_R16P, code=code64)
   !< print "(A)", code64
   !<```
   !=> CKwcWmTHYEA= <<<
   real(R16P),                    intent(in)  :: n       !< Number to be encoded.
   character(len=:), allocatable, intent(out) :: code    !< Encoded scalar.
   integer(I1P),     allocatable              :: nI1P(:) !< One byte integer array containing n.
   integer(I4P)                               :: padd    !< Number of padding characters ('=').

   allocate(nI1P(1:((BYR16P+2)/3)*3)) ; nI1P = 0_I1P
   code = repeat(' ',((BYR16P+2)/3)*4)
   nI1P = transfer(n,nI1P)
#if defined _R16P
   padd = mod((BYR16P),3_I2P) ; if (padd>0_I4P) padd = 3_I4P - padd
#else
   padd = mod((BYR16P),3_I1P) ; if (padd>0_I4P) padd = 3_I4P - padd
#endif
   call encode_bits(bits=nI1P,padd=padd,code=code)
   endsubroutine b64_encode_R16