diff --git a/.gitignore b/.gitignore index 4cc901d7b..92ba22f06 100644 --- a/.gitignore +++ b/.gitignore @@ -1,7 +1,9 @@ # gradle .gradle/ -/build/ +fabric/build +common/build +forge/build out/ classes/ @@ -31,3 +33,5 @@ bin/ # fabric run/ + +.architectury-transformer/ diff --git a/build.gradle b/build.gradle index 039b98261..96cd7eca7 100644 --- a/build.gradle +++ b/build.gradle @@ -1,14 +1,12 @@ plugins { - id 'fabric-loom' version '0.12-SNAPSHOT' - id 'maven-publish' + id "architectury-plugin" version "3.4-SNAPSHOT" + id "dev.architectury.loom" version "1.3-SNAPSHOT" apply false + id 'maven-publish' } -sourceCompatibility = JavaVersion.VERSION_17 -targetCompatibility = JavaVersion.VERSION_17 - -archivesBaseName = project.archives_base_name -version = project.mod_version -group = project.maven_group +architectury { + minecraft = rootProject.minecraft_version +} project.ext.lwjglVersion = "3.3.1" project.ext.jomlVersion = "1.10.4" @@ -17,102 +15,44 @@ project.ext.linuxNatives = "natives-linux" project.ext.macosNatives = "natives-macos" project.ext.macosArmNatives = "natives-macos-arm64" -dependencies { -// include(implementation("org.lwjgl:lwjgl:$lwjglVersion")) -// include(implementation("org.lwjgl:lwjgl-glfw:$lwjglVersion")) -// include(runtimeOnly("org.lwjgl:lwjgl-glfw:$lwjglVersion:$winNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl-glfw:$lwjglVersion:$linuxNatives")) -// include(implementation("org.lwjgl:lwjgl-stb:$lwjglVersion")) -// include(runtimeOnly("org.lwjgl:lwjgl-stb:$lwjglVersion:$winNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl-stb:$lwjglVersion:$linuxNatives")) -// include(implementation("org.lwjgl:lwjgl-openal:$lwjglVersion")) -// include(runtimeOnly("org.lwjgl:lwjgl-openal:$lwjglVersion:$winNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl-openal:$lwjglVersion:$linuxNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl:$lwjglVersion:$winNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl:$lwjglVersion:$linuxNatives")) - - include(implementation("org.lwjgl:lwjgl-vulkan:$lwjglVersion")) - include(implementation("org.lwjgl:lwjgl-vma:$lwjglVersion")) -// include(implementation("org.joml:joml:${jomlVersion}")) - include(runtimeOnly("org.lwjgl:lwjgl-vma:$lwjglVersion:$winNatives")) - include(runtimeOnly("org.lwjgl:lwjgl-vma:$lwjglVersion:$linuxNatives")) +subprojects { + apply plugin: "java" + apply plugin: "architectury-plugin" + apply plugin: "dev.architectury.loom" + apply plugin: "maven-publish" - include(implementation("org.lwjgl:lwjgl-shaderc:$lwjglVersion")) - include(runtimeOnly("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$winNatives")) - include(runtimeOnly("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$linuxNatives")) + archivesBaseName = project.archives_base_name + version = project.mod_version + group = project.maven_group - //MacOS -// include(runtimeOnly("org.lwjgl:lwjgl-vulkan:$lwjglVersion:$macosNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl-vulkan:$lwjglVersion:$macosArmNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl-vma:$lwjglVersion:$macosNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl-vma:$lwjglVersion:$macosArmNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$macosNatives")) -// include(runtimeOnly("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$macosArmNatives")) - -// implementation("org.openjdk.jol:jol-core:0.17") -} + tasks.withType(JavaCompile) { + options.encoding = "UTF-8" + options.release = 17 + } -repositories { - // Add repositories to retrieve artifacts from in here. - // You should only use this when depending on other mods because - // Loom adds the essential maven repositories to download Minecraft and libraries from automatically. - // See https://docs.gradle.org/current/userguide/declaring_repositories.html - // for more information about repositories. -} - -dependencies { - // To change the versions see the gradle.properties file - minecraft "com.mojang:minecraft:${project.minecraft_version}" - mappings loom.officialMojangMappings() - modImplementation "net.fabricmc:fabric-loader:${project.loader_version}" - - // Fabric API. This is technically optional, but you probably want it anyway. - modImplementation "net.fabricmc.fabric-api:fabric-api:${project.fabric_version}" -} + java { + withSourcesJar() + } -processResources { - inputs.property "version", project.version + loom { + silentMojangMappingsLicense() + } - filesMatching("fabric.mod.json") { - expand "version": project.version - } -} + dependencies { + minecraft "com.mojang:minecraft:${rootProject.minecraft_version}" + // The following line declares the mojmap mappings, you may use other mappings as well + mappings loom.officialMojangMappings() -tasks.withType(JavaCompile).configureEach { - // Minecraft 1.18 (1.18-pre2) upwards uses Java 17. - it.options.release = 17 + } } -loom { - accessWidenerPath = file("src/main/resources/vulkanmod.accesswidener") -} +allprojects { + apply plugin: "architectury-plugin" -java { - // Loom will automatically attach sourcesJar to a RemapSourcesJar task and to the "build" task - // if it is present. - // If you remove this line, sources will not be generated. - withSourcesJar() } -jar { +/*jar { from("LICENSE") { rename { "${it}_${project.archivesBaseName}"} } -} - -// configure the maven publication -publishing { - publications { - mavenJava(MavenPublication) { - from components.java - } - } - - // See https://docs.gradle.org/current/userguide/publishing_maven.html for information on how to set up publishing. - repositories { - // Add repositories to publish to here. - // Notice: This block does NOT have the same function as the block in the top level. - // The repositories here will be used for publishing your artifact, not for - // retrieving dependencies. - } -} +}*/ diff --git a/common/build.gradle b/common/build.gradle new file mode 100644 index 000000000..beb6108a4 --- /dev/null +++ b/common/build.gradle @@ -0,0 +1,35 @@ +architectury { + common(rootProject.enabled_platforms.split(",")) +} + +loom { + accessWidenerPath = file("src/main/resources/vulkanmod.accesswidener") +} + +dependencies { + // We depend on fabric loader here to use the fabric @Environment annotations and get the mixin dependencies + // Do NOT use other classes from fabric loader + modImplementation "net.fabricmc:fabric-loader:${rootProject.fabric_loader_version}" + // Remove the next line if you don't want to depend on the API + modApi "dev.architectury:architectury:${rootProject.architectury_version}" + + include(implementation("org.lwjgl:lwjgl-vulkan:$lwjglVersion")) + include(implementation("org.lwjgl:lwjgl-vma:$lwjglVersion")) + include(runtimeOnly("org.lwjgl:lwjgl-vma:$lwjglVersion:$winNatives")) + include(runtimeOnly("org.lwjgl:lwjgl-vma:$lwjglVersion:$linuxNatives")) + + include(implementation("org.lwjgl:lwjgl-shaderc:$lwjglVersion")) + include(runtimeOnly("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$winNatives")) + include(runtimeOnly("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$linuxNatives")) + + include(implementation("com.google.code.findbugs:jsr305:3.0.2")) +} + +publishing { + publications { + mavenCommon(MavenPublication) { + artifactId = rootProject.archives_base_name + from components.java + } + } +} diff --git a/src/main/java/net/vulkanmod/Initializer.java b/common/src/main/java/net/vulkanmod/Initializer.java similarity index 52% rename from src/main/java/net/vulkanmod/Initializer.java rename to common/src/main/java/net/vulkanmod/Initializer.java index 88f2a9581..469e76313 100644 --- a/src/main/java/net/vulkanmod/Initializer.java +++ b/common/src/main/java/net/vulkanmod/Initializer.java @@ -1,8 +1,5 @@ package net.vulkanmod; -import net.fabricmc.api.ClientModInitializer; -import net.fabricmc.api.ModInitializer; -import net.fabricmc.loader.api.FabricLoader; import net.vulkanmod.config.Config; import net.vulkanmod.config.VideoResolution; import org.apache.logging.log4j.LogManager; @@ -10,31 +7,15 @@ import java.nio.file.Path; -public class Initializer implements ClientModInitializer { +public class Initializer { public static final Logger LOGGER = LogManager.getLogger("VulkanMod"); - private static String VERSION; - public static Config CONFIG; - - @Override - public void onInitializeClient() { - - VERSION = FabricLoader.getInstance() - .getModContainer("vulkanmod") - .get() - .getMetadata() - .getVersion().getFriendlyString(); - + public static Config CONFIG = loadConfig(VulkanModExpectPlatform.getConfigDirectory().resolve("vulkanmod_settings.json")); + public static final String MODID = "vulkanmod"; + public static void onInitializeClient() { + VERSION = VulkanModExpectPlatform.getVersion(); LOGGER.info("== VulkanMod =="); - VideoResolution.init(); - - var configPath = FabricLoader.getInstance() - .getConfigDir() - .resolve("vulkanmod_settings.json"); - - CONFIG = loadConfig(configPath); - } private static Config loadConfig(Path path) { @@ -49,4 +30,4 @@ private static Config loadConfig(Path path) { public static String getVersion() { return VERSION; } -} +} \ No newline at end of file diff --git a/common/src/main/java/net/vulkanmod/VulkanModExpectPlatform.java b/common/src/main/java/net/vulkanmod/VulkanModExpectPlatform.java new file mode 100644 index 000000000..f4c983333 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/VulkanModExpectPlatform.java @@ -0,0 +1,19 @@ +package net.vulkanmod; + +import dev.architectury.injectables.annotations.ExpectPlatform; + +import java.nio.file.Path; + +public class VulkanModExpectPlatform { + + @ExpectPlatform + public static Path getConfigDirectory() { + // Just throw an error, the content should get replaced at runtime. + throw new AssertionError(); + } + + @ExpectPlatform + public static String getVersion() { + throw new AssertionError(); + } +} diff --git a/src/main/java/net/vulkanmod/config/Config.java b/common/src/main/java/net/vulkanmod/config/Config.java similarity index 97% rename from src/main/java/net/vulkanmod/config/Config.java rename to common/src/main/java/net/vulkanmod/config/Config.java index 08fc8d243..b4a3e67e1 100644 --- a/src/main/java/net/vulkanmod/config/Config.java +++ b/common/src/main/java/net/vulkanmod/config/Config.java @@ -19,6 +19,7 @@ public class Config { public int advCulling = 2; public boolean indirectDraw = false; public boolean uniqueOpaqueLayer = true; + public boolean entityCulling = true; private static Path path; diff --git a/src/main/java/net/vulkanmod/config/CyclingOption.java b/common/src/main/java/net/vulkanmod/config/CyclingOption.java similarity index 100% rename from src/main/java/net/vulkanmod/config/CyclingOption.java rename to common/src/main/java/net/vulkanmod/config/CyclingOption.java diff --git a/src/main/java/net/vulkanmod/config/Option.java b/common/src/main/java/net/vulkanmod/config/Option.java similarity index 100% rename from src/main/java/net/vulkanmod/config/Option.java rename to common/src/main/java/net/vulkanmod/config/Option.java diff --git a/src/main/java/net/vulkanmod/config/OptionList2.java b/common/src/main/java/net/vulkanmod/config/OptionList2.java similarity index 100% rename from src/main/java/net/vulkanmod/config/OptionList2.java rename to common/src/main/java/net/vulkanmod/config/OptionList2.java diff --git a/src/main/java/net/vulkanmod/config/OptionScreenV.java b/common/src/main/java/net/vulkanmod/config/OptionScreenV.java similarity index 100% rename from src/main/java/net/vulkanmod/config/OptionScreenV.java rename to common/src/main/java/net/vulkanmod/config/OptionScreenV.java diff --git a/src/main/java/net/vulkanmod/config/Options.java b/common/src/main/java/net/vulkanmod/config/Options.java similarity index 97% rename from src/main/java/net/vulkanmod/config/Options.java rename to common/src/main/java/net/vulkanmod/config/Options.java index b6e4312a1..a6401f89c 100644 --- a/src/main/java/net/vulkanmod/config/Options.java +++ b/common/src/main/java/net/vulkanmod/config/Options.java @@ -203,12 +203,17 @@ Enable Gui optimizations (Stats bar, Chat, Debug Hud) Use a culling algorithm that might improve performance by reducing the number of non visible chunk sections rendered. """)), + new SwitchOption("Entity Culling", + value -> config.entityCulling = value, + () -> config.entityCulling) + .setTooltip(Component.nullToEmpty(""" + Enables culling for entities on non visible sections.""")), new SwitchOption("Indirect Draw", value -> config.indirectDraw = value, () -> config.indirectDraw) .setTooltip(Component.nullToEmpty(""" Reduces CPU overhead but increases GPU overhead. - Enabling it might help in CPU limited systems.""")), + Enabling it might help in CPU limited systems.""")) }; } diff --git a/src/main/java/net/vulkanmod/config/RangeOption.java b/common/src/main/java/net/vulkanmod/config/RangeOption.java similarity index 100% rename from src/main/java/net/vulkanmod/config/RangeOption.java rename to common/src/main/java/net/vulkanmod/config/RangeOption.java diff --git a/src/main/java/net/vulkanmod/config/SliderWidgetImpl.java b/common/src/main/java/net/vulkanmod/config/SliderWidgetImpl.java similarity index 100% rename from src/main/java/net/vulkanmod/config/SliderWidgetImpl.java rename to common/src/main/java/net/vulkanmod/config/SliderWidgetImpl.java diff --git a/src/main/java/net/vulkanmod/config/SwitchOption.java b/common/src/main/java/net/vulkanmod/config/SwitchOption.java similarity index 100% rename from src/main/java/net/vulkanmod/config/SwitchOption.java rename to common/src/main/java/net/vulkanmod/config/SwitchOption.java diff --git a/src/main/java/net/vulkanmod/config/VideoResolution.java b/common/src/main/java/net/vulkanmod/config/VideoResolution.java similarity index 100% rename from src/main/java/net/vulkanmod/config/VideoResolution.java rename to common/src/main/java/net/vulkanmod/config/VideoResolution.java diff --git a/src/main/java/net/vulkanmod/config/widget/CustomButtonWidget.java b/common/src/main/java/net/vulkanmod/config/widget/CustomButtonWidget.java similarity index 100% rename from src/main/java/net/vulkanmod/config/widget/CustomButtonWidget.java rename to common/src/main/java/net/vulkanmod/config/widget/CustomButtonWidget.java diff --git a/src/main/java/net/vulkanmod/config/widget/CyclingOptionWidget.java b/common/src/main/java/net/vulkanmod/config/widget/CyclingOptionWidget.java similarity index 100% rename from src/main/java/net/vulkanmod/config/widget/CyclingOptionWidget.java rename to common/src/main/java/net/vulkanmod/config/widget/CyclingOptionWidget.java diff --git a/src/main/java/net/vulkanmod/config/widget/OptionWidget.java b/common/src/main/java/net/vulkanmod/config/widget/OptionWidget.java similarity index 100% rename from src/main/java/net/vulkanmod/config/widget/OptionWidget.java rename to common/src/main/java/net/vulkanmod/config/widget/OptionWidget.java diff --git a/src/main/java/net/vulkanmod/config/widget/RangeOptionWidget.java b/common/src/main/java/net/vulkanmod/config/widget/RangeOptionWidget.java similarity index 100% rename from src/main/java/net/vulkanmod/config/widget/RangeOptionWidget.java rename to common/src/main/java/net/vulkanmod/config/widget/RangeOptionWidget.java diff --git a/src/main/java/net/vulkanmod/config/widget/SwitchOptionWidget.java b/common/src/main/java/net/vulkanmod/config/widget/SwitchOptionWidget.java similarity index 100% rename from src/main/java/net/vulkanmod/config/widget/SwitchOptionWidget.java rename to common/src/main/java/net/vulkanmod/config/widget/SwitchOptionWidget.java diff --git a/src/main/java/net/vulkanmod/gl/GlFramebuffer.java b/common/src/main/java/net/vulkanmod/gl/GlFramebuffer.java similarity index 100% rename from src/main/java/net/vulkanmod/gl/GlFramebuffer.java rename to common/src/main/java/net/vulkanmod/gl/GlFramebuffer.java diff --git a/src/main/java/net/vulkanmod/gl/GlTexture.java b/common/src/main/java/net/vulkanmod/gl/GlTexture.java similarity index 100% rename from src/main/java/net/vulkanmod/gl/GlTexture.java rename to common/src/main/java/net/vulkanmod/gl/GlTexture.java diff --git a/common/src/main/java/net/vulkanmod/gl/Util.java b/common/src/main/java/net/vulkanmod/gl/Util.java new file mode 100644 index 000000000..b7b475b82 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/gl/Util.java @@ -0,0 +1,14 @@ +package net.vulkanmod.gl; + +import net.vulkanmod.vulkan.shader.SPIRVUtils; + +public class Util { + + public static SPIRVUtils.ShaderKind extToShaderKind(String in) { + return switch (in) { + case ".vsh" -> SPIRVUtils.ShaderKind.VERTEX_SHADER; + case ".fsh" -> SPIRVUtils.ShaderKind.FRAGMENT_SHADER; + default -> throw new RuntimeException("unknown shader type: " + in); + }; + } +} diff --git a/src/main/java/net/vulkanmod/interfaces/ExtendedVertexBuilder.java b/common/src/main/java/net/vulkanmod/interfaces/ExtendedVertexBuilder.java similarity index 100% rename from src/main/java/net/vulkanmod/interfaces/ExtendedVertexBuilder.java rename to common/src/main/java/net/vulkanmod/interfaces/ExtendedVertexBuilder.java diff --git a/src/main/java/net/vulkanmod/interfaces/FrustumMixed.java b/common/src/main/java/net/vulkanmod/interfaces/FrustumMixed.java similarity index 100% rename from src/main/java/net/vulkanmod/interfaces/FrustumMixed.java rename to common/src/main/java/net/vulkanmod/interfaces/FrustumMixed.java diff --git a/src/main/java/net/vulkanmod/interfaces/ModelPartCubeMixed.java b/common/src/main/java/net/vulkanmod/interfaces/ModelPartCubeMixed.java similarity index 100% rename from src/main/java/net/vulkanmod/interfaces/ModelPartCubeMixed.java rename to common/src/main/java/net/vulkanmod/interfaces/ModelPartCubeMixed.java diff --git a/common/src/main/java/net/vulkanmod/interfaces/ShaderMixed.java b/common/src/main/java/net/vulkanmod/interfaces/ShaderMixed.java new file mode 100644 index 000000000..e1676144f --- /dev/null +++ b/common/src/main/java/net/vulkanmod/interfaces/ShaderMixed.java @@ -0,0 +1,8 @@ +package net.vulkanmod.interfaces; + +import net.vulkanmod.vulkan.shader.GraphicsPipeline; + +public interface ShaderMixed { + + GraphicsPipeline getPipeline(); +} diff --git a/src/main/java/net/vulkanmod/interfaces/VAbstractTextureI.java b/common/src/main/java/net/vulkanmod/interfaces/VAbstractTextureI.java similarity index 100% rename from src/main/java/net/vulkanmod/interfaces/VAbstractTextureI.java rename to common/src/main/java/net/vulkanmod/interfaces/VAbstractTextureI.java diff --git a/src/main/java/net/vulkanmod/interfaces/VertexFormatMixed.java b/common/src/main/java/net/vulkanmod/interfaces/VertexFormatMixed.java similarity index 100% rename from src/main/java/net/vulkanmod/interfaces/VertexFormatMixed.java rename to common/src/main/java/net/vulkanmod/interfaces/VertexFormatMixed.java diff --git a/src/main/java/net/vulkanmod/interfaces/VisibilitySetExtended.java b/common/src/main/java/net/vulkanmod/interfaces/VisibilitySetExtended.java similarity index 100% rename from src/main/java/net/vulkanmod/interfaces/VisibilitySetExtended.java rename to common/src/main/java/net/vulkanmod/interfaces/VisibilitySetExtended.java diff --git a/src/main/java/net/vulkanmod/mixin/MixinPlugin.java b/common/src/main/java/net/vulkanmod/mixin/MixinPlugin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/MixinPlugin.java rename to common/src/main/java/net/vulkanmod/mixin/MixinPlugin.java diff --git a/src/main/java/net/vulkanmod/mixin/WindowMixin.java b/common/src/main/java/net/vulkanmod/mixin/WindowMixin.java similarity index 98% rename from src/main/java/net/vulkanmod/mixin/WindowMixin.java rename to common/src/main/java/net/vulkanmod/mixin/WindowMixin.java index 296144834..5a536fac6 100644 --- a/src/main/java/net/vulkanmod/mixin/WindowMixin.java +++ b/common/src/main/java/net/vulkanmod/mixin/WindowMixin.java @@ -66,12 +66,12 @@ private GLCapabilities redirect2() { return null; } - @Inject(method = "", at = @At(value = "INVOKE", target = "Lorg/lwjgl/glfw/GLFW;glfwCreateWindow(IILjava/lang/CharSequence;JJ)J")) +/* @Inject(method = "", at = @At(value = "INVOKE", target = "Lorg/lwjgl/glfw/GLFW;glfwCreateWindow(IILjava/lang/CharSequence;JJ)J")) private void vulkanHint(WindowEventHandler windowEventHandler, ScreenManager screenManager, DisplayData displayData, String string, String string2, CallbackInfo ci) { GLFW.glfwWindowHint(GLFW_CLIENT_API, GLFW_NO_API); // GLFW.glfwWindowHint(GLFW_AUTO_ICONIFY, GLFW_FALSE); // GLFW.glfwWindowHint(GLFW_FOCUSED, GLFW_FALSE); - } + }*/ @Inject(method = "", at = @At(value = "RETURN")) private void getHandle(WindowEventHandler windowEventHandler, ScreenManager screenManager, DisplayData displayData, String string, String string2, CallbackInfo ci) { diff --git a/src/main/java/net/vulkanmod/mixin/chunk/DirectionMixin.java b/common/src/main/java/net/vulkanmod/mixin/chunk/DirectionMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/chunk/DirectionMixin.java rename to common/src/main/java/net/vulkanmod/mixin/chunk/DirectionMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/chunk/FrustumMixin.java b/common/src/main/java/net/vulkanmod/mixin/chunk/FrustumMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/chunk/FrustumMixin.java rename to common/src/main/java/net/vulkanmod/mixin/chunk/FrustumMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/chunk/LevelRendererMixin.java b/common/src/main/java/net/vulkanmod/mixin/chunk/LevelRendererMixin.java similarity index 98% rename from src/main/java/net/vulkanmod/mixin/chunk/LevelRendererMixin.java rename to common/src/main/java/net/vulkanmod/mixin/chunk/LevelRendererMixin.java index ec9d9b917..a303b383a 100644 --- a/src/main/java/net/vulkanmod/mixin/chunk/LevelRendererMixin.java +++ b/common/src/main/java/net/vulkanmod/mixin/chunk/LevelRendererMixin.java @@ -17,6 +17,7 @@ import net.minecraft.world.entity.Entity; import net.minecraft.world.level.block.entity.BlockEntity; import net.minecraft.world.phys.Vec3; +import net.vulkanmod.Initializer; import net.vulkanmod.render.chunk.WorldRenderer; import net.vulkanmod.render.profiling.Profiler2; import net.vulkanmod.vulkan.util.Pair; @@ -54,9 +55,6 @@ public abstract class LevelRendererMixin { private WorldRenderer worldRenderer; - @Unique - private static boolean ENTITIES_OPT = true; - @Unique private Object2ReferenceOpenHashMap, ObjectArrayList>> entitiesMap = new Object2ReferenceOpenHashMap<>(); @@ -89,8 +87,6 @@ private void renderBlockEntities(PoseStack poseStack, float f, long l, boolean b private void setupRender(Camera camera, Frustum frustum, boolean isCapturedFrustum, boolean spectator) { this.worldRenderer.setupRenderer(camera, frustum, isCapturedFrustum, spectator); - ENTITIES_OPT = true; -// ENTITIES_OPT = false; entitiesMap.clear(); } @@ -200,7 +196,7 @@ private void popProfiler3(PoseStack poseStack, float f, long l, boolean bl, Came */ @Overwrite private void renderEntity(Entity entity, double d, double e, double f, float g, PoseStack poseStack, MultiBufferSource multiBufferSource) { - if(!ENTITIES_OPT) { + if(!Initializer.CONFIG.entityCulling) { double h = Mth.lerp((double)g, entity.xOld, entity.getX()); double i = Mth.lerp((double)g, entity.yOld, entity.getY()); double j = Mth.lerp((double)g, entity.zOld, entity.getZ()); @@ -226,7 +222,7 @@ private void renderEntity(Entity entity, double d, double e, double f, float g, shift = At.Shift.AFTER, ordinal = 0) ) private void renderEntities(PoseStack poseStack, float partialTicks, long l, boolean bl, Camera camera, GameRenderer gameRenderer, LightTexture lightTexture, Matrix4f matrix4f, CallbackInfo ci) { - if(!ENTITIES_OPT) + if(!Initializer.CONFIG.entityCulling) return; Vec3 cameraPos = WorldRenderer.getCameraPos(); diff --git a/src/main/java/net/vulkanmod/mixin/chunk/VisibilitySetMixin.java b/common/src/main/java/net/vulkanmod/mixin/chunk/VisibilitySetMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/chunk/VisibilitySetMixin.java rename to common/src/main/java/net/vulkanmod/mixin/chunk/VisibilitySetMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/compatibility/EffectInstanceM.java b/common/src/main/java/net/vulkanmod/mixin/compatibility/EffectInstanceM.java similarity index 98% rename from src/main/java/net/vulkanmod/mixin/compatibility/EffectInstanceM.java rename to common/src/main/java/net/vulkanmod/mixin/compatibility/EffectInstanceM.java index aa1e841d6..12c2eadd3 100644 --- a/src/main/java/net/vulkanmod/mixin/compatibility/EffectInstanceM.java +++ b/common/src/main/java/net/vulkanmod/mixin/compatibility/EffectInstanceM.java @@ -11,7 +11,7 @@ import net.minecraft.server.packs.resources.ResourceManager; import net.vulkanmod.vulkan.shader.Pipeline; import net.vulkanmod.vulkan.shader.layout.Field; -import net.vulkanmod.vulkan.shader.layout.UBO; +import net.vulkanmod.vulkan.shader.descriptor.UBO; import net.vulkanmod.vulkan.shader.parser.GlslConverter; import net.vulkanmod.vulkan.util.MappedBuffer; import org.apache.commons.io.IOUtils; @@ -102,7 +102,7 @@ private void createShaders(ResourceManager resourceManager, String vertexShader, builder.setUniforms(Collections.singletonList(ubo), converter.getSamplerList()); builder.compileShaders(converter.getVshConverted(), converter.getFshConverted()); - this.pipeline = builder.createPipeline(); + this.pipeline = builder.createGraphicsPipeline(); } catch (IOException e) { throw new RuntimeException(e); diff --git a/src/main/java/net/vulkanmod/mixin/compatibility/ProgramM.java b/common/src/main/java/net/vulkanmod/mixin/compatibility/ProgramM.java similarity index 90% rename from src/main/java/net/vulkanmod/mixin/compatibility/ProgramM.java rename to common/src/main/java/net/vulkanmod/mixin/compatibility/ProgramM.java index 891ea0b66..2eed96df2 100644 --- a/src/main/java/net/vulkanmod/mixin/compatibility/ProgramM.java +++ b/common/src/main/java/net/vulkanmod/mixin/compatibility/ProgramM.java @@ -3,7 +3,7 @@ import com.mojang.blaze3d.preprocessor.GlslPreprocessor; import com.mojang.blaze3d.shaders.Program; import net.vulkanmod.gl.Util; -import net.vulkanmod.vulkan.shader.ShaderSPIRVUtils; +import net.vulkanmod.vulkan.shader.SPIRVUtils; import org.apache.commons.io.IOUtils; import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.Overwrite; @@ -37,7 +37,7 @@ public static int compileShaderInternal(Program.Type type, String string, InputS //TODO glslPreprocessor.process(string3); - ShaderSPIRVUtils.compileShader(string2 + ":" + string, string3, Util.extToShaderKind(type.getExtension())); + SPIRVUtils.compileShader(string2 + ":" + string, string3, Util.extToShaderKind(type.getExtension())); } return 0; } diff --git a/src/main/java/net/vulkanmod/mixin/compatibility/UniformM.java b/common/src/main/java/net/vulkanmod/mixin/compatibility/UniformM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/compatibility/UniformM.java rename to common/src/main/java/net/vulkanmod/mixin/compatibility/UniformM.java diff --git a/src/main/java/net/vulkanmod/mixin/compatibility/gl/GL11M.java b/common/src/main/java/net/vulkanmod/mixin/compatibility/gl/GL11M.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/compatibility/gl/GL11M.java rename to common/src/main/java/net/vulkanmod/mixin/compatibility/gl/GL11M.java diff --git a/src/main/java/net/vulkanmod/mixin/debug/ChunkBorderRendererM.java b/common/src/main/java/net/vulkanmod/mixin/debug/ChunkBorderRendererM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/debug/ChunkBorderRendererM.java rename to common/src/main/java/net/vulkanmod/mixin/debug/ChunkBorderRendererM.java diff --git a/src/main/java/net/vulkanmod/mixin/debug/DebugScreenOverlayM.java b/common/src/main/java/net/vulkanmod/mixin/debug/DebugScreenOverlayM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/debug/DebugScreenOverlayM.java rename to common/src/main/java/net/vulkanmod/mixin/debug/DebugScreenOverlayM.java diff --git a/src/main/java/net/vulkanmod/mixin/debug/GlDebugInfoM.java b/common/src/main/java/net/vulkanmod/mixin/debug/GlDebugInfoM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/debug/GlDebugInfoM.java rename to common/src/main/java/net/vulkanmod/mixin/debug/GlDebugInfoM.java diff --git a/src/main/java/net/vulkanmod/mixin/debug/KeyboardHandlerM.java b/common/src/main/java/net/vulkanmod/mixin/debug/KeyboardHandlerM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/debug/KeyboardHandlerM.java rename to common/src/main/java/net/vulkanmod/mixin/debug/KeyboardHandlerM.java diff --git a/src/main/java/net/vulkanmod/mixin/gui/ChatComponentM.java b/common/src/main/java/net/vulkanmod/mixin/gui/ChatComponentM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/gui/ChatComponentM.java rename to common/src/main/java/net/vulkanmod/mixin/gui/ChatComponentM.java diff --git a/src/main/java/net/vulkanmod/mixin/gui/DebugHudM.java b/common/src/main/java/net/vulkanmod/mixin/gui/DebugHudM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/gui/DebugHudM.java rename to common/src/main/java/net/vulkanmod/mixin/gui/DebugHudM.java diff --git a/src/main/java/net/vulkanmod/mixin/gui/GuiM.java b/common/src/main/java/net/vulkanmod/mixin/gui/GuiM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/gui/GuiM.java rename to common/src/main/java/net/vulkanmod/mixin/gui/GuiM.java diff --git a/src/main/java/net/vulkanmod/mixin/matrix/Matrix4fM.java b/common/src/main/java/net/vulkanmod/mixin/matrix/Matrix4fM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/matrix/Matrix4fM.java rename to common/src/main/java/net/vulkanmod/mixin/matrix/Matrix4fM.java diff --git a/src/main/java/net/vulkanmod/mixin/profiling/GuiMixin.java b/common/src/main/java/net/vulkanmod/mixin/profiling/GuiMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/profiling/GuiMixin.java rename to common/src/main/java/net/vulkanmod/mixin/profiling/GuiMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/profiling/KeyboardHandlerM.java b/common/src/main/java/net/vulkanmod/mixin/profiling/KeyboardHandlerM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/profiling/KeyboardHandlerM.java rename to common/src/main/java/net/vulkanmod/mixin/profiling/KeyboardHandlerM.java diff --git a/src/main/java/net/vulkanmod/mixin/render/BufferUploaderM.java b/common/src/main/java/net/vulkanmod/mixin/render/BufferUploaderM.java similarity index 84% rename from src/main/java/net/vulkanmod/mixin/render/BufferUploaderM.java rename to common/src/main/java/net/vulkanmod/mixin/render/BufferUploaderM.java index c200305a0..1d3cc0ade 100644 --- a/src/main/java/net/vulkanmod/mixin/render/BufferUploaderM.java +++ b/common/src/main/java/net/vulkanmod/mixin/render/BufferUploaderM.java @@ -5,6 +5,7 @@ import com.mojang.blaze3d.vertex.BufferUploader; import net.vulkanmod.interfaces.ShaderMixed; import net.vulkanmod.vulkan.Renderer; +import net.vulkanmod.vulkan.shader.GraphicsPipeline; import net.vulkanmod.vulkan.shader.Pipeline; import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.Overwrite; @@ -33,8 +34,8 @@ public static void drawWithShader(BufferBuilder.RenderedBuffer buffer) { if(parameters.vertexCount() <= 0) return; - Pipeline pipeline = ((ShaderMixed)(RenderSystem.getShader())).getPipeline(); - renderer.bindPipeline(pipeline); + GraphicsPipeline pipeline = ((ShaderMixed)(RenderSystem.getShader())).getPipeline(); + renderer.bindGraphicsPipeline(pipeline); renderer.uploadAndBindUBOs(pipeline); Renderer.getDrawer().draw(buffer.vertexBuffer(), parameters.mode(), parameters.format(), parameters.vertexCount()); } diff --git a/src/main/java/net/vulkanmod/mixin/render/GameRendererMixin.java b/common/src/main/java/net/vulkanmod/mixin/render/GameRendererMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/GameRendererMixin.java rename to common/src/main/java/net/vulkanmod/mixin/render/GameRendererMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/render/GlProgramManagerMixin.java b/common/src/main/java/net/vulkanmod/mixin/render/GlProgramManagerMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/GlProgramManagerMixin.java rename to common/src/main/java/net/vulkanmod/mixin/render/GlProgramManagerMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/render/GlStateManagerM.java b/common/src/main/java/net/vulkanmod/mixin/render/GlStateManagerM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/GlStateManagerM.java rename to common/src/main/java/net/vulkanmod/mixin/render/GlStateManagerM.java diff --git a/src/main/java/net/vulkanmod/mixin/render/LevelRendererMixin.java b/common/src/main/java/net/vulkanmod/mixin/render/LevelRendererMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/LevelRendererMixin.java rename to common/src/main/java/net/vulkanmod/mixin/render/LevelRendererMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/render/MainTargetMixin.java b/common/src/main/java/net/vulkanmod/mixin/render/MainTargetMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/MainTargetMixin.java rename to common/src/main/java/net/vulkanmod/mixin/render/MainTargetMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/render/MinecraftMixin.java b/common/src/main/java/net/vulkanmod/mixin/render/MinecraftMixin.java similarity index 91% rename from src/main/java/net/vulkanmod/mixin/render/MinecraftMixin.java rename to common/src/main/java/net/vulkanmod/mixin/render/MinecraftMixin.java index 61ec528a4..5e76308ce 100644 --- a/src/main/java/net/vulkanmod/mixin/render/MinecraftMixin.java +++ b/common/src/main/java/net/vulkanmod/mixin/render/MinecraftMixin.java @@ -21,20 +21,17 @@ import net.minecraft.server.packs.resources.ReloadableResourceManager; import net.vulkanmod.Initializer; import net.vulkanmod.render.profiling.Profiler2; -import net.vulkanmod.render.texture.SpriteUtil; import net.vulkanmod.vulkan.Renderer; import net.vulkanmod.vulkan.Vulkan; import org.slf4j.Logger; import org.spongepowered.asm.mixin.Final; import org.spongepowered.asm.mixin.Mixin; -import org.spongepowered.asm.mixin.Overwrite; 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.Redirect; import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable; -import org.spongepowered.asm.mixin.injection.callback.LocalCapture; import java.util.Optional; @@ -108,13 +105,6 @@ private Optional removeTimer() { return Optional.empty(); } - @Inject(method = "runTick", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/Minecraft;tick()V"), - locals = LocalCapture.CAPTURE_FAILHARD) - private void redirectResourceTick(boolean bl, CallbackInfo ci, long l, Runnable runnable, int i, int j) { - int n = Math.min(10, i) - 1; - SpriteUtil.setDoUpload(j == n); - } - @Inject(method = "runTick", at = @At(value = "HEAD")) private void resetBuffers(boolean bl, CallbackInfo ci) { Renderer.getInstance().resetBuffers(); diff --git a/src/main/java/net/vulkanmod/mixin/render/RenderSystemMixin.java b/common/src/main/java/net/vulkanmod/mixin/render/RenderSystemMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/RenderSystemMixin.java rename to common/src/main/java/net/vulkanmod/mixin/render/RenderSystemMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/render/RenderTargetMixin.java b/common/src/main/java/net/vulkanmod/mixin/render/RenderTargetMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/RenderTargetMixin.java rename to common/src/main/java/net/vulkanmod/mixin/render/RenderTargetMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/render/ShaderInstanceM.java b/common/src/main/java/net/vulkanmod/mixin/render/ShaderInstanceM.java similarity index 95% rename from src/main/java/net/vulkanmod/mixin/render/ShaderInstanceM.java rename to common/src/main/java/net/vulkanmod/mixin/render/ShaderInstanceM.java index df6932229..a90f86280 100644 --- a/src/main/java/net/vulkanmod/mixin/render/ShaderInstanceM.java +++ b/common/src/main/java/net/vulkanmod/mixin/render/ShaderInstanceM.java @@ -1,12 +1,10 @@ package net.vulkanmod.mixin.render; import com.google.gson.JsonObject; -import com.mojang.blaze3d.platform.Window; import com.mojang.blaze3d.shaders.Program; import com.mojang.blaze3d.shaders.Uniform; import com.mojang.blaze3d.systems.RenderSystem; import com.mojang.blaze3d.vertex.VertexFormat; -import net.minecraft.client.Minecraft; import net.minecraft.client.renderer.ShaderInstance; import net.minecraft.resources.ResourceLocation; import net.minecraft.server.packs.resources.Resource; @@ -14,9 +12,10 @@ import net.minecraft.util.GsonHelper; import net.vulkanmod.Initializer; import net.vulkanmod.interfaces.ShaderMixed; +import net.vulkanmod.vulkan.shader.GraphicsPipeline; import net.vulkanmod.vulkan.shader.Pipeline; import net.vulkanmod.vulkan.shader.layout.Field; -import net.vulkanmod.vulkan.shader.layout.UBO; +import net.vulkanmod.vulkan.shader.descriptor.UBO; import net.vulkanmod.vulkan.shader.parser.GlslConverter; import net.vulkanmod.vulkan.util.MappedBuffer; import org.apache.commons.io.IOUtils; @@ -50,11 +49,11 @@ public class ShaderInstanceM implements ShaderMixed { @Shadow @Final @Nullable public Uniform PROJECTION_MATRIX; @Shadow @Final @Nullable public Uniform COLOR_MODULATOR; @Shadow @Final @Nullable public Uniform LINE_WIDTH; - private Pipeline pipeline; + private GraphicsPipeline pipeline; boolean isLegacy = false; - public Pipeline getPipeline() { + public GraphicsPipeline getPipeline() { return pipeline; } @@ -69,7 +68,7 @@ private void create(ResourceProvider resourceProvider, String name, VertexFormat Pipeline.Builder pipelineBuilder = new Pipeline.Builder(format, path); pipelineBuilder.parseBindingsJSON(); pipelineBuilder.compileShaders(); - this.pipeline = pipelineBuilder.createPipeline(); + this.pipeline = pipelineBuilder.createGraphicsPipeline(); } @Inject(method = "getOrCreate", at = @At("HEAD"), cancellable = true) @@ -194,7 +193,7 @@ private void createLegacyShader(ResourceProvider resourceProvider, ResourceLocat builder.setUniforms(Collections.singletonList(ubo), converter.getSamplerList()); builder.compileShaders(converter.getVshConverted(), converter.getFshConverted()); - this.pipeline = builder.createPipeline(); + this.pipeline = builder.createGraphicsPipeline(); this.isLegacy = true; } catch (Throwable throwable) { diff --git a/common/src/main/java/net/vulkanmod/mixin/render/entity/EntityRendererM.java b/common/src/main/java/net/vulkanmod/mixin/render/entity/EntityRendererM.java new file mode 100644 index 000000000..e4af8f380 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/mixin/render/entity/EntityRendererM.java @@ -0,0 +1,54 @@ +package net.vulkanmod.mixin.render.entity; + +import net.minecraft.client.renderer.culling.Frustum; +import net.minecraft.client.renderer.entity.EntityRenderer; +import net.minecraft.world.entity.Entity; +import net.minecraft.world.phys.AABB; +import net.minecraft.world.phys.Vec3; +import net.vulkanmod.Initializer; +import net.vulkanmod.render.chunk.WorldRenderer; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Redirect; + +@Mixin(EntityRenderer.class) +public class EntityRendererM { + +// /** +// * @author +// * @reason +// */ +// @Overwrite +// public boolean shouldRender(T entity, Frustum frustum, double d, double e, double f) { +// if (!entity.shouldRender(d, e, f)) { +// return false; +// } else if (entity.noCulling) { +// return true; +// } else { +// AABB aABB = entity.getBoundingBoxForCulling().inflate(0.5); +// if (aABB.hasNaN() || aABB.getSize() == 0.0) { +// aABB = new AABB(entity.getX() - 2.0, entity.getY() - 2.0, entity.getZ() - 2.0, entity.getX() + 2.0, entity.getY() + 2.0, entity.getZ() + 2.0); +// } +// +//// WorldRenderer.getInstance().getSectionGrid().getSectionAtBlockPos((int) entity.getX(), (int) entity.getY(), (int) entity.getZ()); +// WorldRenderer worldRenderer = WorldRenderer.getInstance(); +//// return (worldRenderer.getLastFrame() == worldRenderer.getSectionGrid().getSectionAtBlockPos(entity.getBlockX(), entity.getBlockY(), entity.getBlockZ()).getLastFrame()); +// +// return frustum.isVisible(aABB); +// } +// } + + @Redirect(method = "shouldRender", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/renderer/culling/Frustum;isVisible(Lnet/minecraft/world/phys/AABB;)Z")) + private boolean isVisible(Frustum frustum, AABB aABB) { + if(Initializer.CONFIG.entityCulling) { + WorldRenderer worldRenderer = WorldRenderer.getInstance(); + + Vec3 pos = aABB.getCenter(); + + return (worldRenderer.getLastFrame() == worldRenderer.getSectionGrid().getSectionAtBlockPos((int) pos.x(), (int) pos.y(), (int) pos.z()).getLastFrame()); + } else { + return frustum.isVisible(aABB); + } + + } +} diff --git a/src/main/java/net/vulkanmod/mixin/render/model/ModelPartCubeM.java b/common/src/main/java/net/vulkanmod/mixin/render/model/ModelPartCubeM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/model/ModelPartCubeM.java rename to common/src/main/java/net/vulkanmod/mixin/render/model/ModelPartCubeM.java diff --git a/src/main/java/net/vulkanmod/mixin/render/model/ModelPartM.java b/common/src/main/java/net/vulkanmod/mixin/render/model/ModelPartM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/model/ModelPartM.java rename to common/src/main/java/net/vulkanmod/mixin/render/model/ModelPartM.java diff --git a/src/main/java/net/vulkanmod/mixin/render/vertex/BufferBuilderM.java b/common/src/main/java/net/vulkanmod/mixin/render/vertex/BufferBuilderM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/vertex/BufferBuilderM.java rename to common/src/main/java/net/vulkanmod/mixin/render/vertex/BufferBuilderM.java diff --git a/src/main/java/net/vulkanmod/mixin/render/vertex/FaceBakeryM.java b/common/src/main/java/net/vulkanmod/mixin/render/vertex/FaceBakeryM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/vertex/FaceBakeryM.java rename to common/src/main/java/net/vulkanmod/mixin/render/vertex/FaceBakeryM.java diff --git a/src/main/java/net/vulkanmod/mixin/render/vertex/IndexTypeMixin.java b/common/src/main/java/net/vulkanmod/mixin/render/vertex/IndexTypeMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/vertex/IndexTypeMixin.java rename to common/src/main/java/net/vulkanmod/mixin/render/vertex/IndexTypeMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/render/vertex/LiquidBlockRendererM.java b/common/src/main/java/net/vulkanmod/mixin/render/vertex/LiquidBlockRendererM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/vertex/LiquidBlockRendererM.java rename to common/src/main/java/net/vulkanmod/mixin/render/vertex/LiquidBlockRendererM.java diff --git a/src/main/java/net/vulkanmod/mixin/render/vertex/VertexBufferM.java b/common/src/main/java/net/vulkanmod/mixin/render/vertex/VertexBufferM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/vertex/VertexBufferM.java rename to common/src/main/java/net/vulkanmod/mixin/render/vertex/VertexBufferM.java diff --git a/src/main/java/net/vulkanmod/mixin/render/vertex/VertexConsumerM.java b/common/src/main/java/net/vulkanmod/mixin/render/vertex/VertexConsumerM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/vertex/VertexConsumerM.java rename to common/src/main/java/net/vulkanmod/mixin/render/vertex/VertexConsumerM.java diff --git a/src/main/java/net/vulkanmod/mixin/render/vertex/VertexFormatMixin.java b/common/src/main/java/net/vulkanmod/mixin/render/vertex/VertexFormatMixin.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/render/vertex/VertexFormatMixin.java rename to common/src/main/java/net/vulkanmod/mixin/render/vertex/VertexFormatMixin.java diff --git a/src/main/java/net/vulkanmod/mixin/screen/OptionsScreenM.java b/common/src/main/java/net/vulkanmod/mixin/screen/OptionsScreenM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/screen/OptionsScreenM.java rename to common/src/main/java/net/vulkanmod/mixin/screen/OptionsScreenM.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MAbstractTexture.java b/common/src/main/java/net/vulkanmod/mixin/texture/MAbstractTexture.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MAbstractTexture.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MAbstractTexture.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MDynamicTexture.java b/common/src/main/java/net/vulkanmod/mixin/texture/MDynamicTexture.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MDynamicTexture.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MDynamicTexture.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MFontTexture.java b/common/src/main/java/net/vulkanmod/mixin/texture/MFontTexture.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MFontTexture.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MFontTexture.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MLightTexture.java b/common/src/main/java/net/vulkanmod/mixin/texture/MLightTexture.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MLightTexture.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MLightTexture.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MNativeImage.java b/common/src/main/java/net/vulkanmod/mixin/texture/MNativeImage.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MNativeImage.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MNativeImage.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MOverlayTexture.java b/common/src/main/java/net/vulkanmod/mixin/texture/MOverlayTexture.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MOverlayTexture.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MOverlayTexture.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MPlayerSkinTexture.java b/common/src/main/java/net/vulkanmod/mixin/texture/MPlayerSkinTexture.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MPlayerSkinTexture.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MPlayerSkinTexture.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MSimpleTexture.java b/common/src/main/java/net/vulkanmod/mixin/texture/MSimpleTexture.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MSimpleTexture.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MSimpleTexture.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MSpriteAtlasTexture.java b/common/src/main/java/net/vulkanmod/mixin/texture/MSpriteAtlasTexture.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MSpriteAtlasTexture.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MSpriteAtlasTexture.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MSpriteContents.java b/common/src/main/java/net/vulkanmod/mixin/texture/MSpriteContents.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MSpriteContents.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MSpriteContents.java diff --git a/src/main/java/net/vulkanmod/mixin/texture/MTextureManager.java b/common/src/main/java/net/vulkanmod/mixin/texture/MTextureManager.java similarity index 71% rename from src/main/java/net/vulkanmod/mixin/texture/MTextureManager.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MTextureManager.java index c6747dcdb..dfcca58bc 100644 --- a/src/main/java/net/vulkanmod/mixin/texture/MTextureManager.java +++ b/common/src/main/java/net/vulkanmod/mixin/texture/MTextureManager.java @@ -5,6 +5,8 @@ import net.minecraft.client.renderer.texture.TextureManager; import net.minecraft.client.renderer.texture.Tickable; import net.minecraft.resources.ResourceLocation; +import net.vulkanmod.render.texture.SpriteUtil; +import net.vulkanmod.vulkan.Device; import net.vulkanmod.vulkan.Renderer; import org.spongepowered.asm.mixin.Final; import org.spongepowered.asm.mixin.Mixin; @@ -31,16 +33,16 @@ public void tick() { return; //Debug D -// if(SpriteUtil.shouldUpload()) -// GraphicsQueue.getInstance().startRecording(); -// for (Tickable tickable : this.tickableTextures) { -// tickable.tick(); -// } -// if(SpriteUtil.shouldUpload()) { -// SpriteUtil.transitionLayouts(GraphicsQueue.getInstance().getCommandBuffer()); -// GraphicsQueue.getInstance().endRecordingAndSubmit(); -//// Synchronization.INSTANCE.waitFences(); -// } + if(SpriteUtil.shouldUpload()) + Device.getGraphicsQueue().startRecording(); + for (Tickable tickable : this.tickableTextures) { + tickable.tick(); + } + if(SpriteUtil.shouldUpload()) { + SpriteUtil.transitionLayouts(Device.getGraphicsQueue().getCommandBuffer()); + Device.getGraphicsQueue().endRecordingAndSubmit(); +// Synchronization.INSTANCE.waitFences(); + } } /** diff --git a/src/main/java/net/vulkanmod/mixin/texture/MTextureUtil.java b/common/src/main/java/net/vulkanmod/mixin/texture/MTextureUtil.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/texture/MTextureUtil.java rename to common/src/main/java/net/vulkanmod/mixin/texture/MTextureUtil.java diff --git a/src/main/java/net/vulkanmod/mixin/util/ScreenshotRecorderM.java b/common/src/main/java/net/vulkanmod/mixin/util/ScreenshotRecorderM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/util/ScreenshotRecorderM.java rename to common/src/main/java/net/vulkanmod/mixin/util/ScreenshotRecorderM.java diff --git a/src/main/java/net/vulkanmod/mixin/vertex/SpriteCoordinateExpanderM.java b/common/src/main/java/net/vulkanmod/mixin/vertex/SpriteCoordinateExpanderM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/vertex/SpriteCoordinateExpanderM.java rename to common/src/main/java/net/vulkanmod/mixin/vertex/SpriteCoordinateExpanderM.java diff --git a/src/main/java/net/vulkanmod/mixin/vertex/VertexMultiConsumersM.java b/common/src/main/java/net/vulkanmod/mixin/vertex/VertexMultiConsumersM.java similarity index 100% rename from src/main/java/net/vulkanmod/mixin/vertex/VertexMultiConsumersM.java rename to common/src/main/java/net/vulkanmod/mixin/vertex/VertexMultiConsumersM.java diff --git a/src/main/java/net/vulkanmod/render/VBO.java b/common/src/main/java/net/vulkanmod/render/VBO.java similarity index 96% rename from src/main/java/net/vulkanmod/render/VBO.java rename to common/src/main/java/net/vulkanmod/render/VBO.java index 8cf3415b3..df32109b0 100644 --- a/src/main/java/net/vulkanmod/render/VBO.java +++ b/common/src/main/java/net/vulkanmod/render/VBO.java @@ -10,6 +10,7 @@ import net.vulkanmod.vulkan.Renderer; import net.vulkanmod.vulkan.VRenderSystem; import net.vulkanmod.vulkan.memory.*; +import net.vulkanmod.vulkan.shader.GraphicsPipeline; import net.vulkanmod.vulkan.shader.Pipeline; import org.joml.Matrix4f; @@ -105,14 +106,14 @@ public void drawWithShader(Matrix4f MV, Matrix4f P, ShaderInstance shader) { } } - public void drawWithShader(Matrix4f MV, Matrix4f P, Pipeline pipeline) { + public void drawWithShader(Matrix4f MV, Matrix4f P, GraphicsPipeline pipeline) { if (this.indexCount != 0) { RenderSystem.assertOnRenderThread(); VRenderSystem.applyMVP(MV, P); Renderer renderer = Renderer.getInstance(); - renderer.bindPipeline(pipeline); + renderer.bindGraphicsPipeline(pipeline); renderer.uploadAndBindUBOs(pipeline); if(indexBuffer != null) diff --git a/src/main/java/net/vulkanmod/render/chunk/AreaBuffer.java b/common/src/main/java/net/vulkanmod/render/chunk/AreaBuffer.java similarity index 97% rename from src/main/java/net/vulkanmod/render/chunk/AreaBuffer.java rename to common/src/main/java/net/vulkanmod/render/chunk/AreaBuffer.java index 7c68726ee..70b3247ed 100644 --- a/src/main/java/net/vulkanmod/render/chunk/AreaBuffer.java +++ b/common/src/main/java/net/vulkanmod/render/chunk/AreaBuffer.java @@ -2,6 +2,7 @@ import it.unimi.dsi.fastutil.objects.Reference2ReferenceOpenHashMap; import net.vulkanmod.render.chunk.util.Util; +import net.vulkanmod.vulkan.Device; import net.vulkanmod.vulkan.memory.*; import net.vulkanmod.vulkan.queue.TransferQueue; @@ -122,7 +123,7 @@ public Segment reallocate(int uploadSize) { AreaUploadManager.INSTANCE.waitAllUploads(); //Sync upload - TransferQueue.getInstance().uploadBufferImmediate(this.buffer.getId(), 0, buffer.getId(), 0, this.buffer.getBufferSize()); + Device.getTransferQueue().uploadBufferImmediate(this.buffer.getId(), 0, buffer.getId(), 0, this.buffer.getBufferSize()); this.buffer.freeBuffer(); this.buffer = buffer; diff --git a/src/main/java/net/vulkanmod/render/chunk/AreaUploadManager.java b/common/src/main/java/net/vulkanmod/render/chunk/AreaUploadManager.java similarity index 92% rename from src/main/java/net/vulkanmod/render/chunk/AreaUploadManager.java rename to common/src/main/java/net/vulkanmod/render/chunk/AreaUploadManager.java index 258bf735a..73601d63d 100644 --- a/src/main/java/net/vulkanmod/render/chunk/AreaUploadManager.java +++ b/common/src/main/java/net/vulkanmod/render/chunk/AreaUploadManager.java @@ -45,15 +45,15 @@ public synchronized void submitUploads() { if(this.recordedUploads[this.currentFrame].isEmpty()) return; - TransferQueue.getInstance().submitCommands(this.commandBuffers[currentFrame]); + Device.getTransferQueue().submitCommands(this.commandBuffers[currentFrame]); } public void uploadAsync(AreaBuffer.Segment uploadSegment, long bufferId, long dstOffset, long bufferSize, ByteBuffer src) { Validate.isTrue(currentFrame == Renderer.getCurrentFrame()); if(commandBuffers[currentFrame] == null) - this.commandBuffers[currentFrame] = TransferQueue.getInstance().beginCommands(); -// this.commandBuffers[currentFrame] = GraphicsQueue.getInstance().beginCommands(); + this.commandBuffers[currentFrame] = Device.getTransferQueue().beginCommands(); +// this.commandBuffers[currentFrame] = Device.getGraphicsQueue().beginCommands(); StagingBuffer stagingBuffer = Vulkan.getStagingBuffer(this.currentFrame); stagingBuffer.copyBuffer((int) bufferSize, src); @@ -77,7 +77,7 @@ public void copy(Buffer src, Buffer dst) { } if(commandBuffers[currentFrame] == null) - this.commandBuffers[currentFrame] = TransferQueue.getInstance().beginCommands(); + this.commandBuffers[currentFrame] = Device.getTransferQueue().beginCommands(); TransferQueue.uploadBufferCmd(this.commandBuffers[currentFrame], src.getId(), 0, dst.getId(), 0, src.getBufferSize()); } diff --git a/src/main/java/net/vulkanmod/render/chunk/ChunkArea.java b/common/src/main/java/net/vulkanmod/render/chunk/ChunkArea.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/ChunkArea.java rename to common/src/main/java/net/vulkanmod/render/chunk/ChunkArea.java diff --git a/src/main/java/net/vulkanmod/render/chunk/ChunkAreaManager.java b/common/src/main/java/net/vulkanmod/render/chunk/ChunkAreaManager.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/ChunkAreaManager.java rename to common/src/main/java/net/vulkanmod/render/chunk/ChunkAreaManager.java diff --git a/src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java b/common/src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java similarity index 97% rename from src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java rename to common/src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java index 481b74bfb..580697713 100644 --- a/src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java +++ b/common/src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java @@ -7,7 +7,6 @@ import net.vulkanmod.vulkan.Renderer; import net.vulkanmod.vulkan.memory.IndirectBuffer; import net.vulkanmod.vulkan.shader.Pipeline; -import net.vulkanmod.vulkan.shader.ShaderManager; import org.lwjgl.system.MemoryStack; import org.lwjgl.system.MemoryUtil; import org.lwjgl.vulkan.VkCommandBuffer; @@ -19,7 +18,7 @@ public class DrawBuffers { - private static final int VERTEX_SIZE = ShaderManager.TERRAIN_VERTEX_FORMAT.getVertexSize(); + private static final int VERTEX_SIZE = TerrainShaderManager.TERRAIN_VERTEX_FORMAT.getVertexSize(); private static final int INDEX_SIZE = Short.BYTES; private boolean allocated = false; @@ -85,7 +84,7 @@ public int buildDrawBatchesIndirect(IndirectBuffer indirectBuffer, ChunkArea chu terrainRenderType.setCutoutUniform(); boolean isTranslucent = terrainRenderType == TerrainRenderType.TRANSLUCENT; - Pipeline pipeline = ShaderManager.getInstance().getTerrainIndirectShader(renderType); + Pipeline pipeline = TerrainShaderManager.getTerrainIndirectShader(renderType); if(isTranslucent) { vkCmdBindIndexBuffer(Renderer.getCommandBuffer(), this.indexBuffer.getId(), 0, VK_INDEX_TYPE_UINT16); @@ -168,7 +167,7 @@ public int buildDrawBatchesIndirect(IndirectBuffer indirectBuffer, ChunkArea chu } private static void fakeIndirectCmd(VkCommandBuffer commandBuffer, IndirectBuffer indirectBuffer, int drawCount, ByteBuffer offsetBuffer) { - Pipeline pipeline = ShaderManager.shaderManager.terrainDirectShader; + Pipeline pipeline = TerrainShaderManager.getTerrainDirectShader(null); // Drawer.getInstance().bindPipeline(pipeline); pipeline.bindDescriptorSets(Renderer.getCommandBuffer(), Renderer.getCurrentFrame()); // pipeline.bindDescriptorSets(Drawer.getCommandBuffer(), WorldRenderer.getInstance().getUniformBuffers(), Drawer.getCurrentFrame()); diff --git a/src/main/java/net/vulkanmod/render/chunk/RenderSection.java b/common/src/main/java/net/vulkanmod/render/chunk/RenderSection.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/RenderSection.java rename to common/src/main/java/net/vulkanmod/render/chunk/RenderSection.java diff --git a/src/main/java/net/vulkanmod/render/chunk/SectionGrid.java b/common/src/main/java/net/vulkanmod/render/chunk/SectionGrid.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/SectionGrid.java rename to common/src/main/java/net/vulkanmod/render/chunk/SectionGrid.java diff --git a/common/src/main/java/net/vulkanmod/render/chunk/TerrainShaderManager.java b/common/src/main/java/net/vulkanmod/render/chunk/TerrainShaderManager.java new file mode 100644 index 000000000..affbeeea8 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/render/chunk/TerrainShaderManager.java @@ -0,0 +1,69 @@ +package net.vulkanmod.render.chunk; + +import com.mojang.blaze3d.vertex.VertexFormat; +import net.minecraft.client.renderer.RenderType; +import net.vulkanmod.Initializer; +import net.vulkanmod.render.vertex.CustomVertexFormat; +import net.vulkanmod.vulkan.shader.GraphicsPipeline; +import net.vulkanmod.vulkan.shader.Pipeline; + +import java.util.function.Consumer; +import java.util.function.Function; + +public abstract class TerrainShaderManager { + public static VertexFormat TERRAIN_VERTEX_FORMAT; + + public static void setTerrainVertexFormat(VertexFormat format) { + TERRAIN_VERTEX_FORMAT = format; + } + + static GraphicsPipeline terrainIndirectShader; + public static GraphicsPipeline terrainDirectShader; + + private static Function shaderGetter; + + public static void init() { + setTerrainVertexFormat(CustomVertexFormat.COMPRESSED_TERRAIN); + createBasicPipelines(); + setDefaultShader(); + } + + public static void setDefaultShader() { + setShaderGetter(renderType -> Initializer.CONFIG.indirectDraw ? terrainIndirectShader : terrainDirectShader); + } + + private static void createBasicPipelines() { + terrainIndirectShader = createPipeline("terrain_indirect"); + terrainDirectShader = createPipeline("terrain_direct"); + } + + private static GraphicsPipeline createPipeline(String name) { + String path = String.format("basic/%s/%s", name, name); + + Pipeline.Builder pipelineBuilder = new Pipeline.Builder(CustomVertexFormat.COMPRESSED_TERRAIN, path); + pipelineBuilder.parseBindingsJSON(); + pipelineBuilder.compileShaders(); + return pipelineBuilder.createGraphicsPipeline(); + } + + public static GraphicsPipeline getTerrainShader(RenderType renderType) { + return shaderGetter.apply(renderType); + } + + public static void setShaderGetter(Function consumer) { + shaderGetter = consumer; + } + + public static GraphicsPipeline getTerrainDirectShader(RenderType renderType) { + return terrainDirectShader; + } + + public static GraphicsPipeline getTerrainIndirectShader(RenderType renderType) { + return terrainIndirectShader; + } + + public static void destroyPipelines() { + terrainIndirectShader.cleanUp(); + terrainDirectShader.cleanUp(); + } +} diff --git a/src/main/java/net/vulkanmod/render/chunk/VFrustum.java b/common/src/main/java/net/vulkanmod/render/chunk/VFrustum.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/VFrustum.java rename to common/src/main/java/net/vulkanmod/render/chunk/VFrustum.java diff --git a/src/main/java/net/vulkanmod/render/chunk/WorldRenderer.java b/common/src/main/java/net/vulkanmod/render/chunk/WorldRenderer.java similarity index 96% rename from src/main/java/net/vulkanmod/render/chunk/WorldRenderer.java rename to common/src/main/java/net/vulkanmod/render/chunk/WorldRenderer.java index 6826c52b0..c5e8fa0e5 100644 --- a/src/main/java/net/vulkanmod/render/chunk/WorldRenderer.java +++ b/common/src/main/java/net/vulkanmod/render/chunk/WorldRenderer.java @@ -42,12 +42,11 @@ import net.vulkanmod.vulkan.memory.Buffer; import net.vulkanmod.vulkan.memory.IndirectBuffer; import net.vulkanmod.vulkan.memory.MemoryTypes; -import net.vulkanmod.vulkan.shader.Pipeline; -import net.vulkanmod.vulkan.shader.ShaderManager; +import net.vulkanmod.vulkan.shader.GraphicsPipeline; +import org.jetbrains.annotations.Nullable; import org.joml.FrustumIntersection; import org.joml.Matrix4f; -import javax.annotation.Nullable; import java.util.*; public class WorldRenderer { @@ -91,6 +90,8 @@ public class WorldRenderer { public RenderRegionCache renderRegionCache; int nonEmptyChunks; + private final List onAllChangedCallbacks = new ObjectArrayList<>(); + private WorldRenderer(RenderBuffers renderBuffers) { this.minecraft = Minecraft.getInstance(); this.renderBuffers = renderBuffers; @@ -195,7 +196,7 @@ public void setupRenderer(Camera camera, Frustum frustum, boolean isCapturedFrus if (!isCapturedFrustum) { //Debug -// this.needsUpdate = true; + this.needsUpdate = true; // this.needsUpdate = false; if (this.needsUpdate) { @@ -214,6 +215,7 @@ public void setupRenderer(Camera camera, Frustum frustum, boolean isCapturedFrus this.minecraft.getProfiler().push("partial_update"); this.chunkQueue.clear(); + this.initUpdate(); this.initializeQueueForFullUpdate(camera); this.renderRegionCache = new RenderRegionCache(); @@ -258,6 +260,7 @@ private void initializeQueueForFullUpdate(Camera camera) { RenderSection renderSection1 = this.sectionGrid.getSectionAtBlockPos(new BlockPos(k + SectionPos.sectionToBlockCoord(i1, 8), j, l + SectionPos.sectionToBlockCoord(j1, 8))); if (renderSection1 != null) { renderSection1.setGraphInfo(null, (byte) 0); + renderSection1.setLastFrame(this.lastFrame); list.add(renderSection1); } @@ -275,6 +278,7 @@ private void initializeQueueForFullUpdate(Camera camera) { } else { renderSection.setGraphInfo(null, (byte) 0); + renderSection.setLastFrame(this.lastFrame); this.chunkQueue.add(renderSection); } @@ -295,7 +299,7 @@ private void resetUpdateQueues() { private void updateRenderChunks() { int maxDirectionsChanges = Initializer.CONFIG.advCulling; - this.initUpdate(); +// this.initUpdate(); int rebuildLimit = taskDispatcher.getIdleThreadsCount(); // int rebuildLimit = 32; @@ -492,6 +496,8 @@ public void allChanged() { this.sectionGrid = new SectionGrid(this.level, this.minecraft.options.getEffectiveRenderDistance()); this.chunkAreaQueue = new AreaSetQueue(this.sectionGrid.chunkAreaManager.size); + this.onAllChangedCallbacks.forEach(Runnable::run); + Entity entity = this.minecraft.getCameraEntity(); if (entity != null) { this.sectionGrid.repositionCamera(entity.getX(), entity.getZ()); @@ -510,10 +516,8 @@ public void setLevel(@Nullable ClientLevel level) { // this.entityRenderDispatcher.setLevel(level); this.level = level; if (level != null) { - if(this.sectionGrid == null) { - this.allChanged(); - } - } else { + this.allChanged(); + } else { if (this.sectionGrid != null) { this.sectionGrid.releaseAllBuffers(); this.sectionGrid = null; @@ -526,6 +530,14 @@ public void setLevel(@Nullable ClientLevel level) { } + public void addOnAllChangedCallback(Runnable runnable) { + this.onAllChangedCallbacks.add(runnable); + } + + public void clearOnAllChangedCallbacks() { + this.onAllChangedCallbacks.clear(); + } + public void renderChunkLayer(RenderType renderType, PoseStack poseStack, double camX, double camY, double camZ, Matrix4f projection) { //debug // Profiler p = Profiler.getProfiler("chunks"); @@ -574,8 +586,8 @@ else if(layerName.equals("translucent")) VRenderSystem.applyMVP(poseStack.last().pose(), projection); Renderer renderer = Renderer.getInstance(); - Pipeline pipeline = ShaderManager.getInstance().getTerrainShader(renderType); - renderer.bindPipeline(pipeline); + GraphicsPipeline pipeline = TerrainShaderManager.getTerrainShader(renderType); + renderer.bindGraphicsPipeline(pipeline); Renderer.getDrawer().bindAutoIndexBuffer(Renderer.getCommandBuffer(), 7); p.push("draw batches"); @@ -732,4 +744,9 @@ public String getChunkStatistics() { return String.format("Chunks: %d(%d)/%d D: %d, %s", this.nonEmptyChunks, j, i, this.lastViewDistance, tasksInfo); } + public void cleanUp() { + if(indirectBuffers != null) + Arrays.stream(indirectBuffers).forEach(Buffer::freeBuffer); + } + } diff --git a/src/main/java/net/vulkanmod/render/chunk/build/ChunkTask.java b/common/src/main/java/net/vulkanmod/render/chunk/build/ChunkTask.java similarity index 98% rename from src/main/java/net/vulkanmod/render/chunk/build/ChunkTask.java rename to common/src/main/java/net/vulkanmod/render/chunk/build/ChunkTask.java index 1ebd40f2c..b2c36508f 100644 --- a/src/main/java/net/vulkanmod/render/chunk/build/ChunkTask.java +++ b/common/src/main/java/net/vulkanmod/render/chunk/build/ChunkTask.java @@ -25,7 +25,7 @@ import net.vulkanmod.render.chunk.WorldRenderer; import net.vulkanmod.render.vertex.TerrainBufferBuilder; import net.vulkanmod.render.vertex.TerrainRenderType; -import net.vulkanmod.vulkan.shader.ShaderManager; +import net.vulkanmod.render.chunk.TerrainShaderManager; import javax.annotation.Nullable; import java.util.*; @@ -167,7 +167,7 @@ private CompileResults compile(float camX, float camY, float camZ, ThreadBuilder bufferBuilder = chunkBufferBuilderPack.builder(renderType); if (set.add(renderType)) { - bufferBuilder.begin(VertexFormat.Mode.QUADS, ShaderManager.TERRAIN_VERTEX_FORMAT); + bufferBuilder.begin(VertexFormat.Mode.QUADS, TerrainShaderManager.TERRAIN_VERTEX_FORMAT); } blockRenderDispatcher.renderLiquid(blockPos3, renderChunkRegion, bufferBuilder, blockState2, fluidState); @@ -181,7 +181,7 @@ private CompileResults compile(float camX, float camY, float camZ, ThreadBuilder bufferBuilder = chunkBufferBuilderPack.builder(renderType); if (set.add(renderType)) { - bufferBuilder.begin(VertexFormat.Mode.QUADS, ShaderManager.TERRAIN_VERTEX_FORMAT); + bufferBuilder.begin(VertexFormat.Mode.QUADS, TerrainShaderManager.TERRAIN_VERTEX_FORMAT); } poseStack.pushPose(); @@ -291,7 +291,7 @@ public CompletableFuture doTask(ThreadBuilderPack builderPack) { TerrainBufferBuilder.SortState transparencyState = this.compiledSection.transparencyState; if (transparencyState != null && this.compiledSection.renderTypes.contains(TerrainRenderType.TRANSLUCENT)) { TerrainBufferBuilder bufferbuilder = builderPack.builder(RenderType.translucent()); - bufferbuilder.begin(VertexFormat.Mode.QUADS, ShaderManager.TERRAIN_VERTEX_FORMAT); + bufferbuilder.begin(VertexFormat.Mode.QUADS, TerrainShaderManager.TERRAIN_VERTEX_FORMAT); bufferbuilder.restoreSortState(transparencyState); // bufferbuilder.setQuadSortOrigin(f - (float) this.renderSection.origin.getX(), f1 - (float) renderSection.origin.getY(), f2 - (float) renderSection.origin.getZ()); bufferbuilder.setQuadSortOrigin(f - (float) this.renderSection.xOffset(), f1 - (float) renderSection.yOffset(), f2 - (float) renderSection.zOffset()); diff --git a/src/main/java/net/vulkanmod/render/chunk/build/CompiledSection.java b/common/src/main/java/net/vulkanmod/render/chunk/build/CompiledSection.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/build/CompiledSection.java rename to common/src/main/java/net/vulkanmod/render/chunk/build/CompiledSection.java diff --git a/src/main/java/net/vulkanmod/render/chunk/build/LiquidRenderer.java b/common/src/main/java/net/vulkanmod/render/chunk/build/LiquidRenderer.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/build/LiquidRenderer.java rename to common/src/main/java/net/vulkanmod/render/chunk/build/LiquidRenderer.java diff --git a/src/main/java/net/vulkanmod/render/chunk/build/TaskDispatcher.java b/common/src/main/java/net/vulkanmod/render/chunk/build/TaskDispatcher.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/build/TaskDispatcher.java rename to common/src/main/java/net/vulkanmod/render/chunk/build/TaskDispatcher.java diff --git a/src/main/java/net/vulkanmod/render/chunk/build/ThreadBuilderPack.java b/common/src/main/java/net/vulkanmod/render/chunk/build/ThreadBuilderPack.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/build/ThreadBuilderPack.java rename to common/src/main/java/net/vulkanmod/render/chunk/build/ThreadBuilderPack.java diff --git a/src/main/java/net/vulkanmod/render/chunk/build/UploadBuffer.java b/common/src/main/java/net/vulkanmod/render/chunk/build/UploadBuffer.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/build/UploadBuffer.java rename to common/src/main/java/net/vulkanmod/render/chunk/build/UploadBuffer.java diff --git a/src/main/java/net/vulkanmod/render/chunk/util/AreaSetQueue.java b/common/src/main/java/net/vulkanmod/render/chunk/util/AreaSetQueue.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/util/AreaSetQueue.java rename to common/src/main/java/net/vulkanmod/render/chunk/util/AreaSetQueue.java diff --git a/src/main/java/net/vulkanmod/render/chunk/util/CircularIntList.java b/common/src/main/java/net/vulkanmod/render/chunk/util/CircularIntList.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/util/CircularIntList.java rename to common/src/main/java/net/vulkanmod/render/chunk/util/CircularIntList.java diff --git a/src/main/java/net/vulkanmod/render/chunk/util/ResettableQueue.java b/common/src/main/java/net/vulkanmod/render/chunk/util/ResettableQueue.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/util/ResettableQueue.java rename to common/src/main/java/net/vulkanmod/render/chunk/util/ResettableQueue.java diff --git a/src/main/java/net/vulkanmod/render/chunk/util/Util.java b/common/src/main/java/net/vulkanmod/render/chunk/util/Util.java similarity index 100% rename from src/main/java/net/vulkanmod/render/chunk/util/Util.java rename to common/src/main/java/net/vulkanmod/render/chunk/util/Util.java diff --git a/src/main/java/net/vulkanmod/render/gui/GuiBatchRenderer.java b/common/src/main/java/net/vulkanmod/render/gui/GuiBatchRenderer.java similarity index 100% rename from src/main/java/net/vulkanmod/render/gui/GuiBatchRenderer.java rename to common/src/main/java/net/vulkanmod/render/gui/GuiBatchRenderer.java diff --git a/src/main/java/net/vulkanmod/render/model/CubeModel.java b/common/src/main/java/net/vulkanmod/render/model/CubeModel.java similarity index 100% rename from src/main/java/net/vulkanmod/render/model/CubeModel.java rename to common/src/main/java/net/vulkanmod/render/model/CubeModel.java diff --git a/src/main/java/net/vulkanmod/render/profiling/Profiler.java b/common/src/main/java/net/vulkanmod/render/profiling/Profiler.java similarity index 100% rename from src/main/java/net/vulkanmod/render/profiling/Profiler.java rename to common/src/main/java/net/vulkanmod/render/profiling/Profiler.java diff --git a/src/main/java/net/vulkanmod/render/profiling/Profiler2.java b/common/src/main/java/net/vulkanmod/render/profiling/Profiler2.java similarity index 100% rename from src/main/java/net/vulkanmod/render/profiling/Profiler2.java rename to common/src/main/java/net/vulkanmod/render/profiling/Profiler2.java diff --git a/src/main/java/net/vulkanmod/render/profiling/ProfilerOverlay.java b/common/src/main/java/net/vulkanmod/render/profiling/ProfilerOverlay.java similarity index 100% rename from src/main/java/net/vulkanmod/render/profiling/ProfilerOverlay.java rename to common/src/main/java/net/vulkanmod/render/profiling/ProfilerOverlay.java diff --git a/src/main/java/net/vulkanmod/render/texture/SpriteUtil.java b/common/src/main/java/net/vulkanmod/render/texture/SpriteUtil.java similarity index 100% rename from src/main/java/net/vulkanmod/render/texture/SpriteUtil.java rename to common/src/main/java/net/vulkanmod/render/texture/SpriteUtil.java diff --git a/src/main/java/net/vulkanmod/render/util/MathUtil.java b/common/src/main/java/net/vulkanmod/render/util/MathUtil.java similarity index 100% rename from src/main/java/net/vulkanmod/render/util/MathUtil.java rename to common/src/main/java/net/vulkanmod/render/util/MathUtil.java diff --git a/src/main/java/net/vulkanmod/render/util/SortUtil.java b/common/src/main/java/net/vulkanmod/render/util/SortUtil.java similarity index 100% rename from src/main/java/net/vulkanmod/render/util/SortUtil.java rename to common/src/main/java/net/vulkanmod/render/util/SortUtil.java diff --git a/src/main/java/net/vulkanmod/render/vertex/CustomVertexFormat.java b/common/src/main/java/net/vulkanmod/render/vertex/CustomVertexFormat.java similarity index 100% rename from src/main/java/net/vulkanmod/render/vertex/CustomVertexFormat.java rename to common/src/main/java/net/vulkanmod/render/vertex/CustomVertexFormat.java diff --git a/src/main/java/net/vulkanmod/render/vertex/TerrainBufferBuilder.java b/common/src/main/java/net/vulkanmod/render/vertex/TerrainBufferBuilder.java similarity index 97% rename from src/main/java/net/vulkanmod/render/vertex/TerrainBufferBuilder.java rename to common/src/main/java/net/vulkanmod/render/vertex/TerrainBufferBuilder.java index da40c704e..064adfb60 100644 --- a/src/main/java/net/vulkanmod/render/vertex/TerrainBufferBuilder.java +++ b/common/src/main/java/net/vulkanmod/render/vertex/TerrainBufferBuilder.java @@ -1,21 +1,15 @@ package net.vulkanmod.render.vertex; import com.google.common.collect.ImmutableList; -import com.google.common.primitives.Floats; import com.mojang.blaze3d.platform.MemoryTracker; import com.mojang.blaze3d.vertex.*; import com.mojang.logging.LogUtils; -import it.unimi.dsi.fastutil.ints.IntArrays; -import net.minecraft.client.renderer.block.model.BakedQuad; -import net.minecraft.core.Vec3i; import net.minecraft.util.Mth; import net.vulkanmod.render.util.SortUtil; -import net.vulkanmod.vulkan.shader.ShaderManager; +import net.vulkanmod.render.chunk.TerrainShaderManager; import org.apache.commons.lang3.mutable.MutableInt; import org.jetbrains.annotations.Nullable; -import org.joml.Matrix4f; import org.joml.Vector3f; -import org.joml.Vector4f; import org.lwjgl.system.MemoryUtil; import org.slf4j.Logger; @@ -59,7 +53,7 @@ public TerrainBufferBuilder(int i) { this.buffer = MemoryTracker.create(i * 6); this.bufferPtr = MemoryUtil.memAddress0(this.buffer); - this.vertexBuilder = ShaderManager.TERRAIN_VERTEX_FORMAT == CustomVertexFormat.COMPRESSED_TERRAIN ? new CompressedVertexBuilder() : new DefaultVertexBuilder(); + this.vertexBuilder = TerrainShaderManager.TERRAIN_VERTEX_FORMAT == CustomVertexFormat.COMPRESSED_TERRAIN ? new CompressedVertexBuilder() : new DefaultVertexBuilder(); } private void ensureVertexCapacity() { diff --git a/src/main/java/net/vulkanmod/render/vertex/TerrainRenderType.java b/common/src/main/java/net/vulkanmod/render/vertex/TerrainRenderType.java similarity index 100% rename from src/main/java/net/vulkanmod/render/vertex/TerrainRenderType.java rename to common/src/main/java/net/vulkanmod/render/vertex/TerrainRenderType.java diff --git a/src/main/java/net/vulkanmod/render/vertex/VertexUtil.java b/common/src/main/java/net/vulkanmod/render/vertex/VertexUtil.java similarity index 100% rename from src/main/java/net/vulkanmod/render/vertex/VertexUtil.java rename to common/src/main/java/net/vulkanmod/render/vertex/VertexUtil.java diff --git a/src/main/java/net/vulkanmod/vulkan/Device.java b/common/src/main/java/net/vulkanmod/vulkan/Device.java similarity index 87% rename from src/main/java/net/vulkanmod/vulkan/Device.java rename to common/src/main/java/net/vulkanmod/vulkan/Device.java index 9ed864cf5..52ae3c64e 100644 --- a/src/main/java/net/vulkanmod/vulkan/Device.java +++ b/common/src/main/java/net/vulkanmod/vulkan/Device.java @@ -1,7 +1,7 @@ package net.vulkanmod.vulkan; import net.vulkanmod.Initializer; -import net.vulkanmod.vulkan.queue.Queue; +import net.vulkanmod.vulkan.queue.*; import org.lwjgl.PointerBuffer; import org.lwjgl.system.MemoryStack; import org.lwjgl.vulkan.*; @@ -33,9 +33,10 @@ public class Device { public static SurfaceProperties surfaceProperties; - static VkQueue graphicsQueue; - static VkQueue presentQueue; - static VkQueue transferQueue; + static GraphicsQueue graphicsQueue; + static PresentQueue presentQueue; + static TransferQueue transferQueue; + static ComputeQueue computeQueue; static void pickPhysicalDevice(VkInstance instance) { @@ -176,16 +177,25 @@ static void createLogicalDevice() { device = new VkDevice(pDevice.get(0), physicalDevice, createInfo, VK_API_VERSION_1_2); - PointerBuffer pQueue = stack.pointers(VK_NULL_HANDLE); - - vkGetDeviceQueue(device, indices.graphicsFamily, 0, pQueue); - graphicsQueue = new VkQueue(pQueue.get(0), device); +// PointerBuffer pQueue = stack.pointers(VK_NULL_HANDLE); +// +// vkGetDeviceQueue(device, indices.graphicsFamily, 0, pQueue); +// graphicsQueue = new VkQueue(pQueue.get(0), device); +// +// vkGetDeviceQueue(device, indices.presentFamily, 0, pQueue); +// presentQueue = new VkQueue(pQueue.get(0), device); +// +// vkGetDeviceQueue(device, indices.transferFamily, 0, pQueue); +// transferQueue = new VkQueue(pQueue.get(0), device); - vkGetDeviceQueue(device, indices.presentFamily, 0, pQueue); - presentQueue = new VkQueue(pQueue.get(0), device); + graphicsQueue = new GraphicsQueue(stack, indices.graphicsFamily); + transferQueue = new TransferQueue(stack, indices.transferFamily); + presentQueue = new PresentQueue(stack, indices.presentFamily); + computeQueue = new ComputeQueue(stack, indices.computeFamily); - vkGetDeviceQueue(device, indices.transferFamily, 0, pQueue); - transferQueue = new VkQueue(pQueue.get(0), device); +// GraphicsQueue.createInstance(stack, indices.graphicsFamily); +// TransferQueue.createInstance(stack, indices.transferFamily); +// PresentQueue.createInstance(stack, indices.presentFamily); } } @@ -290,6 +300,30 @@ private static int findSupportedFormat(IntBuffer formatCandidates, int tiling, i throw new RuntimeException("Failed to find supported format"); } + public static void destroy() { + graphicsQueue.cleanUp(); + transferQueue.cleanUp(); + computeQueue.cleanUp(); + + vkDestroyDevice(device, null); + } + + public static GraphicsQueue getGraphicsQueue() { + return graphicsQueue; + } + + public static PresentQueue getPresentQueue() { + return presentQueue; + } + + public static TransferQueue getTransferQueue() { + return transferQueue; + } + + public static ComputeQueue getComputeQueue() { + return computeQueue; + } + public static SurfaceProperties querySurfaceProperties(VkPhysicalDevice device, MemoryStack stack) { long surface = Vulkan.getSurface(); diff --git a/src/main/java/net/vulkanmod/vulkan/DeviceInfo.java b/common/src/main/java/net/vulkanmod/vulkan/DeviceInfo.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/DeviceInfo.java rename to common/src/main/java/net/vulkanmod/vulkan/DeviceInfo.java diff --git a/src/main/java/net/vulkanmod/vulkan/Drawer.java b/common/src/main/java/net/vulkanmod/vulkan/Drawer.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/Drawer.java rename to common/src/main/java/net/vulkanmod/vulkan/Drawer.java diff --git a/src/main/java/net/vulkanmod/vulkan/Renderer.java b/common/src/main/java/net/vulkanmod/vulkan/Renderer.java similarity index 96% rename from src/main/java/net/vulkanmod/vulkan/Renderer.java rename to common/src/main/java/net/vulkanmod/vulkan/Renderer.java index 6c832edfb..f6598ab8d 100644 --- a/src/main/java/net/vulkanmod/vulkan/Renderer.java +++ b/common/src/main/java/net/vulkanmod/vulkan/Renderer.java @@ -4,16 +4,14 @@ import it.unimi.dsi.fastutil.objects.ObjectOpenHashSet; import net.minecraft.client.Minecraft; import net.vulkanmod.render.chunk.AreaUploadManager; +import net.vulkanmod.render.chunk.TerrainShaderManager; import net.vulkanmod.render.profiling.Profiler2; import net.vulkanmod.vulkan.framebuffer.Framebuffer; import net.vulkanmod.vulkan.framebuffer.RenderPass; import net.vulkanmod.vulkan.memory.MemoryManager; import net.vulkanmod.vulkan.passes.DefaultMainPass; import net.vulkanmod.vulkan.passes.MainPass; -import net.vulkanmod.vulkan.shader.Pipeline; -import net.vulkanmod.vulkan.shader.PipelineState; -import net.vulkanmod.vulkan.shader.ShaderManager; -import net.vulkanmod.vulkan.shader.Uniforms; +import net.vulkanmod.vulkan.shader.*; import net.vulkanmod.vulkan.shader.layout.PushConstants; import net.vulkanmod.vulkan.texture.VTextureSelector; import net.vulkanmod.vulkan.util.VUtil; @@ -76,7 +74,7 @@ public Renderer() { device = Vulkan.getDevice(); Uniforms.setupDefaultUniforms(); - ShaderManager.init(); + TerrainShaderManager.init(); AreaUploadManager.createInstance(); framesNum = getSwapChainImages().size(); @@ -321,7 +319,7 @@ private void submitFrame() { Synchronization.INSTANCE.waitFences(); - if((vkResult = vkQueueSubmit(getGraphicsQueue(), submitInfo, inFlightFences.get(currentFrame))) != VK_SUCCESS) { + if((vkResult = vkQueueSubmit(Device.getGraphicsQueue().queue(), submitInfo, inFlightFences.get(currentFrame))) != VK_SUCCESS) { vkResetFences(device, stackGet().longs(inFlightFences.get(currentFrame))); throw new RuntimeException("Failed to submit draw command buffer: " + vkResult); } @@ -336,7 +334,7 @@ private void submitFrame() { presentInfo.pImageIndices(pImageIndex); - vkResult = vkQueuePresentKHR(getPresentQueue(), presentInfo); + vkResult = vkQueuePresentKHR(Device.getPresentQueue().queue(), presentInfo); if(vkResult == VK_ERROR_OUT_OF_DATE_KHR || vkResult == VK_SUBOPTIMAL_KHR || swapCahinUpdate) { swapCahinUpdate = true; @@ -363,7 +361,7 @@ void waitForSwapChain() .pWaitSemaphores(stack.longs(imageAvailableSemaphores.get(currentFrame))) .pWaitDstStageMask(stack.ints(VK_PIPELINE_STAGE_ALL_COMMANDS_BIT)); - vkQueueSubmit(getGraphicsQueue(), info, inFlightFences.get(currentFrame)); + vkQueueSubmit(Device.getGraphicsQueue().queue(), info, inFlightFences.get(currentFrame)); vkWaitForFences(device, inFlightFences.get(currentFrame), true, -1); } } @@ -412,7 +410,7 @@ public void cleanUpResources() { drawer.cleanUpResources(); - ShaderManager.getInstance().destroyPipelines(); + TerrainShaderManager.destroyPipelines(); VTextureSelector.getWhiteTexture().free(); } @@ -438,10 +436,9 @@ public void addOnResizeCallback(Runnable runnable) { this.onResizeCallbacks.add(runnable); } - public void bindPipeline(Pipeline pipeline) { + public void bindGraphicsPipeline(GraphicsPipeline pipeline) { VkCommandBuffer commandBuffer = currentCmdBuffer; -// PipelineState currentState = new PipelineState(currentBlendState, currentDepthState, currentLogicOpState, currentColorMask, boundRenderPass); PipelineState currentState = PipelineState.getCurrentPipelineState(boundRenderPass); vkCmdBindPipeline(commandBuffer, VK_PIPELINE_BIND_POINT_GRAPHICS, pipeline.getHandle(currentState)); diff --git a/src/main/java/net/vulkanmod/vulkan/Synchronization.java b/common/src/main/java/net/vulkanmod/vulkan/Synchronization.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/Synchronization.java rename to common/src/main/java/net/vulkanmod/vulkan/Synchronization.java diff --git a/src/main/java/net/vulkanmod/vulkan/VRenderSystem.java b/common/src/main/java/net/vulkanmod/vulkan/VRenderSystem.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/VRenderSystem.java rename to common/src/main/java/net/vulkanmod/vulkan/VRenderSystem.java diff --git a/src/main/java/net/vulkanmod/vulkan/Vulkan.java b/common/src/main/java/net/vulkanmod/vulkan/Vulkan.java similarity index 97% rename from src/main/java/net/vulkanmod/vulkan/Vulkan.java rename to common/src/main/java/net/vulkanmod/vulkan/Vulkan.java index 52ed957d7..27e67cc56 100644 --- a/src/main/java/net/vulkanmod/vulkan/Vulkan.java +++ b/common/src/main/java/net/vulkanmod/vulkan/Vulkan.java @@ -145,7 +145,6 @@ public static void initVulkan(long window) { createVma(); MemoryTypes.createMemoryTypes(); - Queue.initQueues(); createCommandPool(); allocateImmediateCmdBuffer(); @@ -194,9 +193,6 @@ public static void cleanUp() { vkDestroyCommandPool(Device.device, commandPool, null); vkDestroyFence(Device.device, immediateFence, null); - GraphicsQueue.INSTANCE.cleanUp(); - TransferQueue.INSTANCE.cleanUp(); - Pipeline.destroyPipelineCache(); swapChain.cleanUp(); @@ -211,7 +207,7 @@ public static void cleanUp() { vmaDestroyAllocator(allocator); - vkDestroyDevice(Device.device, null); + Device.destroy(); destroyDebugUtilsMessengerEXT(instance, debugMessenger, null); KHRSurface.vkDestroySurfaceKHR(instance, surface, null); vkDestroyInstance(instance, null); @@ -421,7 +417,7 @@ public static void endImmediateCmd() { submitInfo.sType(VK_STRUCTURE_TYPE_SUBMIT_INFO); submitInfo.pCommandBuffers(stack.pointers(immediateCmdBuffer)); - vkQueueSubmit(Device.graphicsQueue, submitInfo, immediateFence); + vkQueueSubmit(Device.getGraphicsQueue().queue(), submitInfo, immediateFence); vkWaitForFences(Device.device, immediateFence, true, VUtil.UINT64_MAX); vkResetFences(Device.device, immediateFence); @@ -459,12 +455,6 @@ public static void setVsync(boolean b) { public static long getSurface() { return surface; } - public static VkQueue getPresentQueue() { return Device.presentQueue; } - - public static VkQueue getGraphicsQueue() { return Device.graphicsQueue; } - - public static VkQueue getTransferQueue() { return Device.transferQueue; } - public static SwapChain getSwapChain() { return swapChain; } public static VkExtent2D getSwapchainExtent() diff --git a/src/main/java/net/vulkanmod/vulkan/framebuffer/Framebuffer.java b/common/src/main/java/net/vulkanmod/vulkan/framebuffer/Framebuffer.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/framebuffer/Framebuffer.java rename to common/src/main/java/net/vulkanmod/vulkan/framebuffer/Framebuffer.java diff --git a/src/main/java/net/vulkanmod/vulkan/framebuffer/RenderPass.java b/common/src/main/java/net/vulkanmod/vulkan/framebuffer/RenderPass.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/framebuffer/RenderPass.java rename to common/src/main/java/net/vulkanmod/vulkan/framebuffer/RenderPass.java diff --git a/src/main/java/net/vulkanmod/vulkan/framebuffer/SwapChain.java b/common/src/main/java/net/vulkanmod/vulkan/framebuffer/SwapChain.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/framebuffer/SwapChain.java rename to common/src/main/java/net/vulkanmod/vulkan/framebuffer/SwapChain.java diff --git a/src/main/java/net/vulkanmod/vulkan/memory/AutoIndexBuffer.java b/common/src/main/java/net/vulkanmod/vulkan/memory/AutoIndexBuffer.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/memory/AutoIndexBuffer.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/AutoIndexBuffer.java diff --git a/src/main/java/net/vulkanmod/vulkan/memory/Buffer.java b/common/src/main/java/net/vulkanmod/vulkan/memory/Buffer.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/memory/Buffer.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/Buffer.java diff --git a/src/main/java/net/vulkanmod/vulkan/memory/IndexBuffer.java b/common/src/main/java/net/vulkanmod/vulkan/memory/IndexBuffer.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/memory/IndexBuffer.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/IndexBuffer.java diff --git a/src/main/java/net/vulkanmod/vulkan/memory/IndirectBuffer.java b/common/src/main/java/net/vulkanmod/vulkan/memory/IndirectBuffer.java similarity index 92% rename from src/main/java/net/vulkanmod/vulkan/memory/IndirectBuffer.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/IndirectBuffer.java index aa795c916..76f96d82d 100644 --- a/src/main/java/net/vulkanmod/vulkan/memory/IndirectBuffer.java +++ b/common/src/main/java/net/vulkanmod/vulkan/memory/IndirectBuffer.java @@ -28,7 +28,7 @@ public void recordCopyCmd(ByteBuffer byteBuffer) { } else { if(commandBuffer == null) - commandBuffer = TransferQueue.getInstance().beginCommands(); + commandBuffer = Device.getTransferQueue().beginCommands(); StagingBuffer stagingBuffer = Vulkan.getStagingBuffer(Renderer.getCurrentFrame()); stagingBuffer.copyBuffer(size, byteBuffer); @@ -51,7 +51,7 @@ public void submitUploads() { if(commandBuffer == null) return; - TransferQueue.getInstance().submitCommands(commandBuffer); + Device.getTransferQueue().submitCommands(commandBuffer); Synchronization.INSTANCE.addCommandBuffer(commandBuffer); commandBuffer = null; } diff --git a/src/main/java/net/vulkanmod/vulkan/memory/MemoryManager.java b/common/src/main/java/net/vulkanmod/vulkan/memory/MemoryManager.java similarity index 99% rename from src/main/java/net/vulkanmod/vulkan/memory/MemoryManager.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/MemoryManager.java index 89275a084..af824a349 100644 --- a/src/main/java/net/vulkanmod/vulkan/memory/MemoryManager.java +++ b/common/src/main/java/net/vulkanmod/vulkan/memory/MemoryManager.java @@ -160,6 +160,7 @@ public static synchronized void createImage(int width, int height, int mipLevels imageInfo.usage(usage); imageInfo.samples(VK_SAMPLE_COUNT_1_BIT); // imageInfo.sharingMode(VK_SHARING_MODE_CONCURRENT); + //TODO imageInfo.pQueueFamilyIndices(stack.ints(0,1)); VmaAllocationCreateInfo allocationInfo = VmaAllocationCreateInfo.callocStack(stack); @@ -267,7 +268,7 @@ private void freeImages() { List bufferList = freeableImages[currentFrame]; for(VulkanImage image : bufferList) { - image.doFree(this); + image.doFree(); } bufferList.clear(); diff --git a/src/main/java/net/vulkanmod/vulkan/memory/MemoryType.java b/common/src/main/java/net/vulkanmod/vulkan/memory/MemoryType.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/memory/MemoryType.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/MemoryType.java diff --git a/src/main/java/net/vulkanmod/vulkan/memory/MemoryTypes.java b/common/src/main/java/net/vulkanmod/vulkan/memory/MemoryTypes.java similarity index 93% rename from src/main/java/net/vulkanmod/vulkan/memory/MemoryTypes.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/MemoryTypes.java index ad1ba9939..0b8724693 100644 --- a/src/main/java/net/vulkanmod/vulkan/memory/MemoryTypes.java +++ b/common/src/main/java/net/vulkanmod/vulkan/memory/MemoryTypes.java @@ -68,7 +68,7 @@ void copyToBuffer(Buffer buffer, long bufferSize, ByteBuffer byteBuffer) { StagingBuffer stagingBuffer = Vulkan.getStagingBuffer(Renderer.getCurrentFrame()); stagingBuffer.copyBuffer((int) bufferSize, byteBuffer); - TransferQueue.INSTANCE.copyBufferCmd(stagingBuffer.id, stagingBuffer.offset, buffer.getId(), buffer.getUsedBytes(), bufferSize); + Device.getTransferQueue().copyBufferCmd(stagingBuffer.id, stagingBuffer.offset, buffer.getId(), buffer.getUsedBytes(), bufferSize); } @Override @@ -81,7 +81,7 @@ public long copyBuffer(Buffer src, Buffer dst) { throw new IllegalArgumentException("dst size is less than src size."); } - return TransferQueue.INSTANCE.copyBufferCmd(src.getId(), 0, dst.getId(), 0, src.bufferSize); + return Device.getTransferQueue().copyBufferCmd(src.getId(), 0, dst.getId(), 0, src.bufferSize); } @Override @@ -90,7 +90,7 @@ void uploadBuffer(Buffer buffer, ByteBuffer byteBuffer) { StagingBuffer stagingBuffer = Vulkan.getStagingBuffer(Renderer.getCurrentFrame()); stagingBuffer.copyBuffer(bufferSize, byteBuffer); - TransferQueue.INSTANCE.copyBufferCmd(stagingBuffer.id, stagingBuffer.offset, buffer.getId(), 0, bufferSize); + Device.getTransferQueue().copyBufferCmd(stagingBuffer.id, stagingBuffer.offset, buffer.getId(), 0, bufferSize); } diff --git a/src/main/java/net/vulkanmod/vulkan/memory/StagingBuffer.java b/common/src/main/java/net/vulkanmod/vulkan/memory/StagingBuffer.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/memory/StagingBuffer.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/StagingBuffer.java diff --git a/src/main/java/net/vulkanmod/vulkan/memory/UniformBuffers.java b/common/src/main/java/net/vulkanmod/vulkan/memory/UniformBuffers.java similarity index 96% rename from src/main/java/net/vulkanmod/vulkan/memory/UniformBuffers.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/UniformBuffers.java index e8ca97e6d..a93c4a37e 100644 --- a/src/main/java/net/vulkanmod/vulkan/memory/UniformBuffers.java +++ b/common/src/main/java/net/vulkanmod/vulkan/memory/UniformBuffers.java @@ -83,7 +83,7 @@ public void submitUploads() { if(commandBuffer == null) return; - TransferQueue.getInstance().submitCommands(commandBuffer); + Device.getTransferQueue().submitCommands(commandBuffer); Synchronization.INSTANCE.addCommandBuffer(commandBuffer); commandBuffer = null; } @@ -123,7 +123,7 @@ public void uploadUBO(ByteBuffer buffer, int offset) { } else { if(commandBuffer == null) - commandBuffer = TransferQueue.getInstance().beginCommands(); + commandBuffer = Device.getTransferQueue().beginCommands(); int size = buffer.remaining(); diff --git a/src/main/java/net/vulkanmod/vulkan/memory/VertexBuffer.java b/common/src/main/java/net/vulkanmod/vulkan/memory/VertexBuffer.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/memory/VertexBuffer.java rename to common/src/main/java/net/vulkanmod/vulkan/memory/VertexBuffer.java diff --git a/src/main/java/net/vulkanmod/vulkan/passes/DefaultMainPass.java b/common/src/main/java/net/vulkanmod/vulkan/passes/DefaultMainPass.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/passes/DefaultMainPass.java rename to common/src/main/java/net/vulkanmod/vulkan/passes/DefaultMainPass.java diff --git a/src/main/java/net/vulkanmod/vulkan/passes/MainPass.java b/common/src/main/java/net/vulkanmod/vulkan/passes/MainPass.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/passes/MainPass.java rename to common/src/main/java/net/vulkanmod/vulkan/passes/MainPass.java diff --git a/src/main/java/net/vulkanmod/vulkan/queue/CommandPool.java b/common/src/main/java/net/vulkanmod/vulkan/queue/CommandPool.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/queue/CommandPool.java rename to common/src/main/java/net/vulkanmod/vulkan/queue/CommandPool.java diff --git a/common/src/main/java/net/vulkanmod/vulkan/queue/ComputeQueue.java b/common/src/main/java/net/vulkanmod/vulkan/queue/ComputeQueue.java new file mode 100644 index 000000000..1c0d7c025 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/queue/ComputeQueue.java @@ -0,0 +1,10 @@ +package net.vulkanmod.vulkan.queue; + +import org.lwjgl.system.MemoryStack; + +public class ComputeQueue extends Queue { + + public ComputeQueue(MemoryStack stack, int familyIndex) { + super(stack, familyIndex); + } +} diff --git a/src/main/java/net/vulkanmod/vulkan/queue/GraphicsQueue.java b/common/src/main/java/net/vulkanmod/vulkan/queue/GraphicsQueue.java similarity index 68% rename from src/main/java/net/vulkanmod/vulkan/queue/GraphicsQueue.java rename to common/src/main/java/net/vulkanmod/vulkan/queue/GraphicsQueue.java index f27c3a797..e449f617b 100644 --- a/src/main/java/net/vulkanmod/vulkan/queue/GraphicsQueue.java +++ b/common/src/main/java/net/vulkanmod/vulkan/queue/GraphicsQueue.java @@ -4,27 +4,18 @@ import net.vulkanmod.vulkan.Vulkan; import net.vulkanmod.vulkan.memory.MemoryManager; import net.vulkanmod.vulkan.util.VUtil; +import org.lwjgl.system.MemoryStack; import org.lwjgl.vulkan.*; import static org.lwjgl.vulkan.VK10.*; public class GraphicsQueue extends Queue { - private static final VkDevice DEVICE = Vulkan.getDevice(); - public static GraphicsQueue INSTANCE; - public static void createInstance() { - INSTANCE = new GraphicsQueue(); - } - - public static GraphicsQueue getInstance() { - return INSTANCE; - } - private static CommandPool.CommandBuffer currentCmdBuffer; - protected GraphicsQueue() { - this.commandPool = new CommandPool(getQueueFamilies().graphicsFamily); + public GraphicsQueue(MemoryStack stack, int familyIndex) { + super(stack, familyIndex); } public void startRecording() { @@ -54,9 +45,4 @@ public long endIfNeeded(CommandPool.CommandBuffer commandBuffer) { } } - public synchronized long submitCommands(CommandPool.CommandBuffer commandBuffer) { - - return this.commandPool.submitCommands(commandBuffer, Vulkan.getGraphicsQueue()); - } - } diff --git a/common/src/main/java/net/vulkanmod/vulkan/queue/PresentQueue.java b/common/src/main/java/net/vulkanmod/vulkan/queue/PresentQueue.java new file mode 100644 index 000000000..0997e72a4 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/queue/PresentQueue.java @@ -0,0 +1,10 @@ +package net.vulkanmod.vulkan.queue; + +import org.lwjgl.system.MemoryStack; + +public class PresentQueue extends Queue { + + public PresentQueue(MemoryStack stack, int familyIndex) { + super(stack, familyIndex, false); + } +} diff --git a/src/main/java/net/vulkanmod/vulkan/queue/Queue.java b/common/src/main/java/net/vulkanmod/vulkan/queue/Queue.java similarity index 86% rename from src/main/java/net/vulkanmod/vulkan/queue/Queue.java rename to common/src/main/java/net/vulkanmod/vulkan/queue/Queue.java index 46e525da5..b9cbbf8fe 100644 --- a/src/main/java/net/vulkanmod/vulkan/queue/Queue.java +++ b/common/src/main/java/net/vulkanmod/vulkan/queue/Queue.java @@ -1,11 +1,12 @@ package net.vulkanmod.vulkan.queue; +import net.vulkanmod.vulkan.Device; import net.vulkanmod.vulkan.Vulkan; +import org.lwjgl.PointerBuffer; import org.lwjgl.system.MemoryStack; import org.lwjgl.vulkan.*; import java.nio.IntBuffer; -import java.util.ArrayDeque; import java.util.stream.IntStream; import static org.lwjgl.system.MemoryStack.stackPush; @@ -18,15 +19,38 @@ public abstract class Queue { private static QueueFamilyIndices queueFamilyIndices; protected CommandPool commandPool; - public synchronized CommandPool.CommandBuffer beginCommands() { + private final VkQueue queue; + public synchronized CommandPool.CommandBuffer beginCommands() { return this.commandPool.beginCommands(); } - public abstract long submitCommands(CommandPool.CommandBuffer commandBuffer); + Queue(MemoryStack stack, int familyIndex) { + this(stack, familyIndex, true); + } + + Queue(MemoryStack stack, int familyIndex, boolean initCommandPool) { + PointerBuffer pQueue = stack.mallocPointer(1); + vkGetDeviceQueue(Device.device, familyIndex, 0, pQueue); + this.queue = new VkQueue(pQueue.get(0), Device.device); + + if(initCommandPool) + this.commandPool = new CommandPool(familyIndex); + } + + public synchronized long submitCommands(CommandPool.CommandBuffer commandBuffer) { + return this.commandPool.submitCommands(commandBuffer, queue); + } + + public VkQueue queue() { return this.queue; } public void cleanUp() { - commandPool.cleanUp(); + if(commandPool != null) + commandPool.cleanUp(); + } + + public void waitIdle() { + vkQueueWaitIdle(queue); } public enum Family { @@ -35,11 +59,6 @@ public enum Family { Compute } - public static void initQueues() { - GraphicsQueue.createInstance(); - TransferQueue.createInstance(); - } - public static QueueFamilyIndices getQueueFamilies() { if(DEVICE == null) DEVICE = Vulkan.getDevice(); diff --git a/src/main/java/net/vulkanmod/vulkan/queue/TransferQueue.java b/common/src/main/java/net/vulkanmod/vulkan/queue/TransferQueue.java similarity index 78% rename from src/main/java/net/vulkanmod/vulkan/queue/TransferQueue.java rename to common/src/main/java/net/vulkanmod/vulkan/queue/TransferQueue.java index aeeae9bcb..3a27c0453 100644 --- a/src/main/java/net/vulkanmod/vulkan/queue/TransferQueue.java +++ b/common/src/main/java/net/vulkanmod/vulkan/queue/TransferQueue.java @@ -14,18 +14,8 @@ public class TransferQueue extends Queue { private static final VkDevice DEVICE = Vulkan.getDevice(); - public static TransferQueue INSTANCE; - - public static void createInstance() { - INSTANCE = new TransferQueue(); - } - - public static TransferQueue getInstance() { - return INSTANCE; - } - - protected TransferQueue() { - commandPool = new CommandPool(getQueueFamilies().transferFamily); + public TransferQueue(MemoryStack stack, int familyIndex) { + super(stack, familyIndex); } public long copyBufferCmd(long srcBuffer, long srcOffset, long dstBuffer, long dstOffset, long size) { @@ -34,7 +24,7 @@ public long copyBufferCmd(long srcBuffer, long srcOffset, long dstBuffer, long d CommandPool.CommandBuffer commandBuffer = beginCommands(); - VkBufferCopy.Buffer copyRegion = VkBufferCopy.callocStack(1, stack); + VkBufferCopy.Buffer copyRegion = VkBufferCopy.calloc(1, stack); copyRegion.size(size); copyRegion.srcOffset(srcOffset); copyRegion.dstOffset(dstOffset); @@ -53,7 +43,7 @@ public void uploadBufferImmediate(long srcBuffer, long srcOffset, long dstBuffer try(MemoryStack stack = stackPush()) { CommandPool.CommandBuffer commandBuffer = this.beginCommands(); - VkBufferCopy.Buffer copyRegion = VkBufferCopy.callocStack(1, stack); + VkBufferCopy.Buffer copyRegion = VkBufferCopy.calloc(1, stack); copyRegion.size(size); copyRegion.srcOffset(srcOffset); copyRegion.dstOffset(dstOffset); @@ -66,16 +56,11 @@ public void uploadBufferImmediate(long srcBuffer, long srcOffset, long dstBuffer } } - public synchronized long submitCommands(CommandPool.CommandBuffer commandBuffer) { - - return this.commandPool.submitCommands(commandBuffer, Vulkan.getTransferQueue()); - } - public static void uploadBufferCmd(CommandPool.CommandBuffer commandBuffer, long srcBuffer, long srcOffset, long dstBuffer, long dstOffset, long size) { try(MemoryStack stack = stackPush()) { - VkBufferCopy.Buffer copyRegion = VkBufferCopy.callocStack(1, stack); + VkBufferCopy.Buffer copyRegion = VkBufferCopy.calloc(1, stack); copyRegion.size(size); copyRegion.srcOffset(srcOffset); copyRegion.dstOffset(dstOffset); @@ -83,9 +68,5 @@ public static void uploadBufferCmd(CommandPool.CommandBuffer commandBuffer, long vkCmdCopyBuffer(commandBuffer.getHandle(), srcBuffer, dstBuffer, copyRegion); } } - - public static void waitIdle() { - vkQueueWaitIdle(Vulkan.getTransferQueue()); - } } diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/GraphicsPipeline.java b/common/src/main/java/net/vulkanmod/vulkan/shader/GraphicsPipeline.java new file mode 100644 index 000000000..3fe15a346 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/GraphicsPipeline.java @@ -0,0 +1,334 @@ +package net.vulkanmod.vulkan.shader; + +import com.google.common.collect.ImmutableList; +import com.mojang.blaze3d.vertex.VertexFormat; +import com.mojang.blaze3d.vertex.VertexFormatElement; +import net.vulkanmod.interfaces.VertexFormatMixed; +import net.vulkanmod.vulkan.Device; +import net.vulkanmod.vulkan.Renderer; +import net.vulkanmod.vulkan.Vulkan; +import org.lwjgl.system.MemoryStack; +import org.lwjgl.vulkan.*; + +import java.nio.ByteBuffer; +import java.nio.LongBuffer; +import java.util.HashMap; +import java.util.Map; + +import static net.vulkanmod.vulkan.shader.PipelineState.*; +import static net.vulkanmod.vulkan.shader.PipelineState.DEFAULT_COLORMASK; +import static org.lwjgl.system.MemoryStack.stackGet; +import static org.lwjgl.system.MemoryStack.stackPush; +import static org.lwjgl.vulkan.VK10.*; +import static org.lwjgl.vulkan.VK10.vkDestroyPipelineLayout; + +public class GraphicsPipeline extends Pipeline { + + private final Map graphicsPipelines = new HashMap<>(); + private final VertexFormat vertexFormat; + + private long vertShaderModule = 0; + private long fragShaderModule = 0; + + GraphicsPipeline(Builder builder) { + super(builder.shaderPath); + this.buffers = builder.UBOs; + this.manualUBO = builder.manualUBO; + this.images = builder.images; + this.pushConstants = builder.pushConstants; + this.vertexFormat = builder.vertexFormat; + + createDescriptorSetLayout(); + createPipelineLayout(); + createShaderModules(builder.vertShaderSPIRV, builder.fragShaderSPIRV); + + if(builder.renderPass != null) + graphicsPipelines.computeIfAbsent(new PipelineState(DEFAULT_BLEND_STATE, DEFAULT_DEPTH_STATE, DEFAULT_LOGICOP_STATE, DEFAULT_COLORMASK, builder.renderPass), + this::createGraphicsPipeline); + + createDescriptorSets(Vulkan.getSwapChainImages().size()); + + PIPELINES.add(this); + } + + public long getHandle(PipelineState state) { + return graphicsPipelines.computeIfAbsent(state, this::createGraphicsPipeline); + } + + private long createGraphicsPipeline(PipelineState state) { + + try(MemoryStack stack = stackPush()) { + + ByteBuffer entryPoint = stack.UTF8("main"); + + VkPipelineShaderStageCreateInfo.Buffer shaderStages = VkPipelineShaderStageCreateInfo.calloc(2, stack); + + VkPipelineShaderStageCreateInfo vertShaderStageInfo = shaderStages.get(0); + + vertShaderStageInfo.sType(VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO); + vertShaderStageInfo.stage(VK_SHADER_STAGE_VERTEX_BIT); + vertShaderStageInfo.module(vertShaderModule); + vertShaderStageInfo.pName(entryPoint); + + VkPipelineShaderStageCreateInfo fragShaderStageInfo = shaderStages.get(1); + + fragShaderStageInfo.sType(VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO); + fragShaderStageInfo.stage(VK_SHADER_STAGE_FRAGMENT_BIT); + fragShaderStageInfo.module(fragShaderModule); + fragShaderStageInfo.pName(entryPoint); + + // ===> VERTEX STAGE <=== + + VkPipelineVertexInputStateCreateInfo vertexInputInfo = VkPipelineVertexInputStateCreateInfo.calloc(stack); + vertexInputInfo.sType(VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO); + vertexInputInfo.pVertexBindingDescriptions(getBindingDescription(vertexFormat)); + vertexInputInfo.pVertexAttributeDescriptions(getAttributeDescriptions(vertexFormat)); + + // ===> ASSEMBLY STAGE <=== + + VkPipelineInputAssemblyStateCreateInfo inputAssembly = VkPipelineInputAssemblyStateCreateInfo.calloc(stack); + inputAssembly.sType(VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO); + inputAssembly.topology(VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST); + inputAssembly.primitiveRestartEnable(false); + + // ===> VIEWPORT & SCISSOR + + VkPipelineViewportStateCreateInfo viewportState = VkPipelineViewportStateCreateInfo.calloc(stack); + viewportState.sType(VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO); + + viewportState.viewportCount(1); + viewportState.scissorCount(1); + + // ===> RASTERIZATION STAGE <=== + + VkPipelineRasterizationStateCreateInfo rasterizer = VkPipelineRasterizationStateCreateInfo.calloc(stack); + rasterizer.sType(VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO); + rasterizer.depthClampEnable(false); + rasterizer.rasterizerDiscardEnable(false); + rasterizer.polygonMode(VK_POLYGON_MODE_FILL); + rasterizer.lineWidth(1.0f); + + if(state.cullState) + rasterizer.cullMode(VK_CULL_MODE_BACK_BIT); + else + rasterizer.cullMode(VK_CULL_MODE_NONE); + + rasterizer.frontFace(VK_FRONT_FACE_COUNTER_CLOCKWISE); + rasterizer.depthBiasEnable(true); + + // ===> MULTISAMPLING <=== + + VkPipelineMultisampleStateCreateInfo multisampling = VkPipelineMultisampleStateCreateInfo.calloc(stack); + multisampling.sType(VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO); + multisampling.sampleShadingEnable(false); + multisampling.rasterizationSamples(VK_SAMPLE_COUNT_1_BIT); + + // ===> DEPTH TEST <=== + + VkPipelineDepthStencilStateCreateInfo depthStencil = VkPipelineDepthStencilStateCreateInfo.calloc(stack); + depthStencil.sType(VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO); + depthStencil.depthTestEnable(state.depthState.depthTest); + depthStencil.depthWriteEnable(state.depthState.depthMask); + depthStencil.depthCompareOp(state.depthState.function); + depthStencil.depthBoundsTestEnable(false); + depthStencil.minDepthBounds(0.0f); // Optional + depthStencil.maxDepthBounds(1.0f); // Optional + depthStencil.stencilTestEnable(false); + + // ===> COLOR BLENDING <=== + + VkPipelineColorBlendAttachmentState.Buffer colorBlendAttachment = VkPipelineColorBlendAttachmentState.calloc(1, stack); + colorBlendAttachment.colorWriteMask(state.colorMask.colorMask); + + if(state.blendState.enabled) { + colorBlendAttachment.blendEnable(true); + colorBlendAttachment.srcColorBlendFactor(state.blendState.srcRgbFactor); + colorBlendAttachment.dstColorBlendFactor(state.blendState.dstRgbFactor); + colorBlendAttachment.colorBlendOp(VK_BLEND_OP_ADD); + colorBlendAttachment.srcAlphaBlendFactor(state.blendState.srcAlphaFactor); + colorBlendAttachment.dstAlphaBlendFactor(state.blendState.dstAlphaFactor); + colorBlendAttachment.alphaBlendOp(VK_BLEND_OP_ADD); + } + else { + colorBlendAttachment.blendEnable(false); + } + + VkPipelineColorBlendStateCreateInfo colorBlending = VkPipelineColorBlendStateCreateInfo.calloc(stack); + colorBlending.sType(VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO); + colorBlending.logicOpEnable(state.logicOpState.enabled); + colorBlending.logicOp(state.logicOpState.getLogicOp()); + colorBlending.pAttachments(colorBlendAttachment); + colorBlending.blendConstants(stack.floats(0.0f, 0.0f, 0.0f, 0.0f)); + + // ===> DYNAMIC STATES <=== + + VkPipelineDynamicStateCreateInfo dynamicStates = VkPipelineDynamicStateCreateInfo.calloc(stack); + dynamicStates.sType(VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO); + dynamicStates.pDynamicStates(stack.ints(VK_DYNAMIC_STATE_DEPTH_BIAS, VK_DYNAMIC_STATE_VIEWPORT, VK_DYNAMIC_STATE_SCISSOR)); + + VkGraphicsPipelineCreateInfo.Buffer pipelineInfo = VkGraphicsPipelineCreateInfo.calloc(1, stack); + pipelineInfo.sType(VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO); + pipelineInfo.pStages(shaderStages); + pipelineInfo.pVertexInputState(vertexInputInfo); + pipelineInfo.pInputAssemblyState(inputAssembly); + pipelineInfo.pViewportState(viewportState); + pipelineInfo.pRasterizationState(rasterizer); + pipelineInfo.pMultisampleState(multisampling); + pipelineInfo.pDepthStencilState(depthStencil); + pipelineInfo.pColorBlendState(colorBlending); + pipelineInfo.pDynamicState(dynamicStates); + pipelineInfo.layout(pipelineLayout); + pipelineInfo.basePipelineHandle(VK_NULL_HANDLE); + pipelineInfo.basePipelineIndex(-1); + + if(!Vulkan.DYNAMIC_RENDERING) { + pipelineInfo.renderPass(state.renderPass.getId()); + pipelineInfo.subpass(0); + } + else { + //dyn-rendering + VkPipelineRenderingCreateInfoKHR renderingInfo = VkPipelineRenderingCreateInfoKHR.calloc(stack); + renderingInfo.sType(KHRDynamicRendering.VK_STRUCTURE_TYPE_PIPELINE_RENDERING_CREATE_INFO_KHR); + renderingInfo.pColorAttachmentFormats(stack.ints(state.renderPass.getFramebuffer().getFormat())); + renderingInfo.depthAttachmentFormat(state.renderPass.getFramebuffer().getDepthFormat()); + pipelineInfo.pNext(renderingInfo); + } + + LongBuffer pGraphicsPipeline = stack.mallocLong(1); + + if(vkCreateGraphicsPipelines(Device.device, PIPELINE_CACHE, pipelineInfo, null, pGraphicsPipeline) != VK_SUCCESS) { + throw new RuntimeException("Failed to create graphics pipeline"); + } + + return pGraphicsPipeline.get(0); + } + } + + private void createShaderModules(SPIRVUtils.SPIRV vertSpirv, SPIRVUtils.SPIRV fragSpirv) { + this.vertShaderModule = createShaderModule(vertSpirv.bytecode()); + this.fragShaderModule = createShaderModule(fragSpirv.bytecode()); + } + + private static VkVertexInputBindingDescription.Buffer getBindingDescription(VertexFormat vertexFormat) { + + VkVertexInputBindingDescription.Buffer bindingDescription = + VkVertexInputBindingDescription.calloc(1); + + bindingDescription.binding(0); + bindingDescription.stride(vertexFormat.getVertexSize()); + bindingDescription.inputRate(VK_VERTEX_INPUT_RATE_VERTEX); + + return bindingDescription; + } + + private static VkVertexInputAttributeDescription.Buffer getAttributeDescriptions(VertexFormat vertexFormat) { + + ImmutableList elements = vertexFormat.getElements(); + + int size = elements.size(); + if(elements.stream().anyMatch(vertexFormatElement -> vertexFormatElement.getUsage() == VertexFormatElement.Usage.PADDING)) { + size--; + } + + VkVertexInputAttributeDescription.Buffer attributeDescriptions = + VkVertexInputAttributeDescription.calloc(size, stackGet()); + + int offset = 0; + + for(int i = 0; i < size; ++i) { + VkVertexInputAttributeDescription posDescription = attributeDescriptions.get(i); + posDescription.binding(0); + posDescription.location(i); + + VertexFormatElement formatElement = elements.get(i); + VertexFormatElement.Usage usage = formatElement.getUsage(); + VertexFormatElement.Type type = formatElement.getType(); + switch (usage) { + case POSITION : + if(type == VertexFormatElement.Type.FLOAT) { + posDescription.format(VK_FORMAT_R32G32B32_SFLOAT); + posDescription.offset(offset); + + offset += 12; + } + else if (type == VertexFormatElement.Type.SHORT) { + posDescription.format(VK_FORMAT_R16G16B16A16_SINT); + posDescription.offset(offset); + + offset += 8; + } + else if (type == VertexFormatElement.Type.BYTE) { + posDescription.format(VK_FORMAT_R8G8B8A8_SINT); + posDescription.offset(offset); + + offset += 4; + } + + break; + + case COLOR: + posDescription.format(VK_FORMAT_R8G8B8A8_UNORM); + posDescription.offset(offset); + +// offset += 16; + offset += 4; + break; + + case UV: + if(type == VertexFormatElement.Type.FLOAT){ + posDescription.format(VK_FORMAT_R32G32_SFLOAT); + posDescription.offset(offset); + + offset += 8; + } + else if(type == VertexFormatElement.Type.SHORT){ + posDescription.format(VK_FORMAT_R16G16_SINT); + posDescription.offset(offset); + + offset += 4; + } + else if(type == VertexFormatElement.Type.USHORT){ + posDescription.format(VK_FORMAT_R16G16_UINT); + posDescription.offset(offset); + + offset += 4; + } + break; + + case NORMAL: + posDescription.format(VK_FORMAT_R8G8B8A8_SNORM); + posDescription.offset(offset); + + offset += 4; + break; + + case PADDING: + + default: + throw new RuntimeException(String.format("Unknown format: %s", usage)); + } + + posDescription.offset(((VertexFormatMixed)(vertexFormat)).getOffset(i)); + } + + return attributeDescriptions.rewind(); + } + + public void cleanUp() { + vkDestroyShaderModule(Device.device, vertShaderModule, null); + vkDestroyShaderModule(Device.device, fragShaderModule, null); + + destroyDescriptorSets(); + + graphicsPipelines.forEach((state, pipeline) -> { + vkDestroyPipeline(Device.device, pipeline, null); + }); + graphicsPipelines.clear(); + + vkDestroyDescriptorSetLayout(Device.device, descriptorSetLayout, null); + vkDestroyPipelineLayout(Device.device, pipelineLayout, null); + + PIPELINES.remove(this); + Renderer.getInstance().removeUsedPipeline(this); + } +} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/Pipeline.java b/common/src/main/java/net/vulkanmod/vulkan/shader/Pipeline.java similarity index 50% rename from src/main/java/net/vulkanmod/vulkan/shader/Pipeline.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/Pipeline.java index 91b55c44b..23732bd73 100644 --- a/src/main/java/net/vulkanmod/vulkan/shader/Pipeline.java +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/Pipeline.java @@ -1,22 +1,21 @@ package net.vulkanmod.vulkan.shader; -import com.google.common.collect.ImmutableList; import com.google.gson.JsonArray; import com.google.gson.JsonElement; import com.google.gson.JsonObject; import com.mojang.blaze3d.vertex.VertexFormat; -import com.mojang.blaze3d.vertex.VertexFormatElement; import net.minecraft.util.GsonHelper; -import net.vulkanmod.interfaces.VertexFormatMixed; import net.vulkanmod.vulkan.*; import net.vulkanmod.vulkan.framebuffer.RenderPass; -import net.vulkanmod.vulkan.shader.ShaderSPIRVUtils.SPIRV; -import net.vulkanmod.vulkan.shader.ShaderSPIRVUtils.ShaderKind; +import net.vulkanmod.vulkan.shader.SPIRVUtils.SPIRV; +import net.vulkanmod.vulkan.shader.SPIRVUtils.ShaderKind; import net.vulkanmod.vulkan.memory.MemoryManager; import net.vulkanmod.vulkan.memory.UniformBuffers; +import net.vulkanmod.vulkan.shader.descriptor.Image; +import net.vulkanmod.vulkan.shader.descriptor.ManualUBO; import net.vulkanmod.vulkan.shader.layout.AlignedStruct; import net.vulkanmod.vulkan.shader.layout.PushConstants; -import net.vulkanmod.vulkan.shader.layout.UBO; +import net.vulkanmod.vulkan.shader.descriptor.UBO; import net.vulkanmod.vulkan.texture.VTextureSelector; import net.vulkanmod.vulkan.texture.VulkanImage; import org.apache.commons.lang3.Validate; @@ -32,260 +31,106 @@ import java.nio.charset.StandardCharsets; import java.util.*; -import static net.vulkanmod.vulkan.shader.ShaderSPIRVUtils.compileShader; -import static net.vulkanmod.vulkan.shader.ShaderSPIRVUtils.compileShaderFile; -import static net.vulkanmod.vulkan.shader.PipelineState.*; +import static net.vulkanmod.vulkan.shader.SPIRVUtils.*; import static org.lwjgl.system.MemoryStack.stackPush; import static org.lwjgl.vulkan.VK10.*; -public class Pipeline { +public abstract class Pipeline { private static final VkDevice DEVICE = Vulkan.getDevice(); - private static final long PIPELINE_CACHE = createPipelineCache(); - private static final List PIPELINES = new LinkedList<>(); - - public static void recreateDescriptorSets(int frames) { - PIPELINES.forEach(pipeline -> { - pipeline.destroyDescriptorSets(); - pipeline.createDescriptorSets(frames); - }); - } - - private long descriptorSetLayout; - private long pipelineLayout; - private final Map graphicsPipelines = new HashMap<>(); - private final VertexFormat vertexFormat; - - private DescriptorSets[] descriptorSets; - private final List UBOs; - private final ManualUBO manualUBO; - private final List samplers; - private final PushConstants pushConstants; - - private long vertShaderModule = 0; - private long fragShaderModule = 0; - - public Pipeline(VertexFormat vertexFormat, RenderPass renderPass, List UBOs, ManualUBO manualUBO, List samplers, PushConstants pushConstants, SPIRV vertSpirv, SPIRV fragSpirv) { - this.UBOs = UBOs; - this.manualUBO = manualUBO; - this.samplers = samplers; - this.pushConstants = pushConstants; - this.vertexFormat = vertexFormat; - - createDescriptorSetLayout(); - createPipelineLayout(); - createShaderModules(vertSpirv, fragSpirv); - - if(renderPass != null) - graphicsPipelines.computeIfAbsent(new PipelineState(DEFAULT_BLEND_STATE, DEFAULT_DEPTH_STATE, DEFAULT_LOGICOP_STATE, DEFAULT_COLORMASK, renderPass), - this::createGraphicsPipeline); - - createDescriptorSets(Vulkan.getSwapChainImages().size()); - - PIPELINES.add(this); - } - - private long createGraphicsPipeline(PipelineState state) { + protected static final long PIPELINE_CACHE = createPipelineCache(); + protected static final List PIPELINES = new LinkedList<>(); + private static long createPipelineCache() { try(MemoryStack stack = stackPush()) { - ByteBuffer entryPoint = stack.UTF8("main"); - - VkPipelineShaderStageCreateInfo.Buffer shaderStages = VkPipelineShaderStageCreateInfo.callocStack(2, stack); - - VkPipelineShaderStageCreateInfo vertShaderStageInfo = shaderStages.get(0); - - vertShaderStageInfo.sType(VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO); - vertShaderStageInfo.stage(VK_SHADER_STAGE_VERTEX_BIT); - vertShaderStageInfo.module(vertShaderModule); - vertShaderStageInfo.pName(entryPoint); - - VkPipelineShaderStageCreateInfo fragShaderStageInfo = shaderStages.get(1); - - fragShaderStageInfo.sType(VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO); - fragShaderStageInfo.stage(VK_SHADER_STAGE_FRAGMENT_BIT); - fragShaderStageInfo.module(fragShaderModule); - fragShaderStageInfo.pName(entryPoint); - - // ===> VERTEX STAGE <=== - - VkPipelineVertexInputStateCreateInfo vertexInputInfo = VkPipelineVertexInputStateCreateInfo.callocStack(stack); - vertexInputInfo.sType(VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO); - vertexInputInfo.pVertexBindingDescriptions(getBindingDescription(vertexFormat)); - vertexInputInfo.pVertexAttributeDescriptions(getAttributeDescriptions(vertexFormat)); - - // ===> ASSEMBLY STAGE <=== - - VkPipelineInputAssemblyStateCreateInfo inputAssembly = VkPipelineInputAssemblyStateCreateInfo.callocStack(stack); - inputAssembly.sType(VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO); - inputAssembly.topology(VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST); - inputAssembly.primitiveRestartEnable(false); - - // ===> VIEWPORT & SCISSOR - - VkPipelineViewportStateCreateInfo viewportState = VkPipelineViewportStateCreateInfo.callocStack(stack); - viewportState.sType(VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO); - - viewportState.viewportCount(1); - viewportState.scissorCount(1); - - // ===> RASTERIZATION STAGE <=== - - VkPipelineRasterizationStateCreateInfo rasterizer = VkPipelineRasterizationStateCreateInfo.callocStack(stack); - rasterizer.sType(VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO); - rasterizer.depthClampEnable(false); - rasterizer.rasterizerDiscardEnable(false); - rasterizer.polygonMode(VK_POLYGON_MODE_FILL); - rasterizer.lineWidth(1.0f); - - if(state.cullState) - rasterizer.cullMode(VK_CULL_MODE_BACK_BIT); - else - rasterizer.cullMode(VK_CULL_MODE_NONE); - - rasterizer.frontFace(VK_FRONT_FACE_COUNTER_CLOCKWISE); - rasterizer.depthBiasEnable(true); - - // ===> MULTISAMPLING <=== - - VkPipelineMultisampleStateCreateInfo multisampling = VkPipelineMultisampleStateCreateInfo.callocStack(stack); - multisampling.sType(VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO); - multisampling.sampleShadingEnable(false); - multisampling.rasterizationSamples(VK_SAMPLE_COUNT_1_BIT); + VkPipelineCacheCreateInfo cacheCreateInfo = VkPipelineCacheCreateInfo.calloc(stack); + cacheCreateInfo.sType(VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO); - // ===> DEPTH TEST <=== + LongBuffer pPipelineCache = stack.mallocLong(1); - VkPipelineDepthStencilStateCreateInfo depthStencil = VkPipelineDepthStencilStateCreateInfo.callocStack(stack); - depthStencil.sType(VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO); - depthStencil.depthTestEnable(state.depthState.depthTest); - depthStencil.depthWriteEnable(state.depthState.depthMask); - depthStencil.depthCompareOp(state.depthState.function); - depthStencil.depthBoundsTestEnable(false); - depthStencil.minDepthBounds(0.0f); // Optional - depthStencil.maxDepthBounds(1.0f); // Optional - depthStencil.stencilTestEnable(false); + if(vkCreatePipelineCache(DEVICE, cacheCreateInfo, null, pPipelineCache) != VK_SUCCESS) { + throw new RuntimeException("Failed to create graphics pipeline"); + } - // ===> COLOR BLENDING <=== + return pPipelineCache.get(0); + } + } - VkPipelineColorBlendAttachmentState.Buffer colorBlendAttachment = VkPipelineColorBlendAttachmentState.callocStack(1, stack); - colorBlendAttachment.colorWriteMask(state.colorMask.colorMask); + public static void destroyPipelineCache() { + vkDestroyPipelineCache(DEVICE, PIPELINE_CACHE, null); + } - if(state.blendState.enabled) { - colorBlendAttachment.blendEnable(true); - colorBlendAttachment.srcColorBlendFactor(state.blendState.srcRgbFactor); - colorBlendAttachment.dstColorBlendFactor(state.blendState.dstRgbFactor); - colorBlendAttachment.colorBlendOp(VK_BLEND_OP_ADD); - colorBlendAttachment.srcAlphaBlendFactor(state.blendState.srcAlphaFactor); - colorBlendAttachment.dstAlphaBlendFactor(state.blendState.dstAlphaFactor); - colorBlendAttachment.alphaBlendOp(VK_BLEND_OP_ADD); - } - else { - colorBlendAttachment.blendEnable(false); - } + public static void recreateDescriptorSets(int frames) { + PIPELINES.forEach(pipeline -> { + pipeline.destroyDescriptorSets(); + pipeline.createDescriptorSets(frames); + }); + } - VkPipelineColorBlendStateCreateInfo colorBlending = VkPipelineColorBlendStateCreateInfo.callocStack(stack); - colorBlending.sType(VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO); - colorBlending.logicOpEnable(state.logicOpState.enabled); - colorBlending.logicOp(state.logicOpState.getLogicOp()); - colorBlending.pAttachments(colorBlendAttachment); - colorBlending.blendConstants(stack.floats(0.0f, 0.0f, 0.0f, 0.0f)); - - // ===> DYNAMIC STATES <=== - - VkPipelineDynamicStateCreateInfo dynamicStates = VkPipelineDynamicStateCreateInfo.callocStack(stack); - dynamicStates.sType(VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO); - dynamicStates.pDynamicStates(stack.ints(VK_DYNAMIC_STATE_DEPTH_BIAS, VK_DYNAMIC_STATE_VIEWPORT, VK_DYNAMIC_STATE_SCISSOR)); - - VkGraphicsPipelineCreateInfo.Buffer pipelineInfo = VkGraphicsPipelineCreateInfo.callocStack(1, stack); - pipelineInfo.sType(VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO); - pipelineInfo.pStages(shaderStages); - pipelineInfo.pVertexInputState(vertexInputInfo); - pipelineInfo.pInputAssemblyState(inputAssembly); - pipelineInfo.pViewportState(viewportState); - pipelineInfo.pRasterizationState(rasterizer); - pipelineInfo.pMultisampleState(multisampling); - pipelineInfo.pDepthStencilState(depthStencil); - pipelineInfo.pColorBlendState(colorBlending); - pipelineInfo.pDynamicState(dynamicStates); - pipelineInfo.layout(pipelineLayout); - pipelineInfo.basePipelineHandle(VK_NULL_HANDLE); - pipelineInfo.basePipelineIndex(-1); - - if(!Vulkan.DYNAMIC_RENDERING) { - pipelineInfo.renderPass(state.renderPass.getId()); - pipelineInfo.subpass(0); - } - else { - //dyn-rendering - VkPipelineRenderingCreateInfoKHR renderingInfo = VkPipelineRenderingCreateInfoKHR.calloc(stack); - renderingInfo.sType(KHRDynamicRendering.VK_STRUCTURE_TYPE_PIPELINE_RENDERING_CREATE_INFO_KHR); - renderingInfo.pColorAttachmentFormats(stack.ints(state.renderPass.getFramebuffer().getFormat())); - renderingInfo.depthAttachmentFormat(state.renderPass.getFramebuffer().getDepthFormat()); - pipelineInfo.pNext(renderingInfo); - } + public final String name; - LongBuffer pGraphicsPipeline = stack.mallocLong(1); + protected long descriptorSetLayout; + protected long pipelineLayout; - if(vkCreateGraphicsPipelines(DEVICE, PIPELINE_CACHE, pipelineInfo, null, pGraphicsPipeline) != VK_SUCCESS) { - throw new RuntimeException("Failed to create graphics pipeline"); - } + protected DescriptorSets[] descriptorSets; + protected List buffers; + protected ManualUBO manualUBO; + protected List images; + protected PushConstants pushConstants; - return pGraphicsPipeline.get(0); - } + public Pipeline(String name) { + this.name = name; } - private void createDescriptorSetLayout() { + protected void createDescriptorSetLayout() { try(MemoryStack stack = stackPush()) { - int bindingsSize = this.UBOs.size() + samplers.size(); + int bindingsSize = this.buffers.size() + images.size(); - VkDescriptorSetLayoutBinding.Buffer bindings = VkDescriptorSetLayoutBinding.callocStack(bindingsSize, stack); + VkDescriptorSetLayoutBinding.Buffer bindings = VkDescriptorSetLayoutBinding.calloc(bindingsSize, stack); - for(UBO ubo : this.UBOs) { + for(UBO ubo : this.buffers) { VkDescriptorSetLayoutBinding uboLayoutBinding = bindings.get(ubo.getBinding()); uboLayoutBinding.binding(ubo.getBinding()); uboLayoutBinding.descriptorCount(1); - uboLayoutBinding.descriptorType(VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC); + uboLayoutBinding.descriptorType(ubo.getType()); uboLayoutBinding.pImmutableSamplers(null); - uboLayoutBinding.stageFlags(ubo.getFlags()); - + uboLayoutBinding.stageFlags(ubo.getStages()); } - for(Sampler sampler : this.samplers) { - VkDescriptorSetLayoutBinding samplerLayoutBinding = bindings.get(sampler.binding); - samplerLayoutBinding.binding(sampler.binding); + for(Image image : this.images) { + VkDescriptorSetLayoutBinding samplerLayoutBinding = bindings.get(image.getBinding()); + samplerLayoutBinding.binding(image.getBinding()); samplerLayoutBinding.descriptorCount(1); - samplerLayoutBinding.descriptorType(VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER); + samplerLayoutBinding.descriptorType(image.getType()); samplerLayoutBinding.pImmutableSamplers(null); - samplerLayoutBinding.stageFlags(VK_SHADER_STAGE_ALL_GRAPHICS); - -// ++i; + samplerLayoutBinding.stageFlags(image.getStages()); } - VkDescriptorSetLayoutCreateInfo layoutInfo = VkDescriptorSetLayoutCreateInfo.callocStack(stack); + VkDescriptorSetLayoutCreateInfo layoutInfo = VkDescriptorSetLayoutCreateInfo.calloc(stack); layoutInfo.sType(VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO); layoutInfo.pBindings(bindings); LongBuffer pDescriptorSetLayout = stack.mallocLong(1); - if(vkCreateDescriptorSetLayout(DEVICE, layoutInfo, null, pDescriptorSetLayout) != VK_SUCCESS) { + if(vkCreateDescriptorSetLayout(Device.device, layoutInfo, null, pDescriptorSetLayout) != VK_SUCCESS) { throw new RuntimeException("Failed to create descriptor set layout"); } -// this.descriptorSetLayout.put(0, pDescriptorSetLayout.get(0)); this.descriptorSetLayout = pDescriptorSetLayout.get(0); } } - private void createPipelineLayout() { + protected void createPipelineLayout() { try(MemoryStack stack = stackPush()) { // ===> PIPELINE LAYOUT CREATION <=== - VkPipelineLayoutCreateInfo pipelineLayoutInfo = VkPipelineLayoutCreateInfo.callocStack(stack); + VkPipelineLayoutCreateInfo pipelineLayoutInfo = VkPipelineLayoutCreateInfo.calloc(stack); pipelineLayoutInfo.sType(VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO); pipelineLayoutInfo.pSetLayouts(stack.longs(this.descriptorSetLayout)); if(this.pushConstants != null) { - VkPushConstantRange.Buffer pushConstantRange = VkPushConstantRange.callocStack(1, stack); + VkPushConstantRange.Buffer pushConstantRange = VkPushConstantRange.calloc(1, stack); pushConstantRange.size(this.pushConstants.getSize()); pushConstantRange.offset(0); pushConstantRange.stageFlags(VK_SHADER_STAGE_VERTEX_BIT); @@ -303,37 +148,16 @@ private void createPipelineLayout() { } } - private void createDescriptorSets(int frames) { + protected void createDescriptorSets(int frames) { descriptorSets = new DescriptorSets[frames]; for(int i = 0; i < frames; ++i) { descriptorSets[i] = new DescriptorSets(i); } } - private void createShaderModules(SPIRV vertSpirv, SPIRV fragSpirv) { - this.vertShaderModule = createShaderModule(vertSpirv.bytecode()); - this.fragShaderModule = createShaderModule(fragSpirv.bytecode()); - } - - public void cleanUp() { - vkDestroyShaderModule(DEVICE, vertShaderModule, null); - vkDestroyShaderModule(DEVICE, fragShaderModule, null); - - destroyDescriptorSets(); - - graphicsPipelines.forEach((state, pipeline) -> { - vkDestroyPipeline(DEVICE, pipeline, null); - }); - graphicsPipelines.clear(); - - vkDestroyDescriptorSetLayout(DEVICE, descriptorSetLayout, null); - vkDestroyPipelineLayout(DEVICE, pipelineLayout, null); + public abstract void cleanUp(); - PIPELINES.remove(this); - Renderer.getInstance().removeUsedPipeline(this); - } - - private void destroyDescriptorSets() { + void destroyDescriptorSets() { for(DescriptorSets descriptorSets : this.descriptorSets) { descriptorSets.cleanUp(); } @@ -343,116 +167,30 @@ private void destroyDescriptorSets() { public ManualUBO getManualUBO() { return this.manualUBO; } - private static VkVertexInputBindingDescription.Buffer getBindingDescription(VertexFormat vertexFormat) { - - VkVertexInputBindingDescription.Buffer bindingDescription = - VkVertexInputBindingDescription.callocStack(1); - - bindingDescription.binding(0); - bindingDescription.stride(vertexFormat.getVertexSize()); - bindingDescription.inputRate(VK_VERTEX_INPUT_RATE_VERTEX); + public void resetDescriptorPool(int i) { + if(this.descriptorSets != null) + this.descriptorSets[i].resetIdx(); - return bindingDescription; } - private static VkVertexInputAttributeDescription.Buffer getAttributeDescriptions(VertexFormat vertexFormat) { - - ImmutableList elements = vertexFormat.getElements(); - - int size = elements.size(); - if(elements.stream().anyMatch(vertexFormatElement -> vertexFormatElement.getUsage() == VertexFormatElement.Usage.PADDING)) { - size--; - } - - VkVertexInputAttributeDescription.Buffer attributeDescriptions = - VkVertexInputAttributeDescription.callocStack(size); - - int offset = 0; - - for(int i = 0; i < size; ++i) { - VkVertexInputAttributeDescription posDescription = attributeDescriptions.get(i); - posDescription.binding(0); - posDescription.location(i); - - VertexFormatElement formatElement = elements.get(i); - VertexFormatElement.Usage usage = formatElement.getUsage(); - VertexFormatElement.Type type = formatElement.getType(); - switch (usage) { - case POSITION : - if(type == VertexFormatElement.Type.FLOAT) { - posDescription.format(VK_FORMAT_R32G32B32_SFLOAT); - posDescription.offset(offset); - - offset += 12; - } - else if (type == VertexFormatElement.Type.SHORT) { - posDescription.format(VK_FORMAT_R16G16B16A16_SINT); - posDescription.offset(offset); - - offset += 8; - } - else if (type == VertexFormatElement.Type.BYTE) { - posDescription.format(VK_FORMAT_R8G8B8A8_SINT); - posDescription.offset(offset); - - offset += 4; - } - - break; - - case COLOR: - posDescription.format(VK_FORMAT_R8G8B8A8_UNORM); - posDescription.offset(offset); - -// offset += 16; - offset += 4; - break; - - case UV: - if(type == VertexFormatElement.Type.FLOAT){ - posDescription.format(VK_FORMAT_R32G32_SFLOAT); - posDescription.offset(offset); - - offset += 8; - } - else if(type == VertexFormatElement.Type.SHORT){ - posDescription.format(VK_FORMAT_R16G16_SINT); - posDescription.offset(offset); - - offset += 4; - } - else if(type == VertexFormatElement.Type.USHORT){ - posDescription.format(VK_FORMAT_R16G16_UINT); - posDescription.offset(offset); - - offset += 4; - } - break; - - case NORMAL: - posDescription.format(VK_FORMAT_R8G8B8A8_SNORM); - posDescription.offset(offset); - - offset += 4; - break; - - case PADDING: + public PushConstants getPushConstants() { return this.pushConstants; } - default: - throw new RuntimeException(String.format("Unknown format: %s", usage)); - } + public long getLayout() { return pipelineLayout; } - posDescription.offset(((VertexFormatMixed)(vertexFormat)).getOffset(i)); - } + public void bindDescriptorSets(VkCommandBuffer commandBuffer, int frame) { + UniformBuffers uniformBuffers = Renderer.getDrawer().getUniformBuffers(); + this.descriptorSets[frame].bindSets(commandBuffer, uniformBuffers); + } - return attributeDescriptions.rewind(); + public void bindDescriptorSets(VkCommandBuffer commandBuffer, UniformBuffers uniformBuffers, int frame) { + this.descriptorSets[frame].bindSets(commandBuffer, uniformBuffers); } - private static long createShaderModule(ByteBuffer spirvCode) { + static long createShaderModule(ByteBuffer spirvCode) { try(MemoryStack stack = stackPush()) { - VkShaderModuleCreateInfo createInfo = VkShaderModuleCreateInfo.callocStack(stack); + VkShaderModuleCreateInfo createInfo = VkShaderModuleCreateInfo.calloc(stack); createInfo.sType(VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO); createInfo.pCode(spirvCode); @@ -467,51 +205,6 @@ private static long createShaderModule(ByteBuffer spirvCode) { } } - private static long createPipelineCache() { - try(MemoryStack stack = stackPush()) { - - VkPipelineCacheCreateInfo cacheCreateInfo = VkPipelineCacheCreateInfo.callocStack(stack); - cacheCreateInfo.sType(VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO); - - LongBuffer pPipelineCache = stack.mallocLong(1); - - if(vkCreatePipelineCache(DEVICE, cacheCreateInfo, null, pPipelineCache) != VK_SUCCESS) { - throw new RuntimeException("Failed to create graphics pipeline"); - } - - return pPipelineCache.get(0); - } - } - - public static void destroyPipelineCache() { - vkDestroyPipelineCache(DEVICE, PIPELINE_CACHE, null); - } - - public void resetDescriptorPool(int i) { - if(this.descriptorSets != null) - this.descriptorSets[i].resetIdx(); - - } - - public long getHandle(PipelineState state) { - return graphicsPipelines.computeIfAbsent(state, this::createGraphicsPipeline); - } - - public PushConstants getPushConstants() { return this.pushConstants; } - - public long getLayout() { return pipelineLayout; } - - public record Sampler(int binding, String type, String name) {} - - public void bindDescriptorSets(VkCommandBuffer commandBuffer, int frame) { - UniformBuffers uniformBuffers = Renderer.getDrawer().getUniformBuffers(); - this.descriptorSets[frame].bindSets(commandBuffer, uniformBuffers); - } - - public void bindDescriptorSets(VkCommandBuffer commandBuffer, UniformBuffers uniformBuffers, int frame) { - this.descriptorSets[frame].bindSets(commandBuffer, uniformBuffers); - } - private class DescriptorSets { private int poolSize = 10; private long descriptorPool; @@ -521,8 +214,8 @@ private class DescriptorSets { private int currentIdx = -1; private final int frame; - private final VulkanImage.Sampler[] boundTextures = new VulkanImage.Sampler[samplers.size()]; - private final IntBuffer dynamicOffsets = MemoryUtil.memAllocInt(UBOs.size());; + private final VulkanImage.Sampler[] boundTextures = new VulkanImage.Sampler[images.size()]; + private final IntBuffer dynamicOffsets = MemoryUtil.memAllocInt(buffers.size());; DescriptorSets(int frame) { this.frame = frame; @@ -548,7 +241,7 @@ private void updateUniforms(UniformBuffers uniformBuffers) { int currentOffset = uniformBuffers.getUsedBytes(); int i = 0; - for(UBO ubo : UBOs) { + for(UBO ubo : buffers) { // ubo.update(); // uniformBuffers.uploadUBO(ubo.getBuffer(), currentOffset, frame); @@ -570,10 +263,10 @@ private void updateUniforms(UniformBuffers uniformBuffers) { private void updateDescriptorSet(MemoryStack stack, UniformBuffers uniformBuffers) { boolean changed = false; - for(int j = 0; j < samplers.size(); ++j) { - Sampler sampler = samplers.get(j); + for(int j = 0; j < images.size(); ++j) { + Image image = images.get(j); - VulkanImage.Sampler texture = VTextureSelector.getTexture(sampler.name()).getTextureSampler(); + VulkanImage.Sampler texture = VTextureSelector.getTexture(image.name).getTextureSampler(); texture.image().readOnlyLayout(); if(this.boundTextures[j] != texture) { changed = true; @@ -605,14 +298,14 @@ private void updateDescriptorSet(MemoryStack stack, UniformBuffers uniformBuffer this.currentSet = this.sets.get(this.currentIdx); - VkWriteDescriptorSet.Buffer descriptorWrites = VkWriteDescriptorSet.calloc(UBOs.size() + samplers.size(), stack); - VkDescriptorBufferInfo.Buffer[] bufferInfos = new VkDescriptorBufferInfo.Buffer[UBOs.size()]; + VkWriteDescriptorSet.Buffer descriptorWrites = VkWriteDescriptorSet.calloc(buffers.size() + images.size(), stack); + VkDescriptorBufferInfo.Buffer[] bufferInfos = new VkDescriptorBufferInfo.Buffer[buffers.size()]; //TODO maybe ubo update is not needed everytime int i = 0; - for(UBO ubo : UBOs) { + for(UBO ubo : buffers) { - bufferInfos[i] = VkDescriptorBufferInfo.callocStack(1, stack); + bufferInfos[i] = VkDescriptorBufferInfo.calloc(1, stack); bufferInfos[i].buffer(this.uniformBufferId); bufferInfos[i].range(ubo.getSize()); @@ -620,7 +313,7 @@ private void updateDescriptorSet(MemoryStack stack, UniformBuffers uniformBuffer uboDescriptorWrite.sType$Default(); uboDescriptorWrite.dstBinding(ubo.getBinding()); uboDescriptorWrite.dstArrayElement(0); - uboDescriptorWrite.descriptorType(VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC); + uboDescriptorWrite.descriptorType(ubo.getType()); uboDescriptorWrite.descriptorCount(1); uboDescriptorWrite.pBufferInfo(bufferInfos[i]); uboDescriptorWrite.dstSet(currentSet); @@ -628,15 +321,15 @@ private void updateDescriptorSet(MemoryStack stack, UniformBuffers uniformBuffer ++i; } - VkDescriptorImageInfo.Buffer[] imageInfo = new VkDescriptorImageInfo.Buffer[samplers.size()]; + VkDescriptorImageInfo.Buffer[] imageInfo = new VkDescriptorImageInfo.Buffer[images.size()]; - for(int j = 0; j < samplers.size(); ++j) { - Sampler sampler = samplers.get(j); - VulkanImage texture = VTextureSelector.getTexture(sampler.name()); + for(int j = 0; j < images.size(); ++j) { + Image image = images.get(j); + VulkanImage texture = VTextureSelector.getTexture(image.name); VulkanImage.Sampler textureSampler = texture.getTextureSampler(); texture.readOnlyLayout(); - imageInfo[j] = VkDescriptorImageInfo.callocStack(1, stack); + imageInfo[j] = VkDescriptorImageInfo.calloc(1, stack); imageInfo[j].imageLayout(VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL); imageInfo[j].imageView(texture.getImageView()); @@ -644,9 +337,9 @@ private void updateDescriptorSet(MemoryStack stack, UniformBuffers uniformBuffer VkWriteDescriptorSet samplerDescriptorWrite = descriptorWrites.get(i); samplerDescriptorWrite.sType(VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET); - samplerDescriptorWrite.dstBinding(sampler.binding()); + samplerDescriptorWrite.dstBinding(image.getBinding()); samplerDescriptorWrite.dstArrayElement(0); - samplerDescriptorWrite.descriptorType(VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER); + samplerDescriptorWrite.descriptorType(image.getType()); samplerDescriptorWrite.descriptorCount(1); samplerDescriptorWrite.pImageInfo(imageInfo[j]); samplerDescriptorWrite.dstSet(currentSet); @@ -666,7 +359,7 @@ private void createDescriptorSets(MemoryStack stack) { layout.put(i, descriptorSetLayout); } - VkDescriptorSetAllocateInfo allocInfo = VkDescriptorSetAllocateInfo.callocStack(stack); + VkDescriptorSetAllocateInfo allocInfo = VkDescriptorSetAllocateInfo.calloc(stack); allocInfo.sType$Default(); allocInfo.descriptorPool(descriptorPool); allocInfo.pSetLayouts(layout); @@ -680,25 +373,25 @@ private void createDescriptorSets(MemoryStack stack) { } private void createDescriptorPool(MemoryStack stack) { - int size = UBOs.size() + samplers.size(); + int size = buffers.size() + images.size(); - VkDescriptorPoolSize.Buffer poolSizes = VkDescriptorPoolSize.callocStack(size, stack); + VkDescriptorPoolSize.Buffer poolSizes = VkDescriptorPoolSize.calloc(size, stack); int i; - for(i = 0; i < UBOs.size(); ++i) { + for(i = 0; i < buffers.size(); ++i) { VkDescriptorPoolSize uniformBufferPoolSize = poolSizes.get(i); // uniformBufferPoolSize.type(VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER); uniformBufferPoolSize.type(VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC); uniformBufferPoolSize.descriptorCount(this.poolSize); } - for(; i < UBOs.size() + samplers.size(); ++i) { + for(; i < buffers.size() + images.size(); ++i) { VkDescriptorPoolSize textureSamplerPoolSize = poolSizes.get(i); textureSamplerPoolSize.type(VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER); textureSamplerPoolSize.descriptorCount(this.poolSize); } - VkDescriptorPoolCreateInfo poolInfo = VkDescriptorPoolCreateInfo.callocStack(stack); + VkDescriptorPoolCreateInfo poolInfo = VkDescriptorPoolCreateInfo.calloc(stack); poolInfo.sType(VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO); poolInfo.pPoolSizes(poolSizes); poolInfo.maxSets(this.poolSize); @@ -730,25 +423,25 @@ private void cleanUp() { public static class Builder { - public static Pipeline create(VertexFormat format, String path) { + public static GraphicsPipeline createGraphicsPipeline(VertexFormat format, String path) { Pipeline.Builder pipelineBuilder = new Pipeline.Builder(format, path); pipelineBuilder.parseBindingsJSON(); pipelineBuilder.compileShaders(); - return pipelineBuilder.createPipeline(); + return pipelineBuilder.createGraphicsPipeline(); } - private final VertexFormat vertexFormat; - private final String shaderPath; - private List UBOs; - private ManualUBO manualUBO; - private PushConstants pushConstants; - private List samplers; - private int currentBinding; + final VertexFormat vertexFormat; + final String shaderPath; + List UBOs; + ManualUBO manualUBO; + PushConstants pushConstants; + List images; + int currentBinding; - private SPIRV vertShaderSPIRV; - private SPIRV fragShaderSPIRV; + SPIRV vertShaderSPIRV; + SPIRV fragShaderSPIRV; - private RenderPass renderPass; + RenderPass renderPass; public Builder(VertexFormat vertexFormat, String path) { this.vertexFormat = vertexFormat; @@ -759,26 +452,27 @@ public Builder(VertexFormat vertexFormat) { this(vertexFormat, null); } - public Pipeline createPipeline() { - Validate.isTrue(this.samplers != null && this.UBOs != null + public GraphicsPipeline createGraphicsPipeline() { + Validate.isTrue(this.images != null && this.UBOs != null && this.vertShaderSPIRV != null && this.fragShaderSPIRV != null, "Cannot create Pipeline: resources missing"); if(this.manualUBO != null) this.UBOs.add(this.manualUBO); - return new Pipeline(this.vertexFormat, this.renderPass, - this.UBOs, this.manualUBO, this.samplers, this.pushConstants, this.vertShaderSPIRV, this.fragShaderSPIRV); + return new GraphicsPipeline(this); } - public void setUniforms(List UBOs, List samplers) { + public void setUniforms(List UBOs, List images) { this.UBOs = UBOs; - this.samplers = samplers; + this.images = images; } public void compileShaders() { - this.vertShaderSPIRV = compileShaderFile(this.shaderPath + ".vsh", ShaderKind.VERTEX_SHADER); - this.fragShaderSPIRV = compileShaderFile(this.shaderPath + ".fsh", ShaderKind.FRAGMENT_SHADER); + String resourcePath = SPIRVUtils.class.getResource("/assets/vulkanmod/shaders/").toExternalForm(); + + this.vertShaderSPIRV = compileShaderAbsoluteFile(String.format("%s%s.vsh", resourcePath, this.shaderPath), ShaderKind.VERTEX_SHADER); + this.fragShaderSPIRV = compileShaderAbsoluteFile(String.format("%s%s.fsh", resourcePath, this.shaderPath), ShaderKind.FRAGMENT_SHADER); } public void compileShaders(String vsh, String fsh) { @@ -790,7 +484,7 @@ public void parseBindingsJSON() { Validate.notNull(this.shaderPath, "Cannot parse bindings: shaderPath is null"); this.UBOs = new ArrayList<>(); - this.samplers = new ArrayList<>(); + this.images = new ArrayList<>(); JsonObject jsonObject; @@ -831,7 +525,7 @@ public void parseBindingsJSON() { private void parseUboNode(JsonElement jsonelement) { JsonObject jsonobject = GsonHelper.convertToJsonObject(jsonelement, "UBO"); int binding = GsonHelper.getAsInt(jsonobject, "binding"); - int type = getTypeFromString(GsonHelper.getAsString(jsonobject, "type")); + int type = getStageFromString(GsonHelper.getAsString(jsonobject, "type")); JsonArray fields = GsonHelper.getAsJsonArray(jsonobject, "fields"); AlignedStruct.Builder builder = new AlignedStruct.Builder(); @@ -857,22 +551,22 @@ private void parseUboNode(JsonElement jsonelement) { private void parseManualUboNode(JsonElement jsonelement) { JsonObject jsonobject = GsonHelper.convertToJsonObject(jsonelement, "ManualUBO"); int binding = GsonHelper.getAsInt(jsonobject, "binding"); - int type = getTypeFromString(GsonHelper.getAsString(jsonobject, "type")); + int stage = getStageFromString(GsonHelper.getAsString(jsonobject, "type")); int size = GsonHelper.getAsInt(jsonobject, "size"); if(binding > this.currentBinding) this.currentBinding = binding; - this.manualUBO = new ManualUBO(binding, type, size); + this.manualUBO = new ManualUBO(binding, stage, size); } private void parseSamplerNode(JsonElement jsonelement) { - JsonObject jsonobject = GsonHelper.convertToJsonObject(jsonelement, "UBO"); + JsonObject jsonobject = GsonHelper.convertToJsonObject(jsonelement, "Sampler"); String name = GsonHelper.getAsString(jsonobject, "name"); this.currentBinding++; - this.samplers.add(new Sampler(this.currentBinding, "sampler2D", name)); + this.images.add(new Image(this.currentBinding, "sampler2D", name)); } private void parsePushConstantNode(JsonArray jsonArray) { @@ -891,11 +585,12 @@ private void parsePushConstantNode(JsonArray jsonArray) { this.pushConstants = builder.buildPushConstant(); } - public static int getTypeFromString(String s) { + public static int getStageFromString(String s) { return switch (s) { case "vertex" -> VK_SHADER_STAGE_VERTEX_BIT; case "fragment" -> VK_SHADER_STAGE_FRAGMENT_BIT; case "all" -> VK_SHADER_STAGE_ALL_GRAPHICS; + case "compute" -> VK_SHADER_STAGE_COMPUTE_BIT; default -> throw new RuntimeException("cannot identify type.."); }; diff --git a/src/main/java/net/vulkanmod/vulkan/shader/PipelineState.java b/common/src/main/java/net/vulkanmod/vulkan/shader/PipelineState.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/shader/PipelineState.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/PipelineState.java diff --git a/src/main/java/net/vulkanmod/vulkan/shader/ShaderSPIRVUtils.java b/common/src/main/java/net/vulkanmod/vulkan/shader/SPIRVUtils.java similarity index 83% rename from src/main/java/net/vulkanmod/vulkan/shader/ShaderSPIRVUtils.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/SPIRVUtils.java index b809fdab8..8238611c2 100644 --- a/src/main/java/net/vulkanmod/vulkan/shader/ShaderSPIRVUtils.java +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/SPIRVUtils.java @@ -14,14 +14,11 @@ import static org.lwjgl.system.MemoryUtil.NULL; import static org.lwjgl.util.shaderc.Shaderc.*; -public class ShaderSPIRVUtils { - private static long compiler; +public class SPIRVUtils { + private static final boolean DEBUG = true; + private static final boolean OPTIMIZATIONS = false; - public static SPIRV compileShaderFile(String shaderFile, ShaderKind shaderKind) { - //TODO name out - String path = ShaderSPIRVUtils.class.getResource("/assets/vulkanmod/shaders/" + shaderFile).toExternalForm(); - return compileShaderAbsoluteFile(path, shaderKind); - } + private static long compiler; public static SPIRV compileShaderAbsoluteFile(String shaderFile, ShaderKind shaderKind) { try { @@ -47,9 +44,11 @@ public static SPIRV compileShader(String filename, String source, ShaderKind sha throw new RuntimeException("Failed to create compiler options"); } -// shaderc_compile_options_set_optimization_level(options, shaderc_optimization_level_performance); + if(OPTIMIZATIONS) + shaderc_compile_options_set_optimization_level(options, shaderc_optimization_level_performance); - shaderc_compile_options_set_generate_debug_info(options); + if(DEBUG) + shaderc_compile_options_set_generate_debug_info(options); long result = shaderc_compile_into_spv(compiler, source, shaderKind.kind, filename, "main", options); @@ -61,8 +60,6 @@ public static SPIRV compileShader(String filename, String source, ShaderKind sha throw new RuntimeException("Failed to compile shader " + filename + " into SPIR-V:\n" + shaderc_result_get_error_message(result)); } -// shaderc_compiler_release(compiler); - return new SPIRV(result, shaderc_result_get_bytes(result)); } @@ -83,7 +80,8 @@ private static SPIRV readFromStream(InputStream inputStream) { public enum ShaderKind { VERTEX_SHADER(shaderc_glsl_vertex_shader), GEOMETRY_SHADER(shaderc_glsl_geometry_shader), - FRAGMENT_SHADER(shaderc_glsl_fragment_shader); + FRAGMENT_SHADER(shaderc_glsl_fragment_shader), + COMPUTE_SHADER(shaderc_glsl_compute_shader); private final int kind; diff --git a/src/main/java/net/vulkanmod/vulkan/shader/Uniforms.java b/common/src/main/java/net/vulkanmod/vulkan/shader/Uniforms.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/shader/Uniforms.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/Uniforms.java diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/Descriptor.java b/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/Descriptor.java new file mode 100644 index 000000000..2685ccd0e --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/Descriptor.java @@ -0,0 +1,10 @@ +package net.vulkanmod.vulkan.shader.descriptor; + +public interface Descriptor { + + int getBinding(); + + int getType(); + + int getStages(); +} diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/Image.java b/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/Image.java new file mode 100644 index 000000000..f96be3ef8 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/Image.java @@ -0,0 +1,40 @@ +package net.vulkanmod.vulkan.shader.descriptor; + +import static org.lwjgl.vulkan.VK10.*; + +public class Image implements Descriptor { + + private final int descriptorType; + private final int binding; + public final String qualifier; + public final String name; + public final boolean useSampler; + + public Image(int binding, String type, String name) { + this(binding, type, name, true); + } + + public Image(int binding, String type, String name, boolean useSampler) { + this.binding = binding; + this.qualifier = type; + this.name = name; + this.useSampler = useSampler; + + descriptorType = useSampler ? VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER : VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE; + } + + @Override + public int getBinding() { + return binding; + } + + @Override + public int getType() { + return descriptorType; + } + + @Override + public int getStages() { + return VK_SHADER_STAGE_ALL_GRAPHICS; + } +} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/ManualUBO.java b/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/ManualUBO.java similarity index 71% rename from src/main/java/net/vulkanmod/vulkan/shader/ManualUBO.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/ManualUBO.java index e685ce6d5..45ca1841c 100644 --- a/src/main/java/net/vulkanmod/vulkan/shader/ManualUBO.java +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/ManualUBO.java @@ -1,7 +1,5 @@ -package net.vulkanmod.vulkan.shader; +package net.vulkanmod.vulkan.shader.descriptor; -import net.vulkanmod.vulkan.shader.layout.Field; -import net.vulkanmod.vulkan.shader.layout.UBO; import org.lwjgl.system.MemoryUtil; public class ManualUBO extends UBO { @@ -13,10 +11,6 @@ public ManualUBO(int binding, int type, int size) { super(binding, type, size * 4, null); } - public void update() { - //update manually - } - @Override public void update(long ptr) { //update manually diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/UBO.java b/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/UBO.java new file mode 100644 index 000000000..039b14799 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/descriptor/UBO.java @@ -0,0 +1,33 @@ +package net.vulkanmod.vulkan.shader.descriptor; + +import net.vulkanmod.vulkan.shader.layout.AlignedStruct; +import net.vulkanmod.vulkan.shader.layout.Field; + +import java.util.List; + +import static org.lwjgl.vulkan.VK10.VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC; + +public class UBO extends AlignedStruct implements Descriptor { + private final int binding; + private final int stages; + + public UBO(int binding, int stages, int size, List infoList) { + super(infoList, size); + this.binding = binding; + this.stages = stages; + } + + public int getBinding() { + return binding; + } + + @Override + public int getType() { + return VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC; + } + + public int getStages() { + return stages; + } + +} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/AlignedStruct.java b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/AlignedStruct.java similarity index 74% rename from src/main/java/net/vulkanmod/vulkan/shader/layout/AlignedStruct.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/layout/AlignedStruct.java index 0ff0a3541..9daf680a4 100644 --- a/src/main/java/net/vulkanmod/vulkan/shader/layout/AlignedStruct.java +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/AlignedStruct.java @@ -1,40 +1,28 @@ package net.vulkanmod.vulkan.shader.layout; -import net.vulkanmod.vulkan.shader.ManualUBO; -import net.vulkanmod.vulkan.util.MappedBuffer; +import net.vulkanmod.vulkan.shader.descriptor.UBO; import java.util.ArrayList; import java.util.List; public abstract class AlignedStruct { - @Deprecated - protected MappedBuffer buffer; protected List fields = new ArrayList<>(); protected int size; protected AlignedStruct(List infoList, int size) { this.size = size; - this.buffer = new MappedBuffer(size); if(infoList == null) return; for(Field.FieldInfo fieldInfo : infoList) { - Field field = Field.createField(fieldInfo, this.buffer.ptr); + Field field = Field.createField(fieldInfo); this.fields.add(field); } } - @Deprecated - public void update() { - for(Field field : this.fields) { - field.update(); - } - - } - public void update(long ptr) { for(Field field : this.fields) { field.update(ptr); @@ -45,10 +33,6 @@ public List getFields() { return this.fields; } - public long getBufferPtr() { - return this.buffer.ptr; - } - public int getSize() { return size; } @@ -74,9 +58,9 @@ public void addFieldInfo(String type, String name) { this.fields.add(fieldInfo); } - public UBO buildUBO(int binding, int type) { + public UBO buildUBO(int binding, int stages) { //offset is expressed in floats/ints - return new UBO(binding, type, this.currentOffset * 4, this.fields); + return new UBO(binding, stages, this.currentOffset * 4, this.fields); } public PushConstants buildPushConstant() { diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/Field.java b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Field.java similarity index 84% rename from src/main/java/net/vulkanmod/vulkan/shader/layout/Field.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/layout/Field.java index 4d0ea41af..47a49f04f 100644 --- a/src/main/java/net/vulkanmod/vulkan/shader/layout/Field.java +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Field.java @@ -3,20 +3,17 @@ import net.vulkanmod.vulkan.util.MappedBuffer; import org.lwjgl.system.MemoryUtil; -import java.nio.ByteBuffer; import java.util.function.Supplier; public abstract class Field { protected Supplier values; FieldInfo fieldInfo; - protected long basePtr; protected long offset; protected int size; - Field(FieldInfo fieldInfo, long ptr) { + Field(FieldInfo fieldInfo) { this.fieldInfo = fieldInfo; - this.basePtr = ptr + (fieldInfo.offset * 4L); this.offset = fieldInfo.offset * 4L; this.size = fieldInfo.size * 4; this.setSupplier(); @@ -32,22 +29,20 @@ public String getName() { return this.fieldInfo.name; } - abstract void update(); - void update(long ptr) { MappedBuffer src = values.get(); MemoryUtil.memCopy(src.ptr, ptr + this.offset, this.size); } - public static Field createField(FieldInfo info, long ptr) { + public static Field createField(FieldInfo info) { return switch (info.type) { - case "mat4" -> new Mat4f(info, ptr); - case "vec4" -> new Vec4f(info, ptr); - case "vec3" -> new Vec3f(info, ptr); - case "vec2" -> new Vec2f(info, ptr); - case "float" -> new Vec1f(info, ptr); - case "int" -> new Vec1i(info, ptr); + case "mat4" -> new Mat4f(info); + case "vec4" -> new Vec4f(info); + case "vec3" -> new Vec3f(info); + case "vec2" -> new Vec2f(info); + case "float" -> new Vec1f(info); + case "int" -> new Vec1i(info); default -> throw new RuntimeException("not admitted type: " + info.type); }; } diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Mat4f.java b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Mat4f.java new file mode 100644 index 000000000..503cf8b19 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Mat4f.java @@ -0,0 +1,17 @@ +package net.vulkanmod.vulkan.shader.layout; + +import net.vulkanmod.vulkan.shader.Uniforms; +import org.apache.commons.lang3.Validate; + +public class Mat4f extends Field { + public Mat4f(FieldInfo info) { + super(info); + } + + protected void setSupplier() { + this.values = Uniforms.mat4f_uniformMap.get(this.fieldInfo.name); + + Validate.notNull(this.values, "Field name not found: " + this.fieldInfo.name); + } + +} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/PushConstants.java b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/PushConstants.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/shader/layout/PushConstants.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/layout/PushConstants.java diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1f.java b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1f.java new file mode 100644 index 000000000..2207f9ed3 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1f.java @@ -0,0 +1,26 @@ +package net.vulkanmod.vulkan.shader.layout; + +import net.vulkanmod.vulkan.shader.Uniforms; +import org.apache.commons.lang3.Validate; +import org.lwjgl.system.MemoryUtil; + +import java.util.function.Supplier; + +public class Vec1f extends Field { + private Supplier floatSupplier; + + public Vec1f(FieldInfo fieldInfo) { + super(fieldInfo); + } + + void setSupplier() { + this.floatSupplier = Uniforms.vec1f_uniformMap.get(this.fieldInfo.name); + + Validate.notNull(this.floatSupplier, "Field name not found: " + this.fieldInfo.name); + } + + void update(long ptr) { + float f = this.floatSupplier.get(); + MemoryUtil.memPutFloat(ptr + this.offset, f); + } +} diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1i.java b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1i.java new file mode 100644 index 000000000..a63fdc146 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1i.java @@ -0,0 +1,26 @@ +package net.vulkanmod.vulkan.shader.layout; + +import net.vulkanmod.vulkan.shader.Uniforms; +import org.apache.commons.lang3.Validate; +import org.lwjgl.system.MemoryUtil; + +import java.util.function.Supplier; + +public class Vec1i extends Field { + private Supplier intSupplier; + + public Vec1i(FieldInfo fieldInfo) { + super(fieldInfo); + } + + void setSupplier() { + this.intSupplier = Uniforms.vec1i_uniformMap.get(this.fieldInfo.name); + + Validate.notNull(this.intSupplier, "Field name not found: " + this.fieldInfo.name); + } + + void update(long ptr) { + int i = this.intSupplier.get(); + MemoryUtil.memPutInt(ptr + this.offset, i); + } +} diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec2f.java b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec2f.java new file mode 100644 index 000000000..f7143c760 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec2f.java @@ -0,0 +1,18 @@ +package net.vulkanmod.vulkan.shader.layout; + +import net.vulkanmod.vulkan.shader.Uniforms; +import org.apache.commons.lang3.Validate; + +public class Vec2f extends Field { + + public Vec2f(FieldInfo fieldInfo) { + super(fieldInfo); + } + + void setSupplier() { + this.values = Uniforms.vec2f_uniformMap.get(this.fieldInfo.name); + + Validate.notNull(this.values, "Field name not found: " + this.fieldInfo.name); + } + +} diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec3f.java b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec3f.java new file mode 100644 index 000000000..f4c31e1c4 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec3f.java @@ -0,0 +1,18 @@ +package net.vulkanmod.vulkan.shader.layout; + +import net.vulkanmod.vulkan.shader.Uniforms; +import org.apache.commons.lang3.Validate; + +public class Vec3f extends Field { + + public Vec3f(FieldInfo fieldInfo) { + super(fieldInfo); + } + + void setSupplier() { + this.values = Uniforms.vec3f_uniformMap.get(this.fieldInfo.name); + + Validate.notNull(this.values, "Field name not found: " + this.fieldInfo.name); + } + +} diff --git a/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec4f.java b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec4f.java new file mode 100644 index 000000000..b75a747a5 --- /dev/null +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec4f.java @@ -0,0 +1,18 @@ +package net.vulkanmod.vulkan.shader.layout; + +import net.vulkanmod.vulkan.shader.Uniforms; +import org.apache.commons.lang3.Validate; + +public class Vec4f extends Field { + + public Vec4f(FieldInfo fieldInfo) { + super(fieldInfo); + } + + void setSupplier() { + this.values = Uniforms.vec4f_uniformMap.get(this.fieldInfo.name); + + Validate.notNull(this.values, "Field name not found: " + this.fieldInfo.name); + } + +} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/parser/GlslConverter.java b/common/src/main/java/net/vulkanmod/vulkan/shader/parser/GlslConverter.java similarity index 96% rename from src/main/java/net/vulkanmod/vulkan/shader/parser/GlslConverter.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/parser/GlslConverter.java index 40ae1bc54..1ca9895c7 100644 --- a/src/main/java/net/vulkanmod/vulkan/shader/parser/GlslConverter.java +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/parser/GlslConverter.java @@ -2,7 +2,8 @@ import com.mojang.blaze3d.vertex.VertexFormat; import net.vulkanmod.vulkan.shader.Pipeline; -import net.vulkanmod.vulkan.shader.layout.UBO; +import net.vulkanmod.vulkan.shader.descriptor.Image; +import net.vulkanmod.vulkan.shader.descriptor.UBO; import java.util.Arrays; import java.util.List; @@ -143,7 +144,7 @@ public UBO getUBO() { return this.uniformParser.getUbo(); } - public List getSamplerList() { + public List getSamplerList() { return this.uniformParser.getSamplers(); } diff --git a/src/main/java/net/vulkanmod/vulkan/shader/parser/InputOutputParser.java b/common/src/main/java/net/vulkanmod/vulkan/shader/parser/InputOutputParser.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/shader/parser/InputOutputParser.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/parser/InputOutputParser.java diff --git a/src/main/java/net/vulkanmod/vulkan/shader/parser/UniformParser.java b/common/src/main/java/net/vulkanmod/vulkan/shader/parser/UniformParser.java similarity index 85% rename from src/main/java/net/vulkanmod/vulkan/shader/parser/UniformParser.java rename to common/src/main/java/net/vulkanmod/vulkan/shader/parser/UniformParser.java index e6cdfd7f9..1909bc563 100644 --- a/src/main/java/net/vulkanmod/vulkan/shader/parser/UniformParser.java +++ b/common/src/main/java/net/vulkanmod/vulkan/shader/parser/UniformParser.java @@ -2,8 +2,9 @@ import it.unimi.dsi.fastutil.objects.ObjectArrayList; import net.vulkanmod.vulkan.shader.Pipeline; +import net.vulkanmod.vulkan.shader.descriptor.Image; import net.vulkanmod.vulkan.shader.layout.AlignedStruct; -import net.vulkanmod.vulkan.shader.layout.UBO; +import net.vulkanmod.vulkan.shader.descriptor.UBO; import java.util.ArrayList; import java.util.List; @@ -19,7 +20,7 @@ public class UniformParser { private String name; private UBO ubo; - private List samplers; + private List images; public UniformParser(GlslConverter converterInstance) { this.converterInstance = converterInstance; @@ -86,10 +87,10 @@ public String createUniformsCode() { public String createSamplersCode(GlslConverter.ShaderStage shaderStage) { StringBuilder builder = new StringBuilder(); - this.samplers = createSamplerList(); + this.images = createSamplerList(); - for(Pipeline.Sampler sampler : this.samplers) { - builder.append(String.format("layout(binding = %d) uniform %s %s;\n", sampler.binding(), sampler.type(), sampler.name())); + for(Image image : this.images) { + builder.append(String.format("layout(binding = %d) uniform %s %s;\n", image.getBinding(), image.qualifier, image.name)); } builder.append("\n"); @@ -104,22 +105,22 @@ private UBO createUBO() { } //hardcoded 0 binding as it should always be 0 in this case - return builder.buildUBO(0, Pipeline.Builder.getTypeFromString("all")); + return builder.buildUBO(0, Pipeline.Builder.getStageFromString("all")); } - private List createSamplerList() { + private List createSamplerList() { int currentLocation = 1; - List samplers = new ObjectArrayList<>(); + List images = new ObjectArrayList<>(); for(StageUniforms stageUniforms : this.stageUniforms) { for(Uniform uniform : stageUniforms.samplers) { - samplers.add(new Pipeline.Sampler(currentLocation, uniform.type, uniform.name)); + images.add(new Image(currentLocation, uniform.type, uniform.name)); currentLocation++; } } - return samplers; + return images; } public static String removeSemicolon(String s) { @@ -133,8 +134,8 @@ public UBO getUbo() { return this.ubo; } - public List getSamplers() { - return this.samplers; + public List getSamplers() { + return this.images; } public record Uniform(String type, String name) {} diff --git a/src/main/java/net/vulkanmod/vulkan/texture/VTextureSelector.java b/common/src/main/java/net/vulkanmod/vulkan/texture/VTextureSelector.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/texture/VTextureSelector.java rename to common/src/main/java/net/vulkanmod/vulkan/texture/VTextureSelector.java diff --git a/src/main/java/net/vulkanmod/vulkan/texture/VulkanImage.java b/common/src/main/java/net/vulkanmod/vulkan/texture/VulkanImage.java similarity index 96% rename from src/main/java/net/vulkanmod/vulkan/texture/VulkanImage.java rename to common/src/main/java/net/vulkanmod/vulkan/texture/VulkanImage.java index 9a8b34f04..c2a231d75 100644 --- a/src/main/java/net/vulkanmod/vulkan/texture/VulkanImage.java +++ b/common/src/main/java/net/vulkanmod/vulkan/texture/VulkanImage.java @@ -104,7 +104,7 @@ private void createImage(int mipLevels, int width, int height, int format, int u LongBuffer pTextureImage = stack.mallocLong(1); PointerBuffer pAllocation = stack.pointers(0L); - MemoryManager.getInstance().createImage(width, height, mipLevels, + MemoryManager.createImage(width, height, mipLevels, format, VK_IMAGE_TILING_OPTIMAL, usage, VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT, @@ -114,7 +114,7 @@ private void createImage(int mipLevels, int width, int height, int format, int u id = pTextureImage.get(0); allocation = pAllocation.get(0); - MemoryManager.getInstance().addImage(this); + MemoryManager.addImage(this); } catch (Exception e) { e.printStackTrace(); @@ -149,7 +149,7 @@ public static long createImageView(long image, int format, int aspectFlags, int public void uploadSubTextureAsync(int mipLevel, int width, int height, int xOffset, int yOffset, int unpackSkipRows, int unpackSkipPixels, int unpackRowLength, ByteBuffer buffer) { long imageSize = buffer.limit(); - CommandPool.CommandBuffer commandBuffer = GraphicsQueue.getInstance().getCommandBuffer(); + CommandPool.CommandBuffer commandBuffer = Device.getGraphicsQueue().getCommandBuffer(); transferDstLayout(commandBuffer); StagingBuffer stagingBuffer = Vulkan.getStagingBuffer(Renderer.getCurrentFrame()); @@ -160,7 +160,7 @@ public void uploadSubTextureAsync(int mipLevel, int width, int height, int xOffs copyBufferToImageCmd(commandBuffer, stagingBuffer.getId(), id, mipLevel, width, height, xOffset, yOffset, (int) (stagingBuffer.getOffset() + (unpackRowLength * unpackSkipRows + unpackSkipPixels) * this.formatSize), unpackRowLength, height); - long fence = GraphicsQueue.getInstance().endIfNeeded(commandBuffer); + long fence = Device.getGraphicsQueue().endIfNeeded(commandBuffer); if (fence != VK_NULL_HANDLE) // Synchronization.INSTANCE.addFence(fence); Synchronization.INSTANCE.addCommandBuffer(commandBuffer); @@ -184,7 +184,7 @@ public static void downloadTexture(int width, int height, int formatSize, ByteBu (data) -> VUtil.memcpy(data.getByteBuffer(0, (int)imageSize), buffer) ); - MemoryManager.getInstance().freeBuffer(pStagingBuffer.get(0), pStagingAllocation.get(0)); + MemoryManager.freeBuffer(pStagingBuffer.get(0), pStagingAllocation.get(0)); } } @@ -237,9 +237,9 @@ public void readOnlyLayout() { if (this.currentLayout == VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL) return; - CommandPool.CommandBuffer commandBuffer = GraphicsQueue.getInstance().getCommandBuffer(); + CommandPool.CommandBuffer commandBuffer = Device.getGraphicsQueue().getCommandBuffer(); readOnlyLayout(commandBuffer); - GraphicsQueue.getInstance().submitCommands(commandBuffer); + Device.getGraphicsQueue().submitCommands(commandBuffer); Synchronization.INSTANCE.addCommandBuffer(commandBuffer); } @@ -374,7 +374,7 @@ private static void copyImageToBuffer(long buffer, long image, int mipLevel, int try(MemoryStack stack = stackPush()) { - CommandPool.CommandBuffer commandBuffer = GraphicsQueue.getInstance().beginCommands(); + CommandPool.CommandBuffer commandBuffer = Device.getGraphicsQueue().beginCommands(); VkBufferImageCopy.Buffer region = VkBufferImageCopy.callocStack(1, stack); region.bufferOffset(bufferOffset); @@ -389,7 +389,7 @@ private static void copyImageToBuffer(long buffer, long image, int mipLevel, int vkCmdCopyImageToBuffer(commandBuffer.getHandle(), image, VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL, buffer, region); - long fence = GraphicsQueue.getInstance().submitCommands(commandBuffer); + long fence = Device.getGraphicsQueue().submitCommands(commandBuffer); vkWaitForFences(device, fence, true, VUtil.UINT64_MAX); } @@ -490,8 +490,8 @@ public void free() { MemoryManager.getInstance().addToFreeable(this); } - public void doFree(MemoryManager memoryManager) { - memoryManager.freeImage(this.id, this.allocation); + public void doFree() { + MemoryManager.freeImage(this.id, this.allocation); vkDestroyImageView(Vulkan.getDevice(), this.imageView, null); diff --git a/src/main/java/net/vulkanmod/vulkan/util/ColorUtil.java b/common/src/main/java/net/vulkanmod/vulkan/util/ColorUtil.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/util/ColorUtil.java rename to common/src/main/java/net/vulkanmod/vulkan/util/ColorUtil.java diff --git a/src/main/java/net/vulkanmod/vulkan/util/DrawUtil.java b/common/src/main/java/net/vulkanmod/vulkan/util/DrawUtil.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/util/DrawUtil.java rename to common/src/main/java/net/vulkanmod/vulkan/util/DrawUtil.java diff --git a/src/main/java/net/vulkanmod/vulkan/util/MappedBuffer.java b/common/src/main/java/net/vulkanmod/vulkan/util/MappedBuffer.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/util/MappedBuffer.java rename to common/src/main/java/net/vulkanmod/vulkan/util/MappedBuffer.java diff --git a/src/main/java/net/vulkanmod/vulkan/util/Pair.java b/common/src/main/java/net/vulkanmod/vulkan/util/Pair.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/util/Pair.java rename to common/src/main/java/net/vulkanmod/vulkan/util/Pair.java diff --git a/src/main/java/net/vulkanmod/vulkan/util/VUtil.java b/common/src/main/java/net/vulkanmod/vulkan/util/VUtil.java similarity index 100% rename from src/main/java/net/vulkanmod/vulkan/util/VUtil.java rename to common/src/main/java/net/vulkanmod/vulkan/util/VUtil.java diff --git a/common/src/main/resources/architectury.common.json b/common/src/main/resources/architectury.common.json new file mode 100644 index 000000000..681ddfad6 --- /dev/null +++ b/common/src/main/resources/architectury.common.json @@ -0,0 +1,3 @@ +{ + "accessWidener": "vulkanmod.accesswidener" +} \ No newline at end of file diff --git a/src/main/resources/assets/vulkanmod/Vlogo.png b/common/src/main/resources/assets/vulkanmod/Vlogo.png similarity index 100% rename from src/main/resources/assets/vulkanmod/Vlogo.png rename to common/src/main/resources/assets/vulkanmod/Vlogo.png diff --git a/src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.fsh b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.json b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.json rename to common/src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.json diff --git a/src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.vsh b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/basic/terrain/terrain.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.fsh b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.json b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.json rename to common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.json diff --git a/src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.vsh b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_direct/terrain_direct.vsh diff --git a/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_indirect/terrain_indirect.fsh b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_indirect/terrain_indirect.fsh new file mode 100644 index 000000000..ce60b3fb9 --- /dev/null +++ b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_indirect/terrain_indirect.fsh @@ -0,0 +1,35 @@ +#version 450 + +vec4 linear_fog(vec4 inColor, float vertexDistance, float fogStart, float fogEnd, vec4 fogColor) { + if (vertexDistance <= fogStart) { + return inColor; + } + + float fogValue = vertexDistance < fogEnd ? smoothstep(fogStart, fogEnd, vertexDistance) : 1.0; + return vec4(mix(inColor.rgb, fogColor.rgb, fogValue * fogColor.a), inColor.a); +} + +layout(binding = 3) uniform sampler2D Sampler0; + +layout(binding = 1) uniform UBO{ + vec4 ColorModulator; + vec4 FogColor; + float FogStart; + float FogEnd; + float AlphaCutout; +}; + +layout(location = 0) in float vertexDistance; +layout(location = 1) in vec4 vertexColor; +layout(location = 2) in vec2 texCoord0; +//layout(location = 3) in vec4 normal; + +layout(location = 0) out vec4 fragColor; + +void main() { + vec4 color = texture(Sampler0, texCoord0) * vertexColor * ColorModulator; + if (color.a < AlphaCutout) { + discard; + } + fragColor = linear_fog(color, vertexDistance, FogStart, FogEnd, FogColor); +} \ No newline at end of file diff --git a/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_indirect/terrain_indirect.json b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_indirect/terrain_indirect.json new file mode 100644 index 000000000..9590454c5 --- /dev/null +++ b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_indirect/terrain_indirect.json @@ -0,0 +1,45 @@ +{ + "blend": { + "func": "add", + "srcrgb": "srcalpha", + "dstrgb": "1-srcalpha" + }, + "vertex": "rendertype_solid", + "fragment": "rendertype_solid", + "attributes": [ + "Position", + "Color", + "UV0", + "UV2", + "Normal" + ], + "samplers": [ + { "name": "Sampler0" }, + { "name": "Sampler2" } + ], + "uniforms": [ + { "name": "ModelViewMat", "type": "matrix4x4", "count": 16, "values": [ 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0 ] }, + { "name": "ProjMat", "type": "matrix4x4", "count": 16, "values": [ 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0 ] }, + { "name": "ChunkOffset", "type": "float", "count": 3, "values": [ 0.0, 0.0, 0.0 ] }, + { "name": "ColorModulator", "type": "float", "count": 4, "values": [ 1.0, 1.0, 1.0, 1.0 ] }, + { "name": "FogStart", "type": "float", "count": 1, "values": [ 0.0 ] }, + { "name": "FogEnd", "type": "float", "count": 1, "values": [ 1.0 ] }, + { "name": "FogColor", "type": "float", "count": 4, "values": [ 0.0, 0.0, 0.0, 0.0 ] } + ], + "UBOs": [ + { "type": "vertex", "binding": 0, "fields": [ + { "name": "MVP", "type": "matrix4x4", "count": 16, "values": [ 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0 ] }, + { "name": "ModelViewMat", "type": "matrix4x4", "count": 16, "values": [ 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0 ] } + ] }, + { "type": "fragment", "binding": 1, "fields": [ + { "name": "ColorModulator", "type": "float", "count": 4, "values": [ 1.0, 1.0, 1.0, 1.0 ] }, + { "name": "FogColor", "type": "float", "count": 4, "values": [ 0.0, 0.0, 0.0, 0.0 ] }, + { "name": "FogStart", "type": "float", "count": 1, "values": [ 0.0 ] }, + { "name": "FogEnd", "type": "float", "count": 1, "values": [ 1.0 ] }, + { "name": "AlphaCutout", "type": "float", "count": 1, "values": [ 1.0 ] } + ] } + ], + "ManualUBOs" : [ + { "type": "vertex", "binding": 2, "size": 2048 } + ] +} diff --git a/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_indirect/terrain_indirect.vsh b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_indirect/terrain_indirect.vsh new file mode 100644 index 000000000..17b12036d --- /dev/null +++ b/common/src/main/resources/assets/vulkanmod/shaders/basic/terrain_indirect/terrain_indirect.vsh @@ -0,0 +1,61 @@ +#version 460 + +#define MAX_OFFSET_COUNT 512 + +vec4 minecraft_sample_lightmap(sampler2D lightMap, ivec2 uv) { + return texelFetch(lightMap, (uv & 255) >> 4, 0); +} + +layout(binding = 0) uniform UniformBufferObject { + mat4 MVP; + mat4 ModelViewMat; +}; + +layout(binding = 2) uniform UniformBufferObject2 { + vec3 ChunkOffset[MAX_OFFSET_COUNT]; +}; + +layout(binding = 4) uniform sampler2D Sampler2; + +layout(location = 0) out float vertexDistance; +layout(location = 1) out vec4 vertexColor; +layout(location = 2) out vec2 texCoord0; +//layout(location = 3) out vec4 normal; + +//Compressed Vertex + +const float UV_INV = 1.0 / 65536.0; +const float POSITION_INV = 1.0 / 1900.0; + +layout(location = 0) in ivec3 Position; +layout(location = 1) in vec4 Color; +layout(location = 2) in uvec2 UV0; +layout(location = 3) in ivec2 UV2; +//layout(location = 4) in vec3 Normal; + +void main() { + vec3 pos = (Position * POSITION_INV); + gl_Position = MVP * vec4(pos + ChunkOffset[gl_DrawID], 1.0); + + vertexDistance = length((ModelViewMat * vec4(pos + ChunkOffset[gl_DrawID], 1.0)).xyz); + vertexColor = Color * minecraft_sample_lightmap(Sampler2, UV2); + texCoord0 = UV0 * UV_INV; + // normal = MVP * vec4(Normal, 0.0); +} + +//Default Vertex + +//layout(location = 0) in vec3 Position; +//layout(location = 1) in vec4 Color; +//layout(location = 2) in vec2 UV0; +//layout(location = 3) in ivec2 UV2; +//layout(location = 4) in vec3 Normal; + +//void main() { +// gl_Position = MVP * vec4(Position + ChunkOffset[gl_DrawID], 1.0); +// +// vertexDistance = length((ModelViewMat * vec4(Position + ChunkOffset[gl_DrawID], 1.0)).xyz); +// vertexColor = Color * minecraft_sample_lightmap(Sampler2, UV2); +// texCoord0 = UV0; +// normal = MVP * vec4(Normal, 0.0); +//} \ No newline at end of file diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/blit_screen.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/particle.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_lightmap.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_normal.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_color_tex_lightmap.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/position_tex_color_normal.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_cutout_no_cull.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_entity_glint.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_armor_glint.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_beacon_beam.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_crumbling.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_cutout_mipped.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_end_portal.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_energy_swirl.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_alpha.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_cutout_no_cull_z_offset.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_decal.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_glint_direct.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_no_outline.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_shadow.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_smooth_cutout.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_solid.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_cull.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_entity_translucent_emissive.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_eyes.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_direct.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_glint_translucent.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_item_entity_translucent_cull.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_leash.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lightning.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_lines.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_outline.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_solid.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_background_see_through.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_intensity_see_through.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_text_see_through.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_moving_block.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_translucent_no_crumbling.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_tripwire.vsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.fsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.fsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.fsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.fsh diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.json b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.json similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.json rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.json diff --git a/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.vsh b/common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.vsh similarity index 100% rename from src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.vsh rename to common/src/main/resources/assets/vulkanmod/shaders/minecraft/core/rendertype_water_mask.vsh diff --git a/src/main/resources/vulkanmod.mixins.json b/common/src/main/resources/vulkanmod-common.mixins.json similarity index 98% rename from src/main/resources/vulkanmod.mixins.json rename to common/src/main/resources/vulkanmod-common.mixins.json index ad01a6d4f..6f874367a 100644 --- a/src/main/resources/vulkanmod.mixins.json +++ b/common/src/main/resources/vulkanmod-common.mixins.json @@ -30,6 +30,7 @@ "profiling.GuiMixin", "profiling.KeyboardHandlerM", + "render.entity.EntityRendererM", "render.model.ModelPartCubeM", "render.model.ModelPartM", "render.vertex.FaceBakeryM", diff --git a/src/main/resources/vulkanmod.accesswidener b/common/src/main/resources/vulkanmod.accesswidener similarity index 100% rename from src/main/resources/vulkanmod.accesswidener rename to common/src/main/resources/vulkanmod.accesswidener diff --git a/fabric/build.gradle b/fabric/build.gradle new file mode 100644 index 000000000..3b61e1736 --- /dev/null +++ b/fabric/build.gradle @@ -0,0 +1,86 @@ +plugins { + id "com.github.johnrengelman.shadow" version "7.1.2" + id 'maven-publish' +} + +architectury { + platformSetupLoomIde() + fabric() +} + +loom { + accessWidenerPath = project(":common").loom.accessWidenerPath +} + +configurations { + common + shadowCommon // Don't use shadow from the shadow plugin since it *excludes* files. + compileClasspath.extendsFrom common + runtimeClasspath.extendsFrom common + developmentFabric.extendsFrom common +} + +dependencies { + modImplementation "net.fabricmc:fabric-loader:${rootProject.fabric_loader_version}" + modApi "net.fabricmc.fabric-api:fabric-api:${rootProject.fabric_api_version}" + + include(implementation("org.lwjgl:lwjgl-vulkan:$lwjglVersion")) + include(implementation("org.lwjgl:lwjgl-vma:$lwjglVersion")) + include(runtimeOnly("org.lwjgl:lwjgl-vma:$lwjglVersion:$winNatives")) + include(runtimeOnly("org.lwjgl:lwjgl-vma:$lwjglVersion:$linuxNatives")) + + include(implementation("org.lwjgl:lwjgl-shaderc:$lwjglVersion")) + include(runtimeOnly("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$winNatives")) + include(runtimeOnly("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$linuxNatives")) + + include(implementation("com.google.code.findbugs:jsr305:3.0.2")) + + common(project(path: ":common", configuration: "namedElements")) { transitive false } + shadowCommon(project(path: ":common", configuration: "transformProductionFabric")) { transitive false } +} + +processResources { + inputs.property "version", project.version + + filesMatching("fabric.mod.json") { + expand "version": project.version + } +} + +shadowJar { + exclude "architectury.common.json" + + configurations = [project.configurations.shadowCommon] + //classifier "dev-shadow" +} + +remapJar { + injectAccessWidener = true + input.set shadowJar.archiveFile + dependsOn shadowJar +} + +jar { + //classifier "dev" +} + +sourcesJar { + def commonSources = project(":common").sourcesJar + dependsOn commonSources + from commonSources.archiveFile.map { zipTree(it) } +} + +components.java { + withVariantsFromConfiguration(project.configurations.shadowRuntimeElements) { + skip() + } +} + +publishing { + publications { + mavenFabric(MavenPublication) { + artifactId = rootProject.archives_base_name + "-" + project.name + from components.java + } + } +} diff --git a/fabric/src/main/java/net/vulkanmod/fabric/VulkanModExpectPlatformImpl.java b/fabric/src/main/java/net/vulkanmod/fabric/VulkanModExpectPlatformImpl.java new file mode 100644 index 000000000..2ae66e09f --- /dev/null +++ b/fabric/src/main/java/net/vulkanmod/fabric/VulkanModExpectPlatformImpl.java @@ -0,0 +1,15 @@ +package net.vulkanmod.fabric; + +import net.fabricmc.loader.api.FabricLoader; + +import java.nio.file.Path; + +public class VulkanModExpectPlatformImpl { + public static Path getConfigDirectory() { + return FabricLoader.getInstance().getConfigDir(); + } + + public static String getVersion() { + return FabricLoader.getInstance().getModContainer("vulkanmod").get().getMetadata().getVersion().getFriendlyString(); + } +} diff --git a/fabric/src/main/java/net/vulkanmod/fabric/VulkanModFabric.java b/fabric/src/main/java/net/vulkanmod/fabric/VulkanModFabric.java new file mode 100644 index 000000000..5829d224b --- /dev/null +++ b/fabric/src/main/java/net/vulkanmod/fabric/VulkanModFabric.java @@ -0,0 +1,12 @@ +package net.vulkanmod.fabric; + +import net.fabricmc.api.ClientModInitializer; +import net.vulkanmod.Initializer; + +public class VulkanModFabric implements ClientModInitializer { + + @Override + public void onInitializeClient() { + Initializer.onInitializeClient(); + } +} diff --git a/fabric/src/main/java/net/vulkanmod/fabric/mixin/FabricMinecraftMixin.java b/fabric/src/main/java/net/vulkanmod/fabric/mixin/FabricMinecraftMixin.java new file mode 100644 index 000000000..2cc13eb06 --- /dev/null +++ b/fabric/src/main/java/net/vulkanmod/fabric/mixin/FabricMinecraftMixin.java @@ -0,0 +1,19 @@ +package net.vulkanmod.fabric.mixin; + +import net.minecraft.client.Minecraft; +import net.vulkanmod.render.texture.SpriteUtil; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; +import org.spongepowered.asm.mixin.injection.callback.LocalCapture; + +@Mixin(Minecraft.class) +public class FabricMinecraftMixin { + @Inject(method = "runTick", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/Minecraft;tick()V"), + locals = LocalCapture.CAPTURE_FAILHARD) + private void redirectResourceTick(boolean bl, CallbackInfo ci, long l, int i, int j) { + int n = Math.min(10, i) - 1; + SpriteUtil.setDoUpload(j == n); + } +} diff --git a/fabric/src/main/java/net/vulkanmod/fabric/mixin/FabricWindowMixin.java b/fabric/src/main/java/net/vulkanmod/fabric/mixin/FabricWindowMixin.java new file mode 100644 index 000000000..e13118eff --- /dev/null +++ b/fabric/src/main/java/net/vulkanmod/fabric/mixin/FabricWindowMixin.java @@ -0,0 +1,24 @@ +package net.vulkanmod.fabric.mixin; + +import com.mojang.blaze3d.platform.DisplayData; +import com.mojang.blaze3d.platform.ScreenManager; +import com.mojang.blaze3d.platform.Window; +import com.mojang.blaze3d.platform.WindowEventHandler; +import org.lwjgl.glfw.GLFW; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import static org.lwjgl.glfw.GLFW.GLFW_CLIENT_API; +import static org.lwjgl.glfw.GLFW.GLFW_NO_API; + +@Mixin(Window.class) +public class FabricWindowMixin { + @Inject(method = "", at = @At(value = "INVOKE", target = "Lorg/lwjgl/glfw/GLFW;glfwCreateWindow(IILjava/lang/CharSequence;JJ)J")) + private void vulkanHint(WindowEventHandler windowEventHandler, ScreenManager screenManager, DisplayData displayData, String string, String string2, CallbackInfo ci) { + GLFW.glfwWindowHint(GLFW_CLIENT_API, GLFW_NO_API); +// GLFW.glfwWindowHint(GLFW_AUTO_ICONIFY, GLFW_FALSE); +// GLFW.glfwWindowHint(GLFW_FOCUSED, GLFW_FALSE); + } +} \ No newline at end of file diff --git a/src/main/resources/fabric.mod.json b/fabric/src/main/resources/fabric.mod.json similarity index 68% rename from src/main/resources/fabric.mod.json rename to fabric/src/main/resources/fabric.mod.json index fabc10e6a..eda11788d 100644 --- a/src/main/resources/fabric.mod.json +++ b/fabric/src/main/resources/fabric.mod.json @@ -1,8 +1,7 @@ { "schemaVersion": 1, "id": "vulkanmod", - "version": "0.3.2_dev", - + "version": "${version}", "name": "VulkanMod", "description": "Bring Vulkan to Minecraft!", "authors": [ @@ -15,19 +14,18 @@ "icon": "assets/vulkanmod/Vlogo.png", - "environment": "client", + "environment": "*", "entrypoints": { "client": [ - "net.vulkanmod.Initializer" + "net.vulkanmod.fabric.VulkanModFabric" ] }, "mixins": [ - "vulkanmod.mixins.json" + "vulkanmod.mixins.json", + "vulkanmod-common.mixins.json" ], - "accessWidener" : "vulkanmod.accesswidener", - "depends": { - "fabricloader": ">=0.14.14", + "fabric": "*", "minecraft": ">=1.20", "java": ">=17" } diff --git a/fabric/src/main/resources/vulkanmod.mixins.json b/fabric/src/main/resources/vulkanmod.mixins.json new file mode 100644 index 000000000..5283c9712 --- /dev/null +++ b/fabric/src/main/resources/vulkanmod.mixins.json @@ -0,0 +1,15 @@ +{ + "required": true, + "package": "net.vulkanmod.fabric.mixin", + "compatibilityLevel": "JAVA_17", + "minVersion": "0.8", + "client": [ + "FabricMinecraftMixin", + "FabricWindowMixin" + ], + "mixins": [ + ], + "injectors": { + "defaultRequire": 1 + } +} \ No newline at end of file diff --git a/forge/build.gradle b/forge/build.gradle new file mode 100644 index 000000000..32d7cf34c --- /dev/null +++ b/forge/build.gradle @@ -0,0 +1,102 @@ +plugins { + id "com.github.johnrengelman.shadow" version "7.1.2" + id 'maven-publish' +} + +architectury { + platformSetupLoomIde() + forge() +} + +loom { + accessWidenerPath = project(":common").loom.accessWidenerPath + + forge { + convertAccessWideners = true + extraAccessWideners.add loom.accessWidenerPath.get().asFile.name + + mixinConfig "vulkanmod-common.mixins.json" + mixinConfig "vulkanmod.mixins.json" + } +} + +configurations { + common + shadowCommon // Don't use shadow from the shadow plugin since it *excludes* files. + compileClasspath.extendsFrom common + runtimeClasspath.extendsFrom common + developmentForge.extendsFrom common +} + +dependencies { + forge "net.neoforged:forge:${rootProject.forge_version}" + + include(forgeRuntimeLibrary("org.lwjgl:lwjgl-vulkan:$lwjglVersion")) + include(forgeRuntimeLibrary("org.lwjgl:lwjgl-vma:$lwjglVersion")) + include(forgeRuntimeLibrary("org.lwjgl:lwjgl-vma:$lwjglVersion:$winNatives")) + include(forgeRuntimeLibrary("org.lwjgl:lwjgl-vma:$lwjglVersion:$linuxNatives")) + + include(forgeRuntimeLibrary("org.lwjgl:lwjgl-shaderc:$lwjglVersion")) + include(forgeRuntimeLibrary("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$winNatives")) + include(forgeRuntimeLibrary("org.lwjgl:lwjgl-shaderc:$lwjglVersion:$linuxNatives")) + + include(implementation("com.google.code.findbugs:jsr305:3.0.2")) + + common(project(path: ":common", configuration: "namedElements")) { transitive false } + shadowCommon(project(path: ":common", configuration: "transformProductionForge")) { transitive = false } +} + +repositories { + maven { url "https://maven.neoforged.net/releases/" } +} + +processResources { + inputs.property "version", project.version + + filesMatching("META-INF/mods.toml") { + expand "version": project.version + } +} + +shadowJar { + exclude "fabric.mod.json" + exclude "architectury.common.json" + + configurations = [project.configurations.shadowCommon] + //classifier "dev-shadow" +} + +remapJar { + input.set shadowJar.archiveFile + dependsOn shadowJar +} + +jar { + //classifier "dev" +} + +sourcesJar { + def commonSources = project(":common").sourcesJar + dependsOn commonSources + from commonSources.archiveFile.map { zipTree(it) } +} + +components.java { + withVariantsFromConfiguration(project.configurations.shadowRuntimeElements) { + skip() + } +} + +publishing { + publications { + mavenForge(MavenPublication) { + artifactId = rootProject.archives_base_name + "-" + project.name + from components.java + } + } + + // See https://docs.gradle.org/current/userguide/publishing_maven.html for information on how to set up publishing. + repositories { + // Add repositories to publish to here. + } +} diff --git a/forge/gradle.properties b/forge/gradle.properties new file mode 100644 index 000000000..32f842a63 --- /dev/null +++ b/forge/gradle.properties @@ -0,0 +1 @@ +loom.platform=forge \ No newline at end of file diff --git a/forge/src/main/java/net/vulkanmod/forge/VulkanModExpectPlatformImpl.java b/forge/src/main/java/net/vulkanmod/forge/VulkanModExpectPlatformImpl.java new file mode 100644 index 000000000..e54abc2b3 --- /dev/null +++ b/forge/src/main/java/net/vulkanmod/forge/VulkanModExpectPlatformImpl.java @@ -0,0 +1,16 @@ +package net.vulkanmod.forge; + +import net.minecraftforge.fml.ModList; +import net.minecraftforge.fml.loading.FMLPaths; + +import java.nio.file.Path; + +public class VulkanModExpectPlatformImpl { + public static Path getConfigDirectory() { + return FMLPaths.CONFIGDIR.get(); + } + + public static String getVersion() { + return ModList.get().getModContainerById("vulkanmod").get().getModInfo().getVersion().toString(); + } +} diff --git a/forge/src/main/java/net/vulkanmod/forge/VulkanModForge.java b/forge/src/main/java/net/vulkanmod/forge/VulkanModForge.java new file mode 100644 index 000000000..b59abe241 --- /dev/null +++ b/forge/src/main/java/net/vulkanmod/forge/VulkanModForge.java @@ -0,0 +1,11 @@ +package net.vulkanmod.forge; + +import net.minecraftforge.fml.common.Mod; +import net.vulkanmod.Initializer; + +@Mod(Initializer.MODID) +public class VulkanModForge { + public VulkanModForge() { + Initializer.onInitializeClient(); + } +} \ No newline at end of file diff --git a/forge/src/main/java/net/vulkanmod/forge/mixin/ForgeMinecraftMixin.java b/forge/src/main/java/net/vulkanmod/forge/mixin/ForgeMinecraftMixin.java new file mode 100644 index 000000000..c21b545e8 --- /dev/null +++ b/forge/src/main/java/net/vulkanmod/forge/mixin/ForgeMinecraftMixin.java @@ -0,0 +1,19 @@ +package net.vulkanmod.forge.mixin; + +import dev.architectury.patchedmixin.staticmixin.spongepowered.asm.mixin.injection.At; +import dev.architectury.patchedmixin.staticmixin.spongepowered.asm.mixin.injection.Inject; +import dev.architectury.patchedmixin.staticmixin.spongepowered.asm.mixin.injection.callback.CallbackInfo; +import dev.architectury.patchedmixin.staticmixin.spongepowered.asm.mixin.injection.callback.LocalCapture; +import net.minecraft.client.Minecraft; +import net.vulkanmod.render.texture.SpriteUtil; +import org.spongepowered.asm.mixin.Mixin; + +@Mixin(Minecraft.class) +public class ForgeMinecraftMixin { + @Inject(method = "runTick", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/Minecraft;tick()V"), + locals = LocalCapture.CAPTURE_FAILHARD) + private void redirectResourceTick(boolean bl, CallbackInfo ci, long l, Runnable runnable, int i, int j) { + int n = Math.min(10, i) - 1; + SpriteUtil.setDoUpload(j == n); + } +} diff --git a/forge/src/main/java/net/vulkanmod/forge/mixin/ImmediateWindowHandlerMixin.java b/forge/src/main/java/net/vulkanmod/forge/mixin/ImmediateWindowHandlerMixin.java new file mode 100644 index 000000000..b9e780682 --- /dev/null +++ b/forge/src/main/java/net/vulkanmod/forge/mixin/ImmediateWindowHandlerMixin.java @@ -0,0 +1,20 @@ +package net.vulkanmod.forge.mixin; + +import net.minecraftforge.fml.earlydisplay.DisplayWindow; +import org.lwjgl.glfw.GLFW; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Redirect; + +@Mixin(value = DisplayWindow.class) +public class ImmediateWindowHandlerMixin { + @Redirect(method = "initWindow", at = @At(value = "INVOKE", target = "Lorg/lwjgl/glfw/GLFW;glfwWindowHint(II)V"), remap = false) + public void initWindow(int hint, int value) { + if (hint == GLFW.GLFW_CLIENT_API) { + GLFW.glfwWindowHint(hint, GLFW.GLFW_NO_API); + System.out.println("WindowHint Updated!"); + } else { + GLFW.glfwWindowHint(hint, value); + } + } +} \ No newline at end of file diff --git a/forge/src/main/resources/META-INF/mods.toml b/forge/src/main/resources/META-INF/mods.toml new file mode 100644 index 000000000..8f937a12d --- /dev/null +++ b/forge/src/main/resources/META-INF/mods.toml @@ -0,0 +1,28 @@ +modLoader = "javafml" +loaderVersion = "[47,)" +issueTrackerURL = "https://github.com/xCollateral/VulkanMod/issues" +license = "LGPLv3" + +[[mods]] +modId = "vulkanmod" +version = "${version}" +displayName = "VulkanMod" +authors = "Collateral" +description = ''' +Bring Vulkan to Minecraft! +''' +logoFile = "assets/vulkanmod/Vlogo.png" + +[[dependencies.vulkanmod]] +modId = "forge" +mandatory = true +versionRange = "[47,)" +ordering = "NONE" +side = "BOTH" + +[[dependencies.vulkanmod]] +modId = "minecraft" +mandatory = true +versionRange = "[1.20,)" +ordering = "NONE" +side = "BOTH" \ No newline at end of file diff --git a/forge/src/main/resources/pack.mcmeta b/forge/src/main/resources/pack.mcmeta new file mode 100644 index 000000000..5f81f5081 --- /dev/null +++ b/forge/src/main/resources/pack.mcmeta @@ -0,0 +1,6 @@ +{ + "pack": { + "description": "Example Mod", + "pack_format": 13 + } +} diff --git a/forge/src/main/resources/vulkanmod.mixins.json b/forge/src/main/resources/vulkanmod.mixins.json new file mode 100644 index 000000000..3f347f631 --- /dev/null +++ b/forge/src/main/resources/vulkanmod.mixins.json @@ -0,0 +1,15 @@ +{ + "required": true, + "package": "net.vulkanmod.forge.mixin", + "compatibilityLevel": "JAVA_17", + "minVersion": "0.8", + "client": [ + "ForgeMinecraftMixin", + "ImmediateWindowHandlerMixin" + ], + "mixins": [ + ], + "injectors": { + "defaultRequire": 1 + } +} \ No newline at end of file diff --git a/gradle.properties b/gradle.properties index ac202c580..e85eb65e4 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,16 +1,18 @@ # Done to increase the memory available to gradle. org.gradle.jvmargs=-Xmx3G -# Fabric Properties - # check these on https://fabricmc.net/develop - minecraft_version=1.20.1 - yarn_mappings=1.20.1+build.1 - loader_version=0.14.21 +minecraft_version=1.20.1 +enabled_platforms=fabric,forge -# Mod Properties - mod_version = 0.3.2_dev - maven_group = net.vulkanmod - archives_base_name = VulkanMod_1.20 +architectury_version=9.1.12 + +yarn_mappings=1.20.1+build.1 +fabric_loader_version=0.14.21 +fabric_api_version=0.88.0+1.20.1 + +forge_version=1.20.1-47.1.76 + +mod_version = 0.3.2_dev +maven_group = net.vulkanmod +archives_base_name = VulkanMod_1.20 -# Dependencies - fabric_version=0.88.0+1.20.1 diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar index 7454180f2..e708b1c02 100644 Binary files a/gradle/wrapper/gradle-wrapper.jar and b/gradle/wrapper/gradle-wrapper.jar differ diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties index 41dfb8790..db9a6b825 100644 --- a/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/wrapper/gradle-wrapper.properties @@ -1,5 +1,5 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-7.4-bin.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-8.3-bin.zip zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists diff --git a/gradlew b/gradlew index c53aefaa5..1b6c78733 100644 --- a/gradlew +++ b/gradlew @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright © 2015-2021 the original authors. +# Copyright © 2015-2021 the original authors. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -32,10 +32,10 @@ # Busybox and similar reduced shells will NOT work, because this script # requires all of these POSIX shell features: # * functions; -# * expansions «$var», «${var}», «${var:-default}», «${var+SET}», -# «${var#prefix}», «${var%suffix}», and «$( cmd )»; -# * compound commands having a testable exit status, especially «case»; -# * various built-in commands including «command», «set», and «ulimit». +# * expansions «$var», «${var}», «${var:-default}», «${var+SET}», +# «${var#prefix}», «${var%suffix}», and «$( cmd )»; +# * compound commands having a testable exit status, especially «case»; +# * various built-in commands including «command», «set», and «ulimit». # # Important for patching: # diff --git a/settings.gradle b/settings.gradle index b02216baa..95e655260 100644 --- a/settings.gradle +++ b/settings.gradle @@ -1,10 +1,15 @@ pluginManagement { repositories { - maven { - name = 'Fabric' - url = 'https://maven.fabricmc.net/' - } - mavenCentral() + maven { url "https://maven.fabricmc.net/" } + maven { url "https://maven.architectury.dev/" } + maven { url "https://maven.minecraftforge.net/" } + maven { url "https://maven.neoforged.net/releases/" } gradlePluginPortal() } } + +include("common") +include("fabric") +include("forge") + +rootProject.name = "VulkanMod" diff --git a/src/main/java/net/vulkanmod/gl/Util.java b/src/main/java/net/vulkanmod/gl/Util.java deleted file mode 100644 index 05b8b44b4..000000000 --- a/src/main/java/net/vulkanmod/gl/Util.java +++ /dev/null @@ -1,14 +0,0 @@ -package net.vulkanmod.gl; - -import net.vulkanmod.vulkan.shader.ShaderSPIRVUtils; - -public class Util { - - public static ShaderSPIRVUtils.ShaderKind extToShaderKind(String in) { - return switch (in) { - case ".vsh" -> ShaderSPIRVUtils.ShaderKind.VERTEX_SHADER; - case ".fsh" -> ShaderSPIRVUtils.ShaderKind.FRAGMENT_SHADER; - default -> throw new RuntimeException("unknown shader type: " + in); - }; - } -} diff --git a/src/main/java/net/vulkanmod/interfaces/ShaderMixed.java b/src/main/java/net/vulkanmod/interfaces/ShaderMixed.java deleted file mode 100644 index 28f9121fe..000000000 --- a/src/main/java/net/vulkanmod/interfaces/ShaderMixed.java +++ /dev/null @@ -1,8 +0,0 @@ -package net.vulkanmod.interfaces; - -import net.vulkanmod.vulkan.shader.Pipeline; - -public interface ShaderMixed { - - Pipeline getPipeline(); -} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/ShaderManager.java b/src/main/java/net/vulkanmod/vulkan/shader/ShaderManager.java deleted file mode 100644 index 89682f17a..000000000 --- a/src/main/java/net/vulkanmod/vulkan/shader/ShaderManager.java +++ /dev/null @@ -1,64 +0,0 @@ -package net.vulkanmod.vulkan.shader; - -import com.mojang.blaze3d.vertex.VertexFormat; -import net.minecraft.client.renderer.RenderType; -import net.vulkanmod.Initializer; -import net.vulkanmod.render.vertex.CustomVertexFormat; - -public class ShaderManager { - public static VertexFormat TERRAIN_VERTEX_FORMAT; - - public static ShaderManager shaderManager; - - public static void init() { - setTerrainVertexFormat(CustomVertexFormat.COMPRESSED_TERRAIN); - shaderManager = new ShaderManager(); - } - - public static void setTerrainVertexFormat(VertexFormat format) { - TERRAIN_VERTEX_FORMAT = format; - } - - public static ShaderManager getInstance() { return shaderManager; } - - Pipeline terrainIndirectShader; - public Pipeline terrainDirectShader; - - public ShaderManager() { - createBasicPipelines(); - } - - private void createBasicPipelines() { - this.terrainIndirectShader = createPipeline("terrain"); - - this.terrainDirectShader = createPipeline("terrain_direct"); - } - - private Pipeline createPipeline(String name) { - String path = String.format("basic/%s/%s", name, name); - - Pipeline.Builder pipelineBuilder = new Pipeline.Builder(CustomVertexFormat.COMPRESSED_TERRAIN, path); - pipelineBuilder.parseBindingsJSON(); - pipelineBuilder.compileShaders(); - return pipelineBuilder.createPipeline(); - } - - public Pipeline getTerrainShader(RenderType renderType) { - if(Initializer.CONFIG.indirectDraw) { - return this.terrainIndirectShader; - } - else { - return this.terrainDirectShader; - } - - } - - public Pipeline getTerrainIndirectShader(RenderType renderType) { - return terrainIndirectShader; - } - - public void destroyPipelines() { - this.terrainIndirectShader.cleanUp(); - this.terrainDirectShader.cleanUp(); - } -} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/Mat4f.java b/src/main/java/net/vulkanmod/vulkan/shader/layout/Mat4f.java deleted file mode 100644 index d564ecb57..000000000 --- a/src/main/java/net/vulkanmod/vulkan/shader/layout/Mat4f.java +++ /dev/null @@ -1,27 +0,0 @@ -package net.vulkanmod.vulkan.shader.layout; - -import net.vulkanmod.vulkan.shader.Uniforms; -import net.vulkanmod.vulkan.util.MappedBuffer; -import org.apache.commons.lang3.Validate; -import org.lwjgl.system.MemoryUtil; - -public class Mat4f extends Field { - public Mat4f(FieldInfo info, long ptr) { - super(info, ptr); - } - - protected void setSupplier() { - this.values = Uniforms.mat4f_uniformMap.get(this.fieldInfo.name); - - Validate.notNull(this.values, "Field name not found: " + this.fieldInfo.name); - } - - void update() { - MappedBuffer src = values.get(); - -// float[] floats = new float[16]; -// src.asFloatBuffer().get(floats); - - MemoryUtil.memCopy(src.buffer, MemoryUtil.memByteBuffer(this.basePtr, 64)); - } -} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/UBO.java b/src/main/java/net/vulkanmod/vulkan/shader/layout/UBO.java deleted file mode 100644 index 1bfb0dd44..000000000 --- a/src/main/java/net/vulkanmod/vulkan/shader/layout/UBO.java +++ /dev/null @@ -1,28 +0,0 @@ -package net.vulkanmod.vulkan.shader.layout; - -import java.nio.ByteBuffer; -import java.util.List; - -public class UBO extends AlignedStruct { - private final int binding; - private final int flags; - - protected UBO(int binding, int type, int size, List infoList) { - super(infoList, size); - this.binding = binding; - this.flags = type; - } - - public int getBinding() { - return binding; - } - - public int getFlags() { - return flags; - } - - public ByteBuffer getBuffer() { - return buffer.buffer; - } - -} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1f.java b/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1f.java deleted file mode 100644 index 4835c0946..000000000 --- a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1f.java +++ /dev/null @@ -1,44 +0,0 @@ -package net.vulkanmod.vulkan.shader.layout; - -import net.vulkanmod.vulkan.shader.Uniforms; -import org.apache.commons.lang3.Validate; -import org.lwjgl.system.MemoryUtil; - -import java.util.function.Supplier; - -public class Vec1f extends Field { - private Supplier floatSupplier; - - public Vec1f(FieldInfo fieldInfo, long ptr) { - super(fieldInfo, ptr); - } - - void setSupplier() { - this.floatSupplier = Uniforms.vec1f_uniformMap.get(this.fieldInfo.name); - - Validate.notNull(this.floatSupplier, "Field name not found: " + this.fieldInfo.name); - } - - void update() { - if(this.floatSupplier != null) { - float f = this.floatSupplier.get(); - MemoryUtil.memPutFloat(this.basePtr, f); - } - else { - //TODO -// MappedBuffer buffer = this.values.get(); -// -// MemoryUtil.memPutFloat(this.basePtr, buffer.getFloat(0)); - } - } - - void update(long ptr) { - if(this.floatSupplier != null) { - float f = this.floatSupplier.get(); - MemoryUtil.memPutFloat(ptr + this.offset, f); - } - else { - //TODO - } - } -} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1i.java b/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1i.java deleted file mode 100644 index bfaab6b9c..000000000 --- a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec1i.java +++ /dev/null @@ -1,44 +0,0 @@ -package net.vulkanmod.vulkan.shader.layout; - -import net.vulkanmod.vulkan.shader.Uniforms; -import net.vulkanmod.vulkan.util.MappedBuffer; -import org.apache.commons.lang3.Validate; -import org.lwjgl.system.MemoryUtil; - -import java.util.function.Supplier; - -public class Vec1i extends Field { - private Supplier intSupplier; - - public Vec1i(FieldInfo fieldInfo, long ptr) { - super(fieldInfo, ptr); - } - - void setSupplier() { - this.intSupplier = Uniforms.vec1i_uniformMap.get(this.fieldInfo.name); - - Validate.notNull(this.intSupplier, "Field name not found: " + this.fieldInfo.name); - } - - void update() { - if(this.intSupplier != null) { - int i = this.intSupplier.get(); - MemoryUtil.memPutInt(this.basePtr, i); - } - else { - MappedBuffer buffer = this.values.get(); - - MemoryUtil.memPutInt(this.basePtr, buffer.getInt(0)); - } - } - - void update(long ptr) { - if(this.intSupplier != null) { - int i = this.intSupplier.get(); - MemoryUtil.memPutInt(ptr + this.offset, i); - } - else { - //TODO - } - } -} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec2f.java b/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec2f.java deleted file mode 100644 index d858a5fc3..000000000 --- a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec2f.java +++ /dev/null @@ -1,26 +0,0 @@ -package net.vulkanmod.vulkan.shader.layout; - -import net.vulkanmod.vulkan.shader.Uniforms; -import net.vulkanmod.vulkan.util.MappedBuffer; -import org.apache.commons.lang3.Validate; -import org.lwjgl.system.MemoryUtil; - -public class Vec2f extends Field { - - public Vec2f(FieldInfo fieldInfo, long ptr) { - super(fieldInfo, ptr); - } - - void setSupplier() { - this.values = Uniforms.vec2f_uniformMap.get(this.fieldInfo.name); - - Validate.notNull(this.values, "Field name not found: " + this.fieldInfo.name); - } - - void update() { - MappedBuffer buffer = this.values.get(); - - MemoryUtil.memPutFloat(this.basePtr, buffer.getFloat(0)); - MemoryUtil.memPutFloat(this.basePtr + 4, buffer.getFloat(4)); - } -} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec3f.java b/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec3f.java deleted file mode 100644 index 6656354c4..000000000 --- a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec3f.java +++ /dev/null @@ -1,27 +0,0 @@ -package net.vulkanmod.vulkan.shader.layout; - -import net.vulkanmod.vulkan.shader.Uniforms; -import net.vulkanmod.vulkan.util.MappedBuffer; -import net.vulkanmod.vulkan.util.VUtil; -import org.apache.commons.lang3.Validate; - -public class Vec3f extends Field { - - public Vec3f(FieldInfo fieldInfo, long ptr) { - super(fieldInfo, ptr); - } - - void setSupplier() { - this.values = Uniforms.vec3f_uniformMap.get(this.fieldInfo.name); - - Validate.notNull(this.values, "Field name not found: " + this.fieldInfo.name); - } - - void update() { - MappedBuffer src = this.values.get(); - - VUtil.UNSAFE.putFloat(this.basePtr, VUtil.UNSAFE.getFloat(src.ptr)); - VUtil.UNSAFE.putFloat(this.basePtr + 4, VUtil.UNSAFE.getFloat(src.ptr + 4)); - VUtil.UNSAFE.putFloat(this.basePtr + 8, VUtil.UNSAFE.getFloat(src.ptr + 8)); - } -} diff --git a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec4f.java b/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec4f.java deleted file mode 100644 index 1bc12df0d..000000000 --- a/src/main/java/net/vulkanmod/vulkan/shader/layout/Vec4f.java +++ /dev/null @@ -1,30 +0,0 @@ -package net.vulkanmod.vulkan.shader.layout; - -import net.vulkanmod.vulkan.shader.Uniforms; -import net.vulkanmod.vulkan.util.MappedBuffer; -import org.apache.commons.lang3.Validate; -import org.lwjgl.system.MemoryUtil; - -public class Vec4f extends Field { - - public Vec4f(FieldInfo fieldInfo, long ptr) { - super(fieldInfo, ptr); - } - - void setSupplier() { - this.values = Uniforms.vec4f_uniformMap.get(this.fieldInfo.name); - - Validate.notNull(this.values, "Field name not found: " + this.fieldInfo.name); - } - - void update() { - MappedBuffer buffer = this.values.get(); - - MemoryUtil.memPutFloat(this.basePtr, buffer.getFloat(0)); - MemoryUtil.memPutFloat(this.basePtr + 4, buffer.getFloat(4)); - MemoryUtil.memPutFloat(this.basePtr + 8, buffer.getFloat(8)); - MemoryUtil.memPutFloat(this.basePtr + 12, buffer.getFloat(12)); - - } - -}