]> git.siccegge.de Git - frida/frida.git/blobdiff - src/core/InformationManager.hxx
Complete accessors for InformationManager managed objects
[frida/frida.git] / src / core / InformationManager.hxx
index f3f34069362ce9541e9f289906d94c71d0ab53e2..555070abefd624cf6e19a5b84218a58ab3b73097 100644 (file)
@@ -13,11 +13,11 @@ class Function;
 class BasicBlock;
 class Comment;
 
+class RenameFunctionEvent;
+
 class QString;
 class QTemporaryFile;
 
-class RenameFunctionEvent;
-
 class InformationManager {
 public:
        InformationManager();
@@ -29,7 +29,7 @@ public:
 
        void signal_new_function(Function* f);
        void signal_new_dyn_symbol(const std::string& f)
-               { new_dyn_symbol_signal(f);     }
+               { new_dyn_symbol_signal(f); }
 
        boost::signals2::connection
        connect_new_function_signal(std::function<void(Function*)> f)
@@ -53,9 +53,17 @@ 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<uint64_t, Function*>::const_iterator beginFunctions();
+       std::map<uint64_t, Function*>::const_iterator endFunctions();
+
+       BasicBlock* getBasicBlock(uint64_t address);
+       bool hasBasicBlocks() const {return blocks.size() != 0;}
+       std::map<uint64_t, BasicBlock*>::const_iterator beginBasicBlocks();
+       std::map<uint64_t, BasicBlock*>::const_iterator endBasicBlocks();
+
 
        /* Protocoll:
         *
@@ -86,6 +94,7 @@ public:
        void deleteFunction(Function* f);
        void deleteBasicBlock(BasicBlock* b);
        void deleteComment(Comment* c);
+
 private:
        boost::signals2::signal<void ()> reset_signal;
        boost::signals2::signal<void (Function*)> new_function_signal;