Print the macro context name on incomplete parse
Fixes #22425 Also fixes #30007, since it's just a change from `true` to `false`.
This commit is contained in:
parent
69b8e74c31
commit
d4a0e545e7
4 changed files with 63 additions and 11 deletions
|
@ -44,7 +44,7 @@ impl<'a> ParserAnyMacro<'a> {
|
||||||
/// about e.g. the semicolon in `macro_rules! kapow { () => {
|
/// about e.g. the semicolon in `macro_rules! kapow { () => {
|
||||||
/// panic!(); } }` doesn't get picked up by .parse_expr(), but it's
|
/// panic!(); } }` doesn't get picked up by .parse_expr(), but it's
|
||||||
/// allowed to be there.
|
/// allowed to be there.
|
||||||
fn ensure_complete_parse(&self, allow_semi: bool) {
|
fn ensure_complete_parse(&self, allow_semi: bool, context: &str) {
|
||||||
let mut parser = self.parser.borrow_mut();
|
let mut parser = self.parser.borrow_mut();
|
||||||
if allow_semi && parser.token == token::Semi {
|
if allow_semi && parser.token == token::Semi {
|
||||||
panictry!(parser.bump())
|
panictry!(parser.bump())
|
||||||
|
@ -58,8 +58,8 @@ impl<'a> ParserAnyMacro<'a> {
|
||||||
parser.span_err(span, &msg[..]);
|
parser.span_err(span, &msg[..]);
|
||||||
|
|
||||||
let msg = format!("caused by the macro expansion here; the usage \
|
let msg = format!("caused by the macro expansion here; the usage \
|
||||||
of `{}` is likely invalid in this context",
|
of `{}!` is likely invalid in this {} context",
|
||||||
self.macro_ident);
|
self.macro_ident, context);
|
||||||
parser.span_note(self.site_span, &msg[..]);
|
parser.span_note(self.site_span, &msg[..]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -68,12 +68,12 @@ impl<'a> ParserAnyMacro<'a> {
|
||||||
impl<'a> MacResult for ParserAnyMacro<'a> {
|
impl<'a> MacResult for ParserAnyMacro<'a> {
|
||||||
fn make_expr(self: Box<ParserAnyMacro<'a>>) -> Option<P<ast::Expr>> {
|
fn make_expr(self: Box<ParserAnyMacro<'a>>) -> Option<P<ast::Expr>> {
|
||||||
let ret = panictry!(self.parser.borrow_mut().parse_expr());
|
let ret = panictry!(self.parser.borrow_mut().parse_expr());
|
||||||
self.ensure_complete_parse(true);
|
self.ensure_complete_parse(true, "expression");
|
||||||
Some(ret)
|
Some(ret)
|
||||||
}
|
}
|
||||||
fn make_pat(self: Box<ParserAnyMacro<'a>>) -> Option<P<ast::Pat>> {
|
fn make_pat(self: Box<ParserAnyMacro<'a>>) -> Option<P<ast::Pat>> {
|
||||||
let ret = panictry!(self.parser.borrow_mut().parse_pat());
|
let ret = panictry!(self.parser.borrow_mut().parse_pat());
|
||||||
self.ensure_complete_parse(false);
|
self.ensure_complete_parse(false, "pattern");
|
||||||
Some(ret)
|
Some(ret)
|
||||||
}
|
}
|
||||||
fn make_items(self: Box<ParserAnyMacro<'a>>) -> Option<SmallVector<P<ast::Item>>> {
|
fn make_items(self: Box<ParserAnyMacro<'a>>) -> Option<SmallVector<P<ast::Item>>> {
|
||||||
|
@ -81,7 +81,7 @@ impl<'a> MacResult for ParserAnyMacro<'a> {
|
||||||
while let Some(item) = panictry!(self.parser.borrow_mut().parse_item()) {
|
while let Some(item) = panictry!(self.parser.borrow_mut().parse_item()) {
|
||||||
ret.push(item);
|
ret.push(item);
|
||||||
}
|
}
|
||||||
self.ensure_complete_parse(false);
|
self.ensure_complete_parse(false, "item");
|
||||||
Some(ret)
|
Some(ret)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,7 +95,7 @@ impl<'a> MacResult for ParserAnyMacro<'a> {
|
||||||
_ => ret.push(panictry!(parser.parse_impl_item()))
|
_ => ret.push(panictry!(parser.parse_impl_item()))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
self.ensure_complete_parse(false);
|
self.ensure_complete_parse(false, "item");
|
||||||
Some(ret)
|
Some(ret)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -115,13 +115,13 @@ impl<'a> MacResult for ParserAnyMacro<'a> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
self.ensure_complete_parse(false);
|
self.ensure_complete_parse(false, "statement");
|
||||||
Some(ret)
|
Some(ret)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn make_ty(self: Box<ParserAnyMacro<'a>>) -> Option<P<ast::Ty>> {
|
fn make_ty(self: Box<ParserAnyMacro<'a>>) -> Option<P<ast::Ty>> {
|
||||||
let ret = panictry!(self.parser.borrow_mut().parse_ty());
|
let ret = panictry!(self.parser.borrow_mut().parse_ty());
|
||||||
self.ensure_complete_parse(true);
|
self.ensure_complete_parse(false, "type");
|
||||||
Some(ret)
|
Some(ret)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -327,7 +327,7 @@ fn check_lhs_nt_follows(cx: &mut ExtCtxt, lhs: &TokenTree, sp: Span) {
|
||||||
tt @ &TokenTree::Sequence(..) => {
|
tt @ &TokenTree::Sequence(..) => {
|
||||||
check_matcher(cx, Some(tt).into_iter(), &Eof);
|
check_matcher(cx, Some(tt).into_iter(), &Eof);
|
||||||
},
|
},
|
||||||
_ => cx.span_err(sp, "Invalid macro matcher; matchers must be contained \
|
_ => cx.span_err(sp, "invalid macro matcher; matchers must be contained \
|
||||||
in balanced delimiters or a repetition indicator")
|
in balanced delimiters or a repetition indicator")
|
||||||
};
|
};
|
||||||
// we don't abort on errors on rejection, the driver will do that for us
|
// we don't abort on errors on rejection, the driver will do that for us
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
// except according to those terms.
|
// except according to those terms.
|
||||||
|
|
||||||
macro_rules! invalid {
|
macro_rules! invalid {
|
||||||
_ => (); //~^ ERROR Invalid macro matcher
|
_ => (); //~^ ERROR invalid macro matcher
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
|
19
src/test/compile-fail/issue-30007.rs
Normal file
19
src/test/compile-fail/issue-30007.rs
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
#![feature(type_macros)]
|
||||||
|
|
||||||
|
macro_rules! t {
|
||||||
|
() => ( String ; ); //~ ERROR macro expansion ignores token `;`
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let i: Vec<t!()>; //~ NOTE caused by the macro expansion here
|
||||||
|
}
|
33
src/test/compile-fail/macro-context.rs
Normal file
33
src/test/compile-fail/macro-context.rs
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
#![feature(type_macros)]
|
||||||
|
|
||||||
|
// (typeof used because it's surprisingly hard to find an unparsed token after a stmt)
|
||||||
|
macro_rules! m {
|
||||||
|
() => ( i ; typeof ); //~ ERROR `typeof` is a reserved keyword
|
||||||
|
//~| ERROR macro expansion ignores token `typeof`
|
||||||
|
//~| ERROR macro expansion ignores token `typeof`
|
||||||
|
//~| ERROR macro expansion ignores token `;`
|
||||||
|
//~| ERROR macro expansion ignores token `;`
|
||||||
|
//~| ERROR macro expansion ignores token `i`
|
||||||
|
}
|
||||||
|
|
||||||
|
m!(); //~ NOTE the usage of `m!` is likely invalid in this item context
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let a: m!(); //~ NOTE the usage of `m!` is likely invalid in this type context
|
||||||
|
let i = m!(); //~ NOTE the usage of `m!` is likely invalid in this expression context
|
||||||
|
match 0 {
|
||||||
|
m!() => {} //~ NOTE the usage of `m!` is likely invalid in this pattern context
|
||||||
|
}
|
||||||
|
|
||||||
|
m!(); //~ NOTE the usage of `m!` is likely invalid in this statement context
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue