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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
impl B32Encode<u8,String> for B32<String>{
    fn encode(data:u8)->String{
        let mut string=String::with_capacity(8);
        unsafe{
            let vec=&mut string.as_mut_vec();
            vec.set_len(8);
            b32_encode_1(&data,1,ALPHABET32_ENCODE.as_ptr(),vec.as_mut_ptr());
        }
        return string;
    }
}

// impl B32Decode<String,u8> for B32<u8>{
//     fn validation(data:String)->B32DecodeError{
//         return b32_validation(data.as_ptr(),data.len(),1,ALPHABET32_DECODE.as_ptr(),6,0b01000000,8,8,8);
//     }
//     fn decode(data:String)->Result<u8,B32DecodeError>{
//         let ptr_data=data.as_ptr();
//         let len_data=data.len();
//         let ptr_alphabet=ALPHABET32_DECODE.as_ptr();
//
//         let error=b32_validation(ptr_data,len_data,1,ptr_alphabet,6,0b01000000,8,8,8);
//         if error!=B32DecodeError::Null {return Err(error)};
//
//         let mut n=0u8;
//         b32_decode_1(ptr_data,len_data,ptr_alphabet,&mut n,6);
//         return Ok(n);
//     }
//     unsafe fn unsafe_decode(data:String)->u8{
//         let mut n=0u8;
//         b32_decode_1(data.as_ptr(),data.len(),ALPHABET32_DECODE.as_ptr(),&mut n,6);
//         return n;
//     }
// }
//
// impl B32Decode<&'static str,u8> for B32<u8>{
//     fn validation(data:&'static str)->B32DecodeError{
//         return b32_validation(data.as_ptr(),data.len(),1,ALPHABET32_DECODE.as_ptr(),6,0b01000000,8,8,8);
//     }
//     fn decode(data:&'static str)->Result<u8,B32DecodeError>{
//         let ptr_data=data.as_ptr();
//         let len_data=data.len();
//         let ptr_alphabet=ALPHABET32_DECODE.as_ptr();
//
//         let error=b32_validation(ptr_data,len_data,1,ptr_alphabet,6,0b01000000,8,8,8);
//         if error!=B32DecodeError::Null {return Err(error)};
//
//         let mut n=0u8;
//         b32_decode_1(ptr_data,len_data,ptr_alphabet,&mut n,6);
//         return Ok(n);
//     }
//     unsafe fn unsafe_decode(data:&'static str)->u8{
//         let mut n=0u8;
//         b32_decode_1(data.as_ptr(),data.len(),ALPHABET32_DECODE.as_ptr(),&mut n,6);
//         return n;
//     }
// }

impl<T:AsRef<[u8]>+Sized> B32Decode<T,u8> for B32<u8>{
    fn validation(data:T)->B32DecodeError{
        return b32_validation((*data.as_ref()).as_ptr(),data.as_ref().len(),1,ALPHABET32_DECODE.as_ptr(),6,0b01000000,8,8,8);
    }
    fn decode(data:T)->Result<u8,B32DecodeError>{
        let ptr_data=(*data.as_ref()).as_ptr();
        let len_data=data.as_ref().len();
        let ptr_alphabet=ALPHABET32_DECODE.as_ptr();

        let error=b32_validation(ptr_data,len_data,1,ptr_alphabet,6,0b01000000,8,8,8);
        if error!=B32DecodeError::Null {return Err(error)};

        let mut n=0u8;
        b32_decode_1(ptr_data,len_data,ptr_alphabet,&mut n,6);
        return Ok(n);
    }
    unsafe fn unsafe_decode(data:T)->u8{
        let mut n=0u8;
        b32_decode_1((*data.as_ref()).as_ptr(),data.as_ref().len(),ALPHABET32_DECODE.as_ptr(),&mut n,6);
        return n;
    }
}