Automaticly ingest chunks created by chunky
This commit is contained in:
11
build.gradle
11
build.gradle
@@ -62,8 +62,15 @@ dependencies {
|
|||||||
modCompileOnly("maven.modrinth:starlight:1.1.3+1.20.4")
|
modCompileOnly("maven.modrinth:starlight:1.1.3+1.20.4")
|
||||||
//modCompileOnly("maven.modrinth:immersiveportals:v5.1.7-mc1.20.4")
|
//modCompileOnly("maven.modrinth:immersiveportals:v5.1.7-mc1.20.4")
|
||||||
modCompileOnly("maven.modrinth:vivecraft:1.20.4-1.1.6-fabric")
|
modCompileOnly("maven.modrinth:vivecraft:1.20.4-1.1.6-fabric")
|
||||||
modCompileOnly("maven.modrinth:chunky:1.3.138")
|
|
||||||
modRuntimeOnly("maven.modrinth:chunky:1.3.138")
|
modCompileOnly("maven.modrinth:chunky:1.4.16-fabric")
|
||||||
|
modRuntimeOnly("maven.modrinth:chunky:1.4.16-fabric")
|
||||||
|
|
||||||
|
modRuntimeOnly("maven.modrinth:spark:1.10.73-fabric")
|
||||||
|
modRuntimeOnly("maven.modrinth:fabric-permissions-api:0.3.1")
|
||||||
|
//modRuntimeOnly("maven.modrinth:nsight-loader:1.2.0")
|
||||||
|
|
||||||
|
modImplementation('io.github.douira:glsl-transformer:2.0.1')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,44 @@
|
|||||||
|
package me.cortex.voxy.client.mixin.chunky;
|
||||||
|
|
||||||
|
import com.llamalad7.mixinextras.injector.wrapoperation.Operation;
|
||||||
|
import com.llamalad7.mixinextras.injector.wrapoperation.WrapOperation;
|
||||||
|
import me.cortex.voxy.client.Voxy;
|
||||||
|
import me.cortex.voxy.client.config.VoxyConfig;
|
||||||
|
import me.cortex.voxy.client.core.IGetVoxelCore;
|
||||||
|
import net.minecraft.client.MinecraftClient;
|
||||||
|
import net.minecraft.client.util.math.MatrixStack;
|
||||||
|
import net.minecraft.server.world.ChunkHolder;
|
||||||
|
import net.minecraft.server.world.OptionalChunk;
|
||||||
|
import net.minecraft.server.world.ServerChunkLoadingManager;
|
||||||
|
import net.minecraft.server.world.ServerWorld;
|
||||||
|
import net.minecraft.world.chunk.Chunk;
|
||||||
|
import net.minecraft.world.chunk.ChunkStatus;
|
||||||
|
import net.minecraft.world.chunk.WorldChunk;
|
||||||
|
import org.joml.Matrix4f;
|
||||||
|
import org.popcraft.chunky.platform.FabricWorld;
|
||||||
|
import org.spongepowered.asm.mixin.Final;
|
||||||
|
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.Redirect;
|
||||||
|
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
import java.util.concurrent.Executor;
|
||||||
|
import java.util.function.BiConsumer;
|
||||||
|
|
||||||
|
@Mixin(FabricWorld.class)
|
||||||
|
public class MixinFabricWorld {
|
||||||
|
@WrapOperation(method = "getChunkAtAsync", at = @At(value = "INVOKE", target = "Lnet/minecraft/server/world/ChunkHolder;load(Lnet/minecraft/world/chunk/ChunkStatus;Lnet/minecraft/server/world/ServerChunkLoadingManager;)Ljava/util/concurrent/CompletableFuture;"))
|
||||||
|
private CompletableFuture<OptionalChunk<Chunk>> captureGeneratedChunk(ChunkHolder instance, ChunkStatus chunkStatus, ServerChunkLoadingManager serverChunkLoadingManager, Operation<CompletableFuture<OptionalChunk<Chunk>>> original) {
|
||||||
|
var future = original.call(instance, chunkStatus, serverChunkLoadingManager);
|
||||||
|
return future.thenApplyAsync(res->{
|
||||||
|
res.ifPresent(chunk -> {
|
||||||
|
var core = ((IGetVoxelCore)(MinecraftClient.getInstance().worldRenderer)).getVoxelCore();
|
||||||
|
if (core != null && VoxyConfig.CONFIG.ingestEnabled) {
|
||||||
|
core.enqueueIngest((WorldChunk) chunk);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return res;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -15,5 +15,8 @@
|
|||||||
],
|
],
|
||||||
"injectors": {
|
"injectors": {
|
||||||
"defaultRequire": 1
|
"defaultRequire": 1
|
||||||
}
|
},
|
||||||
|
"mixins": [
|
||||||
|
"chunky.MixinFabricWorld"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user