diff options
| author | Tim Foley <tfoleyNV@users.noreply.github.com> | 2017-06-28 12:17:47 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-06-28 12:17:47 -0700 |
| commit | 16613ed981fc5dc38966f5108e85b1aee36ef92f (patch) | |
| tree | 0082315629ad76add2ebffe04dcd1f64943c0a9f /source/slang/emit.cpp | |
| parent | b8e31688c6826475b5199468aedea0bc44c0adc1 (diff) | |
| parent | ff53669ed918c87d15ddea2d07fda84d4c8eff5d (diff) | |
Merge pull request #50 from tfoleyNV/literal-fix-fix
Store integer literals at high precision in AST
Diffstat (limited to 'source/slang/emit.cpp')
| -rw-r--r-- | source/slang/emit.cpp | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/source/slang/emit.cpp b/source/slang/emit.cpp index 9a1d44641..dc7c68aa4 100644 --- a/source/slang/emit.cpp +++ b/source/slang/emit.cpp @@ -197,6 +197,14 @@ static void emitName(EmitContext* context, String const& name) emitName(context, name, CodePosition()); } +static void Emit(EmitContext* context, IntegerLiteralValue value) +{ + char buffer[32]; + sprintf(buffer, "%lld", value); + Emit(context, buffer); +} + + static void Emit(EmitContext* context, UInt value) { char buffer[32]; @@ -923,7 +931,7 @@ static void EmitExprWithPrecedence(EmitContext* context, RefPtr<ExpressionSyntax { assert(!"unimplemented"); } - Emit(context, litExpr->IntValue); + Emit(context, litExpr->integerValue); Emit(context, suffix); break; @@ -945,12 +953,12 @@ static void EmitExprWithPrecedence(EmitContext* context, RefPtr<ExpressionSyntax { assert(!"unimplemented"); } - Emit(context, litExpr->FloatValue); + Emit(context, litExpr->floatingPointValue); Emit(context, suffix); break; case ConstantExpressionSyntaxNode::ConstantType::Bool: - Emit(context, litExpr->IntValue ? "true" : "false"); + Emit(context, litExpr->integerValue ? "true" : "false"); break; case ConstantExpressionSyntaxNode::ConstantType::String: emitStringLiteral(context, litExpr->stringValue); |
