X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FBasicBlock.hxx;h=bec0da3a7d77752c78b031a429ea52a2f36908ee;hp=b3e5a89d819cfbd74c5b375919eba6dcccd7e09a;hb=149f8e76d1eed5037c583bad599a27154ce3d9a9;hpb=32e87746db981882b95aceddde79ef12034a3405 diff --git a/src/core/BasicBlock.hxx b/src/core/BasicBlock.hxx index b3e5a89..bec0da3 100644 --- a/src/core/BasicBlock.hxx +++ b/src/core/BasicBlock.hxx @@ -5,13 +5,13 @@ #include #include +class Disassembler; +class InformationManager; +class QXmlStreamWriter; +class QXmlStreamReader; + class BasicBlock { public: - BasicBlock() { - next_blocks[0] = 0; - next_blocks[1] = 0; - } - uint64_t getStartAddress() const { return start_address; } @@ -38,17 +38,34 @@ public: end_address = address; } - std::string getName() { + std::string getName() const { std::stringstream s; s << "BLOCK_" << std::hex << start_address << '_' << end_address; return s.str(); } + InformationManager* getManager() const { + return manager; + } + + void serialize(QXmlStreamWriter& stream); + static BasicBlock* deserialize(QXmlStreamReader& stream, InformationManager* manager); + private: + BasicBlock(uint64_t start_address, InformationManager* manager) + : start_address(start_address) + , manager(manager) { + next_blocks[0] = 0; + next_blocks[1] = 0; + } + uint64_t start_address; uint64_t end_address; - + Disassembler* disassembler; + InformationManager* manager; uint64_t next_blocks[2]; + + friend class InformationManager; }; #endif