diff options
| author | jsmall-nvidia <jsmall@nvidia.com> | 2019-08-20 09:43:59 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-08-20 09:43:59 -0400 |
| commit | 7258ef4ddebd021208a019f6ee73edcda57a88f7 (patch) | |
| tree | 30cccf48c8f03e59e48a2d265e05494238fe758d /source/slang/slang-emit.cpp | |
| parent | 3e78e4654cdf9556869325f2ed2da517f252d879 (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.cpp | 25 |
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(); |
