summaryrefslogtreecommitdiff
path: root/source/slang/slang-options.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang-options.cpp')
-rw-r--r--source/slang/slang-options.cpp20
1 files changed, 16 insertions, 4 deletions
diff --git a/source/slang/slang-options.cpp b/source/slang/slang-options.cpp
index 681999168..a0e8515eb 100644
--- a/source/slang/slang-options.cpp
+++ b/source/slang/slang-options.cpp
@@ -527,9 +527,7 @@ void initCommandOptions(CommandOptions& options)
{OptionKind::EmitReflectionJSON,
"-reflection-json",
"reflection-json <path>",
- "Emit reflection data in JSON format to a file."},
- };
-
+ "Emit reflection data in JSON format to a file."}};
_addOptions(makeConstArrayView(generalOpts), options);
@@ -672,7 +670,10 @@ void initCommandOptions(CommandOptions& options)
"-incomplete-library",
nullptr,
"Allow generating code from incomplete libraries with unresolved external functions"},
- };
+ {OptionKind::BindlessSpaceIndex,
+ "-bindless-space-index",
+ "-bindless-space-index <index>",
+ "Specify the space index for the system defined global bindless resource array."}};
_addOptions(makeConstArrayView(targetOpts), options);
@@ -2475,6 +2476,10 @@ SlangResult OptionsParser::_parse(int argc, char const* const* argv)
// value in only allowing a single `-profile` option per target while still allowing
// zero or more `-capability` options.
+ // Don't treat zero args as an error.
+ if (!m_reader.hasArg())
+ break;
+
CommandLineArg operand;
SLANG_RETURN_ON_FAIL(m_reader.expectArg(operand));
@@ -2899,6 +2904,13 @@ SlangResult OptionsParser::_parse(int argc, char const* const* argv)
linkage->m_optionSet.add(OptionKind::DisableShortCircuit, true);
break;
}
+ case OptionKind::BindlessSpaceIndex:
+ {
+ Int index = 0;
+ SLANG_RETURN_ON_FAIL(_expectInt(arg, index));
+ linkage->m_optionSet.add(OptionKind::BindlessSpaceIndex, (int)index);
+ break;
+ }
default:
{
// Hmmm, we looked up and produced a valid enum, but it wasn't handled in the