aboutsummaryrefslogtreecommitdiff
path: root/src/hooks
diff options
context:
space:
mode:
Diffstat (limited to 'src/hooks')
-rw-r--r--src/hooks/sed.rs18
1 files changed, 16 insertions, 2 deletions
diff --git a/src/hooks/sed.rs b/src/hooks/sed.rs
index d46a9bf..1ee0b20 100644
--- a/src/hooks/sed.rs
+++ b/src/hooks/sed.rs
@@ -24,7 +24,11 @@ impl Sed {
}
fn log_msg(&mut self, msg: Message) -> Result<()> {
- if let Command::PRIVMSG(target, text) = msg.command.clone() {
+ if let Command::PRIVMSG(target, mut text) = msg.command.clone() {
+ if text.starts_with("\x01ACTION") {
+ text = text.replace("\x01ACTION", "\x01\x01");
+ }
+
match self.0.get_mut(&target) {
Some(log) => {
if log.len() >= LOG_MAX_SIZE {
@@ -72,7 +76,17 @@ impl Sed {
.iter()
.rev()
.find(|(_, text)| cmd.expr.is_match(text) && !RE.with(|re| re.is_match(text)))
- .and_then(|(nick, text)| Some(format!("<{}> {}", nick, cmd.execute(text))))
+ .and_then(|(nick, text)| {
+ if text.starts_with("\x01\x01") {
+ Some(format!(
+ "* {}{}",
+ nick,
+ cmd.execute(text.replace("\x01", ""))
+ ))
+ } else {
+ Some(format!("<{}> {}", nick, cmd.execute(text)))
+ }
+ })
.map_or(Err(anyhow!("replace failed")), |v| Ok(v));
}
umentation and reorganize some modulesMax Audron-65/+300 2021-10-22remove wolfram alpha url shorteningMax Audron-1/+2 2021-10-20remove failing wolfram alpha test casesMax Audron-105/+55 2021-10-20bump version to 1.6.2Max Audron-3/+2 2021-10-20prepare for release on crates.ioMax Audron-39/+65 2021-10-20add async docs to macro crate and bump versionMax Audron-9/+10 2021-10-20change hook errors to be logged as warningsMax Audron-3/+3 2021-10-20fix configuration not loading correctly on release buildsMax Audron-8/+23 2021-10-19replace sedregex crate8-rework-sedMax Audron-20/+358 2021-10-19add formatting trait for irc codesMax Audron-0/+129 2021-10-17fix links in readmeMax Audron-2/+2