X-Git-Url: https://git.siccegge.de//index.cgi?a=blobdiff_plain;f=src%2Fdisassembler%2FDisassembler.hxx;h=ad35018e870bab74ae33da162d290be30e3a7832;hb=4979a0a839390713671f3f9756dc6820501d4ad4;hp=5ccd9ff62499c5d55e42b5ce58208d9609842fc7;hpb=2a014774e29e324bc5b5f26143d0384351738ca1;p=frida%2Ffrida.git diff --git a/src/disassembler/Disassembler.hxx b/src/disassembler/Disassembler.hxx index 5ccd9ff..ad35018 100644 --- a/src/disassembler/Disassembler.hxx +++ b/src/disassembler/Disassembler.hxx @@ -1,16 +1,37 @@ #ifndef INCLUDE__Disassembler_hxx #define INCLUDE__Disassembler_hxx -#include "Target.hxx" -#include "include.hxx" +#include +#include +#include -class Disassembler { +#include "qt.hxx" +#include "Instruction.hxx" + +class Function; +class BasicBlock; +class InformationManager; + +class Disassembler : public QObject { +#ifndef SWIG + Q_OBJECT +#endif public: - Disassembler(const std::string& filename); -private: - llvm::OwningPtr _binary; + Disassembler() {} + virtual ~Disassembler() {} - Target _target; + virtual void start() = 0; + virtual void getSymbols() = 0; + virtual uint64_t entryAddress() = 0; + +#ifndef SWIG +public slots: +#endif + virtual Function * disassembleFunctionAt(uint64_t address) { + return disassembleFunctionAt(address, ""); + } + virtual Function * disassembleFunctionAt(uint64_t address, const std::string& name) = 0; + virtual std::vector getInstructions(const BasicBlock* block) = 0; }; #endif