diff options
| author | Tim Foley <tfoleyNV@users.noreply.github.com> | 2017-06-22 15:32:42 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-06-22 15:32:42 -0700 |
| commit | d506737b8b00bcc89adf937994ceb6df4509c98a (patch) | |
| tree | 116aa4ce97675dc8a6690686713b31bd07560c71 /source/slang/emit.cpp | |
| parent | 5170a56727c15da1443e8f9b0f21395861da9b0c (diff) | |
| parent | 1eb5a1bc44e950b6b74c0907984adfe4d971917c (diff) | |
Merge pull request #39 from tfoleyNV/vector-constructors
Standard library additions + supporting features
Diffstat (limited to 'source/slang/emit.cpp')
| -rw-r--r-- | source/slang/emit.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/source/slang/emit.cpp b/source/slang/emit.cpp index c531a0a77..eae9cd052 100644 --- a/source/slang/emit.cpp +++ b/source/slang/emit.cpp @@ -1719,6 +1719,27 @@ static void EmitStmt(EmitContext* context, RefPtr<StatementSyntaxNode> stmt) EmitBlockStmt(context, forStmt->Statement); return; } + else if (auto whileStmt = stmt.As<WhileStatementSyntaxNode>()) + { + EmitLoopAttributes(context, whileStmt); + + Emit(context, "while("); + EmitExpr(context, whileStmt->Predicate); + Emit(context, ")\n"); + EmitBlockStmt(context, whileStmt->Statement); + return; + } + else if (auto doWhileStmt = stmt.As<DoWhileStatementSyntaxNode>()) + { + EmitLoopAttributes(context, doWhileStmt); + + Emit(context, "do("); + EmitBlockStmt(context, doWhileStmt->Statement); + Emit(context, " while("); + EmitExpr(context, doWhileStmt->Predicate); + Emit(context, ")\n"); + return; + } else if (auto discardStmt = stmt.As<DiscardStatementSyntaxNode>()) { Emit(context, "discard;\n"); |
