1use crate::*;
3
4#[inline(always)]
5pub unsafe fn lean_alloc_string(size: usize, capacity: usize, len: usize) -> lean_obj_res {
6 let o = lean_alloc_object(core::mem::size_of::<lean_string_object>() + capacity)
7 as *mut lean_string_object;
8 lean_set_st_header(o as *mut _, LeanString as u32, 0);
9 (raw_field!(o, lean_string_object, m_size) as *mut usize).write(size);
10 (raw_field!(o, lean_string_object, m_capacity) as *mut usize).write(capacity);
11 (raw_field!(o, lean_string_object, m_length) as *mut usize).write(len);
12 o as *mut _
13}
14
15#[inline(always)]
16pub unsafe fn lean_string_capacity(o: *mut lean_object) -> usize {
17 *raw_field!(lean_to_string(o), lean_string_object, m_capacity)
18}
19
20#[inline(always)]
21pub unsafe fn lean_string_byte_size(o: *mut lean_object) -> usize {
22 core::mem::size_of::<lean_string_object>() + lean_string_capacity(o)
23}
24
25#[inline(always)]
27pub fn lean_char_default_value() -> c_char {
28 'A' as c_char
29}
30
31#[inline(always)]
32pub unsafe fn lean_string_cstr(o: b_lean_obj_arg) -> *const u8 {
33 debug_assert!(lean_is_string(o));
34 raw_field!(lean_to_string(o), lean_string_object, m_data) as *const _
35}
36
37#[inline(always)]
38pub unsafe fn lean_string_size(o: b_lean_obj_arg) -> usize {
39 *raw_field!(lean_to_string(o), lean_string_object, m_size)
40}
41
42#[inline(always)]
43pub unsafe fn lean_string_len(o: b_lean_obj_arg) -> usize {
44 *raw_field!(lean_to_string(o), lean_string_object, m_length)
45}
46
47#[inline(always)]
48pub unsafe fn lean_string_data_byte_size(o: *mut lean_object) -> usize {
49 core::mem::size_of::<lean_string_object>() + lean_string_size(o)
50}
51
52#[inline(always)]
53pub unsafe fn lean_string_length(o: b_lean_obj_arg) -> lean_obj_res {
54 lean_box(lean_string_len(o))
55}
56
57#[inline]
58pub unsafe fn lean_string_utf8_at_end(s: b_lean_obj_arg, i: b_lean_obj_arg) -> u8 {
59 (!lean_is_scalar(i) || lean_unbox(i) >= lean_string_size(s) - 1) as u8
60}
61
62#[inline(always)]
63pub unsafe fn lean_string_utf8_byte_size(s: b_lean_obj_arg) -> lean_obj_res {
64 lean_box(lean_string_size(s) - 1)
65}
66
67#[inline]
68pub unsafe fn lean_string_eq(s1: b_lean_obj_arg, s2: b_lean_obj_arg) -> bool {
69 s1 == s2 || (lean_string_size(s1) == lean_string_size(s2) && lean_string_eq_cold(s1, s2))
70}
71
72#[inline(always)]
73pub unsafe fn lean_string_ne(s1: b_lean_obj_arg, s2: b_lean_obj_arg) -> bool {
74 !lean_string_eq(s1, s2)
75}
76
77#[inline(always)]
78pub unsafe fn lean_string_dec_eq(s1: b_lean_obj_arg, s2: b_lean_obj_arg) -> u8 {
79 lean_string_eq(s1, s2) as u8
80}
81
82#[inline(always)]
83pub unsafe fn lean_string_dec_lt(s1: b_lean_obj_arg, s2: b_lean_obj_arg) -> u8 {
84 lean_string_lt(s1, s2) as u8
85}
86
87#[inline(always)]
88pub unsafe fn lean_string_utf8_get_fast(s: b_lean_obj_arg, i: b_lean_obj_arg) -> u32 {
89 let st = lean_string_cstr(s);
90 let idx = lean_unbox(i);
91 let c = *st.add(idx);
92 if c & 0x80 == 0 {
93 c as u32
94 } else {
95 lean_string_utf8_get_fast_cold(st, idx, lean_string_size(s), c)
96 }
97}
98
99#[inline(always)]
100pub unsafe fn lean_string_get_byte_fast(s: b_lean_obj_arg, i: b_lean_obj_arg) -> u8 {
101 let str = lean_string_cstr(s);
102 let idx = lean_unbox(i);
103 *str.add(idx)
104}
105
106#[inline(always)]
107pub unsafe fn lean_string_utf8_next_fast(s: b_lean_obj_arg, i: b_lean_obj_arg) -> lean_obj_res {
108 let s = lean_string_cstr(s);
109 let idx = lean_unbox(i);
110 let c = *s.add(idx);
111 if c & 0x80 == 0 {
112 lean_box(idx + 1)
113 } else {
114 lean_string_utf8_next_fast_cold(idx, c)
115 }
116}
117
118extern "C" {
119 pub fn lean_utf8_strlen(str: *const u8) -> usize;
120 pub fn lean_utf8_n_strlen(str: *const u8, n: usize) -> usize;
121 pub fn lean_mk_string_unchecked(s: *const u8, sz: usize, len: usize) -> lean_obj_res;
122 pub fn lean_mk_string_from_bytes(s: *const u8, sz: usize) -> lean_obj_res;
123 pub fn lean_mk_string_from_bytes_unchecked(s: *const u8, sz: usize) -> lean_obj_res;
124 pub fn lean_mk_ascii_string_unchecked(s: *const u8) -> lean_obj_res;
125 pub fn lean_mk_string(s: *const u8) -> lean_obj_res;
126 pub fn lean_string_push(s: lean_obj_arg, c: u32) -> lean_obj_res;
127 pub fn lean_string_append(s1: lean_obj_arg, s2: lean_obj_arg) -> lean_obj_res;
128 pub fn lean_string_mk(cs: lean_obj_arg) -> lean_obj_res;
129 pub fn lean_string_data(s: lean_obj_arg) -> lean_obj_res;
130 pub fn lean_string_utf8_get(s: b_lean_obj_arg, i: b_lean_obj_arg) -> u32;
131 pub fn lean_string_utf8_get_fast_cold(s: *const u8, i: usize, size: usize, c: u8) -> u32;
132 pub fn lean_string_utf8_next(s: b_lean_obj_arg, i: b_lean_obj_arg) -> lean_obj_res;
133 pub fn lean_string_utf8_next_fast_cold(i: usize, c: u8) -> lean_obj_res;
134 pub fn lean_string_utf8_prev(s: b_lean_obj_arg, i: b_lean_obj_arg) -> lean_obj_res;
135 pub fn lean_string_utf8_set(s: lean_obj_arg, i: b_lean_obj_arg, c: u32) -> lean_obj_res;
136 pub fn lean_string_utf8_extract(
137 s: b_lean_obj_arg,
138 b: b_lean_obj_arg,
139 e: b_lean_obj_arg,
140 ) -> lean_obj_res;
141 #[cold]
142 pub fn lean_string_eq_cold(s1: b_lean_obj_arg, s2: b_lean_obj_arg) -> bool;
143 pub fn lean_string_lt(s1: b_lean_obj_arg, s2: b_lean_obj_arg) -> bool;
144 pub fn lean_string_hash(s: b_lean_obj_arg) -> u64;
145 pub fn lean_string_of_usize(s: usize) -> lean_obj_res;
146}