Fixed some bootup errors
This commit is contained in:
parent
6c89c76c26
commit
6b63be32b0
6 changed files with 66 additions and 28 deletions
|
@ -0,0 +1,9 @@
|
||||||
|
package ru.betterend.interfaces;
|
||||||
|
|
||||||
|
import net.minecraft.world.level.levelgen.feature.ConfiguredStructureFeature;
|
||||||
|
import net.minecraft.world.level.levelgen.feature.StructureFeature;
|
||||||
|
import net.minecraft.world.level.levelgen.feature.configurations.NoneFeatureConfiguration;
|
||||||
|
|
||||||
|
public interface StructureFeaturesAccessor {
|
||||||
|
ConfiguredStructureFeature<NoneFeatureConfiguration, ? extends StructureFeature<NoneFeatureConfiguration>> getEND_CITY();
|
||||||
|
}
|
|
@ -1,13 +1,17 @@
|
||||||
package ru.betterend.mixin.common;
|
package ru.betterend.mixin.common;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
|
import java.util.Random;
|
||||||
|
|
||||||
import net.minecraft.world.level.ChunkPos;
|
import net.minecraft.world.level.ChunkPos;
|
||||||
import net.minecraft.world.level.LevelHeightAccessor;
|
import net.minecraft.world.level.LevelHeightAccessor;
|
||||||
import net.minecraft.world.level.biome.Biome;
|
|
||||||
import net.minecraft.world.level.biome.BiomeSource;
|
|
||||||
import net.minecraft.world.level.chunk.ChunkGenerator;
|
import net.minecraft.world.level.chunk.ChunkGenerator;
|
||||||
|
import net.minecraft.world.level.levelgen.LegacyRandomSource;
|
||||||
import net.minecraft.world.level.levelgen.WorldgenRandom;
|
import net.minecraft.world.level.levelgen.WorldgenRandom;
|
||||||
import net.minecraft.world.level.levelgen.feature.EndCityFeature;
|
import net.minecraft.world.level.levelgen.feature.EndCityFeature;
|
||||||
import net.minecraft.world.level.levelgen.feature.configurations.NoneFeatureConfiguration;
|
import net.minecraft.world.level.levelgen.feature.configurations.NoneFeatureConfiguration;
|
||||||
|
import net.minecraft.world.level.levelgen.structure.pieces.PieceGenerator;
|
||||||
|
import net.minecraft.world.level.levelgen.structure.pieces.PieceGeneratorSupplier;
|
||||||
import org.spongepowered.asm.mixin.Mixin;
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
import org.spongepowered.asm.mixin.Shadow;
|
import org.spongepowered.asm.mixin.Shadow;
|
||||||
import org.spongepowered.asm.mixin.injection.At;
|
import org.spongepowered.asm.mixin.injection.At;
|
||||||
|
@ -17,20 +21,24 @@ import ru.betterend.world.generator.GeneratorOptions;
|
||||||
|
|
||||||
@Mixin(EndCityFeature.class)
|
@Mixin(EndCityFeature.class)
|
||||||
public class EndCityFeatureMixin {
|
public class EndCityFeatureMixin {
|
||||||
@Inject(method = "isFeatureChunk", at = @At("HEAD"), cancellable = true)
|
@Inject(method = "pieceGeneratorSupplier", at = @At("HEAD"), cancellable = true)
|
||||||
private void be_isFeatureChunk(ChunkGenerator chunkGenerator, BiomeSource biomeSource, long l, WorldgenRandom chunkRandom, ChunkPos pos, Biome biome, ChunkPos chunkPos, NoneFeatureConfiguration defaultFeatureConfig, LevelHeightAccessor levelHeightAccessor, CallbackInfoReturnable<Boolean> info) {
|
private static void be_isFeatureChunk(PieceGeneratorSupplier.Context<NoneFeatureConfiguration> context, CallbackInfoReturnable<Optional<PieceGenerator<NoneFeatureConfiguration>>> info) {
|
||||||
|
final ChunkPos pos = context.chunkPos();
|
||||||
|
final ChunkGenerator chunkGenerator = context.chunkGenerator();
|
||||||
|
final LevelHeightAccessor levelHeightAccessor = context.heightAccessor();
|
||||||
|
//TODO: 1.18 that is a different random source!
|
||||||
|
Random chunkRandom = new WorldgenRandom(new LegacyRandomSource(pos.x*pos.z));
|
||||||
|
|
||||||
if (GeneratorOptions.useNewGenerator()) {
|
if (GeneratorOptions.useNewGenerator()) {
|
||||||
int chance = GeneratorOptions.getEndCityFailChance();
|
int chance = GeneratorOptions.getEndCityFailChance();
|
||||||
if (chance == 0) {
|
if (chance == 0 || chunkRandom.nextInt(chance) == 0) {
|
||||||
info.setReturnValue(getYPositionForFeature(pos, chunkGenerator, levelHeightAccessor) >= 60);
|
if (!(getYPositionForFeature(pos, chunkGenerator, levelHeightAccessor) >= 60)){
|
||||||
info.cancel();
|
info.cancel();
|
||||||
}
|
info.setReturnValue(Optional.empty());
|
||||||
else if (chunkRandom.nextInt(chance) == 0) {
|
}
|
||||||
info.setReturnValue(getYPositionForFeature(pos, chunkGenerator, levelHeightAccessor) >= 60);
|
|
||||||
info.cancel();
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
info.setReturnValue(false);
|
info.setReturnValue(Optional.empty());
|
||||||
info.cancel();
|
info.cancel();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
package ru.betterend.mixin.common;
|
package ru.betterend.mixin.common;
|
||||||
|
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
|
import net.minecraft.core.Registry;
|
||||||
import net.minecraft.world.level.biome.BiomeSource;
|
import net.minecraft.world.level.biome.BiomeSource;
|
||||||
import net.minecraft.world.level.chunk.ChunkGenerator;
|
import net.minecraft.world.level.chunk.ChunkGenerator;
|
||||||
import net.minecraft.world.level.levelgen.NoiseBasedChunkGenerator;
|
import net.minecraft.world.level.levelgen.NoiseBasedChunkGenerator;
|
||||||
|
@ -11,11 +14,8 @@ import org.spongepowered.asm.mixin.Shadow;
|
||||||
import org.spongepowered.asm.mixin.injection.At;
|
import org.spongepowered.asm.mixin.injection.At;
|
||||||
import org.spongepowered.asm.mixin.injection.Inject;
|
import org.spongepowered.asm.mixin.injection.Inject;
|
||||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||||
import ru.betterend.world.generator.GeneratorOptions;
|
|
||||||
import ru.betterend.world.generator.TerrainGenerator;
|
import ru.betterend.world.generator.TerrainGenerator;
|
||||||
|
|
||||||
import java.util.function.Supplier;
|
|
||||||
|
|
||||||
@Mixin(NoiseBasedChunkGenerator.class)
|
@Mixin(NoiseBasedChunkGenerator.class)
|
||||||
public abstract class NoiseBasedChunkGeneratorMixin extends ChunkGenerator {
|
public abstract class NoiseBasedChunkGeneratorMixin extends ChunkGenerator {
|
||||||
@Final
|
@Final
|
||||||
|
@ -26,16 +26,17 @@ public abstract class NoiseBasedChunkGeneratorMixin extends ChunkGenerator {
|
||||||
super(populationSource, biomeSource, structuresConfig, worldSeed);
|
super(populationSource, biomeSource, structuresConfig, worldSeed);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Inject(method = "<init>(Lnet/minecraft/world/level/biome/BiomeSource;Lnet/minecraft/world/level/biome/BiomeSource;JLjava/util/function/Supplier;)V", at = @At("TAIL"))
|
@Inject(method = "<init>(Lnet/minecraft/core/Registry;Lnet/minecraft/world/level/biome/BiomeSource;Lnet/minecraft/world/level/biome/BiomeSource;JLjava/util/function/Supplier;)V", at = @At("TAIL"))
|
||||||
private void beOnInit(BiomeSource populationSource, BiomeSource biomeSource, long seed, Supplier<NoiseGeneratorSettings> settings, CallbackInfo info) {
|
private void beOnInit(Registry registry, BiomeSource biomeSource, BiomeSource biomeSource2, long seed, Supplier supplier, CallbackInfo ci) {
|
||||||
TerrainGenerator.initNoise(seed);
|
TerrainGenerator.initNoise(seed);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Inject(method = "fillNoiseColumn([DIIII)V", at = @At("HEAD"), cancellable = true, allow = 2)
|
//TODO: 1.18 Find anothe rplace for this
|
||||||
private void be_fillNoiseColumn(double[] buffer, int x, int z, int k, int l, CallbackInfo info) {
|
// @Inject(method = "fillNoiseColumn([DIIII)V", at = @At("HEAD"), cancellable = true, allow = 2)
|
||||||
if (GeneratorOptions.useNewGenerator() && settings.get().stable(NoiseGeneratorSettings.END)) {
|
// private void be_fillNoiseColumn(double[] buffer, int x, int z, int k, int l, CallbackInfo info) {
|
||||||
TerrainGenerator.fillTerrainDensity(buffer, x, z, getBiomeSource());
|
// if (GeneratorOptions.useNewGenerator() && settings.get().stable(NoiseGeneratorSettings.END)) {
|
||||||
info.cancel();
|
// TerrainGenerator.fillTerrainDensity(buffer, x, z, getBiomeSource());
|
||||||
}
|
// info.cancel();
|
||||||
}
|
// }
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,19 @@
|
||||||
|
package ru.betterend.mixin.common;
|
||||||
|
|
||||||
|
import net.minecraft.data.worldgen.StructureFeatures;
|
||||||
|
import net.minecraft.world.level.levelgen.feature.ConfiguredStructureFeature;
|
||||||
|
import net.minecraft.world.level.levelgen.feature.StructureFeature;
|
||||||
|
import net.minecraft.world.level.levelgen.feature.configurations.NoneFeatureConfiguration;
|
||||||
|
import org.spongepowered.asm.mixin.Final;
|
||||||
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
|
import org.spongepowered.asm.mixin.Shadow;
|
||||||
|
import ru.betterend.interfaces.StructureFeaturesAccessor;
|
||||||
|
|
||||||
|
@Mixin(StructureFeatures.class)
|
||||||
|
public class StructureFeaturesMixin implements StructureFeaturesAccessor {
|
||||||
|
@Shadow @Final private static ConfiguredStructureFeature<NoneFeatureConfiguration, ? extends StructureFeature<NoneFeatureConfiguration>> END_CITY;
|
||||||
|
|
||||||
|
public ConfiguredStructureFeature<NoneFeatureConfiguration, ? extends StructureFeature<NoneFeatureConfiguration>> getEND_CITY(){
|
||||||
|
return END_CITY;
|
||||||
|
}
|
||||||
|
}
|
|
@ -9,9 +9,9 @@ import net.minecraft.world.level.biome.Biome;
|
||||||
import net.minecraft.world.level.block.Blocks;
|
import net.minecraft.world.level.block.Blocks;
|
||||||
import net.minecraft.world.level.levelgen.SurfaceRules;
|
import net.minecraft.world.level.levelgen.SurfaceRules;
|
||||||
import ru.bclib.api.biomes.BCLBiomeBuilder;
|
import ru.bclib.api.biomes.BCLBiomeBuilder;
|
||||||
import ru.bclib.interfaces.StructureFeaturesAccessor;
|
|
||||||
import ru.bclib.world.biomes.BCLBiome;
|
import ru.bclib.world.biomes.BCLBiome;
|
||||||
import ru.betterend.BetterEnd;
|
import ru.betterend.BetterEnd;
|
||||||
|
import ru.betterend.interfaces.StructureFeaturesAccessor;
|
||||||
import ru.betterend.registry.EndBlocks;
|
import ru.betterend.registry.EndBlocks;
|
||||||
import ru.betterend.registry.EndFeatures;
|
import ru.betterend.registry.EndFeatures;
|
||||||
import ru.betterend.registry.EndSounds;
|
import ru.betterend.registry.EndSounds;
|
||||||
|
@ -62,6 +62,7 @@ public class EndBiome extends BCLBiome {
|
||||||
biomeConfig.addCustomBuildData(builder);
|
biomeConfig.addCustomBuildData(builder);
|
||||||
EndFeatures.addDefaultFeatures(builder, biomeConfig.hasCaves());
|
EndFeatures.addDefaultFeatures(builder, biomeConfig.hasCaves());
|
||||||
|
|
||||||
|
|
||||||
EndBiome biome = builder.build(biomeConfig.getSupplier());
|
EndBiome biome = builder.build(biomeConfig.getSupplier());
|
||||||
biome.addCustomData("has_caves", biomeConfig.hasCaves());
|
biome.addCustomData("has_caves", biomeConfig.hasCaves());
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,6 @@
|
||||||
"package": "ru.betterend.mixin.common",
|
"package": "ru.betterend.mixin.common",
|
||||||
"compatibilityLevel": "JAVA_16",
|
"compatibilityLevel": "JAVA_16",
|
||||||
"mixins": [
|
"mixins": [
|
||||||
"BiomeGenerationSettingsAccessor",
|
|
||||||
"NoiseBasedChunkGeneratorMixin",
|
"NoiseBasedChunkGeneratorMixin",
|
||||||
"ChorusPlantFeatureMixin",
|
"ChorusPlantFeatureMixin",
|
||||||
"PlayerAdvancementsMixin",
|
"PlayerAdvancementsMixin",
|
||||||
|
@ -25,7 +24,8 @@
|
||||||
"MonsterMixin",
|
"MonsterMixin",
|
||||||
"EntityMixin",
|
"EntityMixin",
|
||||||
"PlayerMixin",
|
"PlayerMixin",
|
||||||
"SlimeMixin"
|
"SlimeMixin",
|
||||||
|
"StructureFeaturesMixin"
|
||||||
],
|
],
|
||||||
"injectors": {
|
"injectors": {
|
||||||
"defaultRequire": 1
|
"defaultRequire": 1
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue