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
impl<T:C8CP+C8L> B32Decode<T,Vec<i32>> for B32<Vec<i32>>{
fn validation(data:T)->B32DecodeError{
return b32_validation(data.c8_ptr(),data.c8_len(),4,ALPHABET32_DECODE.as_ptr(),6,0b1011011,8,8,0);
}
fn decode(data:T)->Result<Vec<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,ALPHABET32_DECODE.as_ptr(),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/32;
let mut vec=Vec::<i32>::with_capacity(size);
unsafe{(&mut vec).set_len(size);}
b32_decode_4(ptr_input,len_input,ptr_alphabet,vec.as_mut_ptr() as *mut u32,np);
return Ok(vec);
}
unsafe fn unsafe_decode(data:T)->Vec<i32>{
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/32;
let mut vec=Vec::<i32>::with_capacity(size);
(&mut vec).set_len(size);
b32_decode_4(ptr_input,len_input,ALPHABET32_DECODE.as_ptr(),vec.as_mut_ptr() as *mut u32,np);
return vec;
}
}