From 94e792f25e4d987f2de9afdb5c87f7f5a6dd67e2 Mon Sep 17 00:00:00 2001 From: PepperCode1 <44146161+PepperCode1@users.noreply.github.com> Date: Fri, 16 Sep 2022 13:32:13 -0700 Subject: [PATCH] State restoration confusion - Do not wrap BeginFrameEvent and RenderStageEvent with GL restore state - Move GL state restoration into InstancingEngine - Remove BufferUploaderMixin - Add binding enum values to GlBufferType - Remove debugNormals config - Rename some occurrences of "world" to "level" --- .../java/com/jozufozu/flywheel/Flywheel.java | 2 +- ...{FlywheelWorld.java => FlywheelLevel.java} | 6 ++-- .../jozufozu/flywheel/backend/Backend.java | 18 +++++------ .../com/jozufozu/flywheel/backend/Loader.java | 6 ++-- .../jozufozu/flywheel/backend/RenderWork.java | 11 +++---- .../flywheel/backend/gl/GlStateTracker.java | 11 +++---- .../backend/gl/buffer/GlBufferType.java | 30 +++++++++-------- .../backend/instancing/InstanceWorld.java | 6 ++-- .../instancing/InstancedRenderDispatcher.java | 23 ++++++------- .../batching/BatchedMaterialGroup.java | 0 .../BlockEntityInstanceManager.java | 10 +++--- .../entity/EntityInstanceManager.java | 6 ++-- .../instancing/InstancingEngine.java | 13 +++++--- .../jozufozu/flywheel/config/FlwCommands.java | 32 ++++++++----------- .../jozufozu/flywheel/config/FlwConfig.java | 8 ----- .../core/virtual/VirtualRenderWorld.java | 4 +-- .../flywheel/event/ReloadRenderersEvent.java | 10 +++--- .../flywheel/mixin/BufferUploaderMixin.java | 28 ---------------- .../flywheel/mixin/LevelRendererMixin.java | 9 ++---- .../mixin/light/NetworkLightUpdateMixin.java | 6 ++-- src/main/resources/flywheel.mixins.json | 1 - 21 files changed, 99 insertions(+), 141 deletions(-) rename src/main/java/com/jozufozu/flywheel/api/{FlywheelWorld.java => FlywheelLevel.java} (61%) delete mode 100644 src/main/java/com/jozufozu/flywheel/backend/instancing/batching/BatchedMaterialGroup.java delete mode 100644 src/main/java/com/jozufozu/flywheel/mixin/BufferUploaderMixin.java diff --git a/src/main/java/com/jozufozu/flywheel/Flywheel.java b/src/main/java/com/jozufozu/flywheel/Flywheel.java index b239c2926..f00649f89 100644 --- a/src/main/java/com/jozufozu/flywheel/Flywheel.java +++ b/src/main/java/com/jozufozu/flywheel/Flywheel.java @@ -94,7 +94,7 @@ public class Flywheel { forgeEventBus.addListener(ForgeEvents::unloadWorld); forgeEventBus.addListener(ForgeEvents::tickLight); - forgeEventBus.addListener(EventPriority.LOWEST, RenderWork::onRenderWorldLast); + forgeEventBus.addListener(EventPriority.LOWEST, RenderWork::onRenderLevelLast); modEventBus.addListener(PartialModel::onModelRegistry); modEventBus.addListener(PartialModel::onModelBake); diff --git a/src/main/java/com/jozufozu/flywheel/api/FlywheelWorld.java b/src/main/java/com/jozufozu/flywheel/api/FlywheelLevel.java similarity index 61% rename from src/main/java/com/jozufozu/flywheel/api/FlywheelWorld.java rename to src/main/java/com/jozufozu/flywheel/api/FlywheelLevel.java index 968535ed0..de4e0c3ed 100644 --- a/src/main/java/com/jozufozu/flywheel/api/FlywheelWorld.java +++ b/src/main/java/com/jozufozu/flywheel/api/FlywheelLevel.java @@ -1,13 +1,13 @@ package com.jozufozu.flywheel.api; /** - * A marker interface custom worlds can override to indicate - * that block entities and entities inside the world should + * A marker interface custom levels can override to indicate + * that block entities and entities inside the level should * render with Flywheel. * * {@link net.minecraft.client.Minecraft#level Minecraft#level} is special cased and will support Flywheel by default. */ -public interface FlywheelWorld { +public interface FlywheelLevel { default boolean supportsFlywheel() { return true; } diff --git a/src/main/java/com/jozufozu/flywheel/backend/Backend.java b/src/main/java/com/jozufozu/flywheel/backend/Backend.java index b24df2eb6..9f70be07b 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/Backend.java +++ b/src/main/java/com/jozufozu/flywheel/backend/Backend.java @@ -3,7 +3,7 @@ package com.jozufozu.flywheel.backend; import org.jetbrains.annotations.Nullable; import org.slf4j.Logger; -import com.jozufozu.flywheel.api.FlywheelWorld; +import com.jozufozu.flywheel.api.FlywheelLevel; import com.jozufozu.flywheel.backend.gl.versioned.GlCompat; import com.jozufozu.flywheel.backend.instancing.ParallelTaskEngine; import com.jozufozu.flywheel.config.BackendType; @@ -61,21 +61,21 @@ public class Backend { return TYPE != BackendType.OFF; } - public static boolean canUseInstancing(@Nullable Level world) { - return isOn() && isFlywheelWorld(world); + public static boolean canUseInstancing(@Nullable Level level) { + return isOn() && isFlywheelLevel(level); } /** - * Used to avoid calling Flywheel functions on (fake) worlds that don't specifically support it. + * Used to avoid calling Flywheel functions on (fake) levels that don't specifically support it. */ - public static boolean isFlywheelWorld(@Nullable LevelAccessor world) { - if (world == null) return false; + public static boolean isFlywheelLevel(@Nullable LevelAccessor level) { + if (level == null) return false; - if (!world.isClientSide()) return false; + if (!level.isClientSide()) return false; - if (world instanceof FlywheelWorld && ((FlywheelWorld) world).supportsFlywheel()) return true; + if (level instanceof FlywheelLevel && ((FlywheelLevel) level).supportsFlywheel()) return true; - return world == Minecraft.getInstance().level; + return level == Minecraft.getInstance().level; } public static boolean isGameActive() { diff --git a/src/main/java/com/jozufozu/flywheel/backend/Loader.java b/src/main/java/com/jozufozu/flywheel/backend/Loader.java index d37b19a23..4fd27855a 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/Loader.java +++ b/src/main/java/com/jozufozu/flywheel/backend/Loader.java @@ -80,9 +80,9 @@ public class Loader implements ResourceManagerReloadListener { Backend.LOGGER.info("Compiled all programs in " + StringUtil.formatTime(compileEnd - compileStart)); - ClientLevel world = Minecraft.getInstance().level; - if (Backend.canUseInstancing(world)) { - InstancedRenderDispatcher.resetInstanceWorld(world); + ClientLevel level = Minecraft.getInstance().level; + if (Backend.canUseInstancing(level)) { + InstancedRenderDispatcher.resetInstanceLevel(level); } } diff --git a/src/main/java/com/jozufozu/flywheel/backend/RenderWork.java b/src/main/java/com/jozufozu/flywheel/backend/RenderWork.java index 48b5061ef..afa364056 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/RenderWork.java +++ b/src/main/java/com/jozufozu/flywheel/backend/RenderWork.java @@ -6,12 +6,11 @@ import java.util.concurrent.ConcurrentLinkedQueue; import net.minecraftforge.client.event.RenderLevelLastEvent; public class RenderWork { - private static final Queue runs = new ConcurrentLinkedQueue<>(); + private static final Queue RUNS = new ConcurrentLinkedQueue<>(); - - public static void onRenderWorldLast(RenderLevelLastEvent event) { - while (!runs.isEmpty()) { - runs.remove() + public static void onRenderLevelLast(RenderLevelLastEvent event) { + while (!RUNS.isEmpty()) { + RUNS.remove() .run(); } } @@ -20,6 +19,6 @@ public class RenderWork { * Queue work to be executed at the end of a frame */ public static void enqueue(Runnable run) { - runs.add(run); + RUNS.add(run); } } diff --git a/src/main/java/com/jozufozu/flywheel/backend/gl/GlStateTracker.java b/src/main/java/com/jozufozu/flywheel/backend/gl/GlStateTracker.java index 500537425..0dc4f4076 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/gl/GlStateTracker.java +++ b/src/main/java/com/jozufozu/flywheel/backend/gl/GlStateTracker.java @@ -7,13 +7,12 @@ import com.mojang.blaze3d.platform.GlStateManager; * Tracks bound buffers/vbos because GlStateManager doesn't do that for us. */ public class GlStateTracker { - - private static final int[] buffers = new int[GlBufferType.values().length]; + private static final int[] BUFFERS = new int[GlBufferType.values().length]; private static int vao; private static int program; public static int getBuffer(GlBufferType type) { - return buffers[type.ordinal()]; + return BUFFERS[type.ordinal()]; } public static int getVertexArray() { @@ -25,7 +24,7 @@ public class GlStateTracker { } public static void _setBuffer(GlBufferType type, int buffer) { - buffers[type.ordinal()] = buffer; + BUFFERS[type.ordinal()] = buffer; } public static void _setProgram(int id) { @@ -37,7 +36,7 @@ public class GlStateTracker { } public static State getRestoreState() { - return new State(buffers.clone(), vao, program); + return new State(BUFFERS.clone(), vao, program); } public record State(int[] buffers, int vao, int program) implements AutoCloseable { @@ -53,7 +52,7 @@ public class GlStateTracker { GlBufferType[] values = GlBufferType.values(); for (int i = 0; i < values.length; i++) { - if (buffers[i] != GlStateTracker.buffers[i]) { + if (buffers[i] != GlStateTracker.BUFFERS[i]) { GlStateManager._glBindBuffer(values[i].glEnum, buffers[i]); } } diff --git a/src/main/java/com/jozufozu/flywheel/backend/gl/buffer/GlBufferType.java b/src/main/java/com/jozufozu/flywheel/backend/gl/buffer/GlBufferType.java index ead96fb03..9592ef241 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/gl/buffer/GlBufferType.java +++ b/src/main/java/com/jozufozu/flywheel/backend/gl/buffer/GlBufferType.java @@ -12,25 +12,27 @@ import com.jozufozu.flywheel.backend.gl.GlStateTracker; import com.mojang.blaze3d.platform.GlStateManager; public enum GlBufferType { - ARRAY_BUFFER(GL15C.GL_ARRAY_BUFFER), - ELEMENT_ARRAY_BUFFER(GL15C.GL_ELEMENT_ARRAY_BUFFER), - PIXEL_PACK_BUFFER(GL21.GL_PIXEL_PACK_BUFFER), - PIXEL_UNPACK_BUFFER(GL21.GL_PIXEL_UNPACK_BUFFER), - TRANSFORM_FEEDBACK_BUFFER(GL30.GL_TRANSFORM_FEEDBACK_BUFFER), - UNIFORM_BUFFER(GL31.GL_UNIFORM_BUFFER), - TEXTURE_BUFFER(GL31.GL_TEXTURE_BUFFER), - COPY_READ_BUFFER(GL31.GL_COPY_READ_BUFFER), - COPY_WRITE_BUFFER(GL31.GL_COPY_WRITE_BUFFER), - DRAW_INDIRECT_BUFFER(GL40.GL_DRAW_INDIRECT_BUFFER), - ATOMIC_COUNTER_BUFFER(GL42.GL_ATOMIC_COUNTER_BUFFER), - DISPATCH_INDIRECT_BUFFER(GL43.GL_DISPATCH_INDIRECT_BUFFER), - SHADER_STORAGE_BUFFER(GL43.GL_SHADER_STORAGE_BUFFER), + ARRAY_BUFFER(GL15C.GL_ARRAY_BUFFER, GL15C.GL_ARRAY_BUFFER_BINDING), + ELEMENT_ARRAY_BUFFER(GL15C.GL_ELEMENT_ARRAY_BUFFER, GL15C.GL_ELEMENT_ARRAY_BUFFER_BINDING), + PIXEL_PACK_BUFFER(GL21.GL_PIXEL_PACK_BUFFER, GL21.GL_PIXEL_PACK_BUFFER_BINDING), + PIXEL_UNPACK_BUFFER(GL21.GL_PIXEL_UNPACK_BUFFER, GL21.GL_PIXEL_UNPACK_BUFFER_BINDING), + TRANSFORM_FEEDBACK_BUFFER(GL30.GL_TRANSFORM_FEEDBACK_BUFFER, GL30.GL_TRANSFORM_FEEDBACK_BUFFER_BINDING), + UNIFORM_BUFFER(GL31.GL_UNIFORM_BUFFER, GL31.GL_UNIFORM_BUFFER_BINDING), + TEXTURE_BUFFER(GL31.GL_TEXTURE_BUFFER, GL31.GL_TEXTURE_BUFFER), + COPY_READ_BUFFER(GL31.GL_COPY_READ_BUFFER, GL31.GL_COPY_READ_BUFFER), + COPY_WRITE_BUFFER(GL31.GL_COPY_WRITE_BUFFER, GL31.GL_COPY_WRITE_BUFFER), + DRAW_INDIRECT_BUFFER(GL40.GL_DRAW_INDIRECT_BUFFER, GL40.GL_DRAW_INDIRECT_BUFFER_BINDING), + ATOMIC_COUNTER_BUFFER(GL42.GL_ATOMIC_COUNTER_BUFFER, GL42.GL_ATOMIC_COUNTER_BUFFER_BINDING), + DISPATCH_INDIRECT_BUFFER(GL43.GL_DISPATCH_INDIRECT_BUFFER, GL43.GL_DISPATCH_INDIRECT_BUFFER_BINDING), + SHADER_STORAGE_BUFFER(GL43.GL_SHADER_STORAGE_BUFFER, GL43.GL_SHADER_STORAGE_BUFFER_BINDING), ; public final int glEnum; + public final int glBindingEnum; - GlBufferType(int glEnum) { + GlBufferType(int glEnum, int glBindingEnum) { this.glEnum = glEnum; + this.glBindingEnum = glBindingEnum; } public static GlBufferType fromTarget(int pTarget) { diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceWorld.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceWorld.java index 4eb9af7d8..870cdd374 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceWorld.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstanceWorld.java @@ -142,10 +142,10 @@ public class InstanceWorld implements AutoCloseable { /** * Instantiate all the necessary instances to render the given world. */ - public void loadEntities(ClientLevel world) { + public void loadEntities(ClientLevel level) { // Block entities are loaded while chunks are baked. - // Entities are loaded with the world, so when chunks are reloaded they need to be re-added. - ClientLevelExtension.getAllLoadedEntities(world) + // Entities are loaded with the level, so when chunks are reloaded they need to be re-added. + ClientLevelExtension.getAllLoadedEntities(level) .forEach(entities::add); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstancedRenderDispatcher.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstancedRenderDispatcher.java index f58abbb2a..2695ac4d2 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/InstancedRenderDispatcher.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/InstancedRenderDispatcher.java @@ -3,6 +3,7 @@ package com.jozufozu.flywheel.backend.instancing; import java.util.List; import com.jozufozu.flywheel.backend.Backend; +import com.jozufozu.flywheel.backend.gl.GlStateTracker; import com.jozufozu.flywheel.backend.instancing.effect.Effect; import com.jozufozu.flywheel.config.FlwCommands; import com.jozufozu.flywheel.config.FlwConfig; @@ -77,11 +78,11 @@ public class InstancedRenderDispatcher { return; } Minecraft mc = Minecraft.getInstance(); - ClientLevel world = mc.level; + ClientLevel level = mc.level; AnimationTickHolder.tick(); if (Backend.isOn()) { - instanceWorlds.get(world) + instanceWorlds.get(level) .tick(); } } @@ -94,22 +95,22 @@ public class InstancedRenderDispatcher { } public static void onRenderStage(RenderStageEvent event) { - ClientLevel world = event.getContext().level(); - if (!Backend.canUseInstancing(world)) return; + ClientLevel level = event.getContext().level(); + if (!Backend.canUseInstancing(level)) return; - instanceWorlds.get(world).renderStage(event.getContext(), event.getStage()); + instanceWorlds.get(level).renderStage(event.getContext(), event.getStage()); } public static void onReloadRenderers(ReloadRenderersEvent event) { - ClientLevel world = event.getWorld(); - if (Backend.isOn() && world != null) { - resetInstanceWorld(world); + ClientLevel level = event.getLevel(); + if (Backend.isOn() && level != null) { + resetInstanceLevel(level); } } - public static void resetInstanceWorld(ClientLevel world) { - instanceWorlds.replace(world, InstanceWorld::delete) - .loadEntities(world); + public static void resetInstanceLevel(ClientLevel level) { + instanceWorlds.replace(level, InstanceWorld::delete) + .loadEntities(level); } public static void getDebugString(List debug) { diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/BatchedMaterialGroup.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/BatchedMaterialGroup.java deleted file mode 100644 index e69de29bb..000000000 diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/blockentity/BlockEntityInstanceManager.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/blockentity/BlockEntityInstanceManager.java index 7059e4763..7daf01429 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/blockentity/BlockEntityInstanceManager.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/blockentity/BlockEntityInstanceManager.java @@ -47,20 +47,20 @@ public class BlockEntityInstanceManager extends InstanceManager { return false; } - Level world = blockEntity.getLevel(); + Level level = blockEntity.getLevel(); - if (world == null) { + if (level == null) { return false; } - if (world.isEmptyBlock(blockEntity.getBlockPos())) { + if (level.isEmptyBlock(blockEntity.getBlockPos())) { return false; } - if (Backend.isFlywheelWorld(world)) { + if (Backend.isFlywheelLevel(level)) { BlockPos pos = blockEntity.getBlockPos(); - BlockGetter existingChunk = world.getChunkForCollisions(pos.getX() >> 4, pos.getZ() >> 4); + BlockGetter existingChunk = level.getChunkForCollisions(pos.getX() >> 4, pos.getZ() >> 4); return existingChunk != null; } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstanceManager.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstanceManager.java index 8a729a559..33e42b155 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstanceManager.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/entity/EntityInstanceManager.java @@ -42,12 +42,12 @@ public class EntityInstanceManager extends InstanceManager { return false; } - Level world = entity.level; + Level level = entity.level; - if (Backend.isFlywheelWorld(world)) { + if (Backend.isFlywheelLevel(level)) { BlockPos pos = entity.blockPosition(); - BlockGetter existingChunk = world.getChunkForCollisions(pos.getX() >> 4, pos.getZ() >> 4); + BlockGetter existingChunk = level.getChunkForCollisions(pos.getX() >> 4, pos.getZ() >> 4); return existingChunk != null; } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/InstancingEngine.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/InstancingEngine.java index 0417d9124..fe0b825a4 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/InstancingEngine.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/InstancingEngine.java @@ -13,6 +13,7 @@ import com.jozufozu.flywheel.api.instancer.InstancedPart; import com.jozufozu.flywheel.api.material.Material; import com.jozufozu.flywheel.api.struct.StructType; import com.jozufozu.flywheel.api.vertex.VertexType; +import com.jozufozu.flywheel.backend.gl.GlStateTracker; import com.jozufozu.flywheel.backend.gl.GlTextureUnit; import com.jozufozu.flywheel.backend.instancing.Engine; import com.jozufozu.flywheel.backend.instancing.InstanceManager; @@ -66,7 +67,9 @@ public class InstancingEngine implements Engine { @Override public void beginFrame(TaskEngine taskEngine, RenderContext context) { - drawManager.flush(); + try (var restoreState = GlStateTracker.getRestoreState()) { + drawManager.flush(); + } } @Override @@ -77,9 +80,11 @@ public class InstancingEngine implements Engine { return; } - setup(); - - render(drawSet); + try (var restoreState = GlStateTracker.getRestoreState()) { + setup(); + + render(drawSet); + } } protected void setup() { diff --git a/src/main/java/com/jozufozu/flywheel/config/FlwCommands.java b/src/main/java/com/jozufozu/flywheel/config/FlwCommands.java index c9365b451..4a6a5273e 100644 --- a/src/main/java/com/jozufozu/flywheel/config/FlwCommands.java +++ b/src/main/java/com/jozufozu/flywheel/config/FlwCommands.java @@ -54,23 +54,6 @@ public class FlwCommands { return Command.SINGLE_SUCCESS; }))); - commandBuilder.addValue(config.client.debugNormals, "debugNormals", (builder, value) -> booleanValueCommand(builder, value, - (source, bool) -> { - LocalPlayer player = Minecraft.getInstance().player; - if (player == null) return; - - Component text = new TextComponent("Normal debug mode is currently: ").append(boolToText(bool)); - player.displayClientMessage(text, false); - }, - (source, bool) -> { - LocalPlayer player = Minecraft.getInstance().player; - if (player == null) return; - - Component text = boolToText(bool).append(new TextComponent(" normal debug mode").withStyle(ChatFormatting.WHITE)); - player.displayClientMessage(text, false); - } - )); - commandBuilder.addValue(config.client.limitUpdates, "limitUpdates", (builder, value) -> booleanValueCommand(builder, value, (source, bool) -> { LocalPlayer player = Minecraft.getInstance().player; @@ -90,7 +73,18 @@ public class FlwCommands { } )); - commandBuilder.command.then(Commands.literal("debugCrumble") + // TODO + commandBuilder.command.then(Commands.literal("debugNormals")) + .executes(context -> { + LocalPlayer player = Minecraft.getInstance().player; + if (player == null) return 0; + + player.displayClientMessage(new TextComponent("This command is not yet implemented."), false); + + return Command.SINGLE_SUCCESS; + }); + + commandBuilder.command.then(Commands.literal("debugCrumbling") .then(Commands.argument("pos", BlockPosArgument.blockPos()) .then(Commands.argument("stage", IntegerArgumentType.integer(0, 9)) .executes(context -> { @@ -106,7 +100,7 @@ public class FlwCommands { executor.level.destroyBlockProgress(executor.getId(), pos, value); - return 1; + return Command.SINGLE_SUCCESS; })))); commandBuilder.build(event.getDispatcher()); diff --git a/src/main/java/com/jozufozu/flywheel/config/FlwConfig.java b/src/main/java/com/jozufozu/flywheel/config/FlwConfig.java index 1872131f7..857421cf2 100644 --- a/src/main/java/com/jozufozu/flywheel/config/FlwConfig.java +++ b/src/main/java/com/jozufozu/flywheel/config/FlwConfig.java @@ -31,10 +31,6 @@ public class FlwConfig { return client.backend.get(); } - public boolean debugNormals() { - return client.debugNormals.get(); - } - public boolean limitUpdates() { return client.limitUpdates.get(); } @@ -44,16 +40,12 @@ public class FlwConfig { public static class ClientConfig { public final EnumValue backend; - public final BooleanValue debugNormals; public final BooleanValue limitUpdates; public ClientConfig(ForgeConfigSpec.Builder builder) { backend = builder.comment("Select the backend to use.") .defineEnum("backend", BackendType.INSTANCING); - debugNormals = builder.comment("Enable or disable a debug overlay that colors pixels by their normal.") - .define("debugNormals", false); - limitUpdates = builder.comment("Enable or disable instance update limiting with distance.") .define("limitUpdates", true); } diff --git a/src/main/java/com/jozufozu/flywheel/core/virtual/VirtualRenderWorld.java b/src/main/java/com/jozufozu/flywheel/core/virtual/VirtualRenderWorld.java index 68dd97d71..e11b0e118 100644 --- a/src/main/java/com/jozufozu/flywheel/core/virtual/VirtualRenderWorld.java +++ b/src/main/java/com/jozufozu/flywheel/core/virtual/VirtualRenderWorld.java @@ -11,7 +11,7 @@ import java.util.function.Predicate; import org.jetbrains.annotations.Nullable; -import com.jozufozu.flywheel.api.FlywheelWorld; +import com.jozufozu.flywheel.api.FlywheelLevel; import net.minecraft.core.BlockPos; import net.minecraft.core.Direction; @@ -43,7 +43,7 @@ import net.minecraft.world.level.storage.WritableLevelData; import net.minecraft.world.scores.Scoreboard; import net.minecraft.world.ticks.LevelTickAccess; -public class VirtualRenderWorld extends Level implements FlywheelWorld { +public class VirtualRenderWorld extends Level implements FlywheelLevel { public final Map blocksAdded = new HashMap<>(); public final Map besAdded = new HashMap<>(); public final Set spannedSections = new HashSet<>(); diff --git a/src/main/java/com/jozufozu/flywheel/event/ReloadRenderersEvent.java b/src/main/java/com/jozufozu/flywheel/event/ReloadRenderersEvent.java index 6187ae578..01e90a44f 100644 --- a/src/main/java/com/jozufozu/flywheel/event/ReloadRenderersEvent.java +++ b/src/main/java/com/jozufozu/flywheel/event/ReloadRenderersEvent.java @@ -6,14 +6,14 @@ import net.minecraft.client.multiplayer.ClientLevel; import net.minecraftforge.eventbus.api.Event; public class ReloadRenderersEvent extends Event { - private final ClientLevel world; + private final ClientLevel level; - public ReloadRenderersEvent(ClientLevel world) { - this.world = world; + public ReloadRenderersEvent(ClientLevel level) { + this.level = level; } @Nullable - public ClientLevel getWorld() { - return world; + public ClientLevel getLevel() { + return level; } } diff --git a/src/main/java/com/jozufozu/flywheel/mixin/BufferUploaderMixin.java b/src/main/java/com/jozufozu/flywheel/mixin/BufferUploaderMixin.java deleted file mode 100644 index 4eac80524..000000000 --- a/src/main/java/com/jozufozu/flywheel/mixin/BufferUploaderMixin.java +++ /dev/null @@ -1,28 +0,0 @@ -package com.jozufozu.flywheel.mixin; - -import org.jetbrains.annotations.Nullable; -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.CallbackInfo; - -import com.jozufozu.flywheel.backend.gl.GlStateTracker; -import com.mojang.blaze3d.vertex.BufferUploader; -import com.mojang.blaze3d.vertex.VertexFormat; - -@Mixin(BufferUploader.class) -public class BufferUploaderMixin { - @Shadow - @Nullable - private static VertexFormat lastFormat; - - // Stop BufferUploader from clearing buffer state if nothing is bound - @Inject(method = "reset", at = @At("HEAD")) - private static void flywheel$onReset(CallbackInfo ci) { - // Trust our tracker over BufferUploader's. - if (GlStateTracker.getVertexArray() == 0) { - lastFormat = null; - } - } -} diff --git a/src/main/java/com/jozufozu/flywheel/mixin/LevelRendererMixin.java b/src/main/java/com/jozufozu/flywheel/mixin/LevelRendererMixin.java index 5e843dd60..72e31b27d 100644 --- a/src/main/java/com/jozufozu/flywheel/mixin/LevelRendererMixin.java +++ b/src/main/java/com/jozufozu/flywheel/mixin/LevelRendererMixin.java @@ -12,7 +12,6 @@ import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; import com.jozufozu.flywheel.api.RenderStage; import com.jozufozu.flywheel.backend.Backend; -import com.jozufozu.flywheel.backend.gl.GlStateTracker; import com.jozufozu.flywheel.core.RenderContext; import com.jozufozu.flywheel.event.BeginFrameEvent; import com.jozufozu.flywheel.event.ReloadRenderersEvent; @@ -44,9 +43,7 @@ public class LevelRendererMixin { private void flywheel$beginRender(PoseStack pPoseStack, float pPartialTick, long pFinishNanoTime, boolean pRenderBlockOutline, Camera pCamera, GameRenderer pGameRenderer, LightTexture pLightTexture, Matrix4f pProjectionMatrix, CallbackInfo ci) { flywheel$renderContext = new RenderContext((LevelRenderer) (Object) this, level, pPoseStack, RenderContext.createViewProjection(pPoseStack, pProjectionMatrix), pProjectionMatrix, renderBuffers, pCamera); - try (var restoreState = GlStateTracker.getRestoreState()) { - MinecraftForge.EVENT_BUS.post(new BeginFrameEvent(flywheel$renderContext)); - } + MinecraftForge.EVENT_BUS.post(new BeginFrameEvent(flywheel$renderContext)); } @Inject(at = @At("TAIL"), method = "renderLevel") @@ -74,9 +71,7 @@ public class LevelRendererMixin { @Unique private void flywheel$dispatch(RenderStage stage) { if (flywheel$renderContext != null) { - try (var restoreState = GlStateTracker.getRestoreState()) { - MinecraftForge.EVENT_BUS.post(new RenderStageEvent(flywheel$renderContext, stage)); - } + MinecraftForge.EVENT_BUS.post(new RenderStageEvent(flywheel$renderContext, stage)); } } diff --git a/src/main/java/com/jozufozu/flywheel/mixin/light/NetworkLightUpdateMixin.java b/src/main/java/com/jozufozu/flywheel/mixin/light/NetworkLightUpdateMixin.java index 5352e21b5..4c6ae7a8d 100644 --- a/src/main/java/com/jozufozu/flywheel/mixin/light/NetworkLightUpdateMixin.java +++ b/src/main/java/com/jozufozu/flywheel/mixin/light/NetworkLightUpdateMixin.java @@ -18,14 +18,14 @@ public class NetworkLightUpdateMixin { @Inject(at = @At("TAIL"), method = "handleLightUpdatePacket") private void flywheel$onLightPacket(ClientboundLightUpdatePacket packet, CallbackInfo ci) { RenderWork.enqueue(() -> { - ClientLevel world = Minecraft.getInstance().level; + ClientLevel level = Minecraft.getInstance().level; - if (world == null) return; + if (level == null) return; int chunkX = packet.getX(); int chunkZ = packet.getZ(); - LightUpdater.get(world) + LightUpdater.get(level) .onLightPacket(chunkX, chunkZ); }); } diff --git a/src/main/resources/flywheel.mixins.json b/src/main/resources/flywheel.mixins.json index f0cf17998..9d10d66b8 100644 --- a/src/main/resources/flywheel.mixins.json +++ b/src/main/resources/flywheel.mixins.json @@ -8,7 +8,6 @@ "BlockEntityRenderDispatcherAccessor", "BlockEntityTypeMixin", "BufferBuilderMixin", - "BufferUploaderMixin", "ChunkRebuildHooksMixin", "ClientLevelMixin", "EntityTypeMixin",