Non-uniform un-provider

- Delete UniformBuffer on renderer reload to fix crash when switching
  backend to off
- Use library method for getting boolean property (ty pepper!)
This commit is contained in:
Jozufozu 2023-04-16 17:20:32 -07:00
parent 51cbfbc75a
commit 1bd4c4f6cb
3 changed files with 29 additions and 9 deletions

View file

@ -6,6 +6,7 @@ import org.slf4j.Logger;
import com.jozufozu.flywheel.backend.Backends;
import com.jozufozu.flywheel.backend.Loader;
import com.jozufozu.flywheel.backend.Pipelines;
import com.jozufozu.flywheel.backend.engine.UniformBuffer;
import com.jozufozu.flywheel.backend.engine.batching.DrawBuffer;
import com.jozufozu.flywheel.config.BackendArgument;
import com.jozufozu.flywheel.config.FlwCommands;
@ -81,6 +82,7 @@ public class Flywheel {
forgeEventBus.addListener(EventPriority.HIGHEST, QuadConverter::onReloadRenderers);
forgeEventBus.addListener(Models::onReloadRenderers);
forgeEventBus.addListener(DrawBuffer::onReloadRenderers);
forgeEventBus.addListener(UniformBuffer::onReloadRenderers);
forgeEventBus.addListener(VisualizedRenderDispatcher::onRenderStage);
forgeEventBus.addListener(VisualizedRenderDispatcher::onBeginFrame);

View file

@ -6,6 +6,7 @@ import java.util.Set;
import org.lwjgl.opengl.GL32;
import com.google.common.collect.ImmutableList;
import com.jozufozu.flywheel.api.event.ReloadRenderersEvent;
import com.jozufozu.flywheel.api.uniform.ShaderUniforms;
import com.jozufozu.flywheel.gl.buffer.GlBuffer;
import com.jozufozu.flywheel.gl.buffer.GlBufferType;
@ -60,27 +61,39 @@ public class UniformBuffer {
}
}
private void delete() {
providerSet.delete();
buffer.delete();
}
public static void onReloadRenderers(ReloadRenderersEvent event) {
if (instance != null) {
instance.delete();
instance = null;
}
}
private static class LiveProvider {
private final ShaderUniforms provider;
private final ShaderUniforms shaderUniforms;
private final int offset;
private final int size;
private ShaderUniforms.Provider activeProvider;
private ShaderUniforms.Provider provider;
private LiveProvider(ShaderUniforms provider, int offset, int size) {
this.provider = provider;
private LiveProvider(ShaderUniforms shaderUniforms, int offset, int size) {
this.shaderUniforms = shaderUniforms;
this.offset = offset;
this.size = size;
}
private void updatePtr(MemoryBlock bufferBase) {
if (activeProvider != null) {
activeProvider.delete();
if (provider != null) {
provider.delete();
}
activeProvider = provider.activate(bufferBase.ptr() + offset);
provider = shaderUniforms.activate(bufferBase.ptr() + offset);
}
public boolean maybePoll() {
return activeProvider != null && activeProvider.poll();
return provider != null && provider.poll();
}
}
@ -116,5 +129,10 @@ public class UniformBuffer {
}
return changed;
}
public void delete() {
allocatedProviders.forEach(p -> p.provider.delete());
data.free();
}
}
}

View file

@ -12,7 +12,7 @@ public class ClientMainMixin {
@Inject(method = "main([Ljava/lang/String;)V", at = @At("HEAD"))
private static void flywheel$injectRenderDoc(CallbackInfo ci) {
// Only try to load RenderDoc if a system property is set to true.
if (!Boolean.parseBoolean(System.getProperty("flw.loadRenderDoc"))) {
if (!Boolean.getBoolean("flw.loadRenderDoc")) {
return;
}