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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
use std::fmt::Display;
use cosmwasm_std::StdResult;
use cw_storage_plus::{Key, KeyDeserialize, Prefixer, PrimaryKey};
use schemars::JsonSchema;
use serde::{Deserialize, Serialize};
#[derive(
Deserialize, Serialize, Clone, Debug, PartialEq, Eq, JsonSchema, PartialOrd, Ord, Default,
)]
pub struct AssetEntry(pub(crate) String);
impl AssetEntry {
pub fn new(entry: &str) -> Self {
Self(str::to_ascii_lowercase(entry))
}
pub fn as_str(&self) -> &str {
&self.0
}
pub fn format(&mut self) {
self.0 = self.0.to_ascii_lowercase();
}
}
impl From<&str> for AssetEntry {
fn from(entry: &str) -> Self {
Self::new(entry)
}
}
impl From<String> for AssetEntry {
fn from(entry: String) -> Self {
Self::new(&entry)
}
}
impl From<&String> for AssetEntry {
fn from(entry: &String) -> Self {
Self::new(entry)
}
}
impl Display for AssetEntry {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(f, "{}", self.0)
}
}
impl<'a> PrimaryKey<'a> for AssetEntry {
type Prefix = ();
type SubPrefix = ();
type Suffix = Self;
type SuperSuffix = Self;
fn key(&self) -> Vec<cw_storage_plus::Key> {
self.0.key()
}
}
impl<'a> Prefixer<'a> for AssetEntry {
fn prefix(&self) -> Vec<Key> {
self.0.prefix()
}
}
impl KeyDeserialize for AssetEntry {
type Output = Self;
#[inline(always)]
fn from_vec(value: Vec<u8>) -> StdResult<Self::Output> {
Ok(Self(String::from_vec(value)?))
}
}
#[cfg(test)]
mod test {
use super::*;
use speculoos::prelude::*;
#[test]
fn test_asset_entry() {
let mut entry = AssetEntry::new("CRAB");
assert_that!(entry.as_str()).is_equal_to("crab");
entry.format();
assert_that!(entry.as_str()).is_equal_to("crab");
}
#[test]
fn test_from_string() {
let entry = AssetEntry::from("CRAB".to_string());
assert_that!(entry.as_str()).is_equal_to("crab");
}
#[test]
fn test_from_str() {
let entry = AssetEntry::from("CRAB");
assert_that!(entry.as_str()).is_equal_to("crab");
}
#[test]
fn test_from_ref_string() {
let entry = AssetEntry::from(&"CRAB".to_string());
assert_that!(entry.as_str()).is_equal_to("crab");
}
#[test]
fn test_to_string() {
let entry = AssetEntry::new("CRAB");
assert_that!(entry.to_string()).is_equal_to("crab".to_string());
}
#[test]
fn string_key_works() {
let k = AssetEntry::new("CRAB");
let path = k.key();
assert_eq!(1, path.len());
assert_eq!(b"crab", path[0].as_ref());
let joined = k.joined_key();
assert_eq!(joined, b"crab")
}
}