1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
impl<T:C8CP+C8L> B32Decode<T,Vec<i16>> for B32<Vec<i16>>{
    fn validation(data:T)->B32DecodeError{
        return b32_validation(data.c8_ptr(),data.c8_len(),2,ALPHABET32_DECODE.as_ptr(),6,0b1011011,8,8,0);
    }
    fn decode(data:T)->Result<Vec<i16>,B32DecodeError>{
        let ptr_input=data.c8_ptr();
        let len_input=data.c8_len();
        let ptr_alphabet=ALPHABET32_DECODE.as_ptr();

        let error=b32_validation(ptr_input,len_input,2,ptr_alphabet,6,0b1011011,8,8,0);
        if error!=B32DecodeError::Null {return Err(error)};

        let np=if len_input>6 {unsafe{if *ptr_input.offset((len_input-6) as isize)==61 {6}else{if *ptr_input.offset((len_input-4) as isize)==61 {4}else{if *ptr_input.offset((len_input-3) as isize)==61 {3}else{if *ptr_input.offset((len_input-1) as isize)==61 {1}else{0}}}}}}else{0};
        let size=(len_input-np)*5/16;

        let mut vec=Vec::<i16>::with_capacity(size);
        unsafe{(&mut vec).set_len(size);}
        b32_decode_2(ptr_input,len_input,ptr_alphabet,vec.as_mut_ptr() as *mut u16,np);
        return Ok(vec);
    }
    unsafe fn unsafe_decode(data:T)->Vec<i16>{
        let ptr_input=data.c8_ptr();
        let len_input=data.c8_len();

        let np=if len_input>6 {if *ptr_input.offset((len_input-6) as isize)==61 {6}else{if *ptr_input.offset((len_input-4) as isize)==61 {4}else{if *ptr_input.offset((len_input-3) as isize)==61 {3}else{if *ptr_input.offset((len_input-1) as isize)==61 {1}else{0}}}}}else{0};
        let size=(len_input-np)*5/16;

        let mut vec=Vec::<i16>::with_capacity(size);
        (&mut vec).set_len(size);
        b32_decode_2(ptr_input,len_input,ALPHABET32_DECODE.as_ptr(),vec.as_mut_ptr() as *mut u16,np);
        return vec;
    }
}