summaryrefslogtreecommitdiff
path: root/source/slang/lower-to-ir.cpp
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2017-11-21 19:55:23 -0500
committerGitHub <noreply@github.com>2017-11-21 19:55:23 -0500
commitcd2d64657e3e07fba0a2021d5e47b7a55bd293e6 (patch)
treec2ed83c02ddb8587f7f5f6ee26e004baafec315c /source/slang/lower-to-ir.cpp
parent43434bf993870ac19722d3a00df704df130619c1 (diff)
parent37315c96ea48045fae60f0e1cb1a3293f3ddd962 (diff)
Merge branch 'master' into generic-param-fix
Diffstat (limited to 'source/slang/lower-to-ir.cpp')
-rw-r--r--source/slang/lower-to-ir.cpp18
1 files changed, 17 insertions, 1 deletions
diff --git a/source/slang/lower-to-ir.cpp b/source/slang/lower-to-ir.cpp
index 9e58d908b..c01059c61 100644
--- a/source/slang/lower-to-ir.cpp
+++ b/source/slang/lower-to-ir.cpp
@@ -2693,7 +2693,23 @@ struct DeclLoweringVisitor : DeclVisitor<DeclLoweringVisitor, LoweredValInfo>
if( auto initExpr = decl->initExpr )
{
- // TODO: need to handle global with initializer!
+ IRBuilder subBuilderStorage = *getBuilder();
+ IRBuilder* subBuilder = &subBuilderStorage;
+
+ subBuilder->curFunc = irGlobal;
+
+ IRGenContext subContextStorage = *context;
+ IRGenContext* subContext = &subContextStorage;
+
+ subContext->irBuilder = subBuilder;
+
+ // TODO: set up a parent IR decl to put the instructions into
+
+ IRBlock* entryBlock = subBuilder->emitBlock();
+ subBuilder->curBlock = entryBlock;
+
+ LoweredValInfo initVal = lowerLValueExpr(subContext, initExpr);
+ subContext->irBuilder->emitReturn(getSimpleVal(subContext, initVal));
}
return globalVal;