diff options
author | Lang Hames <lhames@gmail.com> | 2016-07-14 02:24:01 +0000 |
---|---|---|
committer | Lang Hames <lhames@gmail.com> | 2016-07-14 02:24:01 +0000 |
commit | fc209623e976118cf016c0d3c1dccacb6bfa27c1 (patch) | |
tree | 407a60990972f87acb6c6aed9c218ac6ab4b203a /llvm/tools/llvm-readobj/llvm-readobj.cpp | |
parent | af7e8465e1fabdfff6c3a08a14cdb83ed79a10dc (diff) | |
download | bcm5719-llvm-fc209623e976118cf016c0d3c1dccacb6bfa27c1.tar.gz bcm5719-llvm-fc209623e976118cf016c0d3c1dccacb6bfa27c1.zip |
[Object] Re-apply r275316 now that I have the corresponding LLD patch ready.
llvm-svn: 275361
Diffstat (limited to 'llvm/tools/llvm-readobj/llvm-readobj.cpp')
-rw-r--r-- | llvm/tools/llvm-readobj/llvm-readobj.cpp | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/llvm/tools/llvm-readobj/llvm-readobj.cpp b/llvm/tools/llvm-readobj/llvm-readobj.cpp index ad97dea2d02..c293919fd95 100644 --- a/llvm/tools/llvm-readobj/llvm-readobj.cpp +++ b/llvm/tools/llvm-readobj/llvm-readobj.cpp @@ -295,6 +295,17 @@ static void reportError(StringRef Input, StringRef Message) { reportError(Twine(Input) + ": " + Message); } +static void reportError(StringRef Input, Error Err) { + if (Input == "-") + Input = "<stdin>"; + std::string ErrMsg; + { + raw_string_ostream ErrStream(ErrMsg); + logAllUnhandledErrors(std::move(Err), ErrStream, Input + ": "); + } + reportError(ErrMsg); +} + static bool isMipsArch(unsigned Arch) { switch (Arch) { case llvm::Triple::mips: @@ -424,10 +435,8 @@ static void dumpObject(const ObjectFile *Obj) { /// @brief Dumps each object file in \a Arc; static void dumpArchive(const Archive *Arc) { - for (auto &ErrorOrChild : Arc->children()) { - if (std::error_code EC = ErrorOrChild.getError()) - reportError(Arc->getFileName(), EC.message()); - const auto &Child = *ErrorOrChild; + Error Err; + for (auto &Child : Arc->children(Err)) { Expected<std::unique_ptr<Binary>> ChildOrErr = Child.getAsBinary(); if (!ChildOrErr) { if (auto E = isNotObjectErrorInvalidFileType(ChildOrErr.takeError())) { @@ -444,6 +453,8 @@ static void dumpArchive(const Archive *Arc) { else reportError(Arc->getFileName(), readobj_error::unrecognized_file_format); } + if (Err) + reportError(Arc->getFileName(), std::move(Err)); } /// @brief Dumps each object file in \a MachO Universal Binary; |