diff options
| author | Michael J. Spencer <bigcheesegs@gmail.com> | 2011-06-25 17:55:23 +0000 | 
|---|---|---|
| committer | Michael J. Spencer <bigcheesegs@gmail.com> | 2011-06-25 17:55:23 +0000 | 
| commit | 1d6167fd30d3adde4b34d349ce95c557fedc0874 (patch) | |
| tree | 9db8a1dffd095b08ded38f71f5e0434877087d93 /llvm/tools/llvm-objdump/llvm-objdump.cpp | |
| parent | 6d7138a16862495165ef6c362ed6d1ff005a69a3 (diff) | |
| download | llvm-1d6167fd30d3adde4b34d349ce95c557fedc0874.zip llvm-1d6167fd30d3adde4b34d349ce95c557fedc0874.tar.gz llvm-1d6167fd30d3adde4b34d349ce95c557fedc0874.tar.bz2 | |
Object: Add proper error handling.
llvm-svn: 133872
Diffstat (limited to 'llvm/tools/llvm-objdump/llvm-objdump.cpp')
| -rw-r--r-- | llvm/tools/llvm-objdump/llvm-objdump.cpp | 29 | 
1 files changed, 23 insertions, 6 deletions
| diff --git a/llvm/tools/llvm-objdump/llvm-objdump.cpp b/llvm/tools/llvm-objdump/llvm-objdump.cpp index a17624a..c971e49 100644 --- a/llvm/tools/llvm-objdump/llvm-objdump.cpp +++ b/llvm/tools/llvm-objdump/llvm-objdump.cpp @@ -69,6 +69,14 @@ namespace {                              "see -version for available targets"));    StringRef ToolName; + +  bool error(error_code ec) { +    if (!ec) return false; + +    outs() << ToolName << ": error reading file: " << ec.message() << ".\n"; +    outs().flush(); +    return true; +  }  }  static const Target *GetTarget(const ObjectFile *Obj = NULL) { @@ -161,12 +169,18 @@ static void DisassembleInput(const StringRef &Filename) {    outs() << Filename           << ":\tfile format " << Obj->getFileFormatName() << "\n\n\n"; +  error_code ec;    for (ObjectFile::section_iterator i = Obj->begin_sections(),                                      e = Obj->end_sections(); -                                    i != e; ++i) { -    if (!i->isText()) -      continue; -    outs() << "Disassembly of section " << i->getName() << ":\n\n"; +                                    i != e; i.increment(ec)) { +    if (error(ec)) break; +    bool text; +    if (error(i->isText(text))) break; +    if (!text) continue; + +    StringRef name; +    if (error(i->getName(name))) break; +    outs() << "Disassembly of section " << name << ":\n\n";      // Set up disassembler.      OwningPtr<const MCAsmInfo> AsmInfo(TheTarget->createAsmInfo(TripleName)); @@ -202,7 +216,8 @@ static void DisassembleInput(const StringRef &Filename) {        return;      } -    StringRef Bytes = i->getContents(); +    StringRef Bytes; +    if (error(i->getContents(Bytes))) break;      StringRefMemoryObject memoryObject(Bytes);      uint64_t Size;      uint64_t Index; @@ -217,7 +232,9 @@ static void DisassembleInput(const StringRef &Filename) {  #     endif        if (DisAsm->getInstruction(Inst, Size, memoryObject, Index, DebugOut)) { -        outs() << format("%8x:\t", i->getAddress() + Index); +        uint64_t addr; +        if (error(i->getAddress(addr))) break; +        outs() << format("%8x:\t", addr + Index);          DumpBytes(StringRef(Bytes.data() + Index, Size));          IP->printInst(&Inst, outs());          outs() << "\n"; | 
