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
use convert_case::{Boundary, Case, Casing};
use odra_types::event;
pub fn camel_to_snake(text: &str) -> String {
text.from_case(Case::UpperCamel)
.without_boundaries(&[Boundary::UpperDigit, Boundary::LowerDigit])
.to_case(Case::Snake)
}
pub fn event_absolute_position(len: usize, index: i32) -> Result<usize, event::EventError> {
if index.is_negative() {
let abs_idx = index.wrapping_abs() as usize;
if abs_idx > len {
return Err(event::EventError::IndexOutOfBounds);
}
Ok(len - abs_idx)
} else {
if index as usize >= len {
return Err(event::EventError::IndexOutOfBounds);
}
Ok(index as usize)
}
}
#[cfg(test)]
mod tests {
use crate::{camel_to_snake, event_absolute_position};
use odra_types::event;
#[test]
fn camel_to_snake_works() {
assert_eq!("owned_token", camel_to_snake("OwnedToken"));
assert_eq!("ownable", camel_to_snake("Ownable"));
assert_eq!("erc20", camel_to_snake("Erc20"));
assert_eq!(
"erc20_implementation",
camel_to_snake("Erc20Implementation")
);
}
#[test]
fn event_absolute_position_works() {
assert_eq!(
event_absolute_position(0, 1),
Err(event::EventError::IndexOutOfBounds)
);
assert_eq!(
event_absolute_position(10, 10),
Err(event::EventError::IndexOutOfBounds)
);
assert_eq!(
event_absolute_position(10, -11),
Err(event::EventError::IndexOutOfBounds)
);
assert_eq!(event_absolute_position(10, 0), Ok(0));
assert_eq!(event_absolute_position(10, 1), Ok(1));
assert_eq!(event_absolute_position(10, -1), Ok(9));
assert_eq!(event_absolute_position(10, -2), Ok(8));
assert_eq!(event_absolute_position(10, -10), Ok(0));
}
}