diff options
| author | ArielG-NV <159081215+ArielG-NV@users.noreply.github.com> | 2024-06-24 10:20:19 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-06-24 10:20:19 -0400 |
| commit | 8d2f6e4ddceb83009bb5f6b3d49001a2fd3cd761 (patch) | |
| tree | 5780523e78ffa42562a2c49945c45a6c3295bbef /source/slang | |
| parent | d832e33574ed772db1fa9b7ba184b37d0e3704cf (diff) | |
Add case to `emitVectorReshape` for when using a `vector<M, N>` type with `T` value (#4419)
* Add case to `emitVectorReshape` for `vector<>` type, `scalar` value
1. Add new case
2. Add test
* fix warning
* fix warning
Diffstat (limited to 'source/slang')
| -rw-r--r-- | source/slang/slang-ir.cpp | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/source/slang/slang-ir.cpp b/source/slang/slang-ir.cpp index 22ef4e6be..c0541f4c4 100644 --- a/source/slang/slang-ir.cpp +++ b/source/slang/slang-ir.cpp @@ -3894,7 +3894,23 @@ namespace Slang { auto targetVectorType = as<IRVectorType>(type); auto sourceVectorType = as<IRVectorType>(value->getDataType()); - if (!targetVectorType) + if (targetVectorType && !sourceVectorType) + { + auto elementType = targetVectorType->getElementType(); + Index elemCount = 1; + if(auto intLit = as<IRIntLit>(targetVectorType->getElementCount())) + { + elemCount = (Index)intLit->getValue(); + } + IRInst* zeroVal = emitDefaultConstruct(elementType); + List<IRInst*> defaultVals; + defaultVals.reserve(elemCount); + defaultVals.add(value); + for(auto i = 1; i < elemCount; i++) + defaultVals.add(zeroVal); + return emitMakeVector(targetVectorType, defaultVals); + } + else if (!targetVectorType) { if (!sourceVectorType) return emitCast(targetVectorType, value); |
