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; } }