R4d (Rad)

R4d is a text oriented macro prosessor aims to be an alternative to m4 macro processor.

R4d's foreach behaviour has changes, you can use previous logic by disable default features.

Changes

Note

Because crates.io's readme is tied to version. There might be undocumented readme changes. Please use github for latest information.

Demo

Raw texts ```text $define(author=Simon Creek)

$define(title=R4d demo)

title : $title()

author : $author()

My name is $author() and I made r4d to make macros can be used within various forms of texts. This article was written in $date() $time().

$ifdef(test, This should be only printed when I'm testing not in release)$dnl()

This is some important table automatically formatted according to environment variable.

$regcsv(addr,$include(addr.csv))$dnl()

$static( queried, $query( SELECT id,firstname,address FROM addr where firstname = John ) )$dnl()

% Comments are disabled by default for better compatibility % TABLEFORM == github $table($env(TABLEFORM),$queried())

$wrap(40,$lipsum(15))

Evaluation : $prec($eval( $num(0.1second) + $num(0.2sekunde)),2) Evaluation : $evalk( 1 + 2 ) ``` Processed texts

```

title : R4d demo

author : Simon Creek

My name is Simon Creek and I made r4d to make macros can be used within various forms of texts. This article was written in 2022-01-18 16:38:07.

This is some important table automatically formatted according to environment variable.

|id|first_name|address| |-|-|-| |1|John|111-2222| |2|John|222-3333|

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore.

Evaluation : 0.30 Evaluation : 1 + 2 = 3 ```

Install

I recommend using cargo install until I prepare a proper CD pipeline.

e.g.

```bash

Binary with full macros support

cargo install r4d --features binary --locked

If you need color prompt, then use features "color"

cargo install r4d --features binary,color --locked

Only include macros that doesnt't require external crates

cargo install r4d --features basic --locked

Refer docs.rs or usage section for detailed feature usage

```

Simple usage

Binary ```

Read from file and print to stdout

rad input_file.txt

Read from standard input and print to file

printf '...text...' | rad -o out_file.txt ```

Library ```rust use rad::RadError; use rad::Processor;

let processor = Processor::new() .writetofile(Some(PathBuf::from("cache.txt")))?;

processor.fromfile(Path::new("input.txt"))?; processor.printresult()?; ```

Usage

Detailed usage

Syntax

Macro syntax

Built-in macros

Macros

About various modes

Modes

Macro types

Types

How to extend function macros

extension

Extend processor with storage feature

Storage

How to debug

Debug

2.0 changes

From 2.0, following breaking changes have been applied.

Goal

R4d aims to be a modern alternative to m4 processor, which means

CVE related issue

Setvar data races vulnerability is known issue at the time but for current state, it doesn't affect r4d since r4d doesn't utillize multi threading in processing. Every time,date call and env_set calls are sequential and doensn't overlap.