]> git.siccegge.de Git - frida/frida.git/blobdiff - src/disassembler/Disassembler.hxx
Add doc repo as submodule
[frida/frida.git] / src / disassembler / Disassembler.hxx
index 78c67c6610ac5b75d709d2ac0b2e0d15a4058aba..669dd82076b5f3627fe8cd9a2a1394b51849b5ee 100644 (file)
@@ -3,28 +3,38 @@
 
 #include <string>
 #include <functional>
-#include <list>
+#include <vector>
 
+#include "qt.hxx"
 #include "Instruction.hxx"
 
 class Function;
 class BasicBlock;
 class InformationManager;
 
-class Disassembler {
+class Disassembler : public QObject {
+#ifndef SWIG
+       Q_OBJECT
+#endif
 public:
        Disassembler() {}
        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<void (uint8_t*, size_t, const std::string&,
-                                                             const std::string&)> fun) = 0;
-       virtual Function * disassembleFunctionAt(uint64_t address, const std::string& name = "") = 0;
-       virtual std::list<Instruction> getInstructions(const BasicBlock* block) = 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;
+
+       // TODO: Should use move semantics!
+       virtual std::vector<Instruction> getInstructions(const BasicBlock* block) = 0;
 };
 
 #endif