diff options
| author | Yong He <yonghe@outlook.com> | 2022-06-01 22:29:10 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-06-01 22:29:10 -0700 |
| commit | bc6bc56db51d06b92dc63ef9c9e0def6c9760c9e (patch) | |
| tree | 55aae1b64e3c0befe4b424764f6f0064701a9ffe /source/slang/slang-ir-lower-result-type.cpp | |
| parent | 4f14efc9752d9ebc8538a2e29ed154a00dc99682 (diff) | |
Clean up void returns. (#2260)
* Clean up `IRReturnVoid`.
* Update gitignore.
Co-authored-by: Yong He <yhe@nvidia.com>
Diffstat (limited to 'source/slang/slang-ir-lower-result-type.cpp')
| -rw-r--r-- | source/slang/slang-ir-lower-result-type.cpp | 33 |
1 files changed, 13 insertions, 20 deletions
diff --git a/source/slang/slang-ir-lower-result-type.cpp b/source/slang/slang-ir-lower-result-type.cpp index e46a0ceb5..7e632241b 100644 --- a/source/slang/slang-ir-lower-result-type.cpp +++ b/source/slang/slang-ir-lower-result-type.cpp @@ -124,23 +124,19 @@ namespace Slang builder->setInsertBefore(inst); auto info = getLoweredResultType(builder, inst->getDataType()); - List<IRInst*> operands; - operands.add(inst->getOperand(0)); - operands.add(getSuccessErrorValue(info->errorType)); - auto makeStruct = builder->emitMakeStruct(info->loweredType, operands); - inst->replaceUsesWith(makeStruct); - inst->removeAndDeallocate(); - } - - void processMakeResultValueVoid(IRMakeResultValueVoid* inst) - { - IRBuilder builderStorage(sharedBuilderStorage); - auto builder = &builderStorage; - builder->setInsertBefore(inst); - - auto info = getLoweredResultType(builder, inst->getDataType()); - auto errCode = getSuccessErrorValue(info->errorType); - inst->replaceUsesWith(errCode); + if (info->loweredType->getOp() == kIROp_VoidType) + { + List<IRInst*> operands; + operands.add(inst->getOperand(0)); + operands.add(getSuccessErrorValue(info->errorType)); + auto makeStruct = builder->emitMakeStruct(info->loweredType, operands); + inst->replaceUsesWith(makeStruct); + } + else + { + auto errCode = getSuccessErrorValue(info->errorType); + inst->replaceUsesWith(errCode); + } inst->removeAndDeallocate(); } @@ -251,9 +247,6 @@ namespace Slang case kIROp_MakeResultValue: processMakeResultValue((IRMakeResultValue*)inst); break; - case kIROp_MakeResultValueVoid: - processMakeResultValueVoid((IRMakeResultValueVoid*)inst); - break; case kIROp_MakeResultError: processMakeResultError((IRMakeResultError*)inst); break; |
