Skip to content

Commit

Permalink
Match errors using the callsite of macro expansions
Browse files Browse the repository at this point in the history
  • Loading branch information
fpoli committed Jul 23, 2018
1 parent 3900bf8 commit 8ec9d72
Show file tree
Hide file tree
Showing 43 changed files with 137 additions and 49 deletions.
6 changes: 3 additions & 3 deletions src/test/ui/codemap_tests/bad-format-args.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
// except according to those terms.

fn main() {
format!();
format!("" 1);
format!("", 1 1);
format!(); //~ ERROR requires at least a format string argument
format!("" 1); //~ ERROR expected token: `,`
format!("", 1 1); //~ ERROR expected token: `,`
}
6 changes: 3 additions & 3 deletions src/test/ui/codemap_tests/bad-format-args.stderr
Original file line number Diff line number Diff line change
@@ -1,23 +1,23 @@
error: requires at least a format string argument
--> $DIR/bad-format-args.rs:12:5
|
LL | format!();
LL | format!(); //~ ERROR requires at least a format string argument
| ^^^^^^^^^^
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)

error: expected token: `,`
--> $DIR/bad-format-args.rs:13:5
|
LL | format!("" 1);
LL | format!("" 1); //~ ERROR expected token: `,`
| ^^^^^^^^^^^^^^
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)

error: expected token: `,`
--> $DIR/bad-format-args.rs:14:5
|
LL | format!("", 1 1);
LL | format!("", 1 1); //~ ERROR expected token: `,`
| ^^^^^^^^^^^^^^^^^
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)
Expand Down
3 changes: 1 addition & 2 deletions src/test/ui/cross-crate-macro-backtrace/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,11 @@
// option. This file may not be copied, modified, or distributed
// except according to those terms.

// error-pattern: in format string

// aux-build:extern_macro_crate.rs
#[macro_use(myprintln, myprint)]
extern crate extern_macro_crate;

fn main() {
myprintln!("{}");
//~^ ERROR in format string
}
2 changes: 1 addition & 1 deletion src/test/ui/cross-crate-macro-backtrace/main.stderr
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
error: 1 positional argument in format string, but no arguments were given
--> $DIR/main.rs:18:5
--> $DIR/main.rs:16:5
|
LL | myprintln!("{}");
| ^^^^^^^^^^^^^^^^^
Expand Down
1 change: 1 addition & 0 deletions src/test/ui/cross-file-errors/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,4 +13,5 @@ mod underscore;

fn main() {
underscore!();
//~^ ERROR expected expression, found reserved identifier `_`
}
2 changes: 1 addition & 1 deletion src/test/ui/edition-keywords-2015-2018-expansion.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
extern crate edition_kw_macro_2018;

mod one_async {
produces_async! {} // ERROR expected identifier, found reserved keyword
produces_async! {} //~ ERROR expected identifier, found reserved keyword
}
mod two_async {
produces_async_raw! {} // OK
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/edition-keywords-2015-2018-expansion.stderr
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
error: expected identifier, found reserved keyword `async`
--> $DIR/edition-keywords-2015-2018-expansion.rs:20:5
|
LL | produces_async! {} // ERROR expected identifier, found reserved keyword
LL | produces_async! {} //~ ERROR expected identifier, found reserved keyword
| ^^^^^^^^^^^^^^^^^^ expected identifier, found reserved keyword
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/edition-keywords-2018-2018-expansion.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
extern crate edition_kw_macro_2018;

mod one_async {
produces_async! {} // ERROR expected identifier, found reserved keyword `async`
produces_async! {} //~ ERROR expected identifier, found reserved keyword `async`
}
mod two_async {
produces_async_raw! {} // OK
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/edition-keywords-2018-2018-expansion.stderr
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
error: expected identifier, found reserved keyword `async`
--> $DIR/edition-keywords-2018-2018-expansion.rs:20:5
|
LL | produces_async! {} // ERROR expected identifier, found reserved keyword `async`
LL | produces_async! {} //~ ERROR expected identifier, found reserved keyword `async`
| ^^^^^^^^^^^^^^^^^^ expected identifier, found reserved keyword
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)
Expand Down
3 changes: 1 addition & 2 deletions src/test/ui/hygiene/intercrate.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,11 @@

// aux-build:intercrate.rs

// error-pattern:type `fn() -> u32 {intercrate::foo::bar::f}` is private

#![feature(decl_macro)]

extern crate intercrate;

fn main() {
assert_eq!(intercrate::foo::m!(), 1);
//~^ ERROR type `fn() -> u32 {intercrate::foo::bar::f}` is private
}
2 changes: 1 addition & 1 deletion src/test/ui/hygiene/intercrate.stderr
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
error: type `fn() -> u32 {intercrate::foo::bar::f}` is private
--> $DIR/intercrate.rs:22:16
--> $DIR/intercrate.rs:20:16
|
LL | assert_eq!(intercrate::foo::m!(), 1);
| ^^^^^^^^^^^^^^^^^^^^^
Expand Down
3 changes: 1 addition & 2 deletions src/test/ui/hygiene/local_inner_macros_disabled.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,10 @@
// `local_inner_macros` has no effect if `feature(use_extern_macros)` is not enabled

// aux-build:local_inner_macros.rs
// error-pattern: cannot find macro `helper2!` in this scope

#[macro_use(public_macro)]
extern crate local_inner_macros;

public_macro!();
public_macro!(); //~ ERROR cannot find macro `helper2!` in this scope

fn main() {}
4 changes: 2 additions & 2 deletions src/test/ui/hygiene/local_inner_macros_disabled.stderr
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
error: cannot find macro `helper2!` in this scope
--> $DIR/local_inner_macros_disabled.rs:19:1
--> $DIR/local_inner_macros_disabled.rs:18:1
|
LL | public_macro!();
LL | public_macro!(); //~ ERROR cannot find macro `helper2!` in this scope
| ^^^^^^^^^^^^^^^^
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)
Expand Down
3 changes: 1 addition & 2 deletions src/test/ui/issue-13446.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,7 @@

// Used to cause ICE

// error-pattern: mismatched types

static VEC: [u32; 256] = vec![];
//~^ ERROR mismatched types

fn main() {}
2 changes: 1 addition & 1 deletion src/test/ui/issue-13446.stderr
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
error[E0308]: mismatched types
--> $DIR/issue-13446.rs:16:26
--> $DIR/issue-13446.rs:14:26
|
LL | static VEC: [u32; 256] = vec![];
| ^^^^^^ expected array of 256 elements, found struct `std::vec::Vec`
Expand Down
6 changes: 2 additions & 4 deletions src/test/ui/issue-16966.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,7 @@
// option. This file may not be copied, modified, or distributed
// except according to those terms.

// error-pattern:type annotations needed
fn main() {
panic!(
std::default::Default::default()
);
panic!(std::default::Default::default());
//~^ ERROR type annotations needed
}
8 changes: 3 additions & 5 deletions src/test/ui/issue-16966.stderr
Original file line number Diff line number Diff line change
@@ -1,10 +1,8 @@
error[E0282]: type annotations needed
--> $DIR/issue-16966.rs:13:5
--> $DIR/issue-16966.rs:12:5
|
LL | / panic!(
LL | | std::default::Default::default()
LL | | );
| |______^ cannot infer type for `M`
LL | panic!(std::default::Default::default());
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ cannot infer type for `M`
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)

Expand Down
3 changes: 1 addition & 2 deletions src/test/ui/issue-32829.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,8 @@
// option. This file may not be copied, modified, or distributed
// except according to those terms.

// error-pattern: calls in statics are limited

static S : u64 = { { panic!("foo"); 0 } };
//~^ ERROR calls in statics are limited

fn main() {
println!("{:?}", S);
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/issue-32829.stderr
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
error[E0015]: calls in statics are limited to constant functions, tuple structs and tuple variants
--> $DIR/issue-32829.rs:13:22
--> $DIR/issue-32829.rs:11:22
|
LL | static S : u64 = { { panic!("foo"); 0 } };
| ^^^^^^^^^^^^^^
Expand Down
1 change: 1 addition & 0 deletions src/test/ui/issue-50577.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,5 +11,6 @@
fn main() {
enum Foo {
Drop = assert_eq!(1, 1)
//~^ ERROR if may be missing an else clause
}
}
30 changes: 30 additions & 0 deletions src/test/ui/issue-51848.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
// Copyright 2014 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.

// In case of macro expansion, the errors should be matched using the deepest callsite in the
// macro call stack whose span is in the current file

macro_rules! macro_with_error {
( ) => {
println!("{"); //~ ERROR invalid
};
}

fn foo() {

}

fn main() {
macro_with_error!();
//^ In case of a local macro we want the error to be matched in the macro definition, not here

println!("}"); //~ ERROR invalid
//^ In case of an external macro we want the error to be matched here
}
21 changes: 21 additions & 0 deletions src/test/ui/issue-51848.stderr
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
error: invalid format string: expected `'}'` but string was terminated
--> $DIR/issue-51848.rs:16:20
|
LL | println!("{"); //~ ERROR invalid
| ^ expected `'}'` in format string
...
LL | macro_with_error!();
| -------------------- in this macro invocation
|
= note: if you intended to print `{`, you can escape it using `{{`

error: invalid format string: unmatched `}` found
--> $DIR/issue-51848.rs:28:15
|
LL | println!("}"); //~ ERROR invalid
| ^ unmatched `}` in format string
|
= note: if you intended to print `}`, you can escape it using `}}`

error: aborting due to 2 previous errors

1 change: 1 addition & 0 deletions src/test/ui/lifetimes/borrowck-let-suggestion.nll.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ LL | let mut x = vec![1].iter();
| ^^^^^^^ - temporary value only lives until here
| |
| temporary value does not live long enough
LL | //~^ ERROR borrowed value does not live long enough
LL | x.use_mut();
| - borrow later used here
|
Expand Down
1 change: 1 addition & 0 deletions src/test/ui/lifetimes/borrowck-let-suggestion.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@

fn f() {
let mut x = vec![1].iter();
//~^ ERROR borrowed value does not live long enough
x.use_mut();
}

Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/lifetimes/borrowck-let-suggestion.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ LL | let mut x = vec![1].iter();
| ^^^^^^^ - temporary value dropped here while still borrowed
| |
| temporary value does not live long enough
LL | x.use_mut();
...
LL | }
| - temporary value needs to live until here
|
Expand Down
1 change: 1 addition & 0 deletions src/test/ui/reachable/expr_again.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,5 +16,6 @@ fn main() {
let x = loop {
continue;
println!("hi");
//~^ ERROR unreachable statement
};
}
1 change: 1 addition & 0 deletions src/test/ui/reachable/expr_block.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ fn c() {
let x = {
return;
println!("foo");
//~^ ERROR unreachable statement
22
};
}
Expand Down
1 change: 1 addition & 0 deletions src/test/ui/reachable/expr_if.rs
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ fn baz() {
// As the next action to be taken after the if arms, we should
// report the `println!` as unreachable:
println!("But I am.");
//~^ ERROR unreachable statement
}

fn main() { }
3 changes: 3 additions & 0 deletions src/test/ui/reachable/expr_loop.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
fn a() {
loop { return; }
println!("I am dead.");
//~^ ERROR unreachable statement
}

fn b() {
Expand All @@ -28,6 +29,7 @@ fn b() {
fn c() {
loop { return; }
println!("I am dead.");
//~^ ERROR unreachable statement
}

fn d() {
Expand All @@ -38,6 +40,7 @@ fn d() {
fn e() {
loop { 'middle: loop { loop { break 'middle; } } }
println!("I am dead.");
//~^ ERROR unreachable statement
}

fn main() { }
4 changes: 2 additions & 2 deletions src/test/ui/reachable/expr_loop.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -12,15 +12,15 @@ LL | #![deny(unreachable_code)]
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)

error: unreachable statement
--> $DIR/expr_loop.rs:30:5
--> $DIR/expr_loop.rs:31:5
|
LL | println!("I am dead.");
| ^^^^^^^^^^^^^^^^^^^^^^^
|
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)

error: unreachable statement
--> $DIR/expr_loop.rs:40:5
--> $DIR/expr_loop.rs:42:5
|
LL | println!("I am dead.");
| ^^^^^^^^^^^^^^^^^^^^^^^
Expand Down
2 changes: 2 additions & 0 deletions src/test/ui/reachable/expr_match.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ fn a() {
fn b() {
match () { () => return }
println!("I am dead");
//~^ ERROR unreachable statement
}

fn c() {
Expand All @@ -32,6 +33,7 @@ fn c() {
fn d() {
match () { () if false => return, () => return }
println!("I am dead");
//~^ ERROR unreachable statement
}

fn e() {
Expand Down
2 changes: 1 addition & 1 deletion src/test/ui/reachable/expr_match.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ LL | println!("I am dead");
= note: this error originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info)

error: unreachable statement
--> $DIR/expr_match.rs:34:5
--> $DIR/expr_match.rs:35:5
|
LL | println!("I am dead");
| ^^^^^^^^^^^^^^^^^^^^^^
Expand Down
3 changes: 3 additions & 0 deletions src/test/ui/reachable/expr_while.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
fn foo() {
while {return} {
println!("Hello, world!");
//~^ ERROR unreachable
}
}

Expand All @@ -30,8 +31,10 @@ fn baz() {
// Here, we cite the `while` loop as dead.
while {return} {
println!("I am dead.");
//~^ ERROR unreachable
}
println!("I am, too.");
//~^ ERROR unreachable
}

fn main() { }
Loading

0 comments on commit 8ec9d72

Please sign in to comment.