Expand description
A support library for macro authors when defining new macros.
This library, provided by the standard distribution, provides the types
consumed in the interfaces of procedurally defined macro definitions such as
function-like macros #[proc_macro]
, macro attributes #[proc_macro_attribute]
and
custom derive attributes#[proc_macro_derive]
.
See the book for more.
Re-exportsยง
pub use diagnostic::Diagnostic;
Experimental pub use diagnostic::Level;
Experimental pub use diagnostic::MultiSpan;
Experimental pub use to_tokens::ToTokens;
Experimental pub use quote::quote;
Experimental pub use quote::quote_span;
Experimental
Modulesยง
- diagnostic ๐
- escape ๐
- to_
tokens ๐ - token_
stream - Public implementation details for the
TokenStream
type, such as iterators. - bridge ๐ป
Experimental - Internal interface for communicating between a
proc_macro
client (a proc macro crate) and aproc_macro
server (a compiler front-end). - quote ๐๐ป
Experimental - Quasiquoter
- tracked_
env Experimental - Tracked access to environment variables.
- tracked_
path Experimental - Tracked access to additional files.
Macrosยง
- diagnostic_
method ๐ - suffixed_
int_ ๐literals - unsuffixed_
int_ ๐literals - quote
Experimental quote!(..)
accepts arbitrary tokens and expands into aTokenStream
describing the input. For example,quote!(a + b)
will produce an expression, that, when evaluated, constructs theTokenStream
[Ident("a"), Punct('+', Alone), Ident("b")]
.
Structsยง
- Concat
Streams ๐Helper - Non-generic helper for implementing
FromIterator<TokenStream>
andExtend<TokenStream>
with less monomorphization in calling crates. - Concat
Trees ๐Helper - Non-generic helper for implementing
FromIterator<TokenTree>
andExtend<TokenTree>
with less monomorphization in calling crates. - Group
- A delimited token stream.
- Ident
- An identifier (
ident
). - LexError
- Error returned from
TokenStream::from_str
. - Literal
- A literal string (
"hello"
), byte string (b"hello"
), C string (c"hello"
), character ('a'
), byte character (b'a'
), an integer or floating point number with or without a suffix (1
,1u8
,2.3
,2.3f32
). Boolean literals liketrue
andfalse
do not belong here, they areIdent
s. - Punct
- A
Punct
is a single punctuation character such as+
,-
or#
. - Span
- A region of source code, along with macro expansion information.
- Token
Stream - The main type provided by this crate, representing an abstract stream of tokens, or, more specifically, a sequence of token trees. The type provides interfaces for iterating over those token trees and, conversely, collecting a number of token trees into one stream.
- Expand
Error Experimental - Error returned from
TokenStream::expand_expr
.
Enumsยง
- Delimiter
- Describes how a sequence of token trees is delimited.
- Spacing
- Indicates whether a
Punct
token can join with the following token to form a multi-character operator. - Token
Tree - A single token or a delimited sequence of token trees (e.g.,
[1, (), ..]
). - Conversion
Error Kind Experimental - Errors returned when trying to retrieve a literal unescaped value.
- Escape
Error - Errors and warnings that can occur during string unescaping. They mostly relate to malformed escape sequences, but there are a few that are about other problems.
Functionsยง
- is_
available - Determines whether proc_macro has been made accessible to the currently running program.
- tree_
to_ ๐bridge_ tree