diff --git a/compiler/rustc_typeck/src/check/upvar.rs b/compiler/rustc_typeck/src/check/upvar.rs index ae6bebcf727d1..bb8d2ecdcf054 100644 --- a/compiler/rustc_typeck/src/check/upvar.rs +++ b/compiler/rustc_typeck/src/check/upvar.rs @@ -400,6 +400,11 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> { }; capture_info.capture_kind = capture_kind; + let capture_info = if let Some(existing) = processed.get(&place) { + determine_capture_info(*existing, capture_info) + } else { + capture_info + }; processed.insert(place, capture_info); } diff --git a/src/test/ui/closures/2229_closure_analysis/run_pass/issue-88372.rs b/src/test/ui/closures/2229_closure_analysis/run_pass/issue-88372.rs new file mode 100644 index 0000000000000..25fbb6cb90696 --- /dev/null +++ b/src/test/ui/closures/2229_closure_analysis/run_pass/issue-88372.rs @@ -0,0 +1,19 @@ +// edition:2021 +// run-pass + + +fn solve(validate: F) -> Option +where + F: Fn(&mut [i8; 1]), +{ + let mut position: [i8; 1] = [1]; + Some(0).map(|_| { + validate(&mut position); + let [_x] = position; + 0 + }) +} + +fn main() { + solve(|_| ()); +}