about summary refs log tree commit diff
path: root/src/libsyntax/parse
diff options
context:
space:
mode:
authorJeffrey Seyfried <jeffrey.seyfried@gmail.com>2016-05-25 20:05:47 +0000
committerJeffrey Seyfried <jeffrey.seyfried@gmail.com>2016-05-26 01:20:55 +0000
commit5b82c5f369fa9b7ab8ace58b3112e44ff5a1d388 (patch)
treee44b9cf236cf47f41b1ba66f0d83471a92a3e18d /src/libsyntax/parse
parent2c937204e9172121da5439f08c2b631de1e135e2 (diff)
downloadrust-5b82c5f369fa9b7ab8ace58b3112e44ff5a1d388.tar.gz
rust-5b82c5f369fa9b7ab8ace58b3112e44ff5a1d388.zip
Fix ICE on failure to parse token tree
Diffstat (limited to 'src/libsyntax/parse')
-rw-r--r--src/libsyntax/parse/parser.rs7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs
index 3a28632f07a..9f4a773973e 100644
--- a/src/libsyntax/parse/parser.rs
+++ b/src/libsyntax/parse/parser.rs
@@ -2702,7 +2702,10 @@ impl<'a> Parser<'a> {
                     return Ok(TokenTree::Token(sp, SpecialVarNt(SpecialMacroVar::CrateMacroVar)));
                 } else {
                     sp = mk_sp(sp.lo, self.span.hi);
-                    self.parse_ident()?
+                    self.parse_ident().unwrap_or_else(|mut e| {
+                        e.emit();
+                        keywords::Invalid.ident()
+                    })
                 }
             }
             token::SubstNt(name) => {
@@ -2845,7 +2848,7 @@ impl<'a> Parser<'a> {
                         // and an error emitted then. Thus we don't pop from
                         // self.open_braces here.
                     },
-                    _ => unreachable!(),
+                    _ => {}
                 }
 
                 Ok(TokenTree::Delimited(span, Rc::new(Delimited {