]> git.siccegge.de Git - frida/frida.git/blobdiff - src/core/InformationManager.hxx
Move to Qt Signal/Slots
[frida/frida.git] / src / core / InformationManager.hxx
index 4fdfb7435cd9ea942fafb82a1b3c090e795dc17a..23645440a1e05760abecbf40f0d6587ca66aff81 100644 (file)
@@ -2,12 +2,13 @@
 #define INCLUDE__InformationManager_hxx
 
 #include <log4cxx/logger.h>
-#include <boost/signals2.hpp>
 #include <functional>
 #include <string>
 #include <map>
 #include <vector>
+#include <memory>
 
+#include "qt.hxx"
 #include "disassembler/Disassembler.hxx"
 
 class Interpreter;
@@ -24,9 +25,17 @@ class QString;
 class QTemporaryFile;
 class QPluginLoader;
 
-using boost::signals2::connection;
-
-class InformationManager {
+class InformationManager : public QObject {
+#ifndef SWIG
+       Q_OBJECT
+Q_SIGNALS:
+#else
+public:
+#endif
+       void renameFunctionEvent(RenameFunctionEvent* event);
+       void newFunctionEvent(NewFunctionEvent* event);
+       void changeCommentEvent(ChangeCommentEvent* event);
+       void reset();
 public:
        InformationManager();
        ~InformationManager();
@@ -38,31 +47,6 @@ public:
        Disassembler* getDisassembler()
                { return disassembler.get(); }
 
-       // Rename Function
-       typedef std::function<void (RenameFunctionEvent*)> RenameFunctionHandler;
-       connection registerRenameFunctionEvent(RenameFunctionHandler h)
-               { return renameFunctionSignal.connect(h); }
-       void dispatch(RenameFunctionEvent* event)
-               { renameFunctionSignal(event); }
-
-       // New Function
-       typedef std::function<void (NewFunctionEvent*)> NewFunctionHandler;
-       connection registerNewFunctionEvent(NewFunctionHandler h)
-               { return newFunctionSignal.connect(h); }
-       void dispatch(NewFunctionEvent* event)
-               { newFunctionSignal(event); }
-
-       // Change Comment
-       typedef std::function<void (ChangeCommentEvent*)> ChangeCommentHandler;
-       connection registerChangeCommentEvent(ChangeCommentHandler h)
-               { return changeCommentSignal.connect(h); }
-       void dispatch(ChangeCommentEvent* event)
-               { changeCommentSignal(event); }
-
-       // Reset frida
-       connection connect_reset_signal(std::function<void ()> f)
-               { return reset_signal.connect(f); }
-
        // Accessors
        Function* getFunction(uint64_t address);
        bool hasFunctions() const {return functions.size() != 0;}
@@ -119,12 +103,6 @@ public:
        void deleteComment(Comment* c);
 
 private:
-       boost::signals2::signal<void (RenameFunctionEvent*)> renameFunctionSignal;
-       boost::signals2::signal<void (NewFunctionEvent*)> newFunctionSignal;
-       boost::signals2::signal<void (ChangeCommentEvent*)> changeCommentSignal;
-
-       boost::signals2::signal<void ()> reset_signal;
-
        std::unique_ptr<Disassembler> disassembler;
 
        std::map<std::string, Interpreter*> interpreters;