summaryrefslogtreecommitdiffstats
path: root/source/slang/lower.cpp
diff options
context:
space:
mode:
authorTim Foley <tfoleyNV@users.noreply.github.com>2017-08-17 10:58:11 -0700
committerGitHub <noreply@github.com>2017-08-17 10:58:11 -0700
commit5230ad2edb28e176d0d7d2a9873ffb8f65285269 (patch)
treed1b85e1553b0a81d2322f043d3e4022bd9d780c1 /source/slang/lower.cpp
parent3dd88c2eb5cd2e405cd5aa184a2cd45db6fb027a (diff)
parentd13bd05164c6a3d0b7ba95bb415f6bfac4cfcb70 (diff)
Merge pull request #168 from tfoleyNV/resources-in-structs-control
Add a flag to control type splitting
Diffstat (limited to 'source/slang/lower.cpp')
-rw-r--r--source/slang/lower.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/source/slang/lower.cpp b/source/slang/lower.cpp
index 7a12fc3b7..70c153902 100644
--- a/source/slang/lower.cpp
+++ b/source/slang/lower.cpp
@@ -2833,6 +2833,17 @@ struct LoweringVisitor
// due to, e.g., bindless textures.
shouldDesugarTupleTypes = true;
}
+ else if( shared->compileRequest->compileFlags & SLANG_COMPILE_FLAG_SPLIT_MIXED_TYPES )
+ {
+ // If the user is directly asking us to do this transformation,
+ // then obviously we need to do it.
+ //
+ // TODO: The way this is defined here means it will even apply to user
+ // HLSL code (not just code written in Slang). We may want to
+ // reconsider that choice, and only split things that originated in Slang.
+ //
+ shouldDesugarTupleTypes = true;
+ }
bool isResultATupleType = false;
bool hasAnyNonTupleFields = false;