aboutsummaryrefslogtreecommitdiff
path: root/examples/basic.odin
diff options
context:
space:
mode:
authorGinger Bill <github@gingerbill.org>2016-08-18 15:58:36 +0100
committerGinger Bill <github@gingerbill.org>2016-08-18 15:58:36 +0100
commitf931b089d5ce0374e36c3241176e4ef24953522e (patch)
tree034bcf331e049919b6ecd42ab48e19fc77993a16 /examples/basic.odin
parent6b2cd1b33fafb18e052ebc5df19481232202607b (diff)
print_(f32|f64)
Diffstat (limited to 'examples/basic.odin')
-rw-r--r--examples/basic.odin78
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;
+ }
+}