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
use super::{Decode, Encode, Variant};
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
pub struct Base64Bcrypt;
impl Variant for Base64Bcrypt {
type Unpadded = Self;
const PADDED: bool = false;
const BASE: u8 = b'.';
const DECODER: &'static [Decode] = &[
Decode::Range(b'.'..b'/', -45),
Decode::Range(b'A'..b'Z', -62),
Decode::Range(b'a'..b'z', -68),
Decode::Range(b'0'..b'9', 7),
];
const ENCODER: &'static [Encode] = &[
Encode::Apply(b'/', 17),
Encode::Apply(b'Z', 6),
Encode::Apply(b'z', -75),
];
}