X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FInformationManager.hxx;h=610ece50da253f51820e9af3679ed934008808cb;hp=86e4d8cd80039fbe0b4c3fc43205a4b5d41585f0;hb=9b99fc5856d5fe88bb1d2aad4d2ee7cd86b5be57;hpb=55eb2a804c19c35a9006a2241a0feefe219bf21e diff --git a/src/core/InformationManager.hxx b/src/core/InformationManager.hxx index 86e4d8c..610ece5 100644 --- a/src/core/InformationManager.hxx +++ b/src/core/InformationManager.hxx @@ -6,17 +6,21 @@ #include #include #include +#include #include "disassembler/Disassembler.hxx" +class Interpreter; + class Function; class BasicBlock; class Comment; +class RenameFunctionEvent; + class QString; class QTemporaryFile; - -class RenameFunctionEvent; +class QPluginLoader; class InformationManager { public: @@ -53,9 +57,23 @@ public: void dispatch(RenameFunctionEvent* event) { rename_function_signal(event); } + Function* getFunction(uint64_t address); - BasicBlock* getBasicBlock(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(); + + + Interpreter* getInterpreter(const std::string& name); + bool hasInterpreters() const {return interpreters.size() != 0;} + std::map::const_iterator beginInterpreters(); + std::map::const_iterator endInterpreters(); + /* Protocoll: * @@ -93,10 +111,12 @@ private: 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::string filename; std::unique_ptr tmpfile; + std::vector plugins; log4cxx::LoggerPtr logger; };