diff options
| author | Michael Goulet <michael@errs.io> | 2022-01-06 19:08:04 -0800 |
|---|---|---|
| committer | Michael Goulet <michael@errs.io> | 2022-01-06 19:08:04 -0800 |
| commit | d35b23ecd8f8fd1aa33ebd106bb5f13414a66cf4 (patch) | |
| tree | 484ea6877dae0bcf06fbba5e7b8dcdbd2575df17 /compiler/rustc_mir_transform/src | |
| parent | cfa4ac66c194046f631ce076c75516ecfdeb77ee (diff) | |
| download | rust-d35b23ecd8f8fd1aa33ebd106bb5f13414a66cf4.tar.gz rust-d35b23ecd8f8fd1aa33ebd106bb5f13414a66cf4.zip | |
Normalize generator-local types with unevaluated constants
Diffstat (limited to 'compiler/rustc_mir_transform/src')
| -rw-r--r-- | compiler/rustc_mir_transform/src/generator.rs | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/compiler/rustc_mir_transform/src/generator.rs b/compiler/rustc_mir_transform/src/generator.rs index bc9a104e849..08247e6f22a 100644 --- a/compiler/rustc_mir_transform/src/generator.rs +++ b/compiler/rustc_mir_transform/src/generator.rs @@ -726,9 +726,13 @@ fn sanitize_witness<'tcx>( saved_locals: &GeneratorSavedLocals, ) { let did = body.source.def_id(); - let allowed_upvars = tcx.erase_regions(upvars); + let param_env = tcx.param_env(did); + + let allowed_upvars = tcx.normalize_erasing_regions(param_env, upvars); let allowed = match witness.kind() { - &ty::GeneratorWitness(s) => tcx.erase_late_bound_regions(s), + &ty::GeneratorWitness(interior_tys) => { + tcx.normalize_erasing_late_bound_regions(param_env, interior_tys) + } _ => { tcx.sess.delay_span_bug( body.span, @@ -738,8 +742,6 @@ fn sanitize_witness<'tcx>( } }; - let param_env = tcx.param_env(did); - for (local, decl) in body.local_decls.iter_enumerated() { // Ignore locals which are internal or not saved between yields. if !saved_locals.contains(local) || decl.internal { |
