13 releases (breaking)

0.10.0 Oct 30, 2024
0.8.0 May 11, 2024
0.7.0 Mar 16, 2024
0.3.0 Oct 19, 2023
0.1.3 May 25, 2022

#323 in Development tools

Download history 359/week @ 2024-09-15 275/week @ 2024-09-22 363/week @ 2024-09-29 239/week @ 2024-10-06 318/week @ 2024-10-13 206/week @ 2024-10-20 565/week @ 2024-10-27 1113/week @ 2024-11-03 281/week @ 2024-11-10 502/week @ 2024-11-17 244/week @ 2024-11-24 847/week @ 2024-12-01 365/week @ 2024-12-08 435/week @ 2024-12-15 85/week @ 2024-12-22 84/week @ 2024-12-29

997 downloads per month
Used in 78 crates (2 directly)

MIT license

18KB
415 lines

Module :: for_each

experimental rust-status docs.rs Open in Gitpod discord

Apply a macro for each element of a list.

Macros $Callback is called for each element of the passed list, optionally passing prefix $Prefix as the first argument(s) and postfix $Postfix as the last argument(s). Macros could be invoked in either function call style or map call style. Prefix and postfix could be passed only in map call style. In map call style after passing path to macro pass keyword where and options in format : @KEY Value.

In some cases, the same code may be generated without callback macro, just using prefix and postfix. That's why $Callback is also optional. To invoke for_each without callback use map call style omitting path to callback and keyword where.

Basic Use Case :: function-style call

Apply a macro for each element of a list.

Macro for_each may be called either in function-style way or in map-style way. Pass name of macro to apply to elements as the first arguments and elements after the macro name. Use comma as delimiter.

use for_each::for_each;
for_each!( dbg, "a", "b", "c" );

// generates
dbg!( "a" );
dbg!( "b" );
dbg!( "c" );

Basic Use Case :: map-style call

Macro for_each may be called either in function-style way or in map-style way. Use keys @Prefix @Postfix @Each to pass options as entries of a map. Options @Prefix and @Postfix are optional and their entries could be omitted, but entry @Each is mandatory. Order of options should always be @Prefix, @Postfix, @Each.

use for_each::for_each;

for_each!
{
  dbg where
  @Prefix { "prefix".to_string() + }
  @Postfix { + "postfix" }
  @Each "a" "b" "c"
};

It generates:

// generated
dbg!( "prefix".to_string() + "a" + "postfix" );
dbg!( "prefix".to_string() + "b" + "postfix" );
dbg!( "prefix".to_string() + "c" + "postfix" );

Basic Use Case :: more than single token

Both prefix and postfix have to be token tree ( tt ). But if you need something more complex put it into braces { ... }. Macros for_each will remove outermost braces. Braces are optional in case of prefix/postfix is a single token.

use for_each::for_each;

for_each!
{
  dbg where
  @Prefix { "prefix".to_string() + }
  @Postfix { + "postfix" }
  @Each { "a" + "1" } { "b" + "2" } { "c" + "3" }
};

// generates
dbg!( "prefix".to_string() + "a" + "1" + "postfix" );
dbg!( "prefix".to_string() + "b" + "2" + "postfix" );
dbg!( "prefix".to_string() + "c" + "3" + "postfix" );

Basic Use Case :: callbackless

Callback macro is optional. Use map call style and omit path to callback macro with keyword where to invoke for_each without a callback.

use for_each::for_each;
for_each!
{
  @Prefix { dbg! }
  @Each ( "a" ) ( "b" ) ( "c" )
};
// generates
dbg!( "a" );
dbg!( "b" );
dbg!( "c" );

To add to your project

cargo add for_each

Try out from the repository

git clone https://github.com/Wandalen/wTools
cd wTools
cd examples/for_each_trivial
cargo run
>

No runtime deps

Features