Use Xoshiro256SSRandom instead of CMWC in enormous placements
This commit is contained in:
parent
b8468f7828
commit
ab42d1c1fb
@ -14,6 +14,7 @@ import net.minecraft.world.level.ChunkPos
|
||||
import net.minecraft.world.level.levelgen.placement.PlacementContext
|
||||
import net.minecraft.world.level.levelgen.placement.PlacementModifier
|
||||
import ru.dbotthepony.mc.otm.core.util.CMWCRandom
|
||||
import ru.dbotthepony.mc.otm.core.util.Xoshiro256SSRandom
|
||||
import ru.dbotthepony.mc.otm.data.codec.inRange
|
||||
import ru.dbotthepony.mc.otm.data.codec.minRange
|
||||
import java.time.Duration
|
||||
@ -71,7 +72,7 @@ abstract class AbstractEnormousPlacement(val parameters: Parameters) : Placement
|
||||
.build<ChunkPos, GeneratedChunk>()
|
||||
|
||||
private fun computeChunk(context: PlacementContext, pos: ChunkPos): GeneratedChunk {
|
||||
val random = CMWCRandom(context.level.seed + HashCommon.murmurHash3(pos.x + pos.z * 31) + parameters.seedMix)
|
||||
val random = Xoshiro256SSRandom(context.level.seed, parameters.seedMix, pos.x.toLong(), pos.z.toLong())
|
||||
var stream = Stream.of(BlockPos(pos.minBlockX, 0, pos.minBlockZ))
|
||||
parameters.placementModifiers.forEach { modifier -> stream = stream.flatMap { modifier.getPositions(context, random, it).sequential() } }
|
||||
return GeneratedChunk(stream.flatMap { getPositions(it, random) })
|
||||
|
Loading…
Reference in New Issue
Block a user