X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fcore%2FInformationManager.cxx;h=1234ac96aa64845775af2069a0bf73c901634d80;hp=0907cf9d2d7f7eeb5a191781c4345e1fc3e5a72c;hb=9fe5caf6408d1b7d5eb86dacdb211bd22335398a;hpb=64cdefa8eebaedef3a852b061d4df431b7e6c654 diff --git a/src/core/InformationManager.cxx b/src/core/InformationManager.cxx index 0907cf9..1234ac9 100644 --- a/src/core/InformationManager.cxx +++ b/src/core/InformationManager.cxx @@ -1,8 +1,19 @@ #include "InformationManager.hxx" #include "disassembler/llvm/LLVMDisassembler.hxx" +#include "core/Function.hxx" +#include "core/BasicBlock.hxx" + #include "gui/qt.hxx" -#include "quazip/quazip.h" -#include "quazip/quazipfile.h" +#include +#include + +InformationManager::~InformationManager() { + for (BasicBlock * b : blocks) + delete b; + + for (Function * f : functions) + delete f; +} void InformationManager::reset(const std::string& filename) { disassembler.reset(createLLVMDisassembler(filename, this)); @@ -47,3 +58,10 @@ void InformationManager::save(const QString& filename) { zip.close(); } + +void InformationManager::signal_new_function(Function* fun) { + functions.insert(fun); + for (auto b : fun->blocks()) + blocks.insert(b.second); + new_function_signal(fun); +}