X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FInformationManager.hxx;h=ddba5a3f8e4080f49b4f8cedbd6a51cd47c9a1f5;hp=f39f6e4335af3ef80c3cc5be58951293bc740e0b;hb=HEAD;hpb=568fd6801188fb8c092c7820102824a572ec656e diff --git a/src/core/InformationManager.hxx b/src/core/InformationManager.hxx index f39f6e4..ddba5a3 100644 --- a/src/core/InformationManager.hxx +++ b/src/core/InformationManager.hxx @@ -42,21 +42,31 @@ 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(); } // Accessors - Function* getFunction(uint64_t address); + /* 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); 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(); @@ -64,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();