mirror of
https://github.com/OpenMW/openmw.git
synced 2025-02-01 02:15:34 +00:00
Merge branch 'cleanup_esm3_readers_cache' into 'master'
Remove stateless encoder from ReadersCache See merge request OpenMW/openmw!3823
This commit is contained in:
commit
c9489bad9b
3 changed files with 7 additions and 20 deletions
|
@ -64,11 +64,12 @@ namespace MWWorld
|
||||||
}
|
}
|
||||||
case ESM::Format::Tes4:
|
case ESM::Format::Tes4:
|
||||||
{
|
{
|
||||||
ESM4::Reader readerESM4(std::move(stream), filepath,
|
ESM4::Reader reader(std::move(stream), filepath,
|
||||||
MWBase::Environment::get().getResourceSystem()->getVFS(), mReaders.getStatelessEncoder());
|
MWBase::Environment::get().getResourceSystem()->getVFS(),
|
||||||
readerESM4.setModIndex(index);
|
mEncoder != nullptr ? &mEncoder->getStatelessEncoder() : nullptr);
|
||||||
readerESM4.updateModIndices(mNameToIndex);
|
reader.setModIndex(index);
|
||||||
mStore.loadESM4(readerESM4);
|
reader.updateModIndices(mNameToIndex);
|
||||||
|
mStore.loadESM4(reader);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -274,8 +274,6 @@ namespace MWWorld
|
||||||
const std::vector<std::string>& groundcoverFiles, ToUTF8::Utf8Encoder* encoder, Loading::Listener* listener)
|
const std::vector<std::string>& groundcoverFiles, ToUTF8::Utf8Encoder* encoder, Loading::Listener* listener)
|
||||||
{
|
{
|
||||||
mContentFiles = contentFiles;
|
mContentFiles = contentFiles;
|
||||||
if (encoder)
|
|
||||||
mReaders.setStatelessEncoder(encoder->getStatelessEncoder());
|
|
||||||
mESMVersions.resize(mContentFiles.size(), -1);
|
mESMVersions.resize(mContentFiles.size(), -1);
|
||||||
|
|
||||||
loadContentFiles(fileCollections, contentFiles, encoder, listener);
|
loadContentFiles(fileCollections, contentFiles, encoder, listener);
|
||||||
|
|
|
@ -9,8 +9,6 @@
|
||||||
#include <optional>
|
#include <optional>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include <components/to_utf8/to_utf8.hpp>
|
|
||||||
|
|
||||||
namespace ESM
|
namespace ESM
|
||||||
{
|
{
|
||||||
class ReadersCache
|
class ReadersCache
|
||||||
|
@ -57,23 +55,13 @@ namespace ESM
|
||||||
|
|
||||||
BusyItem get(std::size_t index);
|
BusyItem get(std::size_t index);
|
||||||
|
|
||||||
void setStatelessEncoder(const ToUTF8::StatelessUtf8Encoder& statelessEncoderPtr)
|
|
||||||
{
|
|
||||||
mStatelessEncoder.emplace(statelessEncoderPtr);
|
|
||||||
}
|
|
||||||
|
|
||||||
const ToUTF8::StatelessUtf8Encoder* getStatelessEncoder()
|
|
||||||
{
|
|
||||||
return mStatelessEncoder.has_value() ? &mStatelessEncoder.value() : nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const std::size_t mCapacity;
|
const std::size_t mCapacity;
|
||||||
std::map<std::size_t, std::list<Item>::iterator> mIndex;
|
std::map<std::size_t, std::list<Item>::iterator> mIndex;
|
||||||
std::list<Item> mBusyItems;
|
std::list<Item> mBusyItems;
|
||||||
std::list<Item> mFreeItems;
|
std::list<Item> mFreeItems;
|
||||||
std::list<Item> mClosedItems;
|
std::list<Item> mClosedItems;
|
||||||
std::optional<ToUTF8::StatelessUtf8Encoder> mStatelessEncoder;
|
|
||||||
inline void closeExtraReaders();
|
inline void closeExtraReaders();
|
||||||
|
|
||||||
inline void releaseItem(std::list<Item>::iterator it) noexcept;
|
inline void releaseItem(std::list<Item>::iterator it) noexcept;
|
||||||
|
|
Loading…
Reference in a new issue