diff options
| author | Ginger Bill <github@gingerbill.org> | 2016-08-18 15:58:36 +0100 |
|---|---|---|
| committer | Ginger Bill <github@gingerbill.org> | 2016-08-18 15:58:36 +0100 |
| commit | f931b089d5ce0374e36c3241176e4ef24953522e (patch) | |
| tree | 034bcf331e049919b6ecd42ab48e19fc77993a16 /examples/basic.odin | |
| parent | 6b2cd1b33fafb18e052ebc5df19481232202607b (diff) | |
print_(f32|f64)
Diffstat (limited to 'examples/basic.odin')
| -rw-r--r-- | examples/basic.odin | 78 |
1 files changed, 58 insertions, 20 deletions
diff --git a/examples/basic.odin b/examples/basic.odin index 265d5cc83..548f93fff 100644 --- a/examples/basic.odin +++ b/examples/basic.odin @@ -1,7 +1,5 @@ #load "runtime.odin" -TWO_HEARTS :: '💕'; - print_string :: proc(s: string) { for i := 0; i < len(s); i++ { putchar(s[i] as i32); @@ -15,10 +13,10 @@ byte_reverse :: proc(b: []byte) { } } -encode_rune :: proc(r : rune) -> ([4]byte, int) { - buf : [4]byte; +encode_rune :: proc(r: rune) -> ([4]byte, int) { + buf: [4]byte; i := r as u32; - mask : byte : 0x3f; + mask: byte : 0x3f; if i <= 1<<7-1 { buf[0] = r as byte; return buf, 1; @@ -49,16 +47,16 @@ encode_rune :: proc(r : rune) -> ([4]byte, int) { return buf, 4; } -print_rune :: proc(r : rune) { +print_rune :: proc(r: rune) { buf, n := encode_rune(r); str := buf[:n] as string; print_string(str); } -print_int :: proc(i : int) { +print_int :: proc(i: int) { print_int_base(i, 10); } -print_int_base :: proc(i, base : int) { +print_int_base :: proc(i, base: int) { NUM_TO_CHAR_TABLE :: "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz@$"; buf: [65]byte; @@ -87,19 +85,14 @@ print_int_base :: proc(i, base : int) { print_string(buf[:len] as string); } -print_uint :: proc(i : uint) { - print_uint_base(i, 10); +print_uint :: proc(i: uint) { + print__uint(i, 10, 0, ' '); } -print_uint_base :: proc(i, base : uint) { +print__uint :: proc(i, base: uint, min_width: int, pad_char: byte) { NUM_TO_CHAR_TABLE :: "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz@$"; buf: [65]byte; len := 0; - negative := false; - if i < 0 { - negative = true; - i = -i; - } if i == 0 { buf[len] = '0'; len++; @@ -109,9 +102,8 @@ print_uint_base :: proc(i, base : uint) { len++; i /= base; } - - if negative { - buf[len] = '-'; + for len < min_width { + buf[len] = pad_char; len++; } @@ -119,9 +111,55 @@ print_uint_base :: proc(i, base : uint) { print_string(buf[:len] as string); } - print_bool :: proc(b : bool) { if b { print_string("true"); } else { print_string("false"); } } +print_pointer :: proc(p: rawptr) #inline { print__uint(p as uint, 16, 0, ' '); } + +print_f32 :: proc(f: f32) #inline { print__f64(f as f64, 7); } +print_f64 :: proc(f: f64) #inline { print__f64(f, 10); } + +print__f64 :: proc(f: f64, decimal_places: int) { + if f == 0 { + print_rune('0'); + return; + } + if f < 0 { + print_rune('-'); + f = -f; + } + + print_u64 :: proc(i: u64) { + NUM_TO_CHAR_TABLE :: "0123456789"; + + buf: [22]byte; + len := 0; + if i == 0 { + buf[len] = '0'; + len++; + } + for i > 0 { + buf[len] = NUM_TO_CHAR_TABLE[i % 10]; + len++; + i /= 10; + } + byte_reverse(buf[:len]); + print_string(buf[:len] as string); + } + + i := f as u64; + print_u64(i); + f -= i as f64; + + print_rune('.'); + + mult := 10.0; + for decimal_places := 6; decimal_places >= 0; decimal_places-- { + i = (f * mult) as u64; + print_u64(i as u64); + f -= i as f64 / mult; + mult *= 10; + } +} |