use convert_case::{Boundary, Case, Casing};
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) -> Option<usize> {
if index.is_negative() {
let abs_idx = index.wrapping_abs() as usize;
if abs_idx > len {
return None;
}
Some(len - abs_idx)
} else {
if index as usize >= len {
return None;
}
Some(index as usize)
}
}
#[cfg(test)]
mod tests {
use crate::{camel_to_snake, event_absolute_position};
#[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), None);
assert_eq!(event_absolute_position(10, 10), None);
assert_eq!(event_absolute_position(10, -11), None);
assert_eq!(event_absolute_position(10, 0), Some(0));
assert_eq!(event_absolute_position(10, 1), Some(1));
assert_eq!(event_absolute_position(10, -1), Some(9));
assert_eq!(event_absolute_position(10, -2), Some(8));
assert_eq!(event_absolute_position(10, -10), Some(0));
}
}