Reduce allocations round 1
This commit is contained in:
parent
d7c34f3b34
commit
c3497f6429
|
@ -1,45 +1,34 @@
|
||||||
macro_rules! hashmap {
|
use arrayvec::ArrayString;
|
||||||
($( $key: expr => $val: expr ),*) => {{
|
|
||||||
let mut map = ::std::collections::HashMap::new();
|
|
||||||
$( map.insert($key, $val); )*
|
|
||||||
map
|
|
||||||
}}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn mock(target: &str) -> String {
|
pub fn mock(target: &str) -> ArrayString<512> {
|
||||||
let mut builder = String::with_capacity(target.len());
|
let mut builder = ArrayString::<512>::new();
|
||||||
|
|
||||||
for char in target.chars() {
|
for char in target.chars() {
|
||||||
if rand::random() {
|
if rand::random() {
|
||||||
builder.push_str(&char.to_uppercase().to_string());
|
builder.push(char.to_ascii_uppercase());
|
||||||
} else {
|
} else {
|
||||||
builder.push_str(&char.to_lowercase().to_string());
|
builder.push(char.to_ascii_lowercase());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
builder
|
builder
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn leetify(target: &str) -> String {
|
pub fn leetify(target: &str) -> ArrayString<512> {
|
||||||
let letters = hashmap! {
|
let mut builder = ArrayString::<512>::new();
|
||||||
'a' => '4',
|
|
||||||
'e' => '3',
|
|
||||||
'i' => '1',
|
|
||||||
'o' => '0',
|
|
||||||
'g' => '6',
|
|
||||||
's' => '5',
|
|
||||||
't' => '7',
|
|
||||||
'b' => '8'
|
|
||||||
};
|
|
||||||
|
|
||||||
let mut builder = String::with_capacity(target.len());
|
|
||||||
|
|
||||||
for char in target.chars() {
|
for char in target.chars() {
|
||||||
if let Some(repl) = letters.get(&char.to_ascii_lowercase()) {
|
builder.push(match char {
|
||||||
builder.push(*repl);
|
'a' => '4',
|
||||||
} else {
|
'e' => '3',
|
||||||
builder.push(char);
|
'i' => '1',
|
||||||
}
|
'o' => '0',
|
||||||
|
'g' => '6',
|
||||||
|
's' => '5',
|
||||||
|
't' => '7',
|
||||||
|
'b' => '8',
|
||||||
|
_ => char,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
builder
|
builder
|
||||||
|
|
|
@ -193,7 +193,6 @@ async fn handle_privmsg(
|
||||||
None => &nick,
|
None => &nick,
|
||||||
}
|
}
|
||||||
.trim();
|
.trim();
|
||||||
tracing::info!(user);
|
|
||||||
if let Some(prev_msg) = state.last_msgs.get(user) {
|
if let Some(prev_msg) = state.last_msgs.get(user) {
|
||||||
let resp = bots::leek::leetify(prev_msg);
|
let resp = bots::leek::leetify(prev_msg);
|
||||||
state.client.privmsg(&channel, &resp).await?;
|
state.client.privmsg(&channel, &resp).await?;
|
||||||
|
|
Loading…
Reference in a new issue