X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FInformationManager.hxx;h=ddba5a3f8e4080f49b4f8cedbd6a51cd47c9a1f5;hp=3407113e3324bd14c573a844780ed66926f01557;hb=HEAD;hpb=d1b23c7274d6430ccc70bf2baf616437db9f5706 diff --git a/src/core/InformationManager.hxx b/src/core/InformationManager.hxx index 3407113..ddba5a3 100644 --- a/src/core/InformationManager.hxx +++ b/src/core/InformationManager.hxx @@ -2,14 +2,17 @@ #define INCLUDE__InformationManager_hxx #include -#include #include #include #include #include +#include +#include "qt.hxx" #include "disassembler/Disassembler.hxx" +#include "core/events/NewFunctionEvent.hxx" + class Interpreter; class Function; @@ -24,51 +27,46 @@ class QString; class QTemporaryFile; class QPluginLoader; -using boost::signals2::connection; - -class InformationManager { +class InformationManager : public QObject { +#ifndef SWIG + Q_OBJECT +signals: +#else +public: +#endif + void renameFunctionEvent(RenameFunctionEvent* event); + void newFunctionEvent(NewFunctionEvent event); + void changeCommentEvent(ChangeCommentEvent* event); + void resetEvent(); public: InformationManager(); ~InformationManager(); + // Start working on a fresh binary void reset(const std::string& filename); + + // Load a saved binary void load(const std::string& filename); + + // Save current state to disk void save(const std::string& filename); Disassembler* getDisassembler() { return disassembler.get(); } - // Rename Function - typedef std::function RenameFunctionHandler; - connection registerRenameFunctionEvent(RenameFunctionHandler h) - { return renameFunctionSignal.connect(h); } - void dispatch(RenameFunctionEvent* event) - { renameFunctionSignal(event); } - - // New Function - typedef std::function NewFunctionHandler; - connection registerNewFunctionEvent(NewFunctionHandler h) - { return newFunctionSignal.connect(h); } - void dispatch(NewFunctionEvent* event) - { newFunctionSignal(event); } - - // Change Comment - typedef std::function ChangeCommentHandler; - connection registerChangeCommentEvent(ChangeCommentHandler h) - { return changeCommentSignal.connect(h); } - void dispatch(ChangeCommentEvent* event) - { changeCommentSignal(event); } - - connection connect_reset_signal(std::function f) - { return reset_signal.connect(f); } + // Accessors + /* Used by the disassembler to determine whether to use unsafe + * heuristics for finding an entry point + */ + bool hasFunctions() const {return functions.size() != 0;} + + uint64_t getEntryAddress() {return disassembler->entryAddress();} Function* getFunction(uint64_t address); - bool hasFunctions() const {return functions.size() != 0;} std::map::const_iterator beginFunctions(); std::map::const_iterator endFunctions(); BasicBlock* getBasicBlock(uint64_t address); - bool hasBasicBlocks() const {return blocks.size() != 0;} std::map::const_iterator beginBasicBlocks(); std::map::const_iterator endBasicBlocks(); @@ -76,7 +74,6 @@ public: std::multimap::const_iterator, std::multimap::const_iterator> getComments(uint64_t address); - bool hasComments() const {return ! comments.empty();} std::multimap::const_iterator beginComments(); std::multimap::const_iterator endComments(); @@ -117,12 +114,6 @@ public: void deleteComment(Comment* c); private: - boost::signals2::signal renameFunctionSignal; - boost::signals2::signal newFunctionSignal; - boost::signals2::signal changeCommentSignal; - - boost::signals2::signal reset_signal; - std::unique_ptr disassembler; std::map interpreters; @@ -134,6 +125,7 @@ private: std::unique_ptr tmpfile; std::vector plugins; + QThread disassemblerThread; log4cxx::LoggerPtr logger; };