diff options
| author | Yong He <yonghe@outlook.com> | 2020-06-15 09:05:49 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-06-15 09:05:49 -0700 |
| commit | 7e7425de730d7b3f4590c71111e22e5103b53200 (patch) | |
| tree | 9cdaee6b9deb0a94e40526b698ae13a1dc88da36 /source/slang/slang-ir-link.cpp | |
| parent | 04a81ab634ce058168f7e1554274bbeb34f3a3c5 (diff) | |
| parent | 90444f8366255f274993ce4699738d9ab7cf4ee1 (diff) | |
Merge branch 'master' into glsl-loop
Diffstat (limited to 'source/slang/slang-ir-link.cpp')
| -rw-r--r-- | source/slang/slang-ir-link.cpp | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/source/slang/slang-ir-link.cpp b/source/slang/slang-ir-link.cpp index 904a88d78..3f51aa876 100644 --- a/source/slang/slang-ir-link.cpp +++ b/source/slang/slang-ir-link.cpp @@ -567,7 +567,12 @@ IRWitnessTable* cloneWitnessTableImpl( IRWitnessTable* dstTable = nullptr, bool registerValue = true) { - auto clonedTable = dstTable ? dstTable : builder->createWitnessTable(); + IRWitnessTable* clonedTable = dstTable; + if (!clonedTable) + { + auto clonedBaseType = cloneType(context, as<IRType>(originalTable->getOperand(0))); + clonedTable = builder->createWitnessTable(clonedBaseType); + } cloneSimpleGlobalValueImpl(context, originalTable, originalValues, clonedTable, registerValue); return clonedTable; } @@ -599,7 +604,13 @@ IRInterfaceType* cloneInterfaceTypeImpl( IRInterfaceType* originalInterface, IROriginalValuesForClone const& originalValues) { - auto clonedInterface = builder->createInterfaceType(); + auto clonedInterface = builder->createInterfaceType(originalInterface->getOperandCount(), nullptr); + for (UInt i = 0; i < originalInterface->getOperandCount(); i++) + { + auto clonedKey = findClonedValue(context, originalInterface->getOperand(i)); + SLANG_ASSERT(clonedKey); + clonedInterface->setOperand(i, clonedKey); + } cloneSimpleGlobalValueImpl(context, originalInterface, originalValues, clonedInterface); return clonedInterface; } |
