summaryrefslogtreecommitdiffstats
path: root/source/slang/slang.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang.cpp')
-rw-r--r--source/slang/slang.cpp39
1 files changed, 3 insertions, 36 deletions
diff --git a/source/slang/slang.cpp b/source/slang/slang.cpp
index de3c6b0a6..fce90d612 100644
--- a/source/slang/slang.cpp
+++ b/source/slang/slang.cpp
@@ -205,46 +205,13 @@ SLANG_NO_THROW const char* SLANG_MCALL Session::getBuildTagString()
return SLANG_TAG_VERSION;
}
-static bool _canCompile(PassThroughMode compiler, SourceLanguage sourceLanguage)
+SLANG_NO_THROW SlangResult SLANG_MCALL Session::setDefaultDownstreamCompiler(SlangSourceLanguage sourceLanguage, SlangPassThrough defaultCompiler)
{
- switch (compiler)
+ if (DownstreamCompiler::canCompile(defaultCompiler, sourceLanguage))
{
- case PassThroughMode::Fxc:
- case PassThroughMode::Dxc:
- {
- return sourceLanguage == SourceLanguage::HLSL;
- }
- case PassThroughMode::Glslang:
- {
- return sourceLanguage == SourceLanguage::GLSL;
- }
- case PassThroughMode::Clang:
- case PassThroughMode::VisualStudio:
- case PassThroughMode::Gcc:
- case PassThroughMode::GenericCCpp:
- {
- return sourceLanguage == SourceLanguage::C || sourceLanguage == SourceLanguage::CPP;
- }
- case PassThroughMode::NVRTC:
- {
- return sourceLanguage == SourceLanguage::CUDA;
- }
- default: break;
- }
- return false;
-}
-
-SLANG_NO_THROW SlangResult SLANG_MCALL Session::setDefaultDownstreamCompiler(SlangSourceLanguage inSourceLanguage, SlangPassThrough defaultCompiler)
-{
- auto sourceLanguage = SourceLanguage(inSourceLanguage);
- auto compiler = PassThroughMode(defaultCompiler);
-
- if (_canCompile(compiler, sourceLanguage))
- {
- m_defaultDownstreamCompilers[int(sourceLanguage)] = compiler;
+ m_defaultDownstreamCompilers[int(sourceLanguage)] = PassThroughMode(defaultCompiler);
return SLANG_OK;
}
-
return SLANG_FAIL;
}