9 releases

0.3.0 May 11, 2022
0.2.3 May 10, 2022
0.2.0 Jun 21, 2019
0.1.1 Jun 19, 2019

#61 in Procedural macros

Download history 15458/week @ 2024-09-16 16474/week @ 2024-09-23 15206/week @ 2024-09-30 16419/week @ 2024-10-07 18089/week @ 2024-10-14 14873/week @ 2024-10-21 16621/week @ 2024-10-28 16327/week @ 2024-11-04 17684/week @ 2024-11-11 17835/week @ 2024-11-18 12611/week @ 2024-11-25 16756/week @ 2024-12-02 19679/week @ 2024-12-09 17953/week @ 2024-12-16 6619/week @ 2024-12-23 8444/week @ 2024-12-30

53,229 downloads per month
Used in 120 crates (65 directly)

MIT license

6KB

::function_name

Function attribute #[named] that generates a function_name! macro in the scope of the function's body.

The generated function_name!() is a macro that expands to the name of the annotated function, as a string literal.

Repository Latest version Documentation MSRV unsafe forbidden no_std compatible License CI

Examples

use ::function_name::named;

#[named]
fn my_super_duper_function ()
{
    assert_eq!(
        function_name!(),
        "my_super_duper_function",
    );
}

Since the generated function_name! expands to a string literal, it can be used with other macros such as concat!:

#[macro_use] extern crate function_name;

macro_rules! function_path {() => (concat!(
    module_path!(), "::", function_name!()
))}

pub mod foo {
    pub mod bar {
        #[named]
        pub fn baz ()
        {
            assert_eq!(
                function_path!(),
                [
                    env!("CARGO_PKG_NAME"),
                    "foo", "bar",
                    "baz",
                ].join("::"),
            );
        }
    }
}

Dependencies