auto merge of #6686 : cmr/rust/fix-6596, r=catamorphism

The error message is extremely unideal.
This commit is contained in:
bors 2013-05-22 16:22:35 -07:00
commit f517ed0b08
2 changed files with 16 additions and 4 deletions

View file

@ -118,10 +118,13 @@ fn lookup_cur_matched_by_matched(r: &mut TtReader,
}
fn lookup_cur_matched(r: &mut TtReader, name: ident) -> @named_match {
// FIXME (#3850): this looks a bit silly with an extra scope.
let start;
{ start = *r.interpolations.get(&name); }
return lookup_cur_matched_by_matched(r, start);
match r.interpolations.find_copy(&name) {
Some(s) => lookup_cur_matched_by_matched(r, s),
None => {
r.sp_diag.span_fatal(r.cur_span, fmt!("unknown macro variable `%s`",
*r.interner.get(name)));
}
}
}
enum lis {
lis_unconstrained, lis_constraint(uint, ident), lis_contradiction(~str)

View file

@ -0,0 +1,9 @@
macro_rules! e( //~ ERROR unknown macro variable `nonexistent`
($inp:ident) => (
$nonexistent
);
)
fn main() {
e!(foo);
}