From cd7f01b63a52eaaad00088524801e502bcb0f168 Mon Sep 17 00:00:00 2001 From: Yong He Date: Wed, 17 Jun 2020 13:08:27 -0700 Subject: Generate dynamic C++ code for the minimal test case. (#1391) * Add IR pass to lower generics into ordinary functions. * Fix project files * Emit dynamic C++ code for simple generics and witness tables. Fixes #1386. * Remove -dump-ir flag. * Fixups. --- source/slang/slang-ir.cpp | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) (limited to 'source/slang/slang-ir.cpp') diff --git a/source/slang/slang-ir.cpp b/source/slang/slang-ir.cpp index 4d507de41..34ea23b85 100644 --- a/source/slang/slang-ir.cpp +++ b/source/slang/slang-ir.cpp @@ -2307,6 +2307,16 @@ namespace Slang (IRInst* const*) paramTypes); } + IRWitnessTableType* IRBuilder::getWitnessTableType( + IRType* baseType) + { + return (IRWitnessTableType*)findOrEmitHoistableInst( + nullptr, + kIROp_WitnessTableType, + 1, + (IRInst* const*)&baseType); + } + IRConstantBufferType* IRBuilder::getConstantBufferType(IRType* elementType) { IRInst* operands[] = { elementType }; @@ -2465,7 +2475,7 @@ namespace Slang IRInst* IRBuilder::emitExtractExistentialWitnessTable( IRInst* existentialValue) { - auto type = getWitnessTableType(); + auto type = getWitnessTableType(existentialValue->getDataType()); auto inst = createInst( this, kIROp_ExtractExistentialWitnessTable, @@ -2775,7 +2785,7 @@ namespace Slang IRWitnessTable* witnessTable = createInst( this, kIROp_WitnessTable, - nullptr, + getWitnessTableType(baseType), baseType); addGlobalValue(this, witnessTable); return witnessTable; -- cgit v1.2.3