cSetChunkData constructor explicitly requires std::move() instead of
unsafely stealing data
This commit is contained in:
parent
0bfcd62556
commit
6caf08da99
@ -33,8 +33,8 @@ cSetChunkData::cSetChunkData(
|
|||||||
const NIBBLETYPE * a_SkyLight,
|
const NIBBLETYPE * a_SkyLight,
|
||||||
const cChunkDef::HeightMap * a_HeightMap,
|
const cChunkDef::HeightMap * a_HeightMap,
|
||||||
const cChunkDef::BiomeMap * a_Biomes,
|
const cChunkDef::BiomeMap * a_Biomes,
|
||||||
cEntityList & a_Entities,
|
cEntityList && a_Entities,
|
||||||
cBlockEntityList & a_BlockEntities,
|
cBlockEntityList && a_BlockEntities,
|
||||||
bool a_ShouldMarkDirty
|
bool a_ShouldMarkDirty
|
||||||
) :
|
) :
|
||||||
m_ChunkX(a_ChunkX),
|
m_ChunkX(a_ChunkX),
|
||||||
@ -84,8 +84,8 @@ cSetChunkData::cSetChunkData(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Move entities and blockentities:
|
// Move entities and blockentities:
|
||||||
std::swap(m_Entities, a_Entities);
|
m_Entities = std::move(a_Entities);
|
||||||
std::swap(m_BlockEntities, a_BlockEntities);
|
m_BlockEntities = std::move(a_BlockEntities);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -24,8 +24,10 @@ public:
|
|||||||
|
|
||||||
/** Constructs a new instance based on data existing elsewhere, will copy all the memory. Prefer to use the
|
/** Constructs a new instance based on data existing elsewhere, will copy all the memory. Prefer to use the
|
||||||
other constructor as much as possible.
|
other constructor as much as possible.
|
||||||
Will move the entity and blockentity lists into the internal storage, and empty the a_Entities and
|
Will move the entity and blockentity lists into the internal storage, and invalidate a_Entities and
|
||||||
a_BlockEntities lists.
|
a_BlockEntities.
|
||||||
|
When passing an lvalue, a_Entities and a_BlockEntities must be explicitly converted to an rvalue beforehand
|
||||||
|
with std::move().
|
||||||
a_BlockTypes and a_BlockMetas must always be valid.
|
a_BlockTypes and a_BlockMetas must always be valid.
|
||||||
If either of the light arrays are nullptr, the chunk data will be marked as not having any light at all and
|
If either of the light arrays are nullptr, the chunk data will be marked as not having any light at all and
|
||||||
will be scheduled for re-lighting once it is set into the chunkmap.
|
will be scheduled for re-lighting once it is set into the chunkmap.
|
||||||
@ -41,8 +43,8 @@ public:
|
|||||||
const NIBBLETYPE * a_SkyLight,
|
const NIBBLETYPE * a_SkyLight,
|
||||||
const cChunkDef::HeightMap * a_HeightMap,
|
const cChunkDef::HeightMap * a_HeightMap,
|
||||||
const cChunkDef::BiomeMap * a_Biomes,
|
const cChunkDef::BiomeMap * a_Biomes,
|
||||||
cEntityList & a_Entities,
|
cEntityList && a_Entities,
|
||||||
cBlockEntityList & a_BlockEntities,
|
cBlockEntityList && a_BlockEntities,
|
||||||
bool a_ShouldMarkDirty
|
bool a_ShouldMarkDirty
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -3712,7 +3712,7 @@ void cWorld::cChunkGeneratorCallbacks::OnChunkGenerated(cChunkDesc & a_ChunkDesc
|
|||||||
a_ChunkDesc.GetBlockTypes(), BlockMetas,
|
a_ChunkDesc.GetBlockTypes(), BlockMetas,
|
||||||
nullptr, nullptr, // We don't have lighting, chunk will be lighted when needed
|
nullptr, nullptr, // We don't have lighting, chunk will be lighted when needed
|
||||||
&a_ChunkDesc.GetHeightMap(), &a_ChunkDesc.GetBiomeMap(),
|
&a_ChunkDesc.GetHeightMap(), &a_ChunkDesc.GetBiomeMap(),
|
||||||
a_ChunkDesc.GetEntities(), a_ChunkDesc.GetBlockEntities(),
|
std::move(a_ChunkDesc.GetEntities()), std::move(a_ChunkDesc.GetBlockEntities()),
|
||||||
true
|
true
|
||||||
));
|
));
|
||||||
SetChunkData->RemoveInvalidBlockEntities();
|
SetChunkData->RemoveInvalidBlockEntities();
|
||||||
|
@ -431,7 +431,7 @@ bool cWSSAnvil::LoadChunkFromNBT(const cChunkCoords & a_Chunk, const cParsedNBT
|
|||||||
IsLightValid ? BlockLight : nullptr,
|
IsLightValid ? BlockLight : nullptr,
|
||||||
IsLightValid ? SkyLight : nullptr,
|
IsLightValid ? SkyLight : nullptr,
|
||||||
nullptr, Biomes,
|
nullptr, Biomes,
|
||||||
Entities, BlockEntities,
|
std::move(Entities), std::move(BlockEntities),
|
||||||
false
|
false
|
||||||
));
|
));
|
||||||
m_World->QueueSetChunkData(SetChunkData);
|
m_World->QueueSetChunkData(SetChunkData);
|
||||||
|
Loading…
Reference in New Issue
Block a user