]> git.siccegge.de Git - frida/frida.git/blobdiff - src/disassembler/Disassembler.hxx
Move Function/BasicBlock to core and clean up includes
[frida/frida.git] / src / disassembler / Disassembler.hxx
index c88bfd5f1408933e3d1ccc9bbd055b5a097b2532..4feeddf0e11e03ab97d5b84984daebcfde5af356 100644 (file)
@@ -1,17 +1,17 @@
-  #ifndef INCLUDE__Disassembler_hxx
+#ifndef INCLUDE__Disassembler_hxx
 #define INCLUDE__Disassembler_hxx
 
 #include <string>
 #include <functional>
 
-#include "disassembler/BasicBlock.hxx"
-#include "disassembler/Function.hxx"
-#include "core/InformationManager.hxx"
+class Function;
+class BasicBlock;
+class InformationManager;
 
 class Disassembler {
 public:
        Disassembler(const std::string& filename, InformationManager* manager) {}
-    virtual ~Disassembler() {}
+       virtual ~Disassembler() {}
 
        virtual void start() = 0;
        virtual void getSymbols() = 0;
@@ -20,10 +20,12 @@ public:
 
        virtual void forEachFunction(std::function<void (uint64_t, Function*)> callback) = 0;
        virtual void printEachInstruction(uint64_t start, uint64_t end,
-                                                                         std::function<void (uint8_t*, size_t, const std::string&)> fun) = 0;
+                                         std::function<void (uint8_t*, size_t, const std::string&,
+                                                             const std::string&)> 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;
+       virtual bool isFunctionCall(uint64_t address) = 0;
+       virtual bool isJump(uint64_t address) = 0;
 };
 
 #endif