aboutsummaryrefslogtreecommitdiff
path: root/v_windows/v/vlib/strconv/number_to_base.v
diff options
context:
space:
mode:
authorIndrajith K L2022-12-03 17:00:20 +0530
committerIndrajith K L2022-12-03 17:00:20 +0530
commitf5c4671bfbad96bf346bd7e9a21fc4317b4959df (patch)
tree2764fc62da58f2ba8da7ed341643fc359873142f /v_windows/v/vlib/strconv/number_to_base.v
downloadcli-tools-windows-f5c4671bfbad96bf346bd7e9a21fc4317b4959df.tar.gz
cli-tools-windows-f5c4671bfbad96bf346bd7e9a21fc4317b4959df.tar.bz2
cli-tools-windows-f5c4671bfbad96bf346bd7e9a21fc4317b4959df.zip
Adds most of the toolsHEADmaster
Diffstat (limited to 'v_windows/v/vlib/strconv/number_to_base.v')
-rw-r--r--v_windows/v/vlib/strconv/number_to_base.v61
1 files changed, 61 insertions, 0 deletions
diff --git a/v_windows/v/vlib/strconv/number_to_base.v b/v_windows/v/vlib/strconv/number_to_base.v
new file mode 100644
index 0000000..0ca7e9c
--- /dev/null
+++ b/v_windows/v/vlib/strconv/number_to_base.v
@@ -0,0 +1,61 @@
+module strconv
+
+const base_digits = '0123456789abcdefghijklmnopqrstuvwxyz'
+
+// format_int returns the string representation of the number n in base `radix`
+// for digit values > 10, this function uses the small latin leters a-z.
+[manualfree]
+pub fn format_int(n i64, radix int) string {
+ unsafe {
+ if radix < 2 || radix > 36 {
+ panic('invalid radix: $radix . It should be => 2 and <= 36')
+ }
+ if n == 0 {
+ return '0'
+ }
+ mut n_copy := n
+ mut sign := ''
+ if n < 0 {
+ sign = '-'
+ n_copy = -n_copy
+ }
+ mut res := ''
+ for n_copy != 0 {
+ tmp_0 := res
+ tmp_1 := strconv.base_digits[n_copy % radix].ascii_str()
+ res = tmp_1 + res
+ tmp_0.free()
+ tmp_1.free()
+ // res = base_digits[n_copy % radix].ascii_str() + res
+ n_copy /= radix
+ }
+ return '$sign$res'
+ }
+}
+
+// format_uint returns the string representation of the number n in base `radix`
+// for digit values > 10, this function uses the small latin leters a-z.
+[manualfree]
+pub fn format_uint(n u64, radix int) string {
+ unsafe {
+ if radix < 2 || radix > 36 {
+ panic('invalid radix: $radix . It should be => 2 and <= 36')
+ }
+ if n == 0 {
+ return '0'
+ }
+ mut n_copy := n
+ mut res := ''
+ uradix := u64(radix)
+ for n_copy != 0 {
+ tmp_0 := res
+ tmp_1 := strconv.base_digits[n_copy % uradix].ascii_str()
+ res = tmp_1 + res
+ tmp_0.free()
+ tmp_1.free()
+ // res = base_digits[n_copy % uradix].ascii_str() + res
+ n_copy /= uradix
+ }
+ return res
+ }
+}