proc_macro

结构体 TokenStream

1.15.0 · 源码
pub struct TokenStream(/* private fields */);
展开描述

此 crate 提供的主要类型,表示 token 的抽象流,或者更具体地说,是 token 树的序列。此类型提供了用于迭代这些 token 树的接口,反之,也提供了将多个 token 树收集到一个流中的接口。

这是 #[proc_macro]#[proc_macro_attribute]#[proc_macro_derive] 定义的输入和输出。

实现§

源码§

impl TokenStream

1.29.0 · 源码

pub fn new() -> TokenStream

返回一个不包含任何 token 树的空 TokenStream

1.29.0 · 源码

pub fn is_empty(&self) -> bool

检查此 TokenStream 是否为空。

源码

pub fn expand_expr(&self) -> Result<TokenStream, ExpandError>

🔬这是一个仅限 nightly 版本的实验性 API。(proc_macro_expand #90765)

将此 TokenStream 解析为表达式,并尝试展开其中的任何宏。返回展开后的 TokenStream

目前,只有展开为字面量的表达式才会成功,尽管未来可能会放宽此限制。

注意:在错误情况下,expand_expr 可能会保持宏未展开、报告错误、导致编译失败和/或返回 Err(..)。任何错误情况的具体行为,以及哪些情况被认为是错误,都是未指定的,并且将来可能会更改。

Trait 实现§

1.15.0 · 源码§

impl Clone for TokenStream

源码§

fn clone(&self) -> TokenStream

返回值的副本。 阅读更多
1.0.0 · 源码§

fn clone_from(&mut self, source: &Self)

执行从 source 的复制赋值。 阅读更多
1.15.0 · 源码§

impl Debug for TokenStream

以方便调试的形式打印 token。

源码§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

使用给定的 formatter 格式化值。 阅读更多
1.45.0 · 源码§

impl Default for TokenStream

源码§

fn default() -> Self

返回类型的“默认值”。 阅读更多
1.15.0 · 源码§

impl Display for TokenStream

将 token 流打印为字符串,该字符串应该可以无损地转换回相同的 token 流(模跨度),但可能 TokenTree::GroupDelimiter::None 分隔符和负数数字字面量除外。

注意:输出的确切形式可能会更改,例如,token 之间使用的空格可能会发生变化。因此,您不应对输出字符串(由 to_string 生成)执行任何类型的简单子字符串匹配来实现 proc 宏,因为如果发生此类更改,该匹配可能会停止工作。相反,您应该在 TokenTree 级别工作,例如,匹配 TokenTree::IdentTokenTree::PunctTokenTree::Literal

源码§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

使用给定的 formatter 格式化值。 阅读更多
1.30.0 · 源码§

impl Extend<TokenStream> for TokenStream

源码§

fn extend<I: IntoIterator<Item = TokenStream>>(&mut self, streams: I)

使用迭代器的内容扩展集合。 阅读更多
源码§

fn extend_one(&mut self, item: A)

🔬这是一个仅限 nightly 版本的实验性 API。(extend_one #72631)
使用一个元素扩展集合。
源码§

fn extend_reserve(&mut self, additional: usize)

🔬这是一个仅限 nightly 版本的实验性 API。(extend_one #72631)
在集合中为给定数量的额外元素预留容量。 阅读更多
1.30.0 · 源码§

impl Extend<TokenTree> for TokenStream

源码§

fn extend<I: IntoIterator<Item = TokenTree>>(&mut self, trees: I)

使用迭代器的内容扩展集合。 阅读更多
源码§

fn extend_one(&mut self, item: A)

🔬这是一个仅限 nightly 版本的实验性 API。(extend_one #72631)
使用一个元素扩展集合。
源码§

fn extend_reserve(&mut self, additional: usize)

🔬这是一个仅限 nightly 版本的实验性 API。(extend_one #72631)
在集合中为给定数量的额外元素预留容量。 阅读更多
1.29.0 · 源码§

impl From<TokenTree> for TokenStream

创建一个包含单个 token 树的 token 流。

源码§

fn from(tree: TokenTree) -> TokenStream

从此输入类型转换为此类型。
1.15.0 · 源码§

impl FromIterator<TokenStream> for TokenStream

token 流上的“展平”操作,从多个 token 流中收集 token 树到一个流中。

源码§

fn from_iter<I: IntoIterator<Item = TokenStream>>(streams: I) -> Self

从迭代器创建一个值。 阅读更多
1.29.0 · 源码§

impl FromIterator<TokenTree> for TokenStream

将多个 token 树收集到一个流中。

源码§

fn from_iter<I: IntoIterator<Item = TokenTree>>(trees: I) -> Self

从迭代器创建一个值。 阅读更多
1.15.0 · 源码§

impl FromStr for TokenStream

尝试将字符串分解为 token,并将这些 token 解析为 token 流。可能会因多种原因失败,例如,如果字符串包含不平衡的分隔符或语言中不存在的字符。解析流中的所有 token 都获得 Span::call_site() span。

注意:某些错误可能会导致 panic 而不是返回 LexError。我们保留稍后将这些错误更改为 LexError 的权利。

源码§

type Err = LexError

可以从解析返回的关联错误。
源码§

fn from_str(src: &str) -> Result<TokenStream, LexError>

解析字符串 s 以返回此类型的值。 阅读更多
1.29.0 · 源码§

impl IntoIterator for TokenStream

源码§

type Item = TokenTree

正在迭代的元素的类型。
源码§

type IntoIter = IntoIter

我们要将其转换为哪种迭代器?
源码§

fn into_iter(self) -> IntoIter

从值创建一个迭代器。 阅读更多
源码§

impl ToTokens for TokenStream

源码§

fn to_tokens(&self, tokens: &mut TokenStream)

🔬这是一个仅限 nightly 版本的实验性 API。(proc_macro_totokens #130977)
self 写入给定的 TokenStream阅读更多
源码§

fn into_token_stream(self) -> TokenStream

🔬这是一个仅限 nightly 版本的实验性 API。(proc_macro_totokens #130977)
self 直接转换为 TokenStream 对象。 阅读更多
源码§

fn to_token_stream(&self) -> TokenStream

🔬这是一个仅限 nightly 版本的实验性 API。(proc_macro_totokens #130977)
self 直接转换为 TokenStream 对象。 阅读更多
1.15.0 · 源码§

impl !Send for TokenStream

1.15.0 · 源码§

impl !Sync for TokenStream

自动 Trait 实现§

通用的实现§

源码§

impl<T> Any for T
where T: 'static + ?Sized,

源码§

fn type_id(&self) -> TypeId

获取 selfTypeId阅读更多
源码§

impl<T> Borrow<T> for T
where T: ?Sized,

源码§

fn borrow(&self) -> &T

不可变地从拥有的值借用。 阅读更多
源码§

impl<T> BorrowMut<T> for T
where T: ?Sized,

源码§

fn borrow_mut(&mut self) -> &mut T

可变地从拥有的值借用。 阅读更多
源码§

impl<T> CloneToUninit for T
where T: Clone,

源码§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬这是一个仅限 nightly 版本的实验性 API。(clone_to_uninit #126799)
执行从 selfdst 的复制赋值。 阅读更多
源码§

impl<T> From<T> for T

源码§

fn from(t: T) -> T

返回未更改的参数。

源码§

impl<T, U> Into<U> for T
where U: From<T>,

源码§

fn into(self) -> U

调用 U::from(self)

也就是说,此转换是 From<T> for U 的实现选择执行的任何操作。

源码§

impl<T> ToOwned for T
where T: Clone,

源码§

type Owned = T

获取所有权后的结果类型。
源码§

fn to_owned(&self) -> T

从借用的数据创建拥有的数据,通常通过克隆。 阅读更多
源码§

fn clone_into(&self, target: &mut T)

使用借用的数据替换拥有的数据,通常通过克隆。 阅读更多
源码§

impl<T> ToString for T
where T: Display + ?Sized,

源码§

fn to_string(&self) -> String

将给定值转换为 String阅读更多
源码§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

源码§

type Error = Infallible

转换错误时返回的类型。
源码§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

执行转换。
源码§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

源码§

type Error = <U as TryFrom<T>>::Error

转换错误时返回的类型。
源码§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

执行转换。