X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FBasicBlock.hxx;h=0df07b2a7283d3b270712d7be1477f996ea3cea9;hp=b3e5a89d819cfbd74c5b375919eba6dcccd7e09a;hb=f58969ddf1d22882bff102ef597c6f129255894a;hpb=32e87746db981882b95aceddde79ef12034a3405 diff --git a/src/core/BasicBlock.hxx b/src/core/BasicBlock.hxx index b3e5a89..0df07b2 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,35 @@ 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) + , end_address(0) + , 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