#name #ident #concat #concatenate #combine #generate

macro concat-idents

Allows concatenating multiple identifiers and using them everywhere

7 stable releases

1.1.5 Jun 14, 2023
1.1.4 Oct 31, 2022
1.1.3 Jul 4, 2021
1.1.2 Jan 12, 2021
1.0.0 Aug 4, 2020

#45 in Procedural macros

Download history 12610/week @ 2024-08-13 14597/week @ 2024-08-20 13909/week @ 2024-08-27 13979/week @ 2024-09-03 9157/week @ 2024-09-10 10636/week @ 2024-09-17 11824/week @ 2024-09-24 13246/week @ 2024-10-01 8726/week @ 2024-10-08 11979/week @ 2024-10-15 10363/week @ 2024-10-22 14054/week @ 2024-10-29 9118/week @ 2024-11-05 9367/week @ 2024-11-12 13266/week @ 2024-11-19 14866/week @ 2024-11-26

49,029 downloads per month
Used in 112 crates (58 directly)

MIT/Apache

15KB
184 lines

concat-idents!

crates.io docs.rs licence

This crate provides a single, easy to use macro.

Usage

Basic usage

use concat_idents::concat_idents;

concat_idents!(fn_name = foo_, _, bar {
       fn fn_name() {
           // --snip--
       }
});

foo__bar();

Allowed identifier parts

concat_idents!(fn_name = _, __ { /* underscores */ });
concat_idents!(fn_name = foo, _bar { /* identifiers */ });
concat_idents!(fn_name = "foo", "bar" { /* strings */ });
concat_idents!(fn_name = 'f', 'o', 'o' { /* characters */ });
concat_idents!(fn_name = foo, 1, bar, 2 { /* integers */ });
concat_idents!(fn_name = true, false { /* booleans */ });
concat_idents!(fn_name = "enum", bar { /* quoted reserved keywords (recommended way) */ });
concat_idents!(fn_name = r#struct, bar { /* escaped reserved keywords (not recommended, since some keywords produce error) */ });

Generating Tests

macro_rules! generate_test {
   ($method:ident($lhs:ident, $rhs:ident)) => {
       concat_idents!(test_name = $method, _, $lhs, _, $rhs {
           #[test]
           fn test_name() {
               let _ = $lhs::default().$method($rhs::default());
           }
       });
   };
}

#[derive(Default)]
struct S(i32);

impl Add<i32> for S {
   type Output = S;
   fn add(self,rhs: i32) -> Self::Output { S(self.0 + rhs) }
}

impl Sub<i32> for S {
   type Output = S;
   fn sub(self,rhs: i32) -> Self::Output { S(self.0 - rhs) }
}

generate_test!(add(S, i32));
generate_test!(sub(S, i32));

Error

This macro will throw a compile error, if:

  1. an unexpected syntax is passed
concat_idents!({});
concat_idents!(ident {});
concat_idents!(ident =  {});
concat_idents!(= foo, bar {});
concat_idents!(ident = foo, bar);
...
  1. one of the identifiers is invalid
concat_idents!(ident = true {});        // identifiers cannot consist of only one bool 
concat_idents!(ident = 1 {});           // identifiers cannot consist of only one int
concat_idents!(ident = 1, foo {});      // identifiers cannot start with an int
concat_idents!(ident = foo, 1.0 {});    // identifiers cannot contain floats
concat_idents!(ident = "enum");         // identifiers cannot consist of only one reserved keyword
concat_idents!(ident = r#struct);       // identifiers cannot consist of only one reserved keyword
concat_idents!(ident = " space");       // identifiers cannot contain spaces
concat_idents!(ident = "foo-bar🧨");    // identifiers can only contain [a-zA-Z0-9_]
...

Dependencies

~220–660KB
~16K SLoC