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
34
// impl B32Encode<i32,String> for B32<String>{
//     fn encode(data:i32)->String{
//         let mut string:String=String::with_capacity(8);
//         unsafe{
//             let vec=&mut string.as_mut_vec();
//             vec.set_len(8);
//             b32_encode_4((&data as *const i32) as *const u32,1,ALPHABET32_ENCODE.as_ptr(),vec.as_mut_ptr());
//         }
//         return string;
//     }
// }

impl<T:C8CP+C8L> B32Decode<T,i32> for B32<i32>{
    fn validation(data:T)->B32DecodeError{
        return b32_validation(data.c8_ptr(),data.c8_len(),4,ALPHABET32_DECODE.as_ptr(),1,0b10,8,8,8);
    }
    fn decode(data:T)->Result<i32,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,4,ptr_alphabet,1,0b10,8,8,8);
        if error!=B32DecodeError::Null {return Err(error)};

        let mut n=0i32;
        b32_decode_4(ptr_input,len_input,ptr_alphabet,(&mut n as *mut i32) as *mut u32,1);
        return Ok(n);
    }
    unsafe fn unsafe_decode(data:T)->i32{
        let mut n=0i32;
        b32_decode_4(data.c8_ptr(),data.c8_len(),ALPHABET32_DECODE.as_ptr(),(&mut n as *mut i32) as *mut u32,1);
        return n;
    }
}