X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FInformationManager.hxx;h=03cb3b866ec139b875ffad8a7556820b3733c2e1;hp=a43b1181281cd1deea73b4d8cb595a1128bd108b;hb=0daf9a157f3d41690cf4a0287db1adecc4ad0b71;hpb=d5084161ca261d7fc0bd284621569440b6503eac diff --git a/src/core/InformationManager.hxx b/src/core/InformationManager.hxx index a43b118..03cb3b8 100644 --- a/src/core/InformationManager.hxx +++ b/src/core/InformationManager.hxx @@ -4,14 +4,17 @@ #include #include #include -#include +#include class Disassembler; class Function; class BasicBlock; +class Comment; class QString; +class RenameFunctionEvent; + class InformationManager { public: ~InformationManager(); @@ -20,33 +23,71 @@ public: 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); } - - 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::set blocks; + std::map functions; + std::map blocks; }; #endif /* INCLUDE__InformationManager_hxx */