diff options
| author | Michael Lamparski <diagonaldevice@gmail.com> | 2018-03-13 15:12:15 -0400 |
|---|---|---|
| committer | Michael Lamparski <diagonaldevice@gmail.com> | 2018-03-13 15:23:36 -0400 |
| commit | dc96467e220ffd68a68447a822659e245dcc9a4f (patch) | |
| tree | 5075888d1f6332e72e5363bf8ef508e31db0c4fa /src/libsyntax | |
| parent | decbb83f9e7e763d440d9e00861f6dd066e0e487 (diff) | |
| download | rust-dc96467e220ffd68a68447a822659e245dcc9a4f.tar.gz rust-dc96467e220ffd68a68447a822659e245dcc9a4f.zip | |
Fix ICE on malformed plugin attributes
Diffstat (limited to 'src/libsyntax')
| -rw-r--r-- | src/libsyntax/ext/expand.rs | 6 |
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)) |
