X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fdisassembler%2FDisassembler.hxx;h=776796a8dc22e230201a2cc9f775a284d0cb756f;hp=13c36b6d30a481a7d2892a81a644f1f377ad9464;hb=0daf9a157f3d41690cf4a0287db1adecc4ad0b71;hpb=05fded85315e1977895450456f77d740770d2a9c diff --git a/src/disassembler/Disassembler.hxx b/src/disassembler/Disassembler.hxx index 13c36b6..776796a 100644 --- a/src/disassembler/Disassembler.hxx +++ b/src/disassembler/Disassembler.hxx @@ -1,15 +1,29 @@ #ifndef INCLUDE__Disassembler_hxx #define INCLUDE__Disassembler_hxx -#include "Target.hxx" -#include "include.hxx" +#include +#include + +class Function; +class BasicBlock; +class InformationManager; class Disassembler { public: - Disassembler(const std::string& filename); -private: - llvm::object::Binary* _binary; - Target _target; + Disassembler(const std::string& filename, InformationManager* manager) {} + virtual ~Disassembler() {} + + virtual void start() = 0; + virtual void getSymbols() = 0; + virtual uint64_t entryAddress() = 0; + + virtual void printEachInstruction(uint64_t start, uint64_t end, + std::function fun) = 0; + virtual Function * disassembleFunctionAt(uint64_t address, const std::string& name = "") = 0; +protected: + virtual bool isFunctionCall(uint64_t address) = 0; + virtual bool isJump(uint64_t address) = 0; }; #endif