decode_bits Subroutine

private pure subroutine decode_bits(code, bits)

Arguments

Type IntentOptional Attributes Name
character(len=*), intent(in) :: code
integer(kind=I1P), intent(out) :: bits(1:)

Called by

proc~~decode_bits~~CalledByGraph proc~decode_bits decode_bits proc~b64_decode_i1 b64_decode_I1 proc~b64_decode_i1->proc~decode_bits proc~b64_decode_i1_a b64_decode_I1_a proc~b64_decode_i1_a->proc~decode_bits proc~b64_decode_i2 b64_decode_I2 proc~b64_decode_i2->proc~decode_bits proc~b64_decode_i2_a b64_decode_I2_a proc~b64_decode_i2_a->proc~decode_bits proc~b64_decode_i4 b64_decode_I4 proc~b64_decode_i4->proc~decode_bits proc~b64_decode_i4_a b64_decode_I4_a proc~b64_decode_i4_a->proc~decode_bits proc~b64_decode_i8 b64_decode_I8 proc~b64_decode_i8->proc~decode_bits proc~b64_decode_i8_a b64_decode_I8_a proc~b64_decode_i8_a->proc~decode_bits proc~b64_decode_r16 b64_decode_R16 proc~b64_decode_r16->proc~decode_bits proc~b64_decode_r16_a b64_decode_R16_a proc~b64_decode_r16_a->proc~decode_bits proc~b64_decode_r4 b64_decode_R4 proc~b64_decode_r4->proc~decode_bits proc~b64_decode_r4_a b64_decode_R4_a proc~b64_decode_r4_a->proc~decode_bits proc~b64_decode_r8 b64_decode_R8 proc~b64_decode_r8->proc~decode_bits proc~b64_decode_r8_a b64_decode_R8_a proc~b64_decode_r8_a->proc~decode_bits proc~b64_decode_string b64_decode_string proc~b64_decode_string->proc~decode_bits proc~b64_decode_string_a b64_decode_string_a proc~b64_decode_string_a->proc~decode_bits interface~b64_decode b64_decode interface~b64_decode->proc~b64_decode_i1 interface~b64_decode->proc~b64_decode_i1_a interface~b64_decode->proc~b64_decode_i2 interface~b64_decode->proc~b64_decode_i2_a interface~b64_decode->proc~b64_decode_i4 interface~b64_decode->proc~b64_decode_i4_a interface~b64_decode->proc~b64_decode_i8 interface~b64_decode->proc~b64_decode_i8_a interface~b64_decode->proc~b64_decode_r4 interface~b64_decode->proc~b64_decode_r4_a interface~b64_decode->proc~b64_decode_r8 interface~b64_decode->proc~b64_decode_r8_a interface~b64_decode->proc~b64_decode_string interface~b64_decode->proc~b64_decode_string_a proc~b64_decode_up b64_decode_up proc~b64_decode_up->proc~b64_decode_i1 proc~b64_decode_up->proc~b64_decode_i2 proc~b64_decode_up->proc~b64_decode_i4 proc~b64_decode_up->proc~b64_decode_i8 proc~b64_decode_up->proc~b64_decode_r4 proc~b64_decode_up->proc~b64_decode_r8 proc~b64_decode_up->proc~b64_decode_string proc~b64_decode_up_a b64_decode_up_a proc~b64_decode_up_a->proc~b64_decode_i1_a proc~b64_decode_up_a->proc~b64_decode_i2_a proc~b64_decode_up_a->proc~b64_decode_i4_a proc~b64_decode_up_a->proc~b64_decode_i8_a proc~b64_decode_up_a->proc~b64_decode_r4_a proc~b64_decode_up_a->proc~b64_decode_r8_a proc~b64_decode_up_a->proc~b64_decode_string_a interface~b64_decode_up b64_decode_up interface~b64_decode_up->proc~b64_decode_up_a interface~b64_decode_up->interface~b64_decode_up 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

   pure subroutine decode_bits(code, bits)
   !< Decode a base64 string into a sequence of bits stream.
   !<
   !< The base64 string must be parsed with a strike of 4 characters and converted into a 3 bytes stream. Considering the base64 code
   !< `QUJD` the decoding process must do
   !<```
   !< +-b64 char--+-b64 char--+-b64 char--+-b64 char--+
   !< |      Q    |      U    |      J    |      D    |
   !< +-b64 index-+-b64 index-+-b64 index-+-b64 index-+
   !< !      16   |      20   |      9    |      3    |
   !< +-6 bits----+-6 bits----+-6 bits----+-6 bits----+
   !< |0 1 0 0 0 0|0 1 0 1 0 0|0 0 1 0 0 1|0 0 0 0 1 1|
   !< +-----------+---+-------+-------+---+-----------+
   !< |0 1 0 0 0 0 0 1|0 1 0 0 0 0 1 0|0 1 0 0 0 0 1 1|
   !< +-----8 bits----+-----8 bits----+-----8 bits----+
   !<```
   !< @note The bits pattern is returned as a 1-byte element array, the dimension of witch must be computed outside this procedure.
   !<
   !< @warning This procedure is the backend of decoding, thus it must be never called outside the module.
   character(*), intent(in)  :: code      !< Characters code.
   integer(I1P), intent(out) :: bits(1:)  !< Bits decoded.
   integer(I1P)              :: sixb(1:4) !< 6 bits slices (stored into 8 bits integer) of 24 bits input.
   integer(I8P)              :: c         !< Counter.
   integer(I8P)              :: e         !< Counter.
   integer(I8P)              :: Nb        !< Length of bits array.

   Nb=size(bits,dim=1,kind=I8P)
   e = 1_I8P
   do c=1_I8P,len(code,I8P),4_I8P ! loop over code characters: 3 bytes (24 bits) scanning
      sixb = 0_I1P
      sixb(1) = index(base64,code(c  :c  )) - 1
      sixb(2) = index(base64,code(c+1:c+1)) - 1
      sixb(3) = index(base64,code(c+2:c+2)) - 1
      sixb(4) = index(base64,code(c+3:c+3)) - 1
         call mvbits(sixb(1),0,6,bits(e  ),2) ; call mvbits(sixb(2),4,2,bits(e  ),0)
      if (e+1<=Nb) then
         call mvbits(sixb(2),0,4,bits(e+1),4) ; call mvbits(sixb(3),2,4,bits(e+1),0)
      endif
      if (e+2<=Nb) then
         call mvbits(sixb(3),0,2,bits(e+2),6) ; call mvbits(sixb(4),0,6,bits(e+2),0)
      endif
      e = e + 3_I8P
   enddo
   endsubroutine decode_bits