summaryrefslogtreecommitdiff
path: root/source/slang/slang-ir-link.cpp
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2020-06-15 09:05:49 -0700
committerGitHub <noreply@github.com>2020-06-15 09:05:49 -0700
commit7e7425de730d7b3f4590c71111e22e5103b53200 (patch)
tree9cdaee6b9deb0a94e40526b698ae13a1dc88da36 /source/slang/slang-ir-link.cpp
parent04a81ab634ce058168f7e1554274bbeb34f3a3c5 (diff)
parent90444f8366255f274993ce4699738d9ab7cf4ee1 (diff)
Merge branch 'master' into glsl-loop
Diffstat (limited to 'source/slang/slang-ir-link.cpp')
-rw-r--r--source/slang/slang-ir-link.cpp15
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;
}