1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-02-01 06:15:32 +00:00

Replace raw pointer in BsaArchive with unique_ptr

This commit is contained in:
Azdul 2019-01-17 08:42:43 +01:00
parent e502819246
commit caa0487c6a
2 changed files with 4 additions and 7 deletions

View file

@ -7,15 +7,13 @@ namespace VFS
BsaArchive::BsaArchive(const std::string &filename) BsaArchive::BsaArchive(const std::string &filename)
{ {
mFile = nullptr;
Bsa::BsaVersion bsaVersion = Bsa::TES4BSAFile::detectVersion(filename); Bsa::BsaVersion bsaVersion = Bsa::TES4BSAFile::detectVersion(filename);
if (bsaVersion == Bsa::BSAVER_TES4PLUS) { if (bsaVersion == Bsa::BSAVER_TES4PLUS) {
mFile = new Bsa::TES4BSAFile(); mFile = std::make_unique<Bsa::TES4BSAFile>();
} }
else { else {
mFile = new Bsa::BSAFile(); mFile = std::make_unique<Bsa::BSAFile>();
} }
mFile->open(filename); mFile->open(filename);
@ -23,12 +21,11 @@ BsaArchive::BsaArchive(const std::string &filename)
const Bsa::BSAFile::FileList &filelist = mFile->getList(); const Bsa::BSAFile::FileList &filelist = mFile->getList();
for(Bsa::BSAFile::FileList::const_iterator it = filelist.begin();it != filelist.end();++it) for(Bsa::BSAFile::FileList::const_iterator it = filelist.begin();it != filelist.end();++it)
{ {
mResources.push_back(BsaArchiveFile(&*it, mFile)); mResources.push_back(BsaArchiveFile(&*it, mFile.get()));
} }
} }
BsaArchive::~BsaArchive() { BsaArchive::~BsaArchive() {
delete mFile;
} }
void BsaArchive::listResources(std::map<std::string, File *> &out, char (*normalize_function)(char)) void BsaArchive::listResources(std::map<std::string, File *> &out, char (*normalize_function)(char))

View file

@ -26,7 +26,7 @@ namespace VFS
virtual void listResources(std::map<std::string, File*>& out, char (*normalize_function) (char)); virtual void listResources(std::map<std::string, File*>& out, char (*normalize_function) (char));
private: private:
Bsa::BSAFile* mFile; std::unique_ptr<Bsa::BSAFile> mFile;
std::vector<BsaArchiveFile> mResources; std::vector<BsaArchiveFile> mResources;
}; };
} }