summaryrefslogtreecommitdiffstats
path: root/source/slang/slang-ir-lower-result-type.cpp
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2022-06-01 22:29:10 -0700
committerGitHub <noreply@github.com>2022-06-01 22:29:10 -0700
commitbc6bc56db51d06b92dc63ef9c9e0def6c9760c9e (patch)
tree55aae1b64e3c0befe4b424764f6f0064701a9ffe /source/slang/slang-ir-lower-result-type.cpp
parent4f14efc9752d9ebc8538a2e29ed154a00dc99682 (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.cpp33
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;