std::map<std::string, SectionRef> readSections(const ObjectFile& o) {
error_code ec;
std::map<std::string, SectionRef> result;
- section_iterator i(o.begin_sections()), e(o.end_sections());
- for (; i != e; i.increment(ec)) {
+ section_iterator i(o.section_begin()), e(o.section_end());
+ for (; i != e; ++i) {
StringRef name;
if (error(i->getName(name))) break;
std::map<std::string, SymbolRef> readSymbols(const ObjectFile& o) {
error_code ec;
std::map<std::string, SymbolRef> result;
- symbol_iterator si(o.begin_symbols()), se(o.end_symbols());
- for (; si != se; si.increment(ec)) {
+ symbol_iterator si(o.symbol_begin()), se(o.symbol_end());
+ for (; si != se; ++si) {
StringRef name;
if (error(si->getName(name))) break;
::Disassembler d(filename);
std::string error;
- createBinary(filename, binary);
- if (Archive *a = dyn_cast<Archive>(binary.get())) {
+ binary = createBinary(filename).get();
+ if (Archive *a = dyn_cast<Archive>(binary)) {
std::cerr << "Got an archive!" << std::endl;
return;
}
- o = dyn_cast<ObjectFile>(binary.get());
+ o = dyn_cast<ObjectFile>(binary);
triple.setArch(Triple::ArchType(o->getArch()));
std::string tripleName(triple.getTriple());
if (symbols.end() != symbols.find(function)) {
SymbolRef ref;
- section_iterator sec(o->begin_sections());
+ section_iterator sec(o->section_begin());
ref = symbols.at(function);
if (error(ref.getSection(sec))) return;
void Binary::disassemble_functions() {
error_code ec;
- for (section_iterator i = o->begin_sections(),
- e = o->end_sections();
- i != e; i.increment(ec)) {
+ for (section_iterator i = o->section_begin(),
+ e = o->section_end();
+ i != e; ++i) {
if (error(ec)) break;
bool text;
if (error(i->isText(text))) break;
// Make a list of all the symbols in this section.
std::vector<std::pair<uint64_t, StringRef> > Symbols;
- for (symbol_iterator si = o->begin_symbols(),
- se = o->end_symbols();
- si != se; si.increment(ec)) {
+ for (symbol_iterator si = o->symbol_begin(),
+ se = o->symbol_end();
+ si != se; ++si) {
bool contains;
if (!error(i->containsSymbol(*si, contains)) && contains) {
uint64_t Address;
outs() << '\n' << Symbols[si].second << ":\n";
#ifndef NDEBUG
- raw_ostream &DebugOut = DebugFlag ? dbgs() : nulls();
+ raw_ostream &DebugOut = nulls(); //DebugFlag ? dbgs() : nulls();
#else
raw_ostream &DebugOut = nulls();
#endif
#include "Disassembler.hxx"
-namespace {
- llvm::OwningPtr<llvm::object::Binary>&
- constructor_helper(const std::string& filename,
- llvm::OwningPtr<llvm::object::Binary>& binary) {
- createBinary(filename, binary);
- return binary;
- }
-}
-
+using namespace llvm;
+using namespace llvm::object;
Disassembler::Disassembler(const std::string& filename)
- : _target(constructor_helper(filename, _binary))
+ : _binary(createBinary(filename).get())
+ , _target(_binary)
{
}