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
35
36
37
impl B32Encode<i64,String> for B32<String>{
    fn encode(data:i64)->String{
        let mut string:String=String::with_capacity(16);
        unsafe{
            let vec=&mut string.as_mut_vec();
            vec.set_len(16);
            b32_encode_8((&data as *const i64) as *const u64,1,ALPHABET32_ENCODE.as_ptr(),vec.as_mut_ptr());
        }
        return string;
    }
}

impl<T:AsRef<[u8]>> B32Decode<T,i64> for B32<i64>{
    fn validation(data:T)->B32DecodeError{
        let ar=data.as_ref();
        return b32_validation((*ar).as_ptr(),ar.len(),8,ALPHABET32_DECODE.as_ptr(),3,0b1000,16,16,16);
    }
    fn decode(data:T)->Result<i64,B32DecodeError>{
        let ar=data.as_ref();
        let ptr_input=(*ar).as_ptr();
        let len_input=ar.len();
        let ptr_alphabet=ALPHABET32_DECODE.as_ptr();

        let error=b32_validation(ptr_input,len_input,8,ptr_alphabet,3,0b1000,16,16,16);
        if error!=B32DecodeError::Null {return Err(error)};

        let mut n=0i64;
        b32_decode_8(ptr_input,len_input,ptr_alphabet,(&mut n as *mut i64) as *mut u64,3);
        return Ok(n);
    }
    unsafe fn unsafe_decode(data:T)->i64{
        let ar=data.as_ref();
        let mut n=0i64;
        b32_decode_8((*ar).as_ptr(),ar.len(),ALPHABET32_DECODE.as_ptr(),(&mut n as *mut i64) as *mut u64,3);
        return n;
    }
}