aboutsummaryrefslogtreecommitdiff
path: root/v_windows/v/old/vlib/builtin/rune.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/old/vlib/builtin/rune.v
downloadcli-tools-windows-master.tar.gz
cli-tools-windows-master.tar.bz2
cli-tools-windows-master.zip
Adds most of the toolsHEADmaster
Diffstat (limited to 'v_windows/v/old/vlib/builtin/rune.v')
-rw-r--r--v_windows/v/old/vlib/builtin/rune.v62
1 files changed, 62 insertions, 0 deletions
diff --git a/v_windows/v/old/vlib/builtin/rune.v b/v_windows/v/old/vlib/builtin/rune.v
new file mode 100644
index 0000000..f756452
--- /dev/null
+++ b/v_windows/v/old/vlib/builtin/rune.v
@@ -0,0 +1,62 @@
+// Copyright (c) 2019-2021 Alexander Medvednikov. All rights reserved.
+// Use of this source code is governed by an MIT license that can be found in the LICENSE file.
+module builtin
+
+// This was never working correctly, the issue is now
+// fixed however the type checks in checker need to be
+// updated. if you uncomment it you will see the issue
+// type rune = int
+
+pub fn (c rune) str() string {
+ return utf32_to_str(u32(c))
+ /*
+ unsafe {
+ fst_byte := int(c)>>8 * 3 & 0xff
+ len := utf8_char_len(byte(fst_byte))
+ println('len=$len')
+ mut str := string{
+ len: len
+ str: malloc(len + 1)
+ }
+ for i in 0..len {
+ str.str[i] = byte(int(c)>>8 * (3 - i) & 0xff)
+ }
+ str.str[len] = `\0`
+ println(str)
+ return str
+ }
+ */
+}
+
+// string converts a rune array to a string
+pub fn (ra []rune) string() string {
+ mut res := ''
+ for r in ra {
+ res += r.str()
+ }
+ return res
+}
+
+// Define this on byte as well, so that we can do `s[0].is_capital()`
+pub fn (c byte) is_capital() bool {
+ return c >= `A` && c <= `Z`
+}
+
+pub fn (b []byte) clone() []byte {
+ mut res := []byte{len: b.len}
+ // mut res := make([]byte, {repeat:b.len})
+ for i in 0 .. b.len {
+ res[i] = b[i]
+ }
+ return res
+}
+
+// TODO: remove this once runes are implemented
+pub fn (b []byte) bytestr() string {
+ unsafe {
+ buf := malloc_noscan(b.len + 1)
+ C.memcpy(buf, b.data, b.len)
+ buf[b.len] = 0
+ return tos(buf, b.len)
+ }
+}