aboutsummaryrefslogtreecommitdiff
path: root/src/Ryujinx.Graphics.Shader/CodeGen/Glsl/Declarations.cs
diff options
context:
space:
mode:
Diffstat (limited to 'src/Ryujinx.Graphics.Shader/CodeGen/Glsl/Declarations.cs')
-rw-r--r--src/Ryujinx.Graphics.Shader/CodeGen/Glsl/Declarations.cs46
1 files changed, 16 insertions, 30 deletions
diff --git a/src/Ryujinx.Graphics.Shader/CodeGen/Glsl/Declarations.cs b/src/Ryujinx.Graphics.Shader/CodeGen/Glsl/Declarations.cs
index 500de71f..763487da 100644
--- a/src/Ryujinx.Graphics.Shader/CodeGen/Glsl/Declarations.cs
+++ b/src/Ryujinx.Graphics.Shader/CodeGen/Glsl/Declarations.cs
@@ -339,24 +339,17 @@ namespace Ryujinx.Graphics.Shader.CodeGen.Glsl
private static void DeclareSamplers(CodeGenContext context, IEnumerable<TextureDefinition> definitions)
{
- int arraySize = 0;
-
foreach (var definition in definitions)
{
- string indexExpr = string.Empty;
+ string arrayDecl = string.Empty;
- if (definition.Type.HasFlag(SamplerType.Indexed))
+ if (definition.ArrayLength > 1)
{
- if (arraySize == 0)
- {
- arraySize = ResourceManager.SamplerArraySize;
- }
- else if (--arraySize != 0)
- {
- continue;
- }
-
- indexExpr = $"[{NumberFormatter.FormatInt(arraySize)}]";
+ arrayDecl = $"[{NumberFormatter.FormatInt(definition.ArrayLength)}]";
+ }
+ else if (definition.ArrayLength == 0)
+ {
+ arrayDecl = "[]";
}
string samplerTypeName = definition.Type.ToGlslSamplerType();
@@ -368,30 +361,23 @@ namespace Ryujinx.Graphics.Shader.CodeGen.Glsl
layout = $", set = {definition.Set}";
}
- context.AppendLine($"layout (binding = {definition.Binding}{layout}) uniform {samplerTypeName} {definition.Name}{indexExpr};");
+ context.AppendLine($"layout (binding = {definition.Binding}{layout}) uniform {samplerTypeName} {definition.Name}{arrayDecl};");
}
}
private static void DeclareImages(CodeGenContext context, IEnumerable<TextureDefinition> definitions)
{
- int arraySize = 0;
-
foreach (var definition in definitions)
{
- string indexExpr = string.Empty;
+ string arrayDecl = string.Empty;
- if (definition.Type.HasFlag(SamplerType.Indexed))
+ if (definition.ArrayLength > 1)
{
- if (arraySize == 0)
- {
- arraySize = ResourceManager.SamplerArraySize;
- }
- else if (--arraySize != 0)
- {
- continue;
- }
-
- indexExpr = $"[{NumberFormatter.FormatInt(arraySize)}]";
+ arrayDecl = $"[{NumberFormatter.FormatInt(definition.ArrayLength)}]";
+ }
+ else if (definition.ArrayLength == 0)
+ {
+ arrayDecl = "[]";
}
string imageTypeName = definition.Type.ToGlslImageType(definition.Format.GetComponentType());
@@ -413,7 +399,7 @@ namespace Ryujinx.Graphics.Shader.CodeGen.Glsl
layout = $", set = {definition.Set}{layout}";
}
- context.AppendLine($"layout (binding = {definition.Binding}{layout}) uniform {imageTypeName} {definition.Name}{indexExpr};");
+ context.AppendLine($"layout (binding = {definition.Binding}{layout}) uniform {imageTypeName} {definition.Name}{arrayDecl};");
}
}