Merge pull request #45 from davidalb97/main

Migrated BetterNether's PR BetterNether/pull/437 into BCLib
This commit is contained in:
paulevsGitch 2021-11-20 18:57:13 +03:00 committed by GitHub
commit 8ea432bc19
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 41 additions and 0 deletions

View file

@ -0,0 +1,40 @@
package ru.bclib.mixin.common;
import net.minecraft.core.BlockPos;
import net.minecraft.core.SectionPos;
import net.minecraft.world.level.chunk.DataLayer;
import net.minecraft.world.level.lighting.LayerLightSectionStorage;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.Shadow;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
@Mixin(LayerLightSectionStorage.class)
public class LayerLightSectionStorageMixin {
@Shadow
protected DataLayer getDataLayer(long sectionPos, boolean cached) {
return null;
}
@Inject(method = "getStoredLevel", at = @At(value = "HEAD"), cancellable = true)
private void lightFix(long blockPos, CallbackInfoReturnable<Integer> info) {
try {
long m = SectionPos.blockToSection(blockPos);
DataLayer dataLayer = this.getDataLayer(m, true);
info.setReturnValue(
dataLayer.get(
SectionPos.sectionRelative(BlockPos.getX(blockPos)),
SectionPos.sectionRelative(BlockPos.getY(blockPos)),
SectionPos.sectionRelative(BlockPos.getZ(blockPos))
)
);
info.cancel();
} catch (Exception e) {
info.setReturnValue(0);
info.cancel();
}
}
}

View file

@ -20,6 +20,7 @@
"MinecraftServerMixin", "MinecraftServerMixin",
"PistonBaseBlockMixin", "PistonBaseBlockMixin",
"WorldGenRegionMixin", "WorldGenRegionMixin",
"LayerLightSectionStorageMixin",
"DimensionTypeMixin", "DimensionTypeMixin",
"RecipeManagerMixin", "RecipeManagerMixin",
"CraftingMenuMixin", "CraftingMenuMixin",