diff options
author | Adrian Prantl <aprantl@apple.com> | 2017-09-14 17:01:53 +0000 |
---|---|---|
committer | Adrian Prantl <aprantl@apple.com> | 2017-09-14 17:01:53 +0000 |
commit | 5fd3d49bc4c07e549573924afc00e50d0ed62d44 (patch) | |
tree | 2809a2fba28c39e7f5f5484a91e0a5f2a40dab36 /llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp | |
parent | 779d98e1c008b30a211375a76f3f2c97502a02b5 (diff) | |
download | bcm5719-llvm-5fd3d49bc4c07e549573924afc00e50d0ed62d44.tar.gz bcm5719-llvm-5fd3d49bc4c07e549573924afc00e50d0ed62d44.zip |
llvm-dwarfdump: support dumping static archives.
llvm-svn: 313272
Diffstat (limited to 'llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp')
-rw-r--r-- | llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp | 44 |
1 files changed, 37 insertions, 7 deletions
diff --git a/llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp b/llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp index 9bf8d0147a0..823eb8e8133 100644 --- a/llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp +++ b/llvm/tools/llvm-dwarfdump/llvm-dwarfdump.cpp @@ -15,6 +15,7 @@ #include "llvm/ADT/Triple.h" #include "llvm/DebugInfo/DIContext.h" #include "llvm/DebugInfo/DWARF/DWARFContext.h" +#include "llvm/Object/Archive.h" #include "llvm/Object/MachOUniversal.h" #include "llvm/Object/ObjectFile.h" #include "llvm/Object/RelocVisitor.h" @@ -123,22 +124,51 @@ static bool verifyObjectFile(ObjectFile &Obj, Twine Filename) { } static bool handleBuffer(StringRef Filename, MemoryBufferRef Buffer, + std::function<bool(ObjectFile &, Twine)> HandleObj); + +static bool handleArchive(StringRef Filename, Archive &Arch, + std::function<bool(ObjectFile &, Twine)> HandleObj) { + bool Result = true; + Error Err = Error::success(); + for (auto Child : Arch.children(Err)) { + auto BuffOrErr = Child.getMemoryBufferRef(); + error(Filename, errorToErrorCode(BuffOrErr.takeError())); + auto NameOrErr = Child.getName(); + error(Filename, errorToErrorCode(NameOrErr.takeError())); + std::string Name = (Filename + "(" + NameOrErr.get() + ")").str(); + Result &= handleBuffer(Name, BuffOrErr.get(), HandleObj); + } + error(Filename, errorToErrorCode(std::move(Err))); + + return Result; +} + +static bool handleBuffer(StringRef Filename, MemoryBufferRef Buffer, std::function<bool(ObjectFile &, Twine)> HandleObj) { Expected<std::unique_ptr<Binary>> BinOrErr = object::createBinary(Buffer); - if (!BinOrErr) - error(Filename, errorToErrorCode(BinOrErr.takeError())); + error(Filename, errorToErrorCode(BinOrErr.takeError())); bool Result = true; if (auto *Obj = dyn_cast<ObjectFile>(BinOrErr->get())) Result = HandleObj(*Obj, Filename); else if (auto *Fat = dyn_cast<MachOUniversalBinary>(BinOrErr->get())) for (auto &ObjForArch : Fat->objects()) { - auto MachOOrErr = ObjForArch.getAsObjectFile(); - error(Filename, errorToErrorCode(MachOOrErr.takeError())); - if (!HandleObj(**MachOOrErr, - Filename + " (" + ObjForArch.getArchFlagName() + ")")) - Result = false; + std::string ObjName = + (Filename + "(" + ObjForArch.getArchFlagName() + ")").str(); + if (auto MachOOrErr = ObjForArch.getAsObjectFile()) { + Result &= HandleObj(**MachOOrErr, ObjName); + continue; + } else + consumeError(MachOOrErr.takeError()); + if (auto ArchiveOrErr = ObjForArch.getAsArchive()) { + error(ObjName, errorToErrorCode(ArchiveOrErr.takeError())); + Result &= handleArchive(ObjName, *ArchiveOrErr.get(), HandleObj); + continue; + } else + consumeError(ArchiveOrErr.takeError()); } + else if (auto *Arch = dyn_cast<Archive>(BinOrErr->get())) + Result = handleArchive(Filename, *Arch, HandleObj); return Result; } |