-
Notifications
You must be signed in to change notification settings - Fork 13.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of #68546 - JohnTitor:rollup-znuot4b, r=JohnTitor
Rollup of 5 pull requests Successful merges: - #68485 (add a test for #60976) - #68498 (Add some type-alias-impl-trait regression tests) - #68514 (Use Self instead of self return type) - #68534 (Update submodules to rust-lang) - #68540 (clean up error codes E0229 and E0261) Failed merges: r? @ghost
- Loading branch information
Showing
9 changed files
with
109 additions
and
17 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
27 changes: 27 additions & 0 deletions
27
src/test/ui/type-alias-impl-trait/issue-57611-trait-alias.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
// Regression test for issue #57611 | ||
// Ensures that we don't ICE | ||
// FIXME: This should compile, but it currently doesn't | ||
|
||
#![feature(trait_alias)] | ||
#![feature(type_alias_impl_trait)] | ||
|
||
trait Foo { | ||
type Bar: Baz<Self, Self>; | ||
|
||
fn bar(&self) -> Self::Bar; | ||
} | ||
|
||
struct X; | ||
|
||
impl Foo for X { | ||
type Bar = impl Baz<Self, Self>; //~ ERROR type mismatch in closure arguments | ||
//~^ ERROR type mismatch resolving | ||
|
||
fn bar(&self) -> Self::Bar { | ||
|x| x | ||
} | ||
} | ||
|
||
trait Baz<A, B> = Fn(&A) -> &B; | ||
|
||
fn main() {} |
23 changes: 23 additions & 0 deletions
23
src/test/ui/type-alias-impl-trait/issue-57611-trait-alias.stderr
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
error[E0631]: type mismatch in closure arguments | ||
--> $DIR/issue-57611-trait-alias.rs:17:5 | ||
| | ||
LL | type Bar = impl Baz<Self, Self>; | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected signature of `for<'r> fn(&'r X) -> _` | ||
... | ||
LL | |x| x | ||
| ----- found signature of `fn(_) -> _` | ||
| | ||
= note: the return type of a function must have a statically known size | ||
|
||
error[E0271]: type mismatch resolving `for<'r> <[closure@$DIR/issue-57611-trait-alias.rs:21:9: 21:14] as std::ops::FnOnce<(&'r X,)>>::Output == &'r X` | ||
--> $DIR/issue-57611-trait-alias.rs:17:5 | ||
| | ||
LL | type Bar = impl Baz<Self, Self>; | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected bound lifetime parameter, found concrete lifetime | ||
| | ||
= note: the return type of a function must have a statically known size | ||
|
||
error: aborting due to 2 previous errors | ||
|
||
Some errors have detailed explanations: E0271, E0631. | ||
For more information about an error, try `rustc --explain E0271`. |
31 changes: 31 additions & 0 deletions
31
src/test/ui/type-alias-impl-trait/issue-57807-associated-type.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
// Regression test for issue #57807 - ensure | ||
// that we properly unify associated types within | ||
// a type alias impl trait | ||
// check-pass | ||
#![feature(type_alias_impl_trait)] | ||
|
||
trait Bar { | ||
type A; | ||
} | ||
|
||
impl Bar for () { | ||
type A = (); | ||
} | ||
|
||
trait Foo { | ||
type A; | ||
type B: Bar<A = Self::A>; | ||
|
||
fn foo() -> Self::B; | ||
} | ||
|
||
impl Foo for () { | ||
type A = (); | ||
type B = impl Bar<A = Self::A>; | ||
|
||
fn foo() -> Self::B { | ||
() | ||
} | ||
} | ||
|
||
fn main() {} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
// compile-flags: --edition=2018 | ||
|
||
pub use u32; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
// Regression test for #60976: ICE (with <=1.36.0) when another file had `use <primitive_type>;`. | ||
// check-pass | ||
// aux-build:extern-use-primitive-type-lib.rs | ||
|
||
extern crate extern_use_primitive_type_lib; | ||
|
||
fn main() {} |