Merge remote-tracking branch 'origin/master'
This commit is contained in:
commit
aac3c10a46
6 changed files with 83 additions and 3 deletions
|
@ -39,6 +39,8 @@ import ru.betterend.world.surface.SurfaceBuilders;
|
||||||
public class BetterEnd implements ModInitializer {
|
public class BetterEnd implements ModInitializer {
|
||||||
public static final String MOD_ID = "betterend";
|
public static final String MOD_ID = "betterend";
|
||||||
public static final Logger LOGGER = Logger.get();
|
public static final Logger LOGGER = Logger.get();
|
||||||
|
private static boolean hasHydrogen;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onInitialize() {
|
public void onInitialize() {
|
||||||
EndPortals.loadPortals();
|
EndPortals.loadPortals();
|
||||||
|
@ -70,6 +72,7 @@ public class BetterEnd implements ModInitializer {
|
||||||
if (hasGuideBook()) {
|
if (hasGuideBook()) {
|
||||||
GuideBookItem.register();
|
GuideBookItem.register();
|
||||||
}
|
}
|
||||||
|
hasHydrogen = FabricLoader.getInstance().isModLoaded("hydrogen");
|
||||||
|
|
||||||
FabricLoader.getInstance().getEntrypoints("betterend", BetterEndPlugin.class).forEach(BetterEndPlugin::register);
|
FabricLoader.getInstance().getEntrypoints("betterend", BetterEndPlugin.class).forEach(BetterEndPlugin::register);
|
||||||
Configs.saveConfigs();
|
Configs.saveConfigs();
|
||||||
|
@ -88,6 +91,10 @@ public class BetterEnd implements ModInitializer {
|
||||||
return FabricLoader.getInstance().isModLoaded("patchouli");
|
return FabricLoader.getInstance().isModLoaded("patchouli");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static boolean hasHydrogen() {
|
||||||
|
return hasHydrogen;
|
||||||
|
}
|
||||||
|
|
||||||
public static ResourceLocation makeID(String path) {
|
public static ResourceLocation makeID(String path) {
|
||||||
return new ResourceLocation(MOD_ID, path);
|
return new ResourceLocation(MOD_ID, path);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,17 @@
|
||||||
package ru.betterend.mixin.common;
|
package ru.betterend.mixin.common;
|
||||||
|
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
import org.spongepowered.asm.mixin.Final;
|
import org.spongepowered.asm.mixin.Final;
|
||||||
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 net.minecraft.core.BlockPos;
|
import net.minecraft.core.BlockPos;
|
||||||
|
import net.minecraft.util.BitStorage;
|
||||||
import net.minecraft.util.Mth;
|
import net.minecraft.util.Mth;
|
||||||
import net.minecraft.world.level.biome.Biome;
|
import net.minecraft.world.level.biome.Biome;
|
||||||
import net.minecraft.world.level.chunk.ChunkBiomeContainer;
|
import net.minecraft.world.level.chunk.ChunkBiomeContainer;
|
||||||
|
import ru.betterend.BetterEnd;
|
||||||
import ru.betterend.interfaces.IBiomeArray;
|
import ru.betterend.interfaces.IBiomeArray;
|
||||||
|
|
||||||
@Mixin(ChunkBiomeContainer.class)
|
@Mixin(ChunkBiomeContainer.class)
|
||||||
|
@ -34,6 +38,42 @@ public class ChunkBiomeContainerMixin implements IBiomeArray {
|
||||||
int biomeY = pos.getY() >> 2;
|
int biomeY = pos.getY() >> 2;
|
||||||
int biomeZ = pos.getZ() >> 2;
|
int biomeZ = pos.getZ() >> 2;
|
||||||
int index = be_getArrayIndex(biomeX, biomeY, biomeZ);
|
int index = be_getArrayIndex(biomeX, biomeY, biomeZ);
|
||||||
|
|
||||||
|
if (BetterEnd.hasHydrogen()) {
|
||||||
|
try {
|
||||||
|
ChunkBiomeContainer self = (ChunkBiomeContainer) (Object) this;
|
||||||
|
BitStorage storage = be_getHydrogenStorage(self);
|
||||||
|
Biome[] palette = be_getHydrogenPalette(self);
|
||||||
|
int paletteIndex = be_getHydrogenPaletteIndex(biome, palette);
|
||||||
|
if (paletteIndex == -1) {
|
||||||
|
Biome[] newPalette = new Biome[palette.length + 1];
|
||||||
|
System.arraycopy(palette, 0, newPalette, 0, palette.length);
|
||||||
|
paletteIndex = palette.length;
|
||||||
|
palette = newPalette;
|
||||||
|
palette[paletteIndex] = biome;
|
||||||
|
be_setHydrogenPalette(self, palette);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
storage.set(index, paletteIndex);
|
||||||
|
}
|
||||||
|
catch (Exception e) {
|
||||||
|
int size = storage.getSize();
|
||||||
|
int bits = Mth.ceillog2(palette.length);
|
||||||
|
BitStorage newStorage = new BitStorage(bits, size);
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
|
newStorage.set(i, storage.get(i));
|
||||||
|
}
|
||||||
|
storage = newStorage;
|
||||||
|
storage.set(index, paletteIndex);
|
||||||
|
be_setHydrogenStorage(self, storage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception e) {
|
||||||
|
BetterEnd.LOGGER.warning(e.getLocalizedMessage());
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
biomes[index] = biome;
|
biomes[index] = biome;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,4 +83,37 @@ public class ChunkBiomeContainerMixin implements IBiomeArray {
|
||||||
int k = biomeZ & HORIZONTAL_MASK;
|
int k = biomeZ & HORIZONTAL_MASK;
|
||||||
return j << WIDTH_BITS + WIDTH_BITS | k << WIDTH_BITS | i;
|
return j << WIDTH_BITS + WIDTH_BITS | k << WIDTH_BITS | i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Field be_getField(String name) throws Exception {
|
||||||
|
Field field = ChunkBiomeContainer.class.getDeclaredField(name);
|
||||||
|
field.setAccessible(true);
|
||||||
|
return field;
|
||||||
|
}
|
||||||
|
|
||||||
|
private BitStorage be_getHydrogenStorage(ChunkBiomeContainer container) throws Exception {
|
||||||
|
return (BitStorage) be_getField("intArray").get(container);
|
||||||
|
}
|
||||||
|
|
||||||
|
private Biome[] be_getHydrogenPalette(ChunkBiomeContainer container) throws Exception {
|
||||||
|
return (Biome[]) be_getField("palette").get(container);
|
||||||
|
}
|
||||||
|
|
||||||
|
private int be_getHydrogenPaletteIndex(Biome biome, Biome[] palette) {
|
||||||
|
int index = -1;
|
||||||
|
for (int i = 0; i < palette.length; i++) {
|
||||||
|
if (palette[i] == biome) {
|
||||||
|
index = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return index;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void be_setHydrogenPalette(ChunkBiomeContainer container, Biome[] palette) throws Exception {
|
||||||
|
be_getField("palette").set(container, palette);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void be_setHydrogenStorage(ChunkBiomeContainer container, BitStorage storage) throws Exception {
|
||||||
|
be_getField("intArray").set(container, storage);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -230,7 +230,7 @@ public class EndBiomes {
|
||||||
* @param server - {@link MinecraftServer}
|
* @param server - {@link MinecraftServer}
|
||||||
*/
|
*/
|
||||||
public static void initRegistry(MinecraftServer server) {
|
public static void initRegistry(MinecraftServer server) {
|
||||||
if (biomeRegistry == null) {
|
if (biomeRegistry == null || biomeRegistry == BuiltinRegistries.BIOME) {
|
||||||
biomeRegistry = server.registryAccess().registryOrThrow(Registry.BIOME_REGISTRY);
|
biomeRegistry = server.registryAccess().registryOrThrow(Registry.BIOME_REGISTRY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -257,7 +257,7 @@ public class EndFeatures {
|
||||||
addFeature(ENDER_ORE, features);
|
addFeature(ENDER_ORE, features);
|
||||||
addFeature(CRASHED_SHIP, features);
|
addFeature(CRASHED_SHIP, features);
|
||||||
|
|
||||||
if (EndBiomes.getBiome(id).hasCaves()) {
|
if (EndBiomes.getBiome(id).hasCaves() && !EndBiomes.VOID_BIOMES.containsImmutable(id)) {
|
||||||
addFeature(ROUND_CAVE, features);
|
addFeature(ROUND_CAVE, features);
|
||||||
addFeature(TUNEL_CAVE, features);
|
addFeature(TUNEL_CAVE, features);
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,7 @@ public class BiomeIceStarfield extends EndBiome {
|
||||||
.setFogDensity(2.2F)
|
.setFogDensity(2.2F)
|
||||||
.setFoliageColor(193, 244, 244)
|
.setFoliageColor(193, 244, 244)
|
||||||
.setGenChance(0.25F)
|
.setGenChance(0.25F)
|
||||||
|
.setCaves(false)
|
||||||
.setParticles(EndParticles.SNOWFLAKE, 0.002F)
|
.setParticles(EndParticles.SNOWFLAKE, 0.002F)
|
||||||
.addStructureFeature(EndStructures.GIANT_ICE_STAR)
|
.addStructureFeature(EndStructures.GIANT_ICE_STAR)
|
||||||
.addFeature(EndFeatures.ICE_STAR)
|
.addFeature(EndFeatures.ICE_STAR)
|
||||||
|
|
|
@ -13,7 +13,6 @@ public class PaintedMountainsBiome extends EndBiome {
|
||||||
super(new BiomeDefinition("painted_mountains")
|
super(new BiomeDefinition("painted_mountains")
|
||||||
.setFogColor(226, 239, 168)
|
.setFogColor(226, 239, 168)
|
||||||
.setFogDensity(2)
|
.setFogDensity(2)
|
||||||
.setCaves(false)
|
|
||||||
.setWaterAndFogColor(192, 180, 131)
|
.setWaterAndFogColor(192, 180, 131)
|
||||||
.setMusic(EndSounds.MUSIC_OPENSPACE)
|
.setMusic(EndSounds.MUSIC_OPENSPACE)
|
||||||
.setLoop(EndSounds.AMBIENT_DUST_WASTELANDS)
|
.setLoop(EndSounds.AMBIENT_DUST_WASTELANDS)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue