summaryrefslogtreecommitdiffstats
path: root/source/slang/slang-emit.cpp
diff options
context:
space:
mode:
authorjsmall-nvidia <jsmall@nvidia.com>2019-08-20 09:43:59 -0400
committerGitHub <noreply@github.com>2019-08-20 09:43:59 -0400
commit7258ef4ddebd021208a019f6ee73edcda57a88f7 (patch)
tree30cccf48c8f03e59e48a2d265e05494238fe758d /source/slang/slang-emit.cpp
parent3e78e4654cdf9556869325f2ed2da517f252d879 (diff)
User defined downstream compiler prelude (#1028)
* Added setDownstreamCompilerPrelude Renamed setPassThroughPath to setDownstreamCompilerPath. Fixed tests. Added prelude directory & code to TestToolUtil to setup default preludes for testing/command line apis. * Fix merge problem * Remove hacks to make prelude work by adding a search path as no longer needed with 'user prelude'. * Split up prelude into scalar intrinsics, and types. Use slang.h for main header. slang-cpp-prelude.h can now just include what it needs (relative to prelude directory) and define the few remaining things/work arounds. * Fix typo.
Diffstat (limited to 'source/slang/slang-emit.cpp')
-rw-r--r--source/slang/slang-emit.cpp25
1 files changed, 25 insertions, 0 deletions
diff --git a/source/slang/slang-emit.cpp b/source/slang/slang-emit.cpp
index 205f8ee0e..5a4e8300a 100644
--- a/source/slang/slang-emit.cpp
+++ b/source/slang/slang-emit.cpp
@@ -540,6 +540,31 @@ String emitEntryPoint(
// Now that we've emitted the code for all the declarations in the file,
// it is time to stitch together the final output.
+ {
+ Session* session = compileRequest->getSession();
+
+ // Get the downstream compiler needed for final target
+ PassThroughMode passThru = getDownstreamCompilerRequiredForTarget(targetRequest->target);
+
+ // If generic CPP work out what compiler will actually be used
+ if (passThru == PassThroughMode::GenericCCpp)
+ {
+ CPPCompilerSet* compilerSet = session->requireCPPCompilerSet();
+ CPPCompiler* compiler = compilerSet->getDefaultCompiler();
+ if (compiler)
+ {
+ passThru = getPassThroughModeForCPPCompiler(compiler->getDesc().type);
+ }
+ }
+
+ // If there is a prelude emit it
+ const auto& prelude = compileRequest->getSession()->getDownstreamCompilerPrelude(passThru);
+ if (prelude.getLength() > 0)
+ {
+ sourceWriter.emit(prelude.getUnownedSlice());
+ }
+ }
+
// There may be global-scope modifiers that we should emit now
sourceEmitter->emitPreprocessorDirectives();