diff options
| author | Aaron Hill <aa1ronham@gmail.com> | 2020-12-04 18:37:21 -0500 |
|---|---|---|
| committer | Aaron Hill <aa1ronham@gmail.com> | 2020-12-04 22:16:40 -0500 |
| commit | c2946402ffb5edde461b5047213e56b4e1500ec8 (patch) | |
| tree | 6934b4679aa914e0633f30142979289e82f51032 /compiler/rustc_llvm/llvm-wrapper/PassWrapper.cpp | |
| parent | 3ff10e74a74ed093fcabac1de27fe1cd65bbbb4a (diff) | |
| download | rust-c2946402ffb5edde461b5047213e56b4e1500ec8.tar.gz rust-c2946402ffb5edde461b5047213e56b4e1500ec8.zip | |
Properly re-use def path hash in incremental mode
Fixes #79661 In incremental compilation mode, we update a `DefPathHash -> DefId` mapping every time we create a `DepNode` for a foreign `DefId`. This mapping is written out to the on-disk incremental cache, and is read by the next compilation session to allow us to lazily decode `DefId`s. When we decode a `DepNode` from the current incremental cache, we need to ensure that any previously-recorded `DefPathHash -> DefId` mapping gets recorded in the new mapping that we write out. However, PR #74967 didn't do this in all cases, leading to us being unable to decode a `DefPathHash` in certain circumstances. This PR refactors some of the code around `DepNode` deserialization to prevent this kind of mistake from happening again.
Diffstat (limited to 'compiler/rustc_llvm/llvm-wrapper/PassWrapper.cpp')
0 files changed, 0 insertions, 0 deletions
