From c07ce3ff154c9a245a37f7999e8fd5ace73fa21e Mon Sep 17 00:00:00 2001 From: playX Date: Mon, 10 Jan 2022 13:42:41 +0300 Subject: [PATCH] cgen,json2: improve -nofloat support (#13117) --- vlib/v/gen/c/cgen.v | 3 +++ vlib/v/gen/c/cheaders.v | 9 +++++++++ vlib/x/json2/decoder.v | 6 ++++-- vlib/x/json2/encoder.v | 23 +++++++++++++++-------- 4 files changed, 31 insertions(+), 10 deletions(-) diff --git a/vlib/v/gen/c/cgen.v b/vlib/v/gen/c/cgen.v index b336b4f054..063f5358f2 100644 --- a/vlib/v/gen/c/cgen.v +++ b/vlib/v/gen/c/cgen.v @@ -645,6 +645,9 @@ pub fn (mut g Gen) init() { g.cheaders.writeln(get_guarded_include_text('', 'The C compiler can not find . Please install build-essentials')) // size_t, ptrdiff_t } } + if g.pref.nofloat { + g.cheaders.writeln('#define VNOFLOAT 1') + } g.cheaders.writeln(c_builtin_types) if g.pref.is_bare { g.cheaders.writeln(c_bare_headers) diff --git a/vlib/v/gen/c/cheaders.v b/vlib/v/gen/c/cheaders.v index e9a2d3ef46..bba7441d06 100644 --- a/vlib/v/gen/c/cheaders.v +++ b/vlib/v/gen/c/cheaders.v @@ -656,10 +656,19 @@ typedef uint8_t byte; typedef uint32_t rune; typedef size_t usize; typedef ptrdiff_t isize; +#ifndef VNOFLOAT typedef float f32; typedef double f64; +#else +typedef int32_t f32; +typedef int64_t f64; +#endif typedef int64_t int_literal; +#ifndef VNOFLOAT typedef double float_literal; +#else +typedef int64_t float_literal; +#endif typedef unsigned char* byteptr; typedef void* voidptr; typedef char* charptr; diff --git a/vlib/x/json2/decoder.v b/vlib/x/json2/decoder.v index a649c1276c..de88be8854 100644 --- a/vlib/x/json2/decoder.v +++ b/vlib/x/json2/decoder.v @@ -106,8 +106,10 @@ fn (mut p Parser) decode_value() ?Any { kind := p.tok.kind p.next_with_err() ? if p.convert_type { - if kind == .float { - return Any(tl.f64()) + $if !nofloat ? { + if kind == .float { + return Any(tl.f64()) + } } return Any(tl.i64()) } diff --git a/vlib/x/json2/encoder.v b/vlib/x/json2/encoder.v index 89a706da7e..ffa3224ee7 100644 --- a/vlib/x/json2/encoder.v +++ b/vlib/x/json2/encoder.v @@ -73,18 +73,25 @@ pub fn (f Any) json_str() string { return f.str() } f32 { - str_f32 := f.str() - if str_f32.ends_with('.') { - return '${str_f32}0' + $if !nofloat ? { + str_f32 := f.str() + if str_f32.ends_with('.') { + return '${str_f32}0' + } + return str_f32 } - return str_f32 + + return '0' } f64 { - str_f64 := f.str() - if str_f64.ends_with('.') { - return '${str_f64}0' + $if !nofloat ? { + str_f64 := f.str() + if str_f64.ends_with('.') { + return '${str_f64}0' + } + return str_f64 } - return str_f64 + return '0' } map[string]Any { return f.str()