Crates.io | inpt-macros |
lib.rs | inpt-macros |
version | 0.1.1 |
source | src |
created_at | 2022-09-10 22:33:54.543219 |
updated_at | 2022-11-26 04:30:06.29075 |
description | Procedural macro implementation for the inpt crate. |
homepage | |
repository | https://gitlab.com/samsartor/inpt |
max_upload_size | |
id | 662746 |
size | 32,261 |
Inpt is a derive crate for dumb type-level text parsing.
Read the lastest documentation for more information.
Imagine you need to chop up an annoying string and convert all the bits to useful types.
You could write that sort of code by hand using split
and from_str
, but the boiler-plate
of unwrapping and checking quickly looses all charm. Especially since that sort of parsing
shows up a lot in timed programming competitions like advent of code.
Inpt tries to write that sort of parsing code for you, automatically splitting input strings based on field types and an optional regex. Inpt is absolutely not performant, strict, or formal. Whenever possible, it does the obvious thing:
#[inpt::main]
fn main(x: f32, y: f32) {
println!("{}", x * y);
}
$ echo '6,7' | cargo run
42
use inpt::{Inpt, inpt};
#[derive(Inpt)]
#[inpt(regex = r"(.)=([-\d]+)\.\.([-\d]+),?")]
struct Axis {
name: char,
start: i32,
end: i32,
}
#[derive(Inpt)]
#[inpt(regex = "target area:")]
struct Target {
#[inpt(after)]
axes: Vec<Axis>,
}
impl Target {
fn area(&self) -> i32 {
self.axes.iter().map(|Axis { start, end, ..}| end - start).product()
}
}
let target = inpt::<Target>("target area: x=119..176, y=-114..84").unwrap();
assert_eq!(target.area(), 11286);