[PATCH] D64428: Teach `llvm-pdbutil pretty -native` about `-injected-sources`
Nico Weber via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Jul 16 09:31:46 PDT 2019
thakis marked an inline comment as done.
thakis added inline comments.
================
Comment at: llvm/lib/DebugInfo/PDB/Native/NativeEnumInjectedSources.cpp:50
+ if (!Name) {
+ consumeError(Name.takeError());
+ return "(invalid file name ref)";
----------------
zturner wrote:
> rnk wrote:
> > Hm. I guess perhaps we should've allowed error propagation out of these APIs. I guess that's not fixable without an interface change.
> The thinking at the time was that anything that might generate an error should happen during load, not on lazy evaluation of the properties. That's why most of the classes have a `initialize` or `reload()` static method which returns an `Expected<T>`, so that all validation can be done up front. I'm open to the possibility that that wasn't the best decision though, but it kept the code simple and handled most of the cases we would expect to see in practice.
Thanks for chiming in! That makes sense to me.
I changed the code to verify that all referenced strings exist in `reload()` and removed the error handling here. I didn't (yet) do this for getCode() since that'd duplicate quite a bit of code. From your comment, it kind of sounds like the intended design is that InjectedSourceStream should grab _all_ data from disk and store it in memory, and the NativeEnumInjectedSources should refer to that. Is that accurate? If so, InjectedSourceStream should probably have a
```
struct InjectedSource {
uint32_t CRC32;
StringRef Name;
StringRef ObjName;
StringRef VName;
PDB_SourceCompression Compression;
llvm::MemoryBuffer Contents;
};
```
and store a name->InjectedSource map, and check that the CRC32 matches the CRC32 of Contents at load time too. Does that sound right?
If so, is there an existing method to load the contents of a stream into a MemoryBuffer somewhere?
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D64428/new/
https://reviews.llvm.org/D64428
More information about the llvm-commits
mailing list