Macro quote::format_ident [−][src]
macro_rules! format_ident {
($fmt : expr) => { ... };
($fmt : expr, $($rest : tt) *) => { ... };
}Expand description
Formatting macro for constructing Idents.
Syntax
Syntax is copied from the format! macro, supporting both positional and
named arguments.
Only a limited set of formatting traits are supported. The current mapping of format types to traits is:
See std::fmt for more information.
IdentFragment
Unlike format!, this macro uses the [IdentFragment] formatting trait by
default. This trait is like Display, with a few differences:
IdentFragmentis only implemented for a limited set of types, such as unsigned integers and strings.Identarguments will have theirr#prefixes stripped, if present.
Hygiene
The Span of the first Ident argument is used as the span of the final
identifier, falling back to Span::call_site when no identifiers are
provided.
// If `ident` is an Ident, the span of `my_ident` will be inherited from it.
let my_ident = format_ident!("My{}{}", ident, "IsCool");
assert_eq!(my_ident, "MyIdentIsCool");Alternatively, the span can be overridden by passing the span named
argument.
let my_span = /* ... */;
format_ident!("MyIdent", span = my_span);Panics
This method will panic if the resulting formatted string is not a valid identifier.
Examples
Composing raw and non-raw identifiers:
let my_ident = format_ident!("My{}", "Ident");
assert_eq!(my_ident, "MyIdent");
let raw = format_ident!("r#Raw");
assert_eq!(raw, "r#Raw");
let my_ident_raw = format_ident!("{}Is{}", my_ident, raw);
assert_eq!(my_ident_raw, "MyIdentIsRaw");Integer formatting options:
let num: u32 = 10;
let decimal = format_ident!("Id_{}", num);
assert_eq!(decimal, "Id_10");
let octal = format_ident!("Id_{:o}", num);
assert_eq!(octal, "Id_12");
let binary = format_ident!("Id_{:b}", num);
assert_eq!(binary, "Id_1010");
let lower_hex = format_ident!("Id_{:x}", num);
assert_eq!(lower_hex, "Id_a");
let upper_hex = format_ident!("Id_{:X}", num);
assert_eq!(upper_hex, "Id_A");