about summary refs log tree commit diff
path: root/compiler/rustc_llvm/llvm-wrapper/PassWrapper.cpp
diff options
context:
space:
mode:
authorAaron Hill <aa1ronham@gmail.com>2020-12-04 18:37:21 -0500
committerAaron Hill <aa1ronham@gmail.com>2020-12-04 22:16:40 -0500
commitc2946402ffb5edde461b5047213e56b4e1500ec8 (patch)
tree6934b4679aa914e0633f30142979289e82f51032 /compiler/rustc_llvm/llvm-wrapper/PassWrapper.cpp
parent3ff10e74a74ed093fcabac1de27fe1cd65bbbb4a (diff)
downloadrust-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