From ed8add13e917eb50a0ab4b021b57191271313a58 Mon Sep 17 00:00:00 2001 From: ArielG-NV <159081215+ArielG-NV@users.noreply.github.com> Date: Tue, 22 Jul 2025 22:20:42 -0700 Subject: fix #7869 (#7871) --- source/slang/slang-check-shader.cpp | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) (limited to 'source') 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()) -- cgit v1.2.3