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

#52 in Procedural macros

Download history 15970/week @ 2024-11-05 18262/week @ 2024-11-12 17166/week @ 2024-11-19 13183/week @ 2024-11-26 17203/week @ 2024-12-03 19347/week @ 2024-12-10 16638/week @ 2024-12-17 6438/week @ 2024-12-24 10057/week @ 2024-12-31 26252/week @ 2025-01-07 28868/week @ 2025-01-14 25051/week @ 2025-01-21 24240/week @ 2025-01-28 30161/week @ 2025-02-04 27733/week @ 2025-02-11 54/week @ 2025-02-18

86,931 downloads per month
Used in 130 crates (67 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