use create_snapshot_for_diagnostic
instead of clone
This commit is contained in:
parent
7092d42c04
commit
84a13a28b7
2 changed files with 3 additions and 3 deletions
|
@ -123,7 +123,7 @@ impl<'a> ParserAnyMacro<'a> {
|
|||
is_trailing_mac,
|
||||
is_local,
|
||||
} = *self;
|
||||
let snapshot = &mut parser.clone();
|
||||
let snapshot = &mut parser.create_snapshot_for_diagnostic();
|
||||
let fragment = match parse_ast_fragment(parser, kind) {
|
||||
Ok(f) => f,
|
||||
Err(err) => {
|
||||
|
|
|
@ -336,7 +336,7 @@ struct InInTypo {
|
|||
// SnapshotParser is used to create a snapshot of the parser
|
||||
// without causing duplicate errors being emitted when the `Parser`
|
||||
// is dropped.
|
||||
pub(super) struct SnapshotParser<'a> {
|
||||
pub struct SnapshotParser<'a> {
|
||||
parser: Parser<'a>,
|
||||
unclosed_delims: Vec<UnmatchedBrace>,
|
||||
}
|
||||
|
@ -392,7 +392,7 @@ impl<'a> Parser<'a> {
|
|||
}
|
||||
|
||||
/// Create a snapshot of the `Parser`.
|
||||
pub(super) fn create_snapshot_for_diagnostic(&self) -> SnapshotParser<'a> {
|
||||
pub fn create_snapshot_for_diagnostic(&self) -> SnapshotParser<'a> {
|
||||
let mut snapshot = self.clone();
|
||||
let unclosed_delims = self.unclosed_delims.clone();
|
||||
// Clear `unclosed_delims` in snapshot to avoid
|
||||
|
|
Loading…
Add table
Reference in a new issue