X-Git-Url: https://git.siccegge.de//index.cgi?a=blobdiff_plain;ds=sidebyside;f=src%2Fdisassembler%2FDisassembler.hxx;h=669dd82076b5f3627fe8cd9a2a1394b51849b5ee;hb=be25639ecafa1ec2d37c8e2d6c8225c12ddb59ff;hp=5ccd9ff62499c5d55e42b5ce58208d9609842fc7;hpb=2a014774e29e324bc5b5f26143d0384351738ca1;p=frida%2Ffrida.git diff --git a/src/disassembler/Disassembler.hxx b/src/disassembler/Disassembler.hxx index 5ccd9ff..669dd82 100644 --- a/src/disassembler/Disassembler.hxx +++ b/src/disassembler/Disassembler.hxx @@ -1,16 +1,40 @@ #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() {} + + virtual void getSymbols() = 0; + virtual uint64_t entryAddress() = 0; + +#ifndef SWIG +public slots: +#endif + virtual void start() = 0; + virtual Function * disassembleFunctionAt(uint64_t address) { + return disassembleFunctionAt(address, ""); + } + virtual Function * disassembleFunctionAt(uint64_t address, + const std::string& name) = 0; - Target _target; + // TODO: Should use move semantics! + virtual std::vector getInstructions(const BasicBlock* block) = 0; }; #endif