R4d is a text oriented macro prosessor made with rust.
R4d is in very early stage, so there might be lots of undetected bugs. Fast implementaiton was my priorites, thus optimization has had a least consideration for the time.
```bash
rad inputfile.txt -o outfile.txt
rad input_file.txt
printf '...text...' | rad -o out_file.txt
printf '...text...' | rad
rad -e FileToWriteError.txt # Log error to file rad -s # Suppress error rad -n # Always use unix newline (default is '\r\n' in windows platform) rad -p # Purge mode, print nothing if a macro doesn't exist rad -g # Always enable greedy for every macro invocation
rad test -f frozen.r4f
rad test -m frozen.r4f ```
Type -h
or --help
to see full options.
Definition syntax is similar to macro invocation but requires a specific form to sucessfully register the macro.
$define(name,arg1 arg2=$arg1() $arg2())
You can simply bind the value without giving arguments.
$define(v_name=Simon creek)
Definition's body can include any macro invocation in itself, thus wrong argument declaration cannot be detected at the time of definition.
``` $define(panik,kalm=$calm())
error: Failed to invoke a macro : "calm" --> stdin:2:2 $calm() ```
Prefix is a dollar sign($)
$define(macro_name,a1 a2=$a1() $a2())
$macro_name(arg1, arg2)
Macro can be invoked anywhere after the definition.
My name is $macro_name(Simon, Creek).
converts to
My name is Simon Creek.
Special argument $:
is used for iterated value.
$foreach(\*John,Simon,Jane*\,Name : $:
)
$forloop(5,10,$:th
)
converts to
```
Name : John
Name : Simon
Name : Jane
5th 6th 7th 8th 9th 10th
```
NOTE
An unbalanced parenthesis changes the behaviour of macro invocation and a
non-double-quoted comma will change the number or content of arguments. If
desirable content includes unbalanced parentheses or commas, enclose the body
with string literal with the syntax of \* TEXT GOES HERE *\
``` $repeat(2,I'm,comma,separated
I'mI'm
To include commas you need to enclose with string literal
$repeat(2,*I'm,comma,separated*\
I'm,comma,separated I'm,comma,separated
```
Greedy macro
``` $define(test,a b c=$a() $b() $c()) $test(first, second, third, fourth, fifth, sixth)
first second third first second third, fourth, fifth, sixth ```
Piping
``` $define(test,a=$a()) $test|(I'm going to be used by a pipe macro) $trim($repeat(2,$-() )) $test|(*I'll be requoted with literal*)
I'm going to be used by a pipe macro I'm going to be used by a pipe macro *I'll be requoted with literal*\ ```
R4d aims to be a modern alternative to m4 processor, which means