3
0
Mirror von https://github.com/PaperMC/Paper.git synchronisiert 2025-01-07 05:40:11 +01:00

SPIGOT-5573, SPIGOT-5574: Move CustomChunkGenerator generation code back to buildBase()

Dieser Commit ist enthalten in:
konsolas 2020-02-12 17:58:50 +00:00 committet von md_5
Ursprung d171d7eb8e
Commit 37f32da8f8

Datei anzeigen

@ -99,11 +99,6 @@ public class CustomChunkGenerator extends InternalChunkGenerator<GeneratorSettin
// Don't allow the server to override any custom biomes that have been set // Don't allow the server to override any custom biomes that have been set
} }
@Override
public void buildBase(RegionLimitedWorldAccess regionlimitedworldaccess, IChunkAccess ichunkaccess) {
// Disable vanilla generation
}
@Override @Override
public <C extends WorldGenFeatureConfiguration> C getFeatureConfiguration(BiomeBase biomebase, StructureGenerator<C> structuregenerator) { public <C extends WorldGenFeatureConfiguration> C getFeatureConfiguration(BiomeBase biomebase, StructureGenerator<C> structuregenerator) {
return (C) delegate.getFeatureConfiguration(biomebase, structuregenerator); return (C) delegate.getFeatureConfiguration(biomebase, structuregenerator);
@ -125,7 +120,7 @@ public class CustomChunkGenerator extends InternalChunkGenerator<GeneratorSettin
} }
@Override @Override
public void createStructures(BiomeManager biomemanager, IChunkAccess ichunkaccess, net.minecraft.server.ChunkGenerator<?> chunkgenerator, DefinedStructureManager definedstructuremanager) { public void buildBase(RegionLimitedWorldAccess regionlimitedworldaccess, IChunkAccess ichunkaccess) {
// Call the bukkit ChunkGenerator before structure generation so correct biome information is available. // Call the bukkit ChunkGenerator before structure generation so correct biome information is available.
int x = ichunkaccess.getPos().x; int x = ichunkaccess.getPos().x;
int z = ichunkaccess.getPos().z; int z = ichunkaccess.getPos().z;
@ -176,23 +171,14 @@ public class CustomChunkGenerator extends InternalChunkGenerator<GeneratorSettin
} }
} }
} }
}
@Override
public void createStructures(BiomeManager biomemanager, IChunkAccess ichunkaccess, net.minecraft.server.ChunkGenerator<?> chunkgenerator, DefinedStructureManager definedstructuremanager) {
if (generator.shouldGenerateStructures()) { if (generator.shouldGenerateStructures()) {
// Vanilla only uses biome at block 9 (see createStructures). // Still need a way of getting the biome of this chunk to pass to createStructures
// We don't use BiomeGrid as another aspect of generation may try and get from a chunk somewhere else. // Using default biomes for now.
final BiomeBase biome = biomegrid.biome.getBiome(9 >> 2, 0, 9 >> 2); delegate.createStructures(biomemanager, ichunkaccess, chunkgenerator, definedstructuremanager);
delegate.createStructures(new BiomeManager(null, 0, null) {
@Override
public BiomeManager a(WorldChunkManager worldchunkmanager) {
return this;
}
@Override
public BiomeBase a(BlockPosition blockposition) {
return biome;
}
}, ichunkaccess, chunkgenerator, definedstructuremanager);
} }
} }