X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FInformationManager.hxx;h=bb37a1e9a69ee9965b82a031b4e8d7bb9853d3f8;hp=610ece50da253f51820e9af3679ed934008808cb;hb=546b89382dd61b664c216ad7668ec783f0ad094c;hpb=099f1e8222109bf7397eff6da0c511a07906c9cd diff --git a/src/core/InformationManager.hxx b/src/core/InformationManager.hxx index 610ece5..bb37a1e 100644 --- a/src/core/InformationManager.hxx +++ b/src/core/InformationManager.hxx @@ -17,11 +17,15 @@ class BasicBlock; class Comment; class RenameFunctionEvent; +class NewFunctionEvent; +class ChangeCommentEvent; class QString; class QTemporaryFile; class QPluginLoader; +using boost::signals2::connection; + class InformationManager { public: InformationManager(); @@ -31,32 +35,32 @@ public: void load(const std::string& filename); void save(const std::string& filename); - void signal_new_function(Function* f); - void signal_new_dyn_symbol(const std::string& f) - { new_dyn_symbol_signal(f); } - - boost::signals2::connection - connect_new_function_signal(std::function f) - { return new_function_signal.connect(f); } - - boost::signals2::connection - connect_new_dyn_symbol_signal(std::function f) - { return new_dyn_symbol_signal.connect(f); } - - boost::signals2::connection - connect_reset_signal(std::function f) - { return reset_signal.connect(f); } - - boost::signals2::connection - connect_rename_function_signal(std::function f) - { return rename_function_signal.connect(f); } - Disassembler* getDisassembler() { return disassembler.get(); } + // Rename Function + typedef std::function RenameFunctionHandler; + connection registerRenameFunctionEvent(RenameFunctionHandler h) + { return renameFunctionSignal.connect(h); } void dispatch(RenameFunctionEvent* event) - { rename_function_signal(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); } Function* getFunction(uint64_t address); bool hasFunctions() const {return functions.size() != 0;} @@ -68,7 +72,6 @@ public: std::map::const_iterator beginBasicBlocks(); std::map::const_iterator endBasicBlocks(); - Interpreter* getInterpreter(const std::string& name); bool hasInterpreters() const {return interpreters.size() != 0;} std::map::const_iterator beginInterpreters(); @@ -95,6 +98,7 @@ public: * thingsmay happen. */ Function* newFunction(uint64_t address); + Function* newDynamicFunction(uint64_t address); BasicBlock* newBasicBlock(uint64_t address); Comment* newGlobalComment(uint64_t address); Comment* newLocalComment(uint64_t address, Function* f); @@ -106,14 +110,19 @@ public: void deleteComment(Comment* c); private: + boost::signals2::signal renameFunctionSignal; + boost::signals2::signal newFunctionSignal; + boost::signals2::signal changeCommentSignal; + boost::signals2::signal reset_signal; - boost::signals2::signal new_function_signal; - boost::signals2::signal new_dyn_symbol_signal; - boost::signals2::signal rename_function_signal; + std::unique_ptr disassembler; + std::map interpreters; std::map functions; std::map blocks; + std::multimap comments; + std::string filename; std::unique_ptr tmpfile; std::vector plugins;