
Namely, use a more sensical primary span. Don't pretty-print AST nodes for the diagnostic message. Why: * It's lossy (e.g., it doesn't replicate trailing `+`s in trait objects. * It's prone to leak error nodes (printed as `(/*ERROR*/)`) since the LHS can easily represent recovered code (e.g., `fn(i32?) + T`).
12 lines
477 B
Rust
12 lines
477 B
Rust
#![feature(auto_traits)]
|
|
#![feature(negative_impls)]
|
|
#![allow(bare_trait_objects)]
|
|
|
|
auto trait Auto {}
|
|
|
|
fn main() {
|
|
let _: Box<((Auto)) + Auto>; //~ ERROR expected a path on the left-hand side of `+`
|
|
let _: Box<(Auto + Auto) + Auto>; //~ ERROR expected a path on the left-hand side of `+`
|
|
let _: Box<(Auto +) + Auto>; //~ ERROR expected a path on the left-hand side of `+`
|
|
let _: Box<(dyn Auto) + Auto>; //~ ERROR expected a path on the left-hand side of `+`
|
|
}
|