diff options
| author | liudingming <liudingming@bytedance.com> | 2021-08-09 20:25:57 +0800 |
|---|---|---|
| committer | Niko Matsakis <niko@alum.mit.edu> | 2021-08-23 19:16:16 +0000 |
| commit | e8910440a24ecb2ddb08b4dbe170488ddf61fc87 (patch) | |
| tree | 7b574ec36f695dd6346584fcb7850cafbbc98794 /src | |
| parent | b6e334d87349502766be70d649e6fe4a73573482 (diff) | |
| download | rust-e8910440a24ecb2ddb08b4dbe170488ddf61fc87.tar.gz rust-e8910440a24ecb2ddb08b4dbe170488ddf61fc87.zip | |
select obligations after `check_casts`
Otherwise, we can get into a situation where you have a subtype obligation `#1 <: #2` pending, #1 is constrained by `check_casts`, but #2` is unaffected. Co-authored-by: Niko Matsakis <niko@alum.mit.edu>
Diffstat (limited to 'src')
| -rw-r--r-- | src/test/ui/closures/2229_closure_analysis/issue_88118.rs | 14 | ||||
| -rw-r--r-- | src/test/ui/closures/issue-87814-1.rs | 8 | ||||
| -rw-r--r-- | src/test/ui/closures/issue-87814-2.rs | 11 |
3 files changed, 33 insertions, 0 deletions
diff --git a/src/test/ui/closures/2229_closure_analysis/issue_88118.rs b/src/test/ui/closures/2229_closure_analysis/issue_88118.rs new file mode 100644 index 00000000000..15c6ae4906c --- /dev/null +++ b/src/test/ui/closures/2229_closure_analysis/issue_88118.rs @@ -0,0 +1,14 @@ +// Regression test for #88118. Used to ICE. +// +// check-pass + +#![feature(capture_disjoint_fields)] + +fn foo<MsU>(handler: impl FnOnce() -> MsU + Clone + 'static) { + Box::new(move |value| { + (|_| handler.clone()())(value); + None + }) as Box<dyn Fn(i32) -> Option<i32>>; +} + +fn main() {} \ No newline at end of file diff --git a/src/test/ui/closures/issue-87814-1.rs b/src/test/ui/closures/issue-87814-1.rs new file mode 100644 index 00000000000..5cf01ddf5d7 --- /dev/null +++ b/src/test/ui/closures/issue-87814-1.rs @@ -0,0 +1,8 @@ +// check-pass +fn main() { + let mut schema_all = vec![]; + (0..42).for_each(|_x| match Err(()) as Result<(), _> { + Ok(()) => schema_all.push(()), + Err(_) => (), + }); +} diff --git a/src/test/ui/closures/issue-87814-2.rs b/src/test/ui/closures/issue-87814-2.rs new file mode 100644 index 00000000000..7a5facdac58 --- /dev/null +++ b/src/test/ui/closures/issue-87814-2.rs @@ -0,0 +1,11 @@ +// check-pass +#![feature(try_reserve)] + +fn main() { + let mut schema_all: (Vec<String>, Vec<String>) = (vec![], vec![]); + + let _c = || match schema_all.0.try_reserve(1) as Result<(), _> { + Ok(()) => (), + Err(_) => (), + }; +} |
