mirror of
https://github.com/odin-lang/Odin.git
synced 2026-01-04 04:02:33 +00:00
95 lines
2.1 KiB
Odin
95 lines
2.1 KiB
Odin
#+private
|
|
package os2
|
|
|
|
import "base:intrinsics"
|
|
import "base:runtime"
|
|
import "core:math/rand"
|
|
|
|
|
|
// Splits pattern by the last wildcard "*", if it exists, and returns the prefix and suffix
|
|
// parts which are split by the last "*"
|
|
@(require_results)
|
|
_prefix_and_suffix :: proc(pattern: string) -> (prefix, suffix: string, err: Error) {
|
|
for i in 0..<len(pattern) {
|
|
if is_path_separator(pattern[i]) {
|
|
err = .Pattern_Has_Separator
|
|
return
|
|
}
|
|
}
|
|
prefix = pattern
|
|
for i := len(pattern)-1; i >= 0; i -= 1 {
|
|
if pattern[i] == '*' {
|
|
prefix, suffix = pattern[:i], pattern[i+1:]
|
|
break
|
|
}
|
|
}
|
|
return
|
|
}
|
|
|
|
@(require_results)
|
|
clone_string :: proc(s: string, allocator: runtime.Allocator) -> (res: string, err: runtime.Allocator_Error) {
|
|
buf := make([]byte, len(s), allocator) or_return
|
|
copy(buf, s)
|
|
return string(buf), nil
|
|
}
|
|
|
|
|
|
@(require_results)
|
|
clone_to_cstring :: proc(s: string, allocator: runtime.Allocator) -> (res: cstring, err: runtime.Allocator_Error) {
|
|
res = "" // do not use a `nil` cstring
|
|
buf := make([]byte, len(s)+1, allocator) or_return
|
|
copy(buf, s)
|
|
buf[len(s)] = 0
|
|
return cstring(&buf[0]), nil
|
|
}
|
|
|
|
@(require_results)
|
|
string_from_null_terminated_bytes :: proc(b: []byte) -> (res: string) {
|
|
s := string(b)
|
|
i := 0
|
|
for ; i < len(s); i += 1 {
|
|
if s[i] == 0 {
|
|
break
|
|
}
|
|
}
|
|
return s[:i]
|
|
}
|
|
|
|
@(require_results)
|
|
concatenate_strings_from_buffer :: proc(buf: []byte, strings: ..string) -> string {
|
|
n := 0
|
|
for s in strings {
|
|
(n < len(buf)) or_break
|
|
n += copy(buf[n:], s)
|
|
}
|
|
n = min(len(buf), n)
|
|
return string(buf[:n])
|
|
}
|
|
|
|
@(require_results)
|
|
concatenate :: proc(strings: []string, allocator: runtime.Allocator) -> (res: string, err: runtime.Allocator_Error) {
|
|
n := 0
|
|
for s in strings {
|
|
n += len(s)
|
|
}
|
|
buf := make([]byte, n, allocator) or_return
|
|
n = 0
|
|
for s in strings {
|
|
n += copy(buf[n:], s)
|
|
}
|
|
return string(buf), nil
|
|
}
|
|
|
|
@(require_results)
|
|
random_string :: proc(buf: []byte) -> string {
|
|
for i := 0; i < len(buf); i += 16 {
|
|
n := rand.uint64()
|
|
end := min(i + 16, len(buf))
|
|
for j := i; j < end; j += 1 {
|
|
buf[j] = '0' + u8(n) % 10
|
|
n >>= 4
|
|
}
|
|
}
|
|
return string(buf)
|
|
}
|