irc-command-micro

Crates.ioirc-command-micro
lib.rsirc-command-micro
version0.0.17
sourcesrc
created_at2024-06-03 17:12:31.217057
updated_at2024-06-22 15:13:30.276299
descriptionA library to parse irc messages and provide a stable representation in return
homepage
repository
max_upload_size
id1260296
size30,591
(samuelshiels)

documentation

README

irc-command-micro

Early implementation of a parser for irc messages

Parse a simple NAMES command, CR and LF is optional

use irc_command_micro::Message;

let message_bytes = vec![58, 65, 110, 111, 110, 32, 78, 65, 77, 69, 83];
let message = Message::parse(message_bytes, None).unwrap();
println!("{:?}", message);
//Message { source: Some("Anon"), command: NAMES, params: [] }

Parse a NICK command that contains a single parameter

let message_bytes = vec![58,65,110,111,110,32,78,73,67,75,32,68,97,118,101];
let message = Message::parse(message_bytes, None).unwrap();
println!("{:?}", message);
// Message { source: Some("Anon"), command: NICK, params: ["Dave"] }

Here is the same NICK command but without the provided parameter

let message_bytes = vec![58,65,110,111,110,32,78,73,67,75];
let message = Message::parse(message_bytes, None);
println!("{:?}", message);
// Err(MessageError { detail: NotEnoughParams })

Now the client has sent a NICK command but not capitalised correctly (Nick)

let message_bytes = vec![58,65,110,111,110,32,78,105,99,107,32,68,97,118,101];
let message = Message::parse(message_bytes, None);
println!("{:?}", message);
// Err(MessageError { detail: InvalidCommand })

Whitespace will also be stripped from the start and end

let message_bytes = vec![32, 32, 32, 32, 32, 32, 58, 65, 110, 111, 110, 32, 78, 73, 67, 75, 32, 65, 110, 111, 110, 50, 32, 32, 32, 32, 32, 13, 10];
let message = Message::parse(message_bytes, None);
println!("{:?}", message);
// Message { source: Some("Anon"), command: NICK, params: ["Anon2"] }

You can also construct a Message manually

let message = Message::new(Some("Anon"), IRCCommand::NAMES, Vec::new())

A message object can then be returned to a value to be transmitted, CR and LF is added making exact return value valid

let tcp_data: Vec<u8> = message.serialize()
// [58, 65, 110, 111, 110, 32, 78, 65, 77, 69, 83, 13, 10]
Commit count: 0

cargo fmt