Update to ZSTD

This commit is contained in:
GabsPuNs
2026-06-05 18:48:58 -04:00
parent 267e233f01
commit f3a175c640
12 changed files with 64 additions and 130 deletions

View File

@@ -29,18 +29,10 @@ RegionFile *RegionFileCache::_getRegionFile(ConsoleSaveFile *saveFile, const wst
MemSect(31);
File file;
if(useSplitSaves(saveFile->getSavePlatform()))
{
bool isNew = saveFile->doesFileExist(ConsoleSavePath(L"region_format_16"));
if (isNew)
file = File(prefix + wstring(L"r.") + std::to_wstring(chunkX >> 4) + L"." + std::to_wstring(chunkZ >> 4) + L".mcr");
else
file = File(prefix + wstring(L"r.") + std::to_wstring(chunkX >> 5) + L"." + std::to_wstring(chunkZ >> 5) + L".mcr");
}
file = File(prefix + wstring(L"r.") + std::to_wstring(chunkX >> 4) + L"." + std::to_wstring(chunkZ >> 4) + L".mcr");
else
{
file = File( prefix + wstring(L"r.") + std::to_wstring(chunkX>>5) + L"." + std::to_wstring(chunkZ>>5) + L".mcr" );
}
MemSect(0);
RegionFile *ref = nullptr;
@@ -57,19 +49,15 @@ RegionFile *RegionFileCache::_getRegionFile(ConsoleSaveFile *saveFile, const wst
// 4J Stu - Remove for new save files
/*
if (!regionDir.exists())
{
regionDir.mkdirs();
}
*/
if (cache.size() >= MAX_CACHE_SIZE)
{
_clear();
}
RegionFile *reg = new RegionFile(saveFile, &file);
cache[file] = reg; // 4J - this was originally a softReferenc
return reg;
}
void RegionFileCache::_clear() // 4J - TODO was synchronized
@@ -78,9 +66,8 @@ void RegionFileCache::_clear() // 4J - TODO was synchronized
{
RegionFile *regionFile = it.second;
if (regionFile != nullptr)
{
regionFile->close();
}
delete regionFile;
}
cache.clear();
@@ -95,34 +82,21 @@ int RegionFileCache::_getSizeDelta(ConsoleSaveFile *saveFile, const wstring &pre
DataInputStream *RegionFileCache::_getChunkDataInputStream(ConsoleSaveFile *saveFile, const wstring &prefix, int chunkX, int chunkZ)
{
RegionFile* r = _getRegionFile(saveFile, prefix, chunkX, chunkZ);
bool isNew = saveFile->doesFileExist(ConsoleSavePath(L"region_format_16"));
if (useSplitSaves(saveFile->getSavePlatform()) && isNew)
{
if (useSplitSaves(saveFile->getSavePlatform()))
return r->getChunkDataInputStream(chunkX & 15, chunkZ & 15);
}
else
{
return r->getChunkDataInputStream(chunkX & 31, chunkZ & 31);
}
}
DataOutputStream *RegionFileCache::_getChunkDataOutputStream(ConsoleSaveFile *saveFile, const wstring &prefix, int chunkX, int chunkZ)
{
RegionFile* r = _getRegionFile(saveFile, prefix, chunkX, chunkZ);
bool isNew = saveFile->doesFileExist(ConsoleSavePath(L"region_format_16"));
if (useSplitSaves(saveFile->getSavePlatform()) && isNew)
{
if (useSplitSaves(saveFile->getSavePlatform()))
return r->getChunkDataOutputStream(chunkX & 15, chunkZ & 15);
}
else
{
return r->getChunkDataOutputStream(chunkX & 31, chunkZ & 31);
}
}
RegionFileCache::~RegionFileCache()
{
_clear();