ref: 9f10f9d30d224a28da8fffb93ab53d338ecb6838
dir: /libstd/strcmp.myr/
use "extremum.use" use "types.use" use "fmt.use" pkg std = type comparison const strcmp : (a : byte[:], b : byte[:] -> comparison) const strncmp : (a : byte[:], b : byte[:], n : size -> comparison) const hasprefix : (a : byte[:], b : byte[:] -> bool) ;; type comparison = union `Equal `Before `After ;; const strcmp = {a, b var l var i var v l = min(a.len, b.len) for i = 0; i < l; i++ v = b[i] - a[i] if v < 0 -> `Before elif v < 0 -> `After ;; ;; if a.len < b.len -> `Before elif a.len > b.len -> `After else -> `Equal ;; } const strncmp = {a, b, n a = a[:min(a.len, n)] b = b[:min(b.len, n)] -> strcmp(a, b) } const hasprefix = {s, pre match strncmp(s, pre, pre.len) | `Equal: -> true | _: -> false ;; }