Skip to content

Commit 7d2173e

Browse files
committed
Use P for NtMeta.
This commit reduces the size of `Nonterminal` from a 72 bytes to 40 bytes (on x86-64).
1 parent 0d69fe8 commit 7d2173e

File tree

4 files changed

+7
-5
lines changed

4 files changed

+7
-5
lines changed

src/librustc_expand/mbe/macro_parser.rs

+2-1
Original file line numberDiff line numberDiff line change
@@ -81,6 +81,7 @@ use rustc_parse::Directory;
8181
use rustc_span::symbol::{kw, sym, Symbol};
8282
use syntax::ast::{Ident, Name};
8383
use syntax::print::pprust;
84+
use syntax::ptr::P;
8485
use syntax::sess::ParseSess;
8586
use syntax::token::{self, DocComment, Nonterminal, Token};
8687
use syntax::tokenstream::TokenStream;
@@ -914,7 +915,7 @@ fn parse_nt_inner<'a>(p: &mut Parser<'a>, sp: Span, name: Symbol) -> PResult<'a,
914915
}
915916
}
916917
sym::path => token::NtPath(p.parse_path(PathStyle::Type)?),
917-
sym::meta => token::NtMeta(p.parse_attr_item()?),
918+
sym::meta => token::NtMeta(P(p.parse_attr_item()?)),
918919
sym::vis => token::NtVis(p.parse_visibility(FollowedByType::Yes)?),
919920
sym::lifetime => {
920921
if p.check_lifetime() {

src/librustc_parse/parser/attr.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -177,7 +177,7 @@ impl<'a> Parser<'a> {
177177
pub fn parse_attr_item(&mut self) -> PResult<'a, ast::AttrItem> {
178178
let item = match self.token.kind {
179179
token::Interpolated(ref nt) => match **nt {
180-
Nonterminal::NtMeta(ref item) => Some(item.clone()),
180+
Nonterminal::NtMeta(ref item) => Some(item.clone().into_inner()),
181181
_ => None,
182182
},
183183
_ => None,

src/libsyntax/mut_visit.rs

+2-1
Original file line numberDiff line numberDiff line change
@@ -704,7 +704,8 @@ pub fn noop_visit_interpolated<T: MutVisitor>(nt: &mut token::Nonterminal, vis:
704704
token::NtIdent(ident, _is_raw) => vis.visit_ident(ident),
705705
token::NtLifetime(ident) => vis.visit_ident(ident),
706706
token::NtLiteral(expr) => vis.visit_expr(expr),
707-
token::NtMeta(AttrItem { path, args }) => {
707+
token::NtMeta(item) => {
708+
let AttrItem { path, args } = item.deref_mut();
708709
vis.visit_path(path);
709710
visit_mac_args(args, vis);
710711
}

src/libsyntax/token.rs

+2-2
Original file line numberDiff line numberDiff line change
@@ -673,7 +673,7 @@ pub enum Nonterminal {
673673
NtLifetime(ast::Ident),
674674
NtLiteral(P<ast::Expr>),
675675
/// Stuff inside brackets for attributes
676-
NtMeta(ast::AttrItem),
676+
NtMeta(P<ast::AttrItem>),
677677
NtPath(ast::Path),
678678
NtVis(ast::Visibility),
679679
NtTT(TokenTree),
@@ -687,7 +687,7 @@ pub enum Nonterminal {
687687

688688
// `Nonterminal` is used a lot. Make sure it doesn't unintentionally get bigger.
689689
#[cfg(target_arch = "x86_64")]
690-
rustc_data_structures::static_assert_size!(Nonterminal, 72);
690+
rustc_data_structures::static_assert_size!(Nonterminal, 40);
691691

692692
impl PartialEq for Nonterminal {
693693
fn eq(&self, rhs: &Self) -> bool {

0 commit comments

Comments
 (0)