X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FInformationManager.hxx;h=03cb3b866ec139b875ffad8a7556820b3733c2e1;hp=f8e4f04011bc666c5aff24e14f4d157b2ff66130;hb=0daf9a157f3d41690cf4a0287db1adecc4ad0b71;hpb=32e87746db981882b95aceddde79ef12034a3405 diff --git a/src/core/InformationManager.hxx b/src/core/InformationManager.hxx index f8e4f04..03cb3b8 100644 --- a/src/core/InformationManager.hxx +++ b/src/core/InformationManager.hxx @@ -4,45 +4,90 @@ #include #include #include -#include +#include class Disassembler; class Function; class BasicBlock; +class Comment; class QString; +class RenameFunctionEvent; + class InformationManager { public: + ~InformationManager(); + void reset(const std::string& filename); void save(const QString& 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); } - void signal_new_function(Function* f) - { functions.insert(f); new_function_signal(f); } - boost::signals2::connection connect_new_dyn_symbol_signal(std::function f) { return new_dyn_symbol_signal.connect(f); } - void signal_new_dyn_symbol(const std::string& f) - { new_dyn_symbol_signal(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(); } + + void dispatch(RenameFunctionEvent* event) + { rename_function_signal(event); } + + Function* getFunction(uint64_t address); + BasicBlock* getBasicBlock(uint64_t address); + + /* Protocoll: + * + * Users may allocate new Data containers with the new*() + * functions. Once they have populated the information they hand + * over the object to the information manager using the finish*() + * functions. + * + * if new*() returns NULL there already exists a function at the + * specified address. Users may then get the old object if they + * wish or (more likely) skip creating it. Uniqueness of the + * object is only guaranteed as compared to the finish()ed + * objects. + * + * Users are responsible for destroying functions iff they do not + * finish them using the delete*() functions. Once the objects are + * finished, the information manager is responsible for cleaning + * up the memory. If delete*() is called on a finished object, bad + * thingsmay happen. + */ + Function* newFunction(uint64_t address); + BasicBlock* newBasicBlock(uint64_t address); + Comment* newGlobalComment(uint64_t address); + Comment* newLocalComment(uint64_t address, Function* f); + void finishFunction(Function* f); + void finishBasicBlock(BasicBlock* b); + void finnishComment(Comment* c); + void deleteFunction(Function* f); + void deleteBasicBlock(BasicBlock* b); + void deleteComment(Comment* c); private: 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::set functions; + std::map functions; + std::map blocks; }; #endif /* INCLUDE__InformationManager_hxx */