+ this->filename = filename;
+ disassembler.reset(createLLVMDisassembler(filename, this));
+ if (disassembler.get() != NULL)
+ disassembler.get()->start();
+}
+
+void InformationManager::load(const std::string& filename) {
+ QuaZip zip(filename.c_str());
+ QuaZipFile file(&zip);
+ QuaZipFileInfo info;
+
+ zip.open(QuaZip::mdUnzip);
+ tmpfile.reset(new QTemporaryFile());
+
+ {
+ LOG4CXX_INFO(logger, "Loading binary from archive");
+ zip.setCurrentFile("binary");
+ tmpfile->open();
+ file.open(QIODevice::ReadOnly);
+ QByteArray buffer;
+ while (!file.atEnd()) {
+ buffer = file.read(4096);
+ tmpfile->write(buffer);
+ }
+ tmpfile->flush();
+ file.close();
+ disassembler.reset(createLLVMDisassembler(tmpfile->fileName().toStdString(), this));
+ }
+
+ for (bool more = zip.goToFirstFile(); more; more = zip.goToNextFile()) {
+ zip.getCurrentFileInfo(&info);
+ file.open(QIODevice::ReadOnly);
+
+ if(info.name != "binary") {
+ QXmlStreamReader reader(&file);
+ assert(QXmlStreamReader::StartDocument == reader.readNext());
+ assert(QXmlStreamReader::StartElement == reader.readNext());
+ Function * fun = Function::deserialize(reader, this);
+ }
+ file.close();
+ }
+}
+
+void InformationManager::save(const std::string& filename) {
+ QuaZip zip(filename.c_str());
+ zip.open(QuaZip::mdCreate);
+ zip.setComment("FRIDA 0.0");
+ QuaZipFile outZipFile(&zip);
+
+ {
+ QFile binary(this->filename.c_str());
+ binary.open(QIODevice::ReadOnly);
+ QuaZipNewInfo zipinfo("binary");
+ zipinfo.setPermissions(static_cast<QFile::Permissions>(0x6444));
+ outZipFile.open(QIODevice::WriteOnly, zipinfo);
+ QByteArray buffer;
+ while (!binary.atEnd()) {
+ buffer = binary.read(4096);
+ outZipFile.write(buffer);
+ }
+ outZipFile.close();
+ }
+
+ for (auto funpair : functions) {
+ Function* fun = funpair.second;
+ QuaZipNewInfo zipinfo(fun->getName().c_str());
+ zipinfo.setPermissions(static_cast<QFile::Permissions>(0x6444));
+ outZipFile.open(QIODevice::WriteOnly, zipinfo);
+ QXmlStreamWriter stream(&outZipFile);
+ stream.setAutoFormatting(true);
+ stream.setAutoFormattingIndent(-1);
+ stream.writeStartDocument();
+
+ fun->serialize(stream);
+
+ stream.writeEndDocument();
+ outZipFile.close();
+ }
+
+ zip.close();
+}
+
+void InformationManager::signal_new_function(Function* fun) {
+}
+
+Function* InformationManager::getFunction(uint64_t address) {
+ auto it = functions.find(address);
+ if (it != functions.end())
+ return it->second;
+ else
+ return NULL;
+}
+
+BasicBlock* InformationManager::getBasicBlock(uint64_t address) {
+ auto it = blocks.find(address);
+ if (it != blocks.end())
+ return it->second;
+ else
+ return NULL;
+}
+
+Function* InformationManager::newFunction(uint64_t address) {
+ Function* fun = new Function(address, this);
+ functions.insert(std::make_pair(address, fun));
+ return fun;
+}
+
+BasicBlock* InformationManager::newBasicBlock(uint64_t address) {
+ BasicBlock* block = new BasicBlock(address, this);
+ blocks.insert(std::make_pair(address, block));
+ return block;
+}
+
+Comment* InformationManager::newGlobalComment(uint64_t address) {
+ return NULL;
+}
+
+Comment* InformationManager::newLocalComment(uint64_t address, Function* f) {
+ return NULL;
+}
+
+void InformationManager::finishFunction(Function* fun) {
+ LOG4CXX_DEBUG(logger, "Finishing function " << fun->getName());
+ for (auto b : fun->blocks()) {
+ BasicBlock* bl = b.second;
+ blocks.insert(std::make_pair(bl->getStartAddress(), bl));
+ }
+ new_function_signal(fun);
+}
+
+void InformationManager::finishBasicBlock(BasicBlock* b) {
+}
+
+void InformationManager::finnishComment(Comment* c) {
+}
+
+void InformationManager::deleteFunction(Function* f) {
+ functions.erase(f->getStartAddress());
+ delete f;
+}
+
+void InformationManager::deleteBasicBlock(BasicBlock* b) {
+ blocks.erase(b->getStartAddress());
+ delete b;
+}
+
+void InformationManager::deleteComment(Comment* c) {
+ delete c;