-
Notifications
You must be signed in to change notification settings - Fork 98
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix Sodium 0.5 incompatibility (#178)
* Fix Sodium 0.5 compatibility * Compare against Sodium's minor version * Check if Sodium >=0.5 instead * Ensure Sodium mixin doesn't crash in production * Applied licenses * why did gradle use a broken symbol? * Attempt improving dynamic light update fluidity in Sodium 0.5.x * Another attempt to improve light fluidity with Sodium 0.5.x * Revert "why did gradle use a broken symbol?" This reverts commit a2f6f58. * Revert "Applied licenses" This reverts commit 68f504f * Use actual copyright symbol
- Loading branch information
Showing
9 changed files
with
168 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
36 changes: 36 additions & 0 deletions
36
src/main/java/dev/lambdaurora/lambdynlights/mixin/sodium/ArrayLightDataCacheMixin.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
/* | ||
* Copyright © 2023 LambdAurora <[email protected]> | ||
* | ||
* This file is part of LambDynamicLights. | ||
* | ||
* Licensed under the MIT license. For more information, | ||
* see the LICENSE file. | ||
*/ | ||
|
||
package dev.lambdaurora.lambdynlights.mixin.sodium; | ||
|
||
import dev.lambdaurora.lambdynlights.LambDynLights; | ||
import dev.lambdaurora.lambdynlights.util.SodiumDynamicLightHandler; | ||
import me.jellysquid.mods.sodium.client.model.light.data.LightDataAccess; | ||
import org.spongepowered.asm.mixin.Dynamic; | ||
import org.spongepowered.asm.mixin.Mixin; | ||
import org.spongepowered.asm.mixin.Pseudo; | ||
import org.spongepowered.asm.mixin.injection.At; | ||
import org.spongepowered.asm.mixin.injection.Inject; | ||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; | ||
|
||
@Pseudo | ||
@Mixin(targets = "me.jellysquid.mods.sodium.client.model.light.data.ArrayLightDataCache", remap = false) | ||
public abstract class ArrayLightDataCacheMixin extends LightDataAccess { | ||
@Dynamic | ||
@Inject(method = "get(III)I", at = @At("HEAD")) | ||
private void lambdynlights$storeLightPos(int x, int y, int z, CallbackInfoReturnable<Integer> cir) { | ||
if (!LambDynLights.get().config.getDynamicLightsMode().isEnabled()) | ||
return; | ||
|
||
// Store the current light position. | ||
// This is possible under smooth lighting scenarios, because AoFaceData in Sodium runs a get() call | ||
// before getting the lightmap. | ||
SodiumDynamicLightHandler.lambdynlights$pos.get().set(x, y, z); | ||
} | ||
} |
32 changes: 32 additions & 0 deletions
32
src/main/java/dev/lambdaurora/lambdynlights/mixin/sodium/FlatLightPipelineMixin.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
/* | ||
* Copyright © 2023 LambdAurora <[email protected]> | ||
* | ||
* This file is part of LambDynamicLights. | ||
* | ||
* Licensed under the MIT license. For more information, | ||
* see the LICENSE file. | ||
*/ | ||
|
||
package dev.lambdaurora.lambdynlights.mixin.sodium; | ||
|
||
import dev.lambdaurora.lambdynlights.util.SodiumDynamicLightHandler; | ||
import net.minecraft.util.math.BlockPos; | ||
import net.minecraft.util.math.Direction; | ||
import org.spongepowered.asm.mixin.Dynamic; | ||
import org.spongepowered.asm.mixin.Mixin; | ||
import org.spongepowered.asm.mixin.Pseudo; | ||
import org.spongepowered.asm.mixin.injection.At; | ||
import org.spongepowered.asm.mixin.injection.Inject; | ||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; | ||
import org.spongepowered.asm.mixin.injection.callback.LocalCapture; | ||
|
||
@Pseudo | ||
@Mixin(targets = "me.jellysquid.mods.sodium.client.model.light.flat.FlatLightPipeline", remap = false) | ||
public abstract class FlatLightPipelineMixin { | ||
@Dynamic | ||
@Inject(method = "getOffsetLightmap", at = @At(value = "RETURN", ordinal = 1), remap = false, locals = LocalCapture.CAPTURE_FAILHARD, cancellable = true) | ||
private void lambdynlights$getLightmap(BlockPos pos, Direction face, CallbackInfoReturnable<Integer> cir, int word, int adjWord) { | ||
int lightmap = SodiumDynamicLightHandler.lambdynlights$getLightmap(pos, adjWord, cir.getReturnValueI()); | ||
cir.setReturnValue(lightmap); | ||
} | ||
} |
29 changes: 29 additions & 0 deletions
29
src/main/java/dev/lambdaurora/lambdynlights/mixin/sodium/LightDataAccessMixin.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
/* | ||
* Copyright © 2023 LambdAurora <[email protected]> | ||
* | ||
* This file is part of LambDynamicLights. | ||
* | ||
* Licensed under the MIT license. For more information, | ||
* see the LICENSE file. | ||
*/ | ||
|
||
package dev.lambdaurora.lambdynlights.mixin.sodium; | ||
|
||
import dev.lambdaurora.lambdynlights.util.SodiumDynamicLightHandler; | ||
import org.spongepowered.asm.mixin.Dynamic; | ||
import org.spongepowered.asm.mixin.Mixin; | ||
import org.spongepowered.asm.mixin.Pseudo; | ||
import org.spongepowered.asm.mixin.injection.At; | ||
import org.spongepowered.asm.mixin.injection.Inject; | ||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; | ||
|
||
@Pseudo | ||
@Mixin(targets = "me.jellysquid.mods.sodium.client.model.light.data.LightDataAccess", remap = false) | ||
public abstract class LightDataAccessMixin { | ||
@Dynamic | ||
@Inject(method = "getLightmap", at = @At("RETURN"), remap = false, cancellable = true) | ||
private static void lambdynlights$getLightmap(int word, CallbackInfoReturnable<Integer> cir) { | ||
int lightmap = SodiumDynamicLightHandler.lambdynlights$getLightmap(SodiumDynamicLightHandler.lambdynlights$pos.get(), word, cir.getReturnValueI()); | ||
cir.setReturnValue(lightmap); | ||
} | ||
} |
35 changes: 35 additions & 0 deletions
35
src/main/java/dev/lambdaurora/lambdynlights/util/SodiumDynamicLightHandler.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
/* | ||
* Copyright © 2023 LambdAurora <[email protected]> | ||
* | ||
* This file is part of LambDynamicLights. | ||
* | ||
* Licensed under the MIT license. For more information, | ||
* see the LICENSE file. | ||
*/ | ||
|
||
package dev.lambdaurora.lambdynlights.util; | ||
|
||
import dev.lambdaurora.lambdynlights.LambDynLights; | ||
import me.jellysquid.mods.sodium.client.model.light.data.LightDataAccess; | ||
import net.minecraft.util.math.BlockPos; | ||
import org.jetbrains.annotations.ApiStatus; | ||
|
||
@ApiStatus.Internal | ||
public interface SodiumDynamicLightHandler { | ||
// Stores the current light position being used by ArrayLightDataCache#get | ||
// We use ThreadLocal because Sodium's chunk builder is multithreaded, otherwise it will break | ||
// catastrophically. | ||
ThreadLocal<BlockPos.Mutable> lambdynlights$pos = ThreadLocal.withInitial(BlockPos.Mutable::new); | ||
|
||
static int lambdynlights$getLightmap(BlockPos pos, int word, int lightmap) { | ||
if (!LambDynLights.get().config.getDynamicLightsMode().isEnabled()) | ||
return lightmap; | ||
|
||
// Equivalent to world.getBlockState(pos).isOpaqueFullCube(world, pos) | ||
if (LightDataAccess.unpackFO(word)) | ||
return lightmap; | ||
|
||
double dynamic = LambDynLights.get().getDynamicLightLevel(pos); | ||
return LambDynLights.get().getLightmapWithDynamicLight(dynamic, lightmap); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters