diff options
| author | ArielG-NV <159081215+ArielG-NV@users.noreply.github.com> | 2025-07-22 22:20:42 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-07-23 05:20:42 +0000 |
| commit | ed8add13e917eb50a0ab4b021b57191271313a58 (patch) | |
| tree | 99961d3f500c75b2db0fe5e793cbd6d13897b89f /source | |
| parent | 387ba5b35fe0e3382b9cc043a007eefcca8ca121 (diff) | |
fix #7869 (#7871)
Diffstat (limited to 'source')
| -rw-r--r-- | source/slang/slang-check-shader.cpp | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/source/slang/slang-check-shader.cpp b/source/slang/slang-check-shader.cpp index a360361f7..dc4f84920 100644 --- a/source/slang/slang-check-shader.cpp +++ b/source/slang/slang-check-shader.cpp @@ -549,10 +549,23 @@ void validateEntryPoint(EntryPoint* entryPoint, DiagnosticSink* sink) targetOptionSet.hasOption(CompilerOptionName::Profile) && (targetOptionSet.getIntOption(CompilerOptionName::Profile) != SLANG_PROFILE_UNKNOWN); - bool specificCapabilityRequested = - targetOptionSet.hasOption(CompilerOptionName::Capability) && - (targetOptionSet.getIntOption(CompilerOptionName::Capability) != - SLANG_CAPABILITY_UNKNOWN); + bool specificCapabilityRequested = false; + for (auto atomVal : targetOptionSet.getArray(CompilerOptionName::Capability)) + { + switch (atomVal.kind) + { + case CompilerOptionValueKind::Int: + if (atomVal.intValue != SLANG_CAPABILITY_UNKNOWN) + specificCapabilityRequested = true; + break; + case CompilerOptionValueKind::String: + // User made a specific capability request + specificCapabilityRequested = true; + break; + } + if (specificCapabilityRequested) + break; + } if (auto declaredCapsMod = entryPointFuncDecl->findModifier<ExplicitlyDeclaredCapabilityModifier>()) |
