Make + in impl/dyn Trait non-associative

This commit is contained in:
Vadim Petrochenkov 2018-01-27 22:37:17 +03:00
parent d79f7cde06
commit f57ea7cb3d
3 changed files with 106 additions and 10 deletions

View file

@ -0,0 +1,59 @@
// Copyright 2017 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.
// compile-flags: -Z parse-only -Z continue-parse-after-error
fn f() -> impl A + {} // OK
fn f() -> impl A + B {} // OK
fn f() -> dyn A + B {} // OK
fn f() -> A + B {} // OK
impl S {
fn f(self) -> impl A + { // OK
let _ = |a, b| -> impl A + {}; // OK
}
fn f(self) -> impl A + B { // OK
let _ = |a, b| -> impl A + B {}; // OK
}
fn f(self) -> dyn A + B { // OK
let _ = |a, b| -> dyn A + B {}; // OK
}
fn f(self) -> A + B { // OK
let _ = |a, b| -> A + B {}; // OK
}
}
type A = fn() -> impl A +;
//~^ ERROR ambiguous `+` in a type
type A = fn() -> impl A + B;
//~^ ERROR ambiguous `+` in a type
type A = fn() -> dyn A + B;
//~^ ERROR ambiguous `+` in a type
type A = fn() -> A + B;
//~^ ERROR expected a path on the left-hand side of `+`, not `fn() -> A`
type A = Fn() -> impl A +;
//~^ ERROR ambiguous `+` in a type
type A = Fn() -> impl A + B;
//~^ ERROR ambiguous `+` in a type
type A = Fn() -> dyn A + B;
//~^ ERROR ambiguous `+` in a type
type A = Fn() -> A + B; // OK, interpreted as `(Fn() -> A) + B` for compatibility
type A = &impl A +;
//~^ ERROR ambiguous `+` in a type
type A = &impl A + B;
//~^ ERROR ambiguous `+` in a type
type A = &dyn A + B;
//~^ ERROR ambiguous `+` in a type
type A = &A + B;
//~^ ERROR expected a path on the left-hand side of `+`, not `&A`
fn main() {}

View file

@ -0,0 +1,68 @@
error: ambiguous `+` in a type
--> $DIR/impl-trait-plus-priority.rs:33:18
|
33 | type A = fn() -> impl A +;
| ^^^^^^^^ help: use parentheses to disambiguate: `(impl A)`
error: ambiguous `+` in a type
--> $DIR/impl-trait-plus-priority.rs:35:18
|
35 | type A = fn() -> impl A + B;
| ^^^^^^^^^^ help: use parentheses to disambiguate: `(impl A + B)`
error: ambiguous `+` in a type
--> $DIR/impl-trait-plus-priority.rs:37:18
|
37 | type A = fn() -> dyn A + B;
| ^^^^^^^^^ help: use parentheses to disambiguate: `(dyn A + B)`
error[E0178]: expected a path on the left-hand side of `+`, not `fn() -> A`
--> $DIR/impl-trait-plus-priority.rs:39:10
|
39 | type A = fn() -> A + B;
| ^^^^^^^^^^^^^ perhaps you forgot parentheses?
error: ambiguous `+` in a type
--> $DIR/impl-trait-plus-priority.rs:42:18
|
42 | type A = Fn() -> impl A +;
| ^^^^^^^^ help: use parentheses to disambiguate: `(impl A)`
error: ambiguous `+` in a type
--> $DIR/impl-trait-plus-priority.rs:44:18
|
44 | type A = Fn() -> impl A + B;
| ^^^^^^^^^^ help: use parentheses to disambiguate: `(impl A + B)`
error: ambiguous `+` in a type
--> $DIR/impl-trait-plus-priority.rs:46:18
|
46 | type A = Fn() -> dyn A + B;
| ^^^^^^^^^ help: use parentheses to disambiguate: `(dyn A + B)`
error: ambiguous `+` in a type
--> $DIR/impl-trait-plus-priority.rs:50:11
|
50 | type A = &impl A +;
| ^^^^^^^^ help: use parentheses to disambiguate: `(impl A)`
error: ambiguous `+` in a type
--> $DIR/impl-trait-plus-priority.rs:52:11
|
52 | type A = &impl A + B;
| ^^^^^^^^^^ help: use parentheses to disambiguate: `(impl A + B)`
error: ambiguous `+` in a type
--> $DIR/impl-trait-plus-priority.rs:54:11
|
54 | type A = &dyn A + B;
| ^^^^^^^^^ help: use parentheses to disambiguate: `(dyn A + B)`
error[E0178]: expected a path on the left-hand side of `+`, not `&A`
--> $DIR/impl-trait-plus-priority.rs:56:10
|
56 | type A = &A + B;
| ^^^^^^ help: try adding parentheses: `&(A + B)`
error: aborting due to 11 previous errors