about summary refs log tree commit diff
path: root/src/libsyntax/ext
diff options
context:
space:
mode:
authorMichael Lamparski <diagonaldevice@gmail.com>2018-03-13 15:12:15 -0400
committerMichael Lamparski <diagonaldevice@gmail.com>2018-03-13 15:23:36 -0400
commitdc96467e220ffd68a68447a822659e245dcc9a4f (patch)
tree5075888d1f6332e72e5363bf8ef508e31db0c4fa /src/libsyntax/ext
parentdecbb83f9e7e763d440d9e00861f6dd066e0e487 (diff)
downloadrust-dc96467e220ffd68a68447a822659e245dcc9a4f.tar.gz
rust-dc96467e220ffd68a68447a822659e245dcc9a4f.zip
Fix ICE on malformed plugin attributes
Diffstat (limited to 'src/libsyntax/ext')
-rw-r--r--src/libsyntax/ext/expand.rs6
1 files changed, 4 insertions, 2 deletions
diff --git a/src/libsyntax/ext/expand.rs b/src/libsyntax/ext/expand.rs
index 377f47a3ea5..3e75afcee1c 100644
--- a/src/libsyntax/ext/expand.rs
+++ b/src/libsyntax/ext/expand.rs
@@ -484,13 +484,15 @@ impl<'a, 'b> MacroExpander<'a, 'b> {
 
         match *ext {
             MultiModifier(ref mac) => {
-                let meta = attr.parse_meta(self.cx.parse_sess).ok()?;
+                let meta = attr.parse_meta(self.cx.parse_sess)
+                               .map_err(|mut e| { e.emit(); }).ok()?;
                 let item = mac.expand(self.cx, attr.span, &meta, item);
                 Some(kind.expect_from_annotatables(item))
             }
             MultiDecorator(ref mac) => {
                 let mut items = Vec::new();
-                let meta = attr.parse_meta(self.cx.parse_sess).ok()?;
+                let meta = attr.parse_meta(self.cx.parse_sess)
+                               .expect("derive meta should already have been parsed");
                 mac.expand(self.cx, attr.span, &meta, &item, &mut |item| items.push(item));
                 items.push(item);
                 Some(kind.expect_from_annotatables(items))