v.gen.c: fix codegen for `const a = u64(5) + 5`
parent
063ffe36d9
commit
b44f81528f
|
@ -31,7 +31,7 @@ const (
|
||||||
|
|
||||||
// This implementation is the quickest with gcc -O2
|
// This implementation is the quickest with gcc -O2
|
||||||
// str_l returns the string representation of the integer nn with max chars.
|
// str_l returns the string representation of the integer nn with max chars.
|
||||||
[inline] [direct_array_access]
|
[direct_array_access; inline]
|
||||||
fn (nn int) str_l(max int) string {
|
fn (nn int) str_l(max int) string {
|
||||||
unsafe {
|
unsafe {
|
||||||
mut n := i64(nn)
|
mut n := i64(nn)
|
||||||
|
@ -84,7 +84,7 @@ fn (nn int) str_l(max int) string {
|
||||||
*/
|
*/
|
||||||
return tos(buf, diff)
|
return tos(buf, diff)
|
||||||
|
|
||||||
//return tos(memdup(&buf[0] + index, (max - index)), (max - index))
|
// return tos(memdup(&buf[0] + index, (max - index)), (max - index))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,7 +114,7 @@ pub fn (n int) str() string {
|
||||||
|
|
||||||
// str returns the value of the `u32` as a `string`.
|
// str returns the value of the `u32` as a `string`.
|
||||||
// Example: assert u32(20000).str() == '20000'
|
// Example: assert u32(20000).str() == '20000'
|
||||||
[inline] [direct_array_access]
|
[direct_array_access; inline]
|
||||||
pub fn (nn u32) str() string {
|
pub fn (nn u32) str() string {
|
||||||
unsafe {
|
unsafe {
|
||||||
mut n := nn
|
mut n := nn
|
||||||
|
@ -146,7 +146,7 @@ pub fn (nn u32) str() string {
|
||||||
C.memmove(buf, buf + index, diff + 1)
|
C.memmove(buf, buf + index, diff + 1)
|
||||||
return tos(buf, diff)
|
return tos(buf, diff)
|
||||||
|
|
||||||
//return tos(memdup(&buf[0] + index, (max - index)), (max - index))
|
// return tos(memdup(&buf[0] + index, (max - index)), (max - index))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -158,7 +158,7 @@ pub fn (n int_literal) str() string {
|
||||||
|
|
||||||
// str returns the value of the `i64` as a `string`.
|
// str returns the value of the `i64` as a `string`.
|
||||||
// Example: assert i64(-200000).str() == '-200000'
|
// Example: assert i64(-200000).str() == '-200000'
|
||||||
[inline] [direct_array_access]
|
[direct_array_access; inline]
|
||||||
pub fn (nn i64) str() string {
|
pub fn (nn i64) str() string {
|
||||||
unsafe {
|
unsafe {
|
||||||
mut n := nn
|
mut n := nn
|
||||||
|
@ -199,13 +199,13 @@ pub fn (nn i64) str() string {
|
||||||
diff := max - index
|
diff := max - index
|
||||||
C.memmove(buf, buf + index, diff + 1)
|
C.memmove(buf, buf + index, diff + 1)
|
||||||
return tos(buf, diff)
|
return tos(buf, diff)
|
||||||
//return tos(memdup(&buf[0] + index, (max - index)), (max - index))
|
// return tos(memdup(&buf[0] + index, (max - index)), (max - index))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// str returns the value of the `u64` as a `string`.
|
// str returns the value of the `u64` as a `string`.
|
||||||
// Example: assert u64(2000000).str() == '2000000'
|
// Example: assert u64(2000000).str() == '2000000'
|
||||||
[inline] [direct_array_access]
|
[direct_array_access; inline]
|
||||||
pub fn (nn u64) str() string {
|
pub fn (nn u64) str() string {
|
||||||
unsafe {
|
unsafe {
|
||||||
mut n := nn
|
mut n := nn
|
||||||
|
@ -236,7 +236,7 @@ pub fn (nn u64) str() string {
|
||||||
diff := max - index
|
diff := max - index
|
||||||
C.memmove(buf, buf + index, diff + 1)
|
C.memmove(buf, buf + index, diff + 1)
|
||||||
return tos(buf, diff)
|
return tos(buf, diff)
|
||||||
//return tos(memdup(&buf[0] + index, (max - index)), (max - index))
|
// return tos(memdup(&buf[0] + index, (max - index)), (max - index))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -254,7 +254,7 @@ pub fn (b bool) str() string {
|
||||||
//
|
//
|
||||||
|
|
||||||
// u64_to_hex converts the number `nn` to a (zero padded if necessary) hexadecimal `string`.
|
// u64_to_hex converts the number `nn` to a (zero padded if necessary) hexadecimal `string`.
|
||||||
[inline] [direct_array_access]
|
[direct_array_access; inline]
|
||||||
fn u64_to_hex(nn u64, len byte) string {
|
fn u64_to_hex(nn u64, len byte) string {
|
||||||
mut n := nn
|
mut n := nn
|
||||||
mut buf := [256]byte{}
|
mut buf := [256]byte{}
|
||||||
|
@ -270,7 +270,7 @@ fn u64_to_hex(nn u64, len byte) string {
|
||||||
}
|
}
|
||||||
|
|
||||||
// u64_to_hex_no_leading_zeros converts the number `nn` to hexadecimal `string`.
|
// u64_to_hex_no_leading_zeros converts the number `nn` to hexadecimal `string`.
|
||||||
[inline] [direct_array_access]
|
[direct_array_access; inline]
|
||||||
fn u64_to_hex_no_leading_zeros(nn u64, len byte) string {
|
fn u64_to_hex_no_leading_zeros(nn u64, len byte) string {
|
||||||
mut n := nn
|
mut n := nn
|
||||||
mut buf := [256]byte{}
|
mut buf := [256]byte{}
|
||||||
|
@ -391,19 +391,47 @@ pub fn (nn voidptr) str() string {
|
||||||
|
|
||||||
// hex returns the value of the `byteptr` as a hexadecimal `string`.
|
// hex returns the value of the `byteptr` as a hexadecimal `string`.
|
||||||
// Note that the output is ***not*** zero padded.
|
// Note that the output is ***not*** zero padded.
|
||||||
//pub fn (nn byteptr) str() string {
|
// pub fn (nn byteptr) str() string {
|
||||||
pub fn (nn byteptr) str() string {
|
pub fn (nn byteptr) str() string {
|
||||||
return u64(nn).hex()
|
return u64(nn).hex()
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
pub fn (nn byte) hex_full() string {
|
||||||
pub fn (nn byte) hex_full() string { return u64_to_hex(nn, 2) }
|
return u64_to_hex(u64(nn), 2)
|
||||||
pub fn (nn i8) hex_full() string { return u64_to_hex(byte(nn), 2) }
|
}
|
||||||
pub fn (nn u16) hex_full() string { return u64_to_hex(nn, 4) }
|
|
||||||
pub fn (nn i16) hex_full() string { return u64_to_hex(u16(nn), 4) }
|
pub fn (nn i8) hex_full() string {
|
||||||
pub fn (nn u32) hex_full() string { return u64_to_hex(nn, 8) }
|
return u64_to_hex(u64(nn), 2)
|
||||||
pub fn (nn int) hex_full() string { return u64_to_hex(u32(nn), 8) }
|
}
|
||||||
*/
|
|
||||||
|
pub fn (nn u16) hex_full() string {
|
||||||
|
return u64_to_hex(u64(nn), 4)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn (nn i16) hex_full() string {
|
||||||
|
return u64_to_hex(u64(nn), 4)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn (nn u32) hex_full() string {
|
||||||
|
return u64_to_hex(u64(nn), 8)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn (nn int) hex_full() string {
|
||||||
|
return u64_to_hex(u64(nn), 8)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn (nn i64) hex_full() string {
|
||||||
|
return u64_to_hex(u64(nn), 16)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn (nn voidptr) hex_full() string {
|
||||||
|
return u64_to_hex(u64(nn), 16)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn (nn int_literal) hex_full() string {
|
||||||
|
return u64_to_hex(u64(nn), 16)
|
||||||
|
}
|
||||||
|
|
||||||
// hex_full returns the value of the `u64` as a *full* 16-digit hexadecimal `string`.
|
// hex_full returns the value of the `u64` as a *full* 16-digit hexadecimal `string`.
|
||||||
// Example: assert u64(2).hex_full() == '0000000000000002'
|
// Example: assert u64(2).hex_full() == '0000000000000002'
|
||||||
// Example: assert u64(255).hex_full() == '00000000000000ff'
|
// Example: assert u64(255).hex_full() == '00000000000000ff'
|
||||||
|
@ -411,12 +439,6 @@ pub fn (nn u64) hex_full() string {
|
||||||
return u64_to_hex(nn, 16)
|
return u64_to_hex(nn, 16)
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
pub fn (nn i64) hex_full() string { return u64_to_hex(u64(nn), 16) }
|
|
||||||
pub fn (nn int_literal) hex_full() string { return u64_to_hex(nn, 16) }
|
|
||||||
pub fn (nn voidptr) hex_full() string { return u64_to_hex(nn, 16) }
|
|
||||||
pub fn (nn byteptr) hex_full() string { return u64_to_hex(nn, 16) }
|
|
||||||
*/
|
|
||||||
// str returns the contents of `byte` as a zero terminated `string`.
|
// str returns the contents of `byte` as a zero terminated `string`.
|
||||||
// Example: assert byte(111).str() == '111'
|
// Example: assert byte(111).str() == '111'
|
||||||
pub fn (b byte) str() string {
|
pub fn (b byte) str() string {
|
||||||
|
|
|
@ -5000,6 +5000,9 @@ fn (mut g Gen) const_decl(node ast.ConstDecl) {
|
||||||
fn (mut g Gen) const_decl_precomputed(mod string, name string, ct_value ast.ComptTimeConstValue, typ ast.Type) bool {
|
fn (mut g Gen) const_decl_precomputed(mod string, name string, ct_value ast.ComptTimeConstValue, typ ast.Type) bool {
|
||||||
mut styp := g.typ(typ)
|
mut styp := g.typ(typ)
|
||||||
cname := '_const_$name'
|
cname := '_const_$name'
|
||||||
|
$if trace_const_precomputed ? {
|
||||||
|
eprintln('> styp: $styp | cname: $cname | ct_value: $ct_value | $ct_value.type_name()')
|
||||||
|
}
|
||||||
match ct_value {
|
match ct_value {
|
||||||
byte {
|
byte {
|
||||||
g.const_decl_write_precomputed(styp, cname, ct_value.str())
|
g.const_decl_write_precomputed(styp, cname, ct_value.str())
|
||||||
|
@ -5026,8 +5029,12 @@ fn (mut g Gen) const_decl_precomputed(mod string, name string, ct_value ast.Comp
|
||||||
g.const_decl_simple_define(name, ct_value.str())
|
g.const_decl_simple_define(name, ct_value.str())
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
if typ == ast.u64_type {
|
||||||
|
g.const_decl_write_precomputed(styp, cname, ct_value.str() + 'U')
|
||||||
|
} else {
|
||||||
g.const_decl_write_precomputed(styp, cname, ct_value.str())
|
g.const_decl_write_precomputed(styp, cname, ct_value.str())
|
||||||
}
|
}
|
||||||
|
}
|
||||||
u64 {
|
u64 {
|
||||||
g.const_decl_write_precomputed(styp, cname, ct_value.str() + 'U')
|
g.const_decl_write_precomputed(styp, cname, ct_value.str() + 'U')
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,39 @@
|
||||||
|
const zzz_byte_a = byte(`A`)
|
||||||
|
|
||||||
|
const zzz_u16_a = u16(999) + 5
|
||||||
|
|
||||||
|
const zzza = u64(123)
|
||||||
|
|
||||||
|
const zzzb = 5 + zzzc
|
||||||
|
|
||||||
|
const zzzc = 6 + zzza
|
||||||
|
|
||||||
|
const zzzx = zzza - 124
|
||||||
|
|
||||||
|
const zzz_zz = i64(-1)
|
||||||
|
|
||||||
|
struct Abc {
|
||||||
|
x int
|
||||||
|
}
|
||||||
|
|
||||||
|
const zzz_struct = Abc{123}
|
||||||
|
|
||||||
|
const zzzs = 'xyz' + 'abc'
|
||||||
|
|
||||||
|
fn test_number_consts() {
|
||||||
|
assert zzz_byte_a.hex_full() == '41'
|
||||||
|
assert zzz_u16_a.hex_full() == '03ec'
|
||||||
|
assert zzza.hex_full() == '000000000000007b'
|
||||||
|
assert zzzb.hex_full() == '0000000000000086'
|
||||||
|
assert zzzc.hex_full() == '0000000000000081'
|
||||||
|
// assert zzzx.hex_full() == '00000000ffffffff' // TODO: see why
|
||||||
|
assert zzz_zz.hex_full() == 'ffffffffffffffff'
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_struct_consts() {
|
||||||
|
assert zzz_struct.str().contains('x: 123')
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_string_consts() {
|
||||||
|
assert zzzs == 'xyzabc'
|
||||||
|
}
|
Loading…
Reference in New Issue