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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
use std::fmt::Display;
use amplify::hex::ToHex;
#[derive(Clone, Eq, PartialEq, Debug)]
#[non_exhaustive]
pub enum Encoding {
Base16,
#[cfg(feature = "multibase")]
Base32,
#[cfg(feature = "bech32")]
Bech32(String, bech32::Variant),
#[cfg(feature = "multibase")]
Base58,
#[cfg(feature = "multibase")]
Base64,
#[cfg(feature = "multibase")]
Multibase(multibase::Base),
}
impl Encoding {
pub fn encode(&self, data: &[u8]) -> String {
#[cfg(feature = "multibase")]
use multibase::{encode, Base};
match self {
Encoding::Base16 => data.to_hex(),
#[cfg(feature = "multibase")]
Encoding::Base32 => {
let mut s: String = encode(Base::Base32Lower, data);
s.remove(0);
s
}
#[cfg(feature = "bech32")]
Encoding::Bech32(hrp, variant) => {
let b32 = bech32::ToBase32::to_base32(&data);
bech32::encode(hrp, b32, *variant).expect("invalid HRP")
}
#[cfg(feature = "multibase")]
Encoding::Base58 => {
let mut s: String = encode(Base::Base58Btc, data);
s.remove(0);
s
}
#[cfg(feature = "multibase")]
Encoding::Base64 => {
let mut s: String = encode(Base::Base64, data);
s.remove(0);
s
}
#[cfg(feature = "multibase")]
Encoding::Multibase(base) => encode(*base, data),
}
}
}
pub trait MultiDisplay<F> {
type Display: Display;
fn display(&self) -> Self::Display
where F: Default {
self.display_fmt(&default!())
}
fn display_fmt(&self, f: &F) -> Self::Display;
}