X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FFunction.hxx;h=3a328f6d203c027b57acf18b034477d4ff7192cd;hp=5497800969e57b8f12a2a2c8e24bdaf20688c675;hb=HEAD;hpb=0daf9a157f3d41690cf4a0287db1adecc4ad0b71 diff --git a/src/core/Function.hxx b/src/core/Function.hxx index 5497800..3a328f6 100644 --- a/src/core/Function.hxx +++ b/src/core/Function.hxx @@ -5,21 +5,22 @@ #include "BasicBlock.hxx" class InformationManager; +class QXmlStreamWriter; +class QXmlStreamReader; class Function { public: + uint64_t getStartAddress() const { return start_address; } - uint64_t getStartAddress() const { - return start_address; - } - - std::string getName() const - { return name; } + std::string getName() const { return name; } void setName(const std::string& new_name); - InformationManager* getManager() const { - return manager; - } + InformationManager* getManager() const { return manager; } + + /* Dynamic functions are the ones which are imported from shared + * libraries and not structly part of the binary at hand + */ + bool isDynamic() const { return dynamic; } void addBasicBlock(BasicBlock* block) { _blocks.insert(std::make_pair(block->getStartAddress(), block)); @@ -28,11 +29,16 @@ public: const std::map& blocks() { return _blocks; } + + void serialize(QXmlStreamWriter& stream); + static Function* deserialize(QXmlStreamReader& stream, InformationManager* manager); + private: - Function(uint64_t start_address, InformationManager* manager); + Function(uint64_t start_address, bool dynamic, InformationManager* manager); std::string name; uint64_t start_address; + bool dynamic; InformationManager * manager; std::map _blocks;