diff options
| author | lcnr <rust@lcnr.de> | 2023-12-08 01:34:40 +0100 |
|---|---|---|
| committer | lcnr <rust@lcnr.de> | 2023-12-08 01:34:40 +0100 |
| commit | 1490c58076d019eacf1d0db3dbe93299ecc68a15 (patch) | |
| tree | 98dcfd42a10768360a9f8b2087a9eb5c311f0941 | |
| parent | ffb4c08a8117c8008ff696b6074cdf48889de211 (diff) | |
| download | rust-1490c58076d019eacf1d0db3dbe93299ecc68a15.tar.gz rust-1490c58076d019eacf1d0db3dbe93299ecc68a15.zip | |
add regression tests
| -rw-r--r-- | tests/ui/traits/new-solver/projection/param-env-trait-candidate-1.rs | 14 | ||||
| -rw-r--r-- | tests/ui/traits/new-solver/projection/param-env-trait-candidate-2.rs | 29 |
2 files changed, 43 insertions, 0 deletions
diff --git a/tests/ui/traits/new-solver/projection/param-env-trait-candidate-1.rs b/tests/ui/traits/new-solver/projection/param-env-trait-candidate-1.rs new file mode 100644 index 00000000000..e36d574efe2 --- /dev/null +++ b/tests/ui/traits/new-solver/projection/param-env-trait-candidate-1.rs @@ -0,0 +1,14 @@ +// check-pass +// compile-flags: -Ztrait-solver=next + +// See https://github.com/rust-lang/trait-system-refactor-initiative/issues/1 +// a minimization of a pattern in core. +fn next<T: Iterator<Item = U>, U>(t: &mut T) -> Option<U> { + t.next() +} + +fn foo<T: Iterator>(t: &mut T) { + let _: Option<T::Item> = next(t); +} + +fn main() {} diff --git a/tests/ui/traits/new-solver/projection/param-env-trait-candidate-2.rs b/tests/ui/traits/new-solver/projection/param-env-trait-candidate-2.rs new file mode 100644 index 00000000000..c8050997a1d --- /dev/null +++ b/tests/ui/traits/new-solver/projection/param-env-trait-candidate-2.rs @@ -0,0 +1,29 @@ +// check-pass +// compile-flags: -Ztrait-solver=next + +// See https://github.com/rust-lang/trait-system-refactor-initiative/issues/1, +// a minimization of a pattern in core. + +trait Iterator { + type Item; +} + +struct Flatten<I>(I); + +impl<I, U> Iterator for Flatten<I> +where + I: Iterator<Item = U>, +{ + type Item = U; +} + +fn needs_iterator<I: Iterator>() {} + +fn environment<J>() +where + J: Iterator, +{ + needs_iterator::<Flatten<J>>(); +} + +fn main() {} |
