diff options
| author | Oli Scherer <git-spam-no-reply9815368754983@oli-obk.de> | 2024-04-15 11:20:33 +0000 |
|---|---|---|
| committer | Oli Scherer <git-spam-no-reply9815368754983@oli-obk.de> | 2024-06-13 10:41:52 +0000 |
| commit | c75f7283bf52c6e2ec6a178f2b7717a4daddacf4 (patch) | |
| tree | 05d2c77ddb1ba67d34880c15d0a271b7af1cb9dc /tests/ui/impl-trait/method-resolution3.rs | |
| parent | b28221e74f5f05d0f7a6212f99c9d5af868c0ed3 (diff) | |
| download | rust-c75f7283bf52c6e2ec6a178f2b7717a4daddacf4.tar.gz rust-c75f7283bf52c6e2ec6a178f2b7717a4daddacf4.zip | |
Add some tests
Diffstat (limited to 'tests/ui/impl-trait/method-resolution3.rs')
| -rw-r--r-- | tests/ui/impl-trait/method-resolution3.rs | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/tests/ui/impl-trait/method-resolution3.rs b/tests/ui/impl-trait/method-resolution3.rs new file mode 100644 index 00000000000..8474e2da7db --- /dev/null +++ b/tests/ui/impl-trait/method-resolution3.rs @@ -0,0 +1,29 @@ +//! Check that we consider `Bar<impl Sized>` to successfully unify +//! with both `Bar<u32>` and `Bar<i32>` (in isolation), so we bail +//! out with ambiguity. + +//@ revisions: current next +//@[next] compile-flags: -Znext-solver + +struct Bar<T>(T); + +impl Bar<u32> { + fn bar(self) {} +} + +impl Bar<i32> { + fn bar(self) {} +} + +fn foo(x: bool) -> Bar<impl Sized> { + //[current]~^ ERROR: cycle + if x { + let x = foo(false); + x.bar(); + //[current]~^ ERROR: no method named `bar` + //[next]~^^ ERROR: multiple applicable items in scope + } + todo!() +} + +fn main() {} |
