Auto merge of #30708 - GuillaumeGomez:malformed_macro, r=sanxiyn
Part of #30669
This commit is contained in:
commit
dbacacda8a
2 changed files with 19 additions and 2 deletions
|
|
@ -178,7 +178,7 @@ fn generic_extension<'cx>(cx: &'cx ExtCtxt,
|
|||
for (i, lhs) in lhses.iter().enumerate() { // try each arm's matchers
|
||||
let lhs_tt = match *lhs {
|
||||
TokenTree::Delimited(_, ref delim) => &delim.tts[..],
|
||||
_ => cx.span_bug(sp, "malformed macro lhs")
|
||||
_ => cx.span_fatal(sp, "malformed macro lhs")
|
||||
};
|
||||
|
||||
match TokenTree::parse(cx, lhs_tt, arg) {
|
||||
|
|
@ -186,7 +186,7 @@ fn generic_extension<'cx>(cx: &'cx ExtCtxt,
|
|||
let rhs = match rhses[i] {
|
||||
// ignore delimiters
|
||||
TokenTree::Delimited(_, ref delimed) => delimed.tts.clone(),
|
||||
_ => cx.span_bug(sp, "malformed macro rhs"),
|
||||
_ => cx.span_fatal(sp, "malformed macro rhs"),
|
||||
};
|
||||
// rhs has holes ( `$id` and `$(...)` that need filled)
|
||||
let trncbr = new_tt_reader(&cx.parse_sess().span_diagnostic,
|
||||
|
|
|
|||
17
src/test/compile-fail/malformed_macro_lhs.rs
Normal file
17
src/test/compile-fail/malformed_macro_lhs.rs
Normal file
|
|
@ -0,0 +1,17 @@
|
|||
// 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.
|
||||
|
||||
macro_rules! my_precioooous {
|
||||
$($t:tt)* => (1);
|
||||
}
|
||||
|
||||
fn main() {
|
||||
my_precioooous!(); //~ ERROR malformed macro lhs
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue