From 75d08189223012a175e7165cd665943dc7f5ee9f Mon Sep 17 00:00:00 2001 From: David Tolnay Date: Wed, 20 Nov 2024 21:29:06 -0800 Subject: [PATCH] Make parser's fallback Ident symmetric with Group and Literal --- src/lib.rs | 7 +++++++ src/parse.rs | 16 ++++++---------- src/wrapper.rs | 14 ++++++-------- 3 files changed, 19 insertions(+), 18 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 630343b..9459a54 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -971,6 +971,13 @@ impl Ident { } } + fn _new_fallback(inner: fallback::Ident) -> Self { + Ident { + inner: imp::Ident::from(inner), + _marker: MARKER, + } + } + /// Creates a new `Ident` with the given `string` as well as the specified /// `span`. /// diff --git a/src/parse.rs b/src/parse.rs index 3b3a998..497b68d 100644 --- a/src/parse.rs +++ b/src/parse.rs @@ -1,5 +1,5 @@ use crate::fallback::{ - self, is_ident_continue, is_ident_start, Group, LexError, Literal, Span, TokenStream, + self, is_ident_continue, is_ident_start, Group, Ident, LexError, Literal, Span, TokenStream, TokenStreamBuilder, }; use crate::{Delimiter, Punct, Spacing, TokenTree}; @@ -300,10 +300,8 @@ fn ident_any(input: Cursor) -> PResult { let (rest, sym) = ident_not_raw(rest)?; if !raw { - let ident = crate::Ident::_new(crate::imp::Ident::new_unchecked( - sym, - fallback::Span::call_site(), - )); + let ident = + crate::Ident::_new_fallback(Ident::new_unchecked(sym, fallback::Span::call_site())); return Ok((rest, ident)); } @@ -312,10 +310,8 @@ fn ident_any(input: Cursor) -> PResult { _ => {} } - let ident = crate::Ident::_new(crate::imp::Ident::new_raw_unchecked( - sym, - fallback::Span::call_site(), - )); + let ident = + crate::Ident::_new_fallback(Ident::new_raw_unchecked(sym, fallback::Span::call_site())); Ok((rest, ident)) } @@ -941,7 +937,7 @@ fn doc_comment<'a>(input: Cursor<'a>, trees: &mut TokenStreamBuilder) -> PResult trees.push_token_from_parser(TokenTree::Punct(bang)); } - let doc_ident = crate::Ident::_new(crate::imp::Ident::new_unchecked("doc", fallback_span)); + let doc_ident = crate::Ident::_new_fallback(Ident::new_unchecked("doc", fallback_span)); let mut equal = Punct::new('=', Spacing::Alone); equal.set_span(span); let mut literal = crate::Literal::_new_fallback(Literal::string(comment)); diff --git a/src/wrapper.rs b/src/wrapper.rs index 3d461b6..ecf0bb6 100644 --- a/src/wrapper.rs +++ b/src/wrapper.rs @@ -693,10 +693,6 @@ impl Ident { } } - pub(crate) fn new_unchecked(string: &str, span: fallback::Span) -> Self { - Ident::Fallback(fallback::Ident::new_unchecked(string, span)) - } - #[track_caller] pub(crate) fn new_raw_checked(string: &str, span: Span) -> Self { match span { @@ -705,10 +701,6 @@ impl Ident { } } - pub(crate) fn new_raw_unchecked(string: &str, span: fallback::Span) -> Self { - Ident::Fallback(fallback::Ident::new_raw_unchecked(string, span)) - } - pub(crate) fn span(&self) -> Span { match self { Ident::Compiler(t) => Span::Compiler(t.span()), @@ -733,6 +725,12 @@ impl Ident { } } +impl From for Ident { + fn from(inner: fallback::Ident) -> Self { + Ident::Fallback(inner) + } +} + impl PartialEq for Ident { fn eq(&self, other: &Ident) -> bool { match (self, other) {