impl B32Encode<i8,String> for B32<String>{
fn encode(data:i8)->String{
let mut string=String::with_capacity(8);
unsafe{
let vec=&mut string.as_mut_vec();
vec.set_len(8);
b32_encode_1((&data as *const i8) as *const u8,1,ALPHABET32_ENCODE.as_ptr(),vec.as_mut_ptr());
}
return string;
}
}
impl<T:AsRef<[u8]>> B32Decode<T,i8> for B32<i8>{
fn validation(data:T)->B32DecodeError{
let ar=data.as_ref();
return b32_validation((*ar).as_ptr(),ar.len(),1,ALPHABET32_DECODE.as_ptr(),6,0b01000000,8,8,8);
}
fn decode(data:T)->Result<i8,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,1,ptr_alphabet,6,0b01000000,8,8,8);
if error!=B32DecodeError::Null {return Err(error)};
let mut n=0i8;
b32_decode_1(ptr_input,len_input,ptr_alphabet,(&mut n as *mut i8) as *mut u8,6);
return Ok(n);
}
unsafe fn unsafe_decode(data:T)->i8{
let ar=data.as_ref();
let mut n=0i8;
b32_decode_1((*ar).as_ptr(),ar.len(),ALPHABET32_DECODE.as_ptr(),(&mut n as *mut i8) as *mut u8,6);
return n;
}
}