diff options
| author | Ralf Jung <post@ralfj.de> | 2022-03-22 18:58:23 -0400 |
|---|---|---|
| committer | Ralf Jung <post@ralfj.de> | 2022-03-22 19:03:12 -0400 |
| commit | 8a1f928b8e1969b88de614602bd5d73f6a2b358e (patch) | |
| tree | 94cf8462cdfddb64f733b2b1cf758ea7703d402a | |
| parent | 5f37001055c29982f4c27ee9edd90449c8e07774 (diff) | |
| download | rust-8a1f928b8e1969b88de614602bd5d73f6a2b358e.tar.gz rust-8a1f928b8e1969b88de614602bd5d73f6a2b358e.zip | |
interpret/validity: improve clarity
| -rw-r--r-- | compiler/rustc_const_eval/src/interpret/validity.rs | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/compiler/rustc_const_eval/src/interpret/validity.rs b/compiler/rustc_const_eval/src/interpret/validity.rs index 8fad5e63baf..8bdafa87623 100644 --- a/compiler/rustc_const_eval/src/interpret/validity.rs +++ b/compiler/rustc_const_eval/src/interpret/validity.rs @@ -432,9 +432,8 @@ impl<'rt, 'mir, 'tcx: 'mir, M: Machine<'mir, 'tcx>> ValidityVisitor<'rt, 'mir, ' if let Some(ref mut ref_tracking) = self.ref_tracking { // Proceed recursively even for ZST, no reason to skip them! // `!` is a ZST and we want to validate it. - // Skip validation entirely for some external statics if let Ok((alloc_id, _offset, _ptr)) = self.ecx.memory.ptr_try_get_alloc(place.ptr) { - // not a ZST + // Special handling for pointers to statics (irrespective of their type). let alloc_kind = self.ecx.tcx.get_global_alloc(alloc_id); if let Some(GlobalAlloc::Static(did)) = alloc_kind { assert!(!self.ecx.tcx.is_thread_local_static(did)); @@ -469,7 +468,7 @@ impl<'rt, 'mir, 'tcx: 'mir, M: Machine<'mir, 'tcx>> ValidityVisitor<'rt, 'mir, ' // We need to clone the path anyway, make sure it gets created // with enough space for the additional `Deref`. let mut new_path = Vec::with_capacity(path.len() + 1); - new_path.clone_from(path); + new_path.extend(path); new_path.push(PathElem::Deref); new_path }); |
