Et tu `macro_rules!`
Acme Design is a full service design agency.
— Swarnim Arun
〞
Every programmer is an author.
But why can't the program be one too?
– Somebody somewhere someplace
Hygiene is an important concept for macros.
It describes the ability for a macro to work in its own syntax context, not affecting nor being affected by its surroundings.
In other words this means that a syntax extension should be invocable anywhere without interfering with its surrounding context.
what's hygiene?
macro_rules!
macro_rules! hello {
($e:literal) => { println!("Hello, {}!", $e); };
}
rustc
provides a number of tools to debug general syntax extensions, as well as some more specific ones tailored towards declarative and procedural macros respectively.
Sometimes, it is what the extension expands to that proves problematic as you do not usually see the expanded code. Fortunately rustc
offers the ability to look at the expanded code via the unstable -Zunpretty=expanded
argument.
debug it!
debugging!
rustc +nightly -Zunpretty=expanded hello.rs
fn foo() {
{
::std::io::_print(format_args!("Hello, {0}!\n", "world"));
};
}
fn foo() {
hello!("world");
}
- Callback
- TT munch'in
- Internal "rules"
- Push-Down Accumulation
Some patterns
TT Muncher & Internal Rules
Just the important ones
#[macro_export]
macro_rules! foo {
(@as_expr $e:expr) => {$e};
($($tts:tt)*) => {
foo!(@as_expr $($tts)*)
};
}
Live Demo
Resources
Thank You!
reachout at:
@swarnimarun
Serif
By Swarnim Arun
Serif
- 299