1#[repr(C)]
4#[derive(Copy, Clone, Debug, Default, Eq, Hash, Ord, PartialEq, PartialOrd)]
5pub struct __BindgenBitfieldUnit<Storage> {
6 storage: Storage,
7}
8impl<Storage> __BindgenBitfieldUnit<Storage> {
9 #[inline]
10 pub const fn new(storage: Storage) -> Self {
11 Self { storage }
12 }
13}
14impl<Storage> __BindgenBitfieldUnit<Storage>
15where
16 Storage: AsRef<[u8]> + AsMut<[u8]>,
17{
18 #[inline]
19 fn extract_bit(byte: u8, index: usize) -> bool {
20 let bit_index = if cfg!(target_endian = "big") {
21 7 - (index % 8)
22 } else {
23 index % 8
24 };
25 let mask = 1 << bit_index;
26 byte & mask == mask
27 }
28 #[inline]
29 pub fn get_bit(&self, index: usize) -> bool {
30 debug_assert!(index / 8 < self.storage.as_ref().len());
31 let byte_index = index / 8;
32 let byte = self.storage.as_ref()[byte_index];
33 Self::extract_bit(byte, index)
34 }
35 #[inline]
36 pub unsafe fn raw_get_bit(this: *const Self, index: usize) -> bool {
37 debug_assert!(index / 8 < core::mem::size_of::<Storage>());
38 let byte_index = index / 8;
39 let byte = *(core::ptr::addr_of!((*this).storage) as *const u8).offset(byte_index as isize);
40 Self::extract_bit(byte, index)
41 }
42 #[inline]
43 fn change_bit(byte: u8, index: usize, val: bool) -> u8 {
44 let bit_index = if cfg!(target_endian = "big") {
45 7 - (index % 8)
46 } else {
47 index % 8
48 };
49 let mask = 1 << bit_index;
50 if val {
51 byte | mask
52 } else {
53 byte & !mask
54 }
55 }
56 #[inline]
57 pub fn set_bit(&mut self, index: usize, val: bool) {
58 debug_assert!(index / 8 < self.storage.as_ref().len());
59 let byte_index = index / 8;
60 let byte = &mut self.storage.as_mut()[byte_index];
61 *byte = Self::change_bit(*byte, index, val);
62 }
63 #[inline]
64 pub unsafe fn raw_set_bit(this: *mut Self, index: usize, val: bool) {
65 debug_assert!(index / 8 < core::mem::size_of::<Storage>());
66 let byte_index = index / 8;
67 let byte =
68 (core::ptr::addr_of_mut!((*this).storage) as *mut u8).offset(byte_index as isize);
69 *byte = Self::change_bit(*byte, index, val);
70 }
71 #[inline]
72 pub fn get(&self, bit_offset: usize, bit_width: u8) -> u64 {
73 debug_assert!(bit_width <= 64);
74 debug_assert!(bit_offset / 8 < self.storage.as_ref().len());
75 debug_assert!((bit_offset + (bit_width as usize)) / 8 <= self.storage.as_ref().len());
76 let mut val = 0;
77 for i in 0..(bit_width as usize) {
78 if self.get_bit(i + bit_offset) {
79 let index = if cfg!(target_endian = "big") {
80 bit_width as usize - 1 - i
81 } else {
82 i
83 };
84 val |= 1 << index;
85 }
86 }
87 val
88 }
89 #[inline]
90 pub unsafe fn raw_get(this: *const Self, bit_offset: usize, bit_width: u8) -> u64 {
91 debug_assert!(bit_width <= 64);
92 debug_assert!(bit_offset / 8 < core::mem::size_of::<Storage>());
93 debug_assert!((bit_offset + (bit_width as usize)) / 8 <= core::mem::size_of::<Storage>());
94 let mut val = 0;
95 for i in 0..(bit_width as usize) {
96 if Self::raw_get_bit(this, i + bit_offset) {
97 let index = if cfg!(target_endian = "big") {
98 bit_width as usize - 1 - i
99 } else {
100 i
101 };
102 val |= 1 << index;
103 }
104 }
105 val
106 }
107 #[inline]
108 pub fn set(&mut self, bit_offset: usize, bit_width: u8, val: u64) {
109 debug_assert!(bit_width <= 64);
110 debug_assert!(bit_offset / 8 < self.storage.as_ref().len());
111 debug_assert!((bit_offset + (bit_width as usize)) / 8 <= self.storage.as_ref().len());
112 for i in 0..(bit_width as usize) {
113 let mask = 1 << i;
114 let val_bit_is_set = val & mask == mask;
115 let index = if cfg!(target_endian = "big") {
116 bit_width as usize - 1 - i
117 } else {
118 i
119 };
120 self.set_bit(index + bit_offset, val_bit_is_set);
121 }
122 }
123 #[inline]
124 pub unsafe fn raw_set(this: *mut Self, bit_offset: usize, bit_width: u8, val: u64) {
125 debug_assert!(bit_width <= 64);
126 debug_assert!(bit_offset / 8 < core::mem::size_of::<Storage>());
127 debug_assert!((bit_offset + (bit_width as usize)) / 8 <= core::mem::size_of::<Storage>());
128 for i in 0..(bit_width as usize) {
129 let mask = 1 << i;
130 let val_bit_is_set = val & mask == mask;
131 let index = if cfg!(target_endian = "big") {
132 bit_width as usize - 1 - i
133 } else {
134 i
135 };
136 Self::raw_set_bit(this, index + bit_offset, val_bit_is_set);
137 }
138 }
139}
140#[repr(C)]
141#[derive(Default)]
142pub struct __IncompleteArrayField<T>(::std::marker::PhantomData<T>, [T; 0]);
143impl<T> __IncompleteArrayField<T> {
144 #[inline]
145 pub const fn new() -> Self {
146 __IncompleteArrayField(::std::marker::PhantomData, [])
147 }
148 #[inline]
149 pub fn as_ptr(&self) -> *const T {
150 self as *const _ as *const T
151 }
152 #[inline]
153 pub fn as_mut_ptr(&mut self) -> *mut T {
154 self as *mut _ as *mut T
155 }
156 #[inline]
157 pub unsafe fn as_slice(&self, len: usize) -> &[T] {
158 ::std::slice::from_raw_parts(self.as_ptr(), len)
159 }
160 #[inline]
161 pub unsafe fn as_mut_slice(&mut self, len: usize) -> &mut [T] {
162 ::std::slice::from_raw_parts_mut(self.as_mut_ptr(), len)
163 }
164}
165impl<T> ::std::fmt::Debug for __IncompleteArrayField<T> {
166 fn fmt(&self, fmt: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
167 fmt.write_str("__IncompleteArrayField")
168 }
169}
170#[repr(C)]
171#[derive(Debug, Copy, Clone)]
172pub struct __sigset_t {
173 pub __val: [usize; 16usize],
174}
175#[repr(C)]
176#[derive(Debug, Copy, Clone)]
177pub struct __pthread_internal_list {
178 pub __prev: *mut __pthread_internal_list,
179 pub __next: *mut __pthread_internal_list,
180}
181pub type __pthread_list_t = __pthread_internal_list;
182#[repr(C)]
183#[derive(Debug, Copy, Clone)]
184pub struct __pthread_mutex_s {
185 pub __lock: ::std::os::raw::c_int,
186 pub __count: ::std::os::raw::c_uint,
187 pub __owner: ::std::os::raw::c_int,
188 pub __nusers: ::std::os::raw::c_uint,
189 pub __kind: ::std::os::raw::c_int,
190 pub __spins: ::std::os::raw::c_short,
191 pub __elision: ::std::os::raw::c_short,
192 pub __list: __pthread_list_t,
193}
194#[repr(C)]
195#[derive(Copy, Clone)]
196pub struct __pthread_cond_s {
197 pub __bindgen_anon_1: __pthread_cond_s__bindgen_ty_1,
198 pub __bindgen_anon_2: __pthread_cond_s__bindgen_ty_2,
199 pub __g_refs: [::std::os::raw::c_uint; 2usize],
200 pub __g_size: [::std::os::raw::c_uint; 2usize],
201 pub __g1_orig_size: ::std::os::raw::c_uint,
202 pub __wrefs: ::std::os::raw::c_uint,
203 pub __g_signals: [::std::os::raw::c_uint; 2usize],
204}
205#[repr(C)]
206#[derive(Copy, Clone)]
207pub union __pthread_cond_s__bindgen_ty_1 {
208 pub __wseq: ::std::os::raw::c_ulonglong,
209 pub __wseq32: __pthread_cond_s__bindgen_ty_1__bindgen_ty_1,
210}
211#[repr(C)]
212#[derive(Debug, Copy, Clone)]
213pub struct __pthread_cond_s__bindgen_ty_1__bindgen_ty_1 {
214 pub __low: ::std::os::raw::c_uint,
215 pub __high: ::std::os::raw::c_uint,
216}
217impl ::std::fmt::Debug for __pthread_cond_s__bindgen_ty_1 {
218 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
219 write!(f, "__pthread_cond_s__bindgen_ty_1 {{ union }}")
220 }
221}
222#[repr(C)]
223#[derive(Copy, Clone)]
224pub union __pthread_cond_s__bindgen_ty_2 {
225 pub __g1_start: ::std::os::raw::c_ulonglong,
226 pub __g1_start32: __pthread_cond_s__bindgen_ty_2__bindgen_ty_1,
227}
228#[repr(C)]
229#[derive(Debug, Copy, Clone)]
230pub struct __pthread_cond_s__bindgen_ty_2__bindgen_ty_1 {
231 pub __low: ::std::os::raw::c_uint,
232 pub __high: ::std::os::raw::c_uint,
233}
234impl ::std::fmt::Debug for __pthread_cond_s__bindgen_ty_2 {
235 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
236 write!(f, "__pthread_cond_s__bindgen_ty_2 {{ union }}")
237 }
238}
239impl ::std::fmt::Debug for __pthread_cond_s {
240 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
241 write ! (f , "__pthread_cond_s {{ __bindgen_anon_1: {:?}, __bindgen_anon_2: {:?}, __g_refs: {:?}, __g_size: {:?}, __g1_orig_size: {:?}, __wrefs: {:?}, __g_signals: {:?} }}" , self . __bindgen_anon_1 , self . __bindgen_anon_2 , self . __g_refs , self . __g_size , self . __g1_orig_size , self . __wrefs , self . __g_signals)
242 }
243}
244pub type pthread_t = usize;
245#[repr(C)]
246#[derive(Copy, Clone)]
247pub union pthread_mutex_t {
248 pub __data: __pthread_mutex_s,
249 pub __size: [::std::os::raw::c_char; 40usize],
250 pub __align: ::std::os::raw::c_long,
251}
252impl ::std::fmt::Debug for pthread_mutex_t {
253 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
254 write!(f, "pthread_mutex_t {{ union }}")
255 }
256}
257#[repr(C)]
258#[derive(Copy, Clone)]
259pub union pthread_cond_t {
260 pub __data: __pthread_cond_s,
261 pub __size: [::std::os::raw::c_char; 48usize],
262 pub __align: ::std::os::raw::c_longlong,
263}
264impl ::std::fmt::Debug for pthread_cond_t {
265 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
266 write!(f, "pthread_cond_t {{ union }}")
267 }
268}
269pub type __jmp_buf = [::std::os::raw::c_long; 8usize];
270#[repr(C)]
271#[derive(Debug, Copy, Clone)]
272pub struct __jmp_buf_tag {
273 pub __jmpbuf: __jmp_buf,
274 pub __mask_was_saved: ::std::os::raw::c_int,
275 pub __saved_mask: __sigset_t,
276}
277pub type jmp_buf = [__jmp_buf_tag; 1usize];
278pub type sigjmp_buf = [__jmp_buf_tag; 1usize];
279#[repr(C)]
280#[derive(Debug, Copy, Clone)]
281pub struct ccan_list_node {
282 pub next: *mut ccan_list_node,
283 pub prev: *mut ccan_list_node,
284}
285#[repr(C)]
286#[derive(Debug, Copy, Clone)]
287pub struct ccan_list_head {
288 pub n: ccan_list_node,
289}
290pub const ruby_id_types_RUBY_ID_STATIC_SYM: ruby_id_types = 1;
291pub const ruby_id_types_RUBY_ID_LOCAL: ruby_id_types = 0;
292pub const ruby_id_types_RUBY_ID_INSTANCE: ruby_id_types = 2;
293pub const ruby_id_types_RUBY_ID_GLOBAL: ruby_id_types = 6;
294pub const ruby_id_types_RUBY_ID_ATTRSET: ruby_id_types = 8;
295pub const ruby_id_types_RUBY_ID_CONST: ruby_id_types = 10;
296pub const ruby_id_types_RUBY_ID_CLASS: ruby_id_types = 12;
297pub const ruby_id_types_RUBY_ID_JUNK: ruby_id_types = 14;
298pub const ruby_id_types_RUBY_ID_INTERNAL: ruby_id_types = 14;
299pub const ruby_id_types_RUBY_ID_SCOPE_SHIFT: ruby_id_types = 4;
300pub const ruby_id_types_RUBY_ID_SCOPE_MASK: ruby_id_types = 14;
301pub type ruby_id_types = ::std::os::raw::c_uint;
302pub const ruby_method_ids_idDot2: ruby_method_ids = 128;
303pub const ruby_method_ids_idDot3: ruby_method_ids = 129;
304pub const ruby_method_ids_idUPlus: ruby_method_ids = 132;
305pub const ruby_method_ids_idUMinus: ruby_method_ids = 133;
306pub const ruby_method_ids_idPow: ruby_method_ids = 134;
307pub const ruby_method_ids_idCmp: ruby_method_ids = 135;
308pub const ruby_method_ids_idPLUS: ruby_method_ids = 43;
309pub const ruby_method_ids_idMINUS: ruby_method_ids = 45;
310pub const ruby_method_ids_idMULT: ruby_method_ids = 42;
311pub const ruby_method_ids_idDIV: ruby_method_ids = 47;
312pub const ruby_method_ids_idMOD: ruby_method_ids = 37;
313pub const ruby_method_ids_idLTLT: ruby_method_ids = 136;
314pub const ruby_method_ids_idGTGT: ruby_method_ids = 137;
315pub const ruby_method_ids_idLT: ruby_method_ids = 60;
316pub const ruby_method_ids_idLE: ruby_method_ids = 138;
317pub const ruby_method_ids_idGT: ruby_method_ids = 62;
318pub const ruby_method_ids_idGE: ruby_method_ids = 139;
319pub const ruby_method_ids_idEq: ruby_method_ids = 140;
320pub const ruby_method_ids_idEqq: ruby_method_ids = 141;
321pub const ruby_method_ids_idNeq: ruby_method_ids = 142;
322pub const ruby_method_ids_idNot: ruby_method_ids = 33;
323pub const ruby_method_ids_idAnd: ruby_method_ids = 38;
324pub const ruby_method_ids_idOr: ruby_method_ids = 124;
325pub const ruby_method_ids_idBackquote: ruby_method_ids = 96;
326pub const ruby_method_ids_idEqTilde: ruby_method_ids = 143;
327pub const ruby_method_ids_idNeqTilde: ruby_method_ids = 144;
328pub const ruby_method_ids_idAREF: ruby_method_ids = 145;
329pub const ruby_method_ids_idASET: ruby_method_ids = 146;
330pub const ruby_method_ids_idCOLON2: ruby_method_ids = 147;
331pub const ruby_method_ids_idANDOP: ruby_method_ids = 148;
332pub const ruby_method_ids_idOROP: ruby_method_ids = 149;
333pub const ruby_method_ids_idANDDOT: ruby_method_ids = 150;
334pub const ruby_method_ids_tPRESERVED_ID_BEGIN: ruby_method_ids = 150;
335pub const ruby_method_ids_idNilP: ruby_method_ids = 151;
336pub const ruby_method_ids_idNULL: ruby_method_ids = 152;
337pub const ruby_method_ids_idEmptyP: ruby_method_ids = 153;
338pub const ruby_method_ids_idEqlP: ruby_method_ids = 154;
339pub const ruby_method_ids_idRespond_to: ruby_method_ids = 155;
340pub const ruby_method_ids_idRespond_to_missing: ruby_method_ids = 156;
341pub const ruby_method_ids_idIFUNC: ruby_method_ids = 157;
342pub const ruby_method_ids_idCFUNC: ruby_method_ids = 158;
343pub const ruby_method_ids_id_core_set_method_alias: ruby_method_ids = 159;
344pub const ruby_method_ids_id_core_set_variable_alias: ruby_method_ids = 160;
345pub const ruby_method_ids_id_core_undef_method: ruby_method_ids = 161;
346pub const ruby_method_ids_id_core_define_method: ruby_method_ids = 162;
347pub const ruby_method_ids_id_core_define_singleton_method: ruby_method_ids = 163;
348pub const ruby_method_ids_id_core_set_postexe: ruby_method_ids = 164;
349pub const ruby_method_ids_id_core_hash_merge_ptr: ruby_method_ids = 165;
350pub const ruby_method_ids_id_core_hash_merge_kwd: ruby_method_ids = 166;
351pub const ruby_method_ids_id_core_raise: ruby_method_ids = 167;
352pub const ruby_method_ids_id_core_sprintf: ruby_method_ids = 168;
353pub const ruby_method_ids_id_debug_created_info: ruby_method_ids = 169;
354pub const ruby_method_ids_tPRESERVED_ID_END: ruby_method_ids = 170;
355pub const ruby_method_ids_tTOKEN_LOCAL_BEGIN: ruby_method_ids = 169;
356pub const ruby_method_ids_tMax: ruby_method_ids = 170;
357pub const ruby_method_ids_tMin: ruby_method_ids = 171;
358pub const ruby_method_ids_tFreeze: ruby_method_ids = 172;
359pub const ruby_method_ids_tInspect: ruby_method_ids = 173;
360pub const ruby_method_ids_tIntern: ruby_method_ids = 174;
361pub const ruby_method_ids_tObject_id: ruby_method_ids = 175;
362pub const ruby_method_ids_tConst_added: ruby_method_ids = 176;
363pub const ruby_method_ids_tConst_missing: ruby_method_ids = 177;
364pub const ruby_method_ids_tMethodMissing: ruby_method_ids = 178;
365pub const ruby_method_ids_tMethod_added: ruby_method_ids = 179;
366pub const ruby_method_ids_tSingleton_method_added: ruby_method_ids = 180;
367pub const ruby_method_ids_tMethod_removed: ruby_method_ids = 181;
368pub const ruby_method_ids_tSingleton_method_removed: ruby_method_ids = 182;
369pub const ruby_method_ids_tMethod_undefined: ruby_method_ids = 183;
370pub const ruby_method_ids_tSingleton_method_undefined: ruby_method_ids = 184;
371pub const ruby_method_ids_tLength: ruby_method_ids = 185;
372pub const ruby_method_ids_tSize: ruby_method_ids = 186;
373pub const ruby_method_ids_tGets: ruby_method_ids = 187;
374pub const ruby_method_ids_tSucc: ruby_method_ids = 188;
375pub const ruby_method_ids_tEach: ruby_method_ids = 189;
376pub const ruby_method_ids_tProc: ruby_method_ids = 190;
377pub const ruby_method_ids_tLambda: ruby_method_ids = 191;
378pub const ruby_method_ids_tSend: ruby_method_ids = 192;
379pub const ruby_method_ids_t__send__: ruby_method_ids = 193;
380pub const ruby_method_ids_t__attached__: ruby_method_ids = 194;
381pub const ruby_method_ids_t__recursive_key__: ruby_method_ids = 195;
382pub const ruby_method_ids_tInitialize: ruby_method_ids = 196;
383pub const ruby_method_ids_tInitialize_copy: ruby_method_ids = 197;
384pub const ruby_method_ids_tInitialize_clone: ruby_method_ids = 198;
385pub const ruby_method_ids_tInitialize_dup: ruby_method_ids = 199;
386pub const ruby_method_ids_tTo_int: ruby_method_ids = 200;
387pub const ruby_method_ids_tTo_ary: ruby_method_ids = 201;
388pub const ruby_method_ids_tTo_str: ruby_method_ids = 202;
389pub const ruby_method_ids_tTo_sym: ruby_method_ids = 203;
390pub const ruby_method_ids_tTo_hash: ruby_method_ids = 204;
391pub const ruby_method_ids_tTo_proc: ruby_method_ids = 205;
392pub const ruby_method_ids_tTo_io: ruby_method_ids = 206;
393pub const ruby_method_ids_tTo_a: ruby_method_ids = 207;
394pub const ruby_method_ids_tTo_s: ruby_method_ids = 208;
395pub const ruby_method_ids_tTo_i: ruby_method_ids = 209;
396pub const ruby_method_ids_tTo_f: ruby_method_ids = 210;
397pub const ruby_method_ids_tTo_r: ruby_method_ids = 211;
398pub const ruby_method_ids_tBt: ruby_method_ids = 212;
399pub const ruby_method_ids_tBt_locations: ruby_method_ids = 213;
400pub const ruby_method_ids_tCall: ruby_method_ids = 214;
401pub const ruby_method_ids_tMesg: ruby_method_ids = 215;
402pub const ruby_method_ids_tException: ruby_method_ids = 216;
403pub const ruby_method_ids_tLocals: ruby_method_ids = 217;
404pub const ruby_method_ids_tNOT: ruby_method_ids = 218;
405pub const ruby_method_ids_tAND: ruby_method_ids = 219;
406pub const ruby_method_ids_tOR: ruby_method_ids = 220;
407pub const ruby_method_ids_tDiv: ruby_method_ids = 221;
408pub const ruby_method_ids_tDivmod: ruby_method_ids = 222;
409pub const ruby_method_ids_tFdiv: ruby_method_ids = 223;
410pub const ruby_method_ids_tQuo: ruby_method_ids = 224;
411pub const ruby_method_ids_tName: ruby_method_ids = 225;
412pub const ruby_method_ids_tNil: ruby_method_ids = 226;
413pub const ruby_method_ids_tPath: ruby_method_ids = 227;
414pub const ruby_method_ids_tUScore: ruby_method_ids = 228;
415pub const ruby_method_ids_tNUMPARAM_1: ruby_method_ids = 229;
416pub const ruby_method_ids_tNUMPARAM_2: ruby_method_ids = 230;
417pub const ruby_method_ids_tNUMPARAM_3: ruby_method_ids = 231;
418pub const ruby_method_ids_tNUMPARAM_4: ruby_method_ids = 232;
419pub const ruby_method_ids_tNUMPARAM_5: ruby_method_ids = 233;
420pub const ruby_method_ids_tNUMPARAM_6: ruby_method_ids = 234;
421pub const ruby_method_ids_tNUMPARAM_7: ruby_method_ids = 235;
422pub const ruby_method_ids_tNUMPARAM_8: ruby_method_ids = 236;
423pub const ruby_method_ids_tNUMPARAM_9: ruby_method_ids = 237;
424pub const ruby_method_ids_tDefault: ruby_method_ids = 238;
425pub const ruby_method_ids_tTOKEN_LOCAL_END: ruby_method_ids = 239;
426pub const ruby_method_ids_tTOKEN_INSTANCE_BEGIN: ruby_method_ids = 238;
427pub const ruby_method_ids_tTOKEN_INSTANCE_END: ruby_method_ids = 239;
428pub const ruby_method_ids_tTOKEN_GLOBAL_BEGIN: ruby_method_ids = 238;
429pub const ruby_method_ids_tLASTLINE: ruby_method_ids = 239;
430pub const ruby_method_ids_tBACKREF: ruby_method_ids = 240;
431pub const ruby_method_ids_tERROR_INFO: ruby_method_ids = 241;
432pub const ruby_method_ids_tTOKEN_GLOBAL_END: ruby_method_ids = 242;
433pub const ruby_method_ids_tTOKEN_CONST_BEGIN: ruby_method_ids = 241;
434pub const ruby_method_ids_tTOKEN_CONST_END: ruby_method_ids = 242;
435pub const ruby_method_ids_tTOKEN_CLASS_BEGIN: ruby_method_ids = 241;
436pub const ruby_method_ids_tTOKEN_CLASS_END: ruby_method_ids = 242;
437pub const ruby_method_ids_tTOKEN_ATTRSET_BEGIN: ruby_method_ids = 241;
438pub const ruby_method_ids_tTOKEN_ATTRSET_END: ruby_method_ids = 242;
439pub const ruby_method_ids_tNEXT_ID: ruby_method_ids = 242;
440pub const ruby_method_ids_idMax: ruby_method_ids = 2721;
441pub const ruby_method_ids_idMin: ruby_method_ids = 2737;
442pub const ruby_method_ids_idFreeze: ruby_method_ids = 2753;
443pub const ruby_method_ids_idInspect: ruby_method_ids = 2769;
444pub const ruby_method_ids_idIntern: ruby_method_ids = 2785;
445pub const ruby_method_ids_idObject_id: ruby_method_ids = 2801;
446pub const ruby_method_ids_idConst_added: ruby_method_ids = 2817;
447pub const ruby_method_ids_idConst_missing: ruby_method_ids = 2833;
448pub const ruby_method_ids_idMethodMissing: ruby_method_ids = 2849;
449pub const ruby_method_ids_idMethod_added: ruby_method_ids = 2865;
450pub const ruby_method_ids_idSingleton_method_added: ruby_method_ids = 2881;
451pub const ruby_method_ids_idMethod_removed: ruby_method_ids = 2897;
452pub const ruby_method_ids_idSingleton_method_removed: ruby_method_ids = 2913;
453pub const ruby_method_ids_idMethod_undefined: ruby_method_ids = 2929;
454pub const ruby_method_ids_idSingleton_method_undefined: ruby_method_ids = 2945;
455pub const ruby_method_ids_idLength: ruby_method_ids = 2961;
456pub const ruby_method_ids_idSize: ruby_method_ids = 2977;
457pub const ruby_method_ids_idGets: ruby_method_ids = 2993;
458pub const ruby_method_ids_idSucc: ruby_method_ids = 3009;
459pub const ruby_method_ids_idEach: ruby_method_ids = 3025;
460pub const ruby_method_ids_idProc: ruby_method_ids = 3041;
461pub const ruby_method_ids_idLambda: ruby_method_ids = 3057;
462pub const ruby_method_ids_idSend: ruby_method_ids = 3073;
463pub const ruby_method_ids_id__send__: ruby_method_ids = 3089;
464pub const ruby_method_ids_id__attached__: ruby_method_ids = 3105;
465pub const ruby_method_ids_id__recursive_key__: ruby_method_ids = 3121;
466pub const ruby_method_ids_idInitialize: ruby_method_ids = 3137;
467pub const ruby_method_ids_idInitialize_copy: ruby_method_ids = 3153;
468pub const ruby_method_ids_idInitialize_clone: ruby_method_ids = 3169;
469pub const ruby_method_ids_idInitialize_dup: ruby_method_ids = 3185;
470pub const ruby_method_ids_idTo_int: ruby_method_ids = 3201;
471pub const ruby_method_ids_idTo_ary: ruby_method_ids = 3217;
472pub const ruby_method_ids_idTo_str: ruby_method_ids = 3233;
473pub const ruby_method_ids_idTo_sym: ruby_method_ids = 3249;
474pub const ruby_method_ids_idTo_hash: ruby_method_ids = 3265;
475pub const ruby_method_ids_idTo_proc: ruby_method_ids = 3281;
476pub const ruby_method_ids_idTo_io: ruby_method_ids = 3297;
477pub const ruby_method_ids_idTo_a: ruby_method_ids = 3313;
478pub const ruby_method_ids_idTo_s: ruby_method_ids = 3329;
479pub const ruby_method_ids_idTo_i: ruby_method_ids = 3345;
480pub const ruby_method_ids_idTo_f: ruby_method_ids = 3361;
481pub const ruby_method_ids_idTo_r: ruby_method_ids = 3377;
482pub const ruby_method_ids_idBt: ruby_method_ids = 3393;
483pub const ruby_method_ids_idBt_locations: ruby_method_ids = 3409;
484pub const ruby_method_ids_idCall: ruby_method_ids = 3425;
485pub const ruby_method_ids_idMesg: ruby_method_ids = 3441;
486pub const ruby_method_ids_idException: ruby_method_ids = 3457;
487pub const ruby_method_ids_idLocals: ruby_method_ids = 3473;
488pub const ruby_method_ids_idNOT: ruby_method_ids = 3489;
489pub const ruby_method_ids_idAND: ruby_method_ids = 3505;
490pub const ruby_method_ids_idOR: ruby_method_ids = 3521;
491pub const ruby_method_ids_idDiv: ruby_method_ids = 3537;
492pub const ruby_method_ids_idDivmod: ruby_method_ids = 3553;
493pub const ruby_method_ids_idFdiv: ruby_method_ids = 3569;
494pub const ruby_method_ids_idQuo: ruby_method_ids = 3585;
495pub const ruby_method_ids_idName: ruby_method_ids = 3601;
496pub const ruby_method_ids_idNil: ruby_method_ids = 3617;
497pub const ruby_method_ids_idPath: ruby_method_ids = 3633;
498pub const ruby_method_ids_idUScore: ruby_method_ids = 3649;
499pub const ruby_method_ids_idNUMPARAM_1: ruby_method_ids = 3665;
500pub const ruby_method_ids_idNUMPARAM_2: ruby_method_ids = 3681;
501pub const ruby_method_ids_idNUMPARAM_3: ruby_method_ids = 3697;
502pub const ruby_method_ids_idNUMPARAM_4: ruby_method_ids = 3713;
503pub const ruby_method_ids_idNUMPARAM_5: ruby_method_ids = 3729;
504pub const ruby_method_ids_idNUMPARAM_6: ruby_method_ids = 3745;
505pub const ruby_method_ids_idNUMPARAM_7: ruby_method_ids = 3761;
506pub const ruby_method_ids_idNUMPARAM_8: ruby_method_ids = 3777;
507pub const ruby_method_ids_idNUMPARAM_9: ruby_method_ids = 3793;
508pub const ruby_method_ids_idDefault: ruby_method_ids = 3809;
509pub const ruby_method_ids_idLASTLINE: ruby_method_ids = 3831;
510pub const ruby_method_ids_idBACKREF: ruby_method_ids = 3847;
511pub const ruby_method_ids_idERROR_INFO: ruby_method_ids = 3863;
512pub const ruby_method_ids_tLAST_OP_ID: ruby_method_ids = 169;
513pub const ruby_method_ids_idLAST_OP_ID: ruby_method_ids = 10;
514pub type ruby_method_ids = ::std::os::raw::c_uint;
515pub type VALUE = usize;
516pub type ID = usize;
517#[repr(C)]
518#[derive(Debug, Copy, Clone)]
519pub struct RBasic {
520 pub flags: VALUE,
521 pub klass: VALUE,
522}
523pub const ruby_fl_ushift_RUBY_FL_USHIFT: ruby_fl_ushift = 12;
524pub type ruby_fl_ushift = ::std::os::raw::c_uint;
525pub const ruby_fl_type_RUBY_FL_WB_PROTECTED: ruby_fl_type = 32;
526pub const ruby_fl_type_RUBY_FL_PROMOTED0: ruby_fl_type = 32;
527pub const ruby_fl_type_RUBY_FL_PROMOTED1: ruby_fl_type = 64;
528pub const ruby_fl_type_RUBY_FL_PROMOTED: ruby_fl_type = 96;
529pub const ruby_fl_type_RUBY_FL_FINALIZE: ruby_fl_type = 128;
530pub const ruby_fl_type_RUBY_FL_TAINT: ruby_fl_type = 256;
531pub const ruby_fl_type_RUBY_FL_SHAREABLE: ruby_fl_type = 256;
532pub const ruby_fl_type_RUBY_FL_UNTRUSTED: ruby_fl_type = 256;
533pub const ruby_fl_type_RUBY_FL_SEEN_OBJ_ID: ruby_fl_type = 512;
534pub const ruby_fl_type_RUBY_FL_EXIVAR: ruby_fl_type = 1024;
535pub const ruby_fl_type_RUBY_FL_FREEZE: ruby_fl_type = 2048;
536pub const ruby_fl_type_RUBY_FL_USER0: ruby_fl_type = 4096;
537pub const ruby_fl_type_RUBY_FL_USER1: ruby_fl_type = 8192;
538pub const ruby_fl_type_RUBY_FL_USER2: ruby_fl_type = 16384;
539pub const ruby_fl_type_RUBY_FL_USER3: ruby_fl_type = 32768;
540pub const ruby_fl_type_RUBY_FL_USER4: ruby_fl_type = 65536;
541pub const ruby_fl_type_RUBY_FL_USER5: ruby_fl_type = 131072;
542pub const ruby_fl_type_RUBY_FL_USER6: ruby_fl_type = 262144;
543pub const ruby_fl_type_RUBY_FL_USER7: ruby_fl_type = 524288;
544pub const ruby_fl_type_RUBY_FL_USER8: ruby_fl_type = 1048576;
545pub const ruby_fl_type_RUBY_FL_USER9: ruby_fl_type = 2097152;
546pub const ruby_fl_type_RUBY_FL_USER10: ruby_fl_type = 4194304;
547pub const ruby_fl_type_RUBY_FL_USER11: ruby_fl_type = 8388608;
548pub const ruby_fl_type_RUBY_FL_USER12: ruby_fl_type = 16777216;
549pub const ruby_fl_type_RUBY_FL_USER13: ruby_fl_type = 33554432;
550pub const ruby_fl_type_RUBY_FL_USER14: ruby_fl_type = 67108864;
551pub const ruby_fl_type_RUBY_FL_USER15: ruby_fl_type = 134217728;
552pub const ruby_fl_type_RUBY_FL_USER16: ruby_fl_type = 268435456;
553pub const ruby_fl_type_RUBY_FL_USER17: ruby_fl_type = 536870912;
554pub const ruby_fl_type_RUBY_FL_USER18: ruby_fl_type = 1073741824;
555pub const ruby_fl_type_RUBY_FL_USER19: ruby_fl_type = -2147483648;
556pub const ruby_fl_type_RUBY_ELTS_SHARED: ruby_fl_type = 16384;
557pub const ruby_fl_type_RUBY_FL_SINGLETON: ruby_fl_type = 4096;
558pub type ruby_fl_type = ::std::os::raw::c_int;
559#[repr(C)]
560#[derive(Copy, Clone)]
561pub struct RString {
562 pub basic: RBasic,
563 pub as_: RString__bindgen_ty_1,
564}
565#[repr(C)]
566#[derive(Copy, Clone)]
567pub union RString__bindgen_ty_1 {
568 pub heap: RString__bindgen_ty_1__bindgen_ty_1,
569 pub embed: RString__bindgen_ty_1__bindgen_ty_2,
570}
571#[repr(C)]
572#[derive(Copy, Clone)]
573pub struct RString__bindgen_ty_1__bindgen_ty_1 {
574 pub len: ::std::os::raw::c_long,
575 pub ptr: *mut ::std::os::raw::c_char,
576 pub aux: RString__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1,
577}
578#[repr(C)]
579#[derive(Copy, Clone)]
580pub union RString__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1 {
581 pub capa: ::std::os::raw::c_long,
582 pub shared: VALUE,
583}
584impl ::std::fmt::Debug for RString__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1 {
585 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
586 write!(
587 f,
588 "RString__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1 {{ union }}"
589 )
590 }
591}
592impl ::std::fmt::Debug for RString__bindgen_ty_1__bindgen_ty_1 {
593 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
594 write!(
595 f,
596 "RString__bindgen_ty_1__bindgen_ty_1 {{ len: {:?}, ptr: {:?}, aux: {:?} }}",
597 self.len, self.ptr, self.aux
598 )
599 }
600}
601#[repr(C)]
602#[derive(Debug, Copy, Clone)]
603pub struct RString__bindgen_ty_1__bindgen_ty_2 {
604 pub len: ::std::os::raw::c_long,
605 pub ary: [::std::os::raw::c_char; 1usize],
606}
607impl ::std::fmt::Debug for RString__bindgen_ty_1 {
608 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
609 write!(f, "RString__bindgen_ty_1 {{ union }}")
610 }
611}
612impl ::std::fmt::Debug for RString {
613 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
614 write!(
615 f,
616 "RString {{ basic: {:?}, as: {:?} }}",
617 self.basic, self.as_
618 )
619 }
620}
621pub type st_data_t = usize;
622pub type st_index_t = st_data_t;
623#[repr(C)]
624#[derive(Debug, Copy, Clone)]
625pub struct st_hash_type {
626 pub compare: ::std::option::Option<
627 unsafe extern "C" fn(arg1: st_data_t, arg2: st_data_t) -> ::std::os::raw::c_int,
628 >,
629 pub hash: ::std::option::Option<unsafe extern "C" fn(arg1: st_data_t) -> st_index_t>,
630}
631#[repr(C)]
632#[derive(Debug, Copy, Clone)]
633pub struct st_table_entry {
634 _unused: [u8; 0],
635}
636#[repr(C)]
637#[derive(Debug, Copy, Clone)]
638pub struct st_table {
639 pub entry_power: ::std::os::raw::c_uchar,
640 pub bin_power: ::std::os::raw::c_uchar,
641 pub size_ind: ::std::os::raw::c_uchar,
642 pub rebuilds_num: ::std::os::raw::c_uint,
643 pub type_: *const st_hash_type,
644 pub num_entries: st_index_t,
645 pub bins: *mut st_index_t,
646 pub entries_start: st_index_t,
647 pub entries_bound: st_index_t,
648 pub entries: *mut st_table_entry,
649}
650#[repr(C)]
651#[derive(Copy, Clone)]
652pub struct RArray {
653 pub basic: RBasic,
654 pub as_: RArray__bindgen_ty_1,
655}
656#[repr(C)]
657#[derive(Copy, Clone)]
658pub union RArray__bindgen_ty_1 {
659 pub heap: RArray__bindgen_ty_1__bindgen_ty_1,
660 pub ary: [VALUE; 1usize],
661}
662#[repr(C)]
663#[derive(Copy, Clone)]
664pub struct RArray__bindgen_ty_1__bindgen_ty_1 {
665 pub len: ::std::os::raw::c_long,
666 pub aux: RArray__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1,
667 pub ptr: *const VALUE,
668}
669#[repr(C)]
670#[derive(Copy, Clone)]
671pub union RArray__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1 {
672 pub capa: ::std::os::raw::c_long,
673 pub shared_root: VALUE,
674}
675impl ::std::fmt::Debug for RArray__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1 {
676 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
677 write!(
678 f,
679 "RArray__bindgen_ty_1__bindgen_ty_1__bindgen_ty_1 {{ union }}"
680 )
681 }
682}
683impl ::std::fmt::Debug for RArray__bindgen_ty_1__bindgen_ty_1 {
684 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
685 write!(
686 f,
687 "RArray__bindgen_ty_1__bindgen_ty_1 {{ len: {:?}, aux: {:?}, ptr: {:?} }}",
688 self.len, self.aux, self.ptr
689 )
690 }
691}
692impl ::std::fmt::Debug for RArray__bindgen_ty_1 {
693 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
694 write!(f, "RArray__bindgen_ty_1 {{ union }}")
695 }
696}
697impl ::std::fmt::Debug for RArray {
698 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
699 write!(
700 f,
701 "RArray {{ basic: {:?}, as: {:?} }}",
702 self.basic, self.as_
703 )
704 }
705}
706pub type rb_event_flag_t = u32;
707pub type rb_unblock_function_t =
708 ::std::option::Option<unsafe extern "C" fn(arg1: *mut ::std::os::raw::c_void)>;
709pub type rb_serial_t = ::std::os::raw::c_ulonglong;
710#[repr(C)]
711#[derive(Debug, Copy, Clone)]
712pub struct rb_callinfo {
713 _unused: [u8; 0],
714}
715pub const method_missing_reason_MISSING_NOENTRY: method_missing_reason = 0;
716pub const method_missing_reason_MISSING_PRIVATE: method_missing_reason = 1;
717pub const method_missing_reason_MISSING_PROTECTED: method_missing_reason = 2;
718pub const method_missing_reason_MISSING_FCALL: method_missing_reason = 4;
719pub const method_missing_reason_MISSING_VCALL: method_missing_reason = 8;
720pub const method_missing_reason_MISSING_SUPER: method_missing_reason = 16;
721pub const method_missing_reason_MISSING_MISSING: method_missing_reason = 32;
722pub const method_missing_reason_MISSING_NONE: method_missing_reason = 64;
723pub type method_missing_reason = ::std::os::raw::c_uint;
724#[repr(C)]
725#[derive(Debug, Copy, Clone)]
726pub struct rb_callcache {
727 _unused: [u8; 0],
728}
729#[repr(C)]
730#[derive(Debug, Copy, Clone)]
731pub struct rb_objspace {
732 _unused: [u8; 0],
733}
734#[repr(C)]
735#[derive(Debug, Copy, Clone)]
736pub struct ractor_newobj_size_pool_cache {
737 pub freelist: *mut RVALUE,
738 pub using_page: *mut heap_page,
739}
740pub type rb_ractor_newobj_size_pool_cache_t = ractor_newobj_size_pool_cache;
741#[repr(C)]
742#[derive(Debug, Copy, Clone)]
743pub struct ractor_newobj_cache {
744 pub incremental_mark_step_allocated_slots: usize,
745 pub size_pool_caches: [rb_ractor_newobj_size_pool_cache_t; 5usize],
746}
747pub type rb_ractor_newobj_cache_t = ractor_newobj_cache;
748pub const imemo_type_imemo_env: imemo_type = 0;
749pub const imemo_type_imemo_cref: imemo_type = 1;
750pub const imemo_type_imemo_svar: imemo_type = 2;
751pub const imemo_type_imemo_throw_data: imemo_type = 3;
752pub const imemo_type_imemo_ifunc: imemo_type = 4;
753pub const imemo_type_imemo_memo: imemo_type = 5;
754pub const imemo_type_imemo_ment: imemo_type = 6;
755pub const imemo_type_imemo_iseq: imemo_type = 7;
756pub const imemo_type_imemo_tmpbuf: imemo_type = 8;
757pub const imemo_type_imemo_ast: imemo_type = 9;
758pub const imemo_type_imemo_parser_strterm: imemo_type = 10;
759pub const imemo_type_imemo_callinfo: imemo_type = 11;
760pub const imemo_type_imemo_callcache: imemo_type = 12;
761pub const imemo_type_imemo_constcache: imemo_type = 13;
762pub type imemo_type = ::std::os::raw::c_uint;
763#[repr(C)]
764#[derive(Debug, Copy, Clone)]
765pub struct vm_svar {
766 pub flags: VALUE,
767 pub cref_or_me: VALUE,
768 pub lastline: VALUE,
769 pub backref: VALUE,
770 pub others: VALUE,
771}
772pub const rb_method_visibility_t_METHOD_VISI_UNDEF: rb_method_visibility_t = 0;
773pub const rb_method_visibility_t_METHOD_VISI_PUBLIC: rb_method_visibility_t = 1;
774pub const rb_method_visibility_t_METHOD_VISI_PRIVATE: rb_method_visibility_t = 2;
775pub const rb_method_visibility_t_METHOD_VISI_PROTECTED: rb_method_visibility_t = 3;
776pub const rb_method_visibility_t_METHOD_VISI_MASK: rb_method_visibility_t = 3;
777pub type rb_method_visibility_t = ::std::os::raw::c_uint;
778#[repr(C)]
779#[repr(align(4))]
780#[derive(Debug, Copy, Clone)]
781pub struct rb_scope_visi_struct {
782 pub _bitfield_align_1: [u8; 0],
783 pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
784 pub __bindgen_padding_0: [u8; 3usize],
785}
786impl rb_scope_visi_struct {
787 #[inline]
788 pub fn method_visi(&self) -> rb_method_visibility_t {
789 unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 3u8) as u32) }
790 }
791 #[inline]
792 pub fn set_method_visi(&mut self, val: rb_method_visibility_t) {
793 unsafe {
794 let val: u32 = ::std::mem::transmute(val);
795 self._bitfield_1.set(0usize, 3u8, val as u64)
796 }
797 }
798 #[inline]
799 pub unsafe fn method_visi_raw(this: *const Self) -> rb_method_visibility_t {
800 unsafe {
801 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
802 ::std::ptr::addr_of!((*this)._bitfield_1),
803 0usize,
804 3u8,
805 ) as u32)
806 }
807 }
808 #[inline]
809 pub unsafe fn set_method_visi_raw(this: *mut Self, val: rb_method_visibility_t) {
810 unsafe {
811 let val: u32 = ::std::mem::transmute(val);
812 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
813 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
814 0usize,
815 3u8,
816 val as u64,
817 )
818 }
819 }
820 #[inline]
821 pub fn module_func(&self) -> ::std::os::raw::c_uint {
822 unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
823 }
824 #[inline]
825 pub fn set_module_func(&mut self, val: ::std::os::raw::c_uint) {
826 unsafe {
827 let val: u32 = ::std::mem::transmute(val);
828 self._bitfield_1.set(3usize, 1u8, val as u64)
829 }
830 }
831 #[inline]
832 pub unsafe fn module_func_raw(this: *const Self) -> ::std::os::raw::c_uint {
833 unsafe {
834 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
835 ::std::ptr::addr_of!((*this)._bitfield_1),
836 3usize,
837 1u8,
838 ) as u32)
839 }
840 }
841 #[inline]
842 pub unsafe fn set_module_func_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
843 unsafe {
844 let val: u32 = ::std::mem::transmute(val);
845 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
846 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
847 3usize,
848 1u8,
849 val as u64,
850 )
851 }
852 }
853 #[inline]
854 pub fn new_bitfield_1(
855 method_visi: rb_method_visibility_t,
856 module_func: ::std::os::raw::c_uint,
857 ) -> __BindgenBitfieldUnit<[u8; 1usize]> {
858 let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
859 __bindgen_bitfield_unit.set(0usize, 3u8, {
860 let method_visi: u32 = unsafe { ::std::mem::transmute(method_visi) };
861 method_visi as u64
862 });
863 __bindgen_bitfield_unit.set(3usize, 1u8, {
864 let module_func: u32 = unsafe { ::std::mem::transmute(module_func) };
865 module_func as u64
866 });
867 __bindgen_bitfield_unit
868 }
869}
870pub type rb_scope_visibility_t = rb_scope_visi_struct;
871#[repr(C)]
872#[derive(Debug, Copy, Clone)]
873pub struct rb_cref_struct {
874 pub flags: VALUE,
875 pub refinements: VALUE,
876 pub klass_or_self: VALUE,
877 pub next: *mut rb_cref_struct,
878 pub scope_visi: rb_scope_visibility_t,
879}
880pub type rb_cref_t = rb_cref_struct;
881#[repr(C)]
882#[derive(Debug, Copy, Clone)]
883pub struct rb_method_entry_struct {
884 pub flags: VALUE,
885 pub defined_class: VALUE,
886 pub def: *mut rb_method_definition_struct,
887 pub called_id: ID,
888 pub owner: VALUE,
889}
890pub const rb_method_type_t_VM_METHOD_TYPE_ISEQ: rb_method_type_t = 0;
891pub const rb_method_type_t_VM_METHOD_TYPE_CFUNC: rb_method_type_t = 1;
892pub const rb_method_type_t_VM_METHOD_TYPE_ATTRSET: rb_method_type_t = 2;
893pub const rb_method_type_t_VM_METHOD_TYPE_IVAR: rb_method_type_t = 3;
894pub const rb_method_type_t_VM_METHOD_TYPE_BMETHOD: rb_method_type_t = 4;
895pub const rb_method_type_t_VM_METHOD_TYPE_ZSUPER: rb_method_type_t = 5;
896pub const rb_method_type_t_VM_METHOD_TYPE_ALIAS: rb_method_type_t = 6;
897pub const rb_method_type_t_VM_METHOD_TYPE_UNDEF: rb_method_type_t = 7;
898pub const rb_method_type_t_VM_METHOD_TYPE_NOTIMPLEMENTED: rb_method_type_t = 8;
899pub const rb_method_type_t_VM_METHOD_TYPE_OPTIMIZED: rb_method_type_t = 9;
900pub const rb_method_type_t_VM_METHOD_TYPE_MISSING: rb_method_type_t = 10;
901pub const rb_method_type_t_VM_METHOD_TYPE_REFINED: rb_method_type_t = 11;
902pub type rb_method_type_t = ::std::os::raw::c_uint;
903pub type rb_iseq_t = rb_iseq_struct;
904#[repr(C)]
905#[derive(Debug, Copy, Clone)]
906pub struct rb_method_iseq_struct {
907 pub iseqptr: *const rb_iseq_t,
908 pub cref: *mut rb_cref_t,
909}
910pub type rb_method_iseq_t = rb_method_iseq_struct;
911#[repr(C)]
912#[derive(Debug, Copy, Clone)]
913pub struct rb_method_cfunc_struct {
914 pub func: ::std::option::Option<unsafe extern "C" fn() -> VALUE>,
915 pub invoker: ::std::option::Option<
916 unsafe extern "C" fn(
917 recv: VALUE,
918 argc: ::std::os::raw::c_int,
919 argv: *const VALUE,
920 func: ::std::option::Option<unsafe extern "C" fn() -> VALUE>,
921 ) -> VALUE,
922 >,
923 pub argc: ::std::os::raw::c_int,
924}
925pub type rb_method_cfunc_t = rb_method_cfunc_struct;
926#[repr(C)]
927#[derive(Debug, Copy, Clone)]
928pub struct rb_method_attr_struct {
929 pub id: ID,
930 pub location: VALUE,
931}
932pub type rb_method_attr_t = rb_method_attr_struct;
933#[repr(C)]
934#[derive(Debug, Copy, Clone)]
935pub struct rb_method_alias_struct {
936 pub original_me: *mut rb_method_entry_struct,
937}
938pub type rb_method_alias_t = rb_method_alias_struct;
939#[repr(C)]
940#[derive(Debug, Copy, Clone)]
941pub struct rb_method_refined_struct {
942 pub orig_me: *mut rb_method_entry_struct,
943 pub owner: VALUE,
944}
945pub type rb_method_refined_t = rb_method_refined_struct;
946#[repr(C)]
947#[derive(Debug, Copy, Clone)]
948pub struct rb_method_bmethod_struct {
949 pub proc_: VALUE,
950 pub hooks: *mut rb_hook_list_struct,
951 pub defined_ractor: VALUE,
952}
953pub type rb_method_bmethod_t = rb_method_bmethod_struct;
954pub const method_optimized_type_OPTIMIZED_METHOD_TYPE_SEND: method_optimized_type = 0;
955pub const method_optimized_type_OPTIMIZED_METHOD_TYPE_CALL: method_optimized_type = 1;
956pub const method_optimized_type_OPTIMIZED_METHOD_TYPE_BLOCK_CALL: method_optimized_type = 2;
957pub const method_optimized_type_OPTIMIZED_METHOD_TYPE_STRUCT_AREF: method_optimized_type = 3;
958pub const method_optimized_type_OPTIMIZED_METHOD_TYPE_STRUCT_ASET: method_optimized_type = 4;
959pub const method_optimized_type_OPTIMIZED_METHOD_TYPE__MAX: method_optimized_type = 5;
960pub type method_optimized_type = ::std::os::raw::c_uint;
961#[repr(C)]
962#[derive(Debug, Copy, Clone)]
963pub struct rb_method_optimized {
964 pub type_: method_optimized_type,
965 pub index: ::std::os::raw::c_uint,
966}
967pub type rb_method_optimized_t = rb_method_optimized;
968#[repr(C)]
969#[derive(Copy, Clone)]
970pub struct rb_method_definition_struct {
971 pub _bitfield_align_1: [u32; 0],
972 pub _bitfield_1: __BindgenBitfieldUnit<[u8; 8usize]>,
973 pub body: rb_method_definition_struct__bindgen_ty_1,
974 pub original_id: ID,
975 pub method_serial: usize,
976}
977#[repr(C)]
978#[derive(Copy, Clone)]
979pub union rb_method_definition_struct__bindgen_ty_1 {
980 pub iseq: rb_method_iseq_t,
981 pub cfunc: rb_method_cfunc_t,
982 pub attr: rb_method_attr_t,
983 pub alias: rb_method_alias_t,
984 pub refined: rb_method_refined_t,
985 pub bmethod: rb_method_bmethod_t,
986 pub optimized: rb_method_optimized_t,
987}
988impl ::std::fmt::Debug for rb_method_definition_struct__bindgen_ty_1 {
989 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
990 write!(f, "rb_method_definition_struct__bindgen_ty_1 {{ union }}")
991 }
992}
993impl rb_method_definition_struct {
994 #[inline]
995 pub fn type_(&self) -> rb_method_type_t {
996 unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 4u8) as u32) }
997 }
998 #[inline]
999 pub fn set_type(&mut self, val: rb_method_type_t) {
1000 unsafe {
1001 let val: u32 = ::std::mem::transmute(val);
1002 self._bitfield_1.set(0usize, 4u8, val as u64)
1003 }
1004 }
1005 #[inline]
1006 pub unsafe fn type__raw(this: *const Self) -> rb_method_type_t {
1007 unsafe {
1008 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 8usize]>>::raw_get(
1009 ::std::ptr::addr_of!((*this)._bitfield_1),
1010 0usize,
1011 4u8,
1012 ) as u32)
1013 }
1014 }
1015 #[inline]
1016 pub unsafe fn set_type_raw(this: *mut Self, val: rb_method_type_t) {
1017 unsafe {
1018 let val: u32 = ::std::mem::transmute(val);
1019 <__BindgenBitfieldUnit<[u8; 8usize]>>::raw_set(
1020 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1021 0usize,
1022 4u8,
1023 val as u64,
1024 )
1025 }
1026 }
1027 #[inline]
1028 pub fn iseq_overload(&self) -> ::std::os::raw::c_uint {
1029 unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
1030 }
1031 #[inline]
1032 pub fn set_iseq_overload(&mut self, val: ::std::os::raw::c_uint) {
1033 unsafe {
1034 let val: u32 = ::std::mem::transmute(val);
1035 self._bitfield_1.set(4usize, 1u8, val as u64)
1036 }
1037 }
1038 #[inline]
1039 pub unsafe fn iseq_overload_raw(this: *const Self) -> ::std::os::raw::c_uint {
1040 unsafe {
1041 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 8usize]>>::raw_get(
1042 ::std::ptr::addr_of!((*this)._bitfield_1),
1043 4usize,
1044 1u8,
1045 ) as u32)
1046 }
1047 }
1048 #[inline]
1049 pub unsafe fn set_iseq_overload_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1050 unsafe {
1051 let val: u32 = ::std::mem::transmute(val);
1052 <__BindgenBitfieldUnit<[u8; 8usize]>>::raw_set(
1053 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1054 4usize,
1055 1u8,
1056 val as u64,
1057 )
1058 }
1059 }
1060 #[inline]
1061 pub fn no_redef_warning(&self) -> ::std::os::raw::c_uint {
1062 unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
1063 }
1064 #[inline]
1065 pub fn set_no_redef_warning(&mut self, val: ::std::os::raw::c_uint) {
1066 unsafe {
1067 let val: u32 = ::std::mem::transmute(val);
1068 self._bitfield_1.set(5usize, 1u8, val as u64)
1069 }
1070 }
1071 #[inline]
1072 pub unsafe fn no_redef_warning_raw(this: *const Self) -> ::std::os::raw::c_uint {
1073 unsafe {
1074 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 8usize]>>::raw_get(
1075 ::std::ptr::addr_of!((*this)._bitfield_1),
1076 5usize,
1077 1u8,
1078 ) as u32)
1079 }
1080 }
1081 #[inline]
1082 pub unsafe fn set_no_redef_warning_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1083 unsafe {
1084 let val: u32 = ::std::mem::transmute(val);
1085 <__BindgenBitfieldUnit<[u8; 8usize]>>::raw_set(
1086 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1087 5usize,
1088 1u8,
1089 val as u64,
1090 )
1091 }
1092 }
1093 #[inline]
1094 pub fn aliased(&self) -> ::std::os::raw::c_uint {
1095 unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
1096 }
1097 #[inline]
1098 pub fn set_aliased(&mut self, val: ::std::os::raw::c_uint) {
1099 unsafe {
1100 let val: u32 = ::std::mem::transmute(val);
1101 self._bitfield_1.set(6usize, 1u8, val as u64)
1102 }
1103 }
1104 #[inline]
1105 pub unsafe fn aliased_raw(this: *const Self) -> ::std::os::raw::c_uint {
1106 unsafe {
1107 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 8usize]>>::raw_get(
1108 ::std::ptr::addr_of!((*this)._bitfield_1),
1109 6usize,
1110 1u8,
1111 ) as u32)
1112 }
1113 }
1114 #[inline]
1115 pub unsafe fn set_aliased_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1116 unsafe {
1117 let val: u32 = ::std::mem::transmute(val);
1118 <__BindgenBitfieldUnit<[u8; 8usize]>>::raw_set(
1119 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1120 6usize,
1121 1u8,
1122 val as u64,
1123 )
1124 }
1125 }
1126 #[inline]
1127 pub fn reference_count(&self) -> ::std::os::raw::c_int {
1128 unsafe { ::std::mem::transmute(self._bitfield_1.get(32usize, 28u8) as u32) }
1129 }
1130 #[inline]
1131 pub fn set_reference_count(&mut self, val: ::std::os::raw::c_int) {
1132 unsafe {
1133 let val: u32 = ::std::mem::transmute(val);
1134 self._bitfield_1.set(32usize, 28u8, val as u64)
1135 }
1136 }
1137 #[inline]
1138 pub unsafe fn reference_count_raw(this: *const Self) -> ::std::os::raw::c_int {
1139 unsafe {
1140 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 8usize]>>::raw_get(
1141 ::std::ptr::addr_of!((*this)._bitfield_1),
1142 32usize,
1143 28u8,
1144 ) as u32)
1145 }
1146 }
1147 #[inline]
1148 pub unsafe fn set_reference_count_raw(this: *mut Self, val: ::std::os::raw::c_int) {
1149 unsafe {
1150 let val: u32 = ::std::mem::transmute(val);
1151 <__BindgenBitfieldUnit<[u8; 8usize]>>::raw_set(
1152 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1153 32usize,
1154 28u8,
1155 val as u64,
1156 )
1157 }
1158 }
1159 #[inline]
1160 pub fn new_bitfield_1(
1161 type_: rb_method_type_t,
1162 iseq_overload: ::std::os::raw::c_uint,
1163 no_redef_warning: ::std::os::raw::c_uint,
1164 aliased: ::std::os::raw::c_uint,
1165 reference_count: ::std::os::raw::c_int,
1166 ) -> __BindgenBitfieldUnit<[u8; 8usize]> {
1167 let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 8usize]> = Default::default();
1168 __bindgen_bitfield_unit.set(0usize, 4u8, {
1169 let type_: u32 = unsafe { ::std::mem::transmute(type_) };
1170 type_ as u64
1171 });
1172 __bindgen_bitfield_unit.set(4usize, 1u8, {
1173 let iseq_overload: u32 = unsafe { ::std::mem::transmute(iseq_overload) };
1174 iseq_overload as u64
1175 });
1176 __bindgen_bitfield_unit.set(5usize, 1u8, {
1177 let no_redef_warning: u32 = unsafe { ::std::mem::transmute(no_redef_warning) };
1178 no_redef_warning as u64
1179 });
1180 __bindgen_bitfield_unit.set(6usize, 1u8, {
1181 let aliased: u32 = unsafe { ::std::mem::transmute(aliased) };
1182 aliased as u64
1183 });
1184 __bindgen_bitfield_unit.set(32usize, 28u8, {
1185 let reference_count: u32 = unsafe { ::std::mem::transmute(reference_count) };
1186 reference_count as u64
1187 });
1188 __bindgen_bitfield_unit
1189 }
1190}
1191#[repr(C)]
1192#[derive(Debug, Copy, Clone)]
1193pub struct rb_id_table {
1194 _unused: [u8; 0],
1195}
1196#[repr(C)]
1197#[derive(Debug, Copy, Clone)]
1198pub struct rb_code_position_struct {
1199 pub lineno: ::std::os::raw::c_int,
1200 pub column: ::std::os::raw::c_int,
1201}
1202pub type rb_code_position_t = rb_code_position_struct;
1203#[repr(C)]
1204#[derive(Debug, Copy, Clone)]
1205pub struct rb_code_location_struct {
1206 pub beg_pos: rb_code_position_t,
1207 pub end_pos: rb_code_position_t,
1208}
1209pub type rb_code_location_t = rb_code_location_struct;
1210#[repr(C)]
1211#[derive(Debug)]
1212pub struct rb_ast_id_table {
1213 pub size: ::std::os::raw::c_int,
1214 pub ids: __IncompleteArrayField<ID>,
1215}
1216pub type rb_ast_id_table_t = rb_ast_id_table;
1217#[repr(C)]
1218#[derive(Copy, Clone)]
1219pub struct RNode {
1220 pub flags: VALUE,
1221 pub u1: RNode__bindgen_ty_1,
1222 pub u2: RNode__bindgen_ty_2,
1223 pub u3: RNode__bindgen_ty_3,
1224 pub nd_loc: rb_code_location_t,
1225 pub node_id: ::std::os::raw::c_int,
1226}
1227#[repr(C)]
1228#[derive(Copy, Clone)]
1229pub union RNode__bindgen_ty_1 {
1230 pub node: *mut RNode,
1231 pub id: ID,
1232 pub value: VALUE,
1233 pub tbl: *mut rb_ast_id_table_t,
1234}
1235impl ::std::fmt::Debug for RNode__bindgen_ty_1 {
1236 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1237 write!(f, "RNode__bindgen_ty_1 {{ union }}")
1238 }
1239}
1240#[repr(C)]
1241#[derive(Copy, Clone)]
1242pub union RNode__bindgen_ty_2 {
1243 pub node: *mut RNode,
1244 pub id: ID,
1245 pub argc: ::std::os::raw::c_long,
1246 pub value: VALUE,
1247}
1248impl ::std::fmt::Debug for RNode__bindgen_ty_2 {
1249 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1250 write!(f, "RNode__bindgen_ty_2 {{ union }}")
1251 }
1252}
1253#[repr(C)]
1254#[derive(Copy, Clone)]
1255pub union RNode__bindgen_ty_3 {
1256 pub node: *mut RNode,
1257 pub id: ID,
1258 pub state: ::std::os::raw::c_long,
1259 pub args: *mut rb_args_info,
1260 pub apinfo: *mut rb_ary_pattern_info,
1261 pub fpinfo: *mut rb_fnd_pattern_info,
1262 pub value: VALUE,
1263}
1264impl ::std::fmt::Debug for RNode__bindgen_ty_3 {
1265 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1266 write!(f, "RNode__bindgen_ty_3 {{ union }}")
1267 }
1268}
1269impl ::std::fmt::Debug for RNode {
1270 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1271 write!(
1272 f,
1273 "RNode {{ flags: {:?}, u1: {:?}, u2: {:?}, u3: {:?}, nd_loc: {:?}, node_id: {:?} }}",
1274 self.flags, self.u1, self.u2, self.u3, self.nd_loc, self.node_id
1275 )
1276 }
1277}
1278pub type NODE = RNode;
1279#[repr(C)]
1280#[derive(Debug, Copy, Clone)]
1281pub struct rb_args_info {
1282 pub pre_init: *mut NODE,
1283 pub post_init: *mut NODE,
1284 pub pre_args_num: ::std::os::raw::c_int,
1285 pub post_args_num: ::std::os::raw::c_int,
1286 pub first_post_arg: ID,
1287 pub rest_arg: ID,
1288 pub block_arg: ID,
1289 pub kw_args: *mut NODE,
1290 pub kw_rest_arg: *mut NODE,
1291 pub opt_args: *mut NODE,
1292 pub _bitfield_align_1: [u8; 0],
1293 pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
1294 pub imemo: VALUE,
1295}
1296impl rb_args_info {
1297 #[inline]
1298 pub fn no_kwarg(&self) -> ::std::os::raw::c_uint {
1299 unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
1300 }
1301 #[inline]
1302 pub fn set_no_kwarg(&mut self, val: ::std::os::raw::c_uint) {
1303 unsafe {
1304 let val: u32 = ::std::mem::transmute(val);
1305 self._bitfield_1.set(0usize, 1u8, val as u64)
1306 }
1307 }
1308 #[inline]
1309 pub unsafe fn no_kwarg_raw(this: *const Self) -> ::std::os::raw::c_uint {
1310 unsafe {
1311 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
1312 ::std::ptr::addr_of!((*this)._bitfield_1),
1313 0usize,
1314 1u8,
1315 ) as u32)
1316 }
1317 }
1318 #[inline]
1319 pub unsafe fn set_no_kwarg_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1320 unsafe {
1321 let val: u32 = ::std::mem::transmute(val);
1322 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
1323 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1324 0usize,
1325 1u8,
1326 val as u64,
1327 )
1328 }
1329 }
1330 #[inline]
1331 pub fn ruby2_keywords(&self) -> ::std::os::raw::c_uint {
1332 unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
1333 }
1334 #[inline]
1335 pub fn set_ruby2_keywords(&mut self, val: ::std::os::raw::c_uint) {
1336 unsafe {
1337 let val: u32 = ::std::mem::transmute(val);
1338 self._bitfield_1.set(1usize, 1u8, val as u64)
1339 }
1340 }
1341 #[inline]
1342 pub unsafe fn ruby2_keywords_raw(this: *const Self) -> ::std::os::raw::c_uint {
1343 unsafe {
1344 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
1345 ::std::ptr::addr_of!((*this)._bitfield_1),
1346 1usize,
1347 1u8,
1348 ) as u32)
1349 }
1350 }
1351 #[inline]
1352 pub unsafe fn set_ruby2_keywords_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1353 unsafe {
1354 let val: u32 = ::std::mem::transmute(val);
1355 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
1356 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1357 1usize,
1358 1u8,
1359 val as u64,
1360 )
1361 }
1362 }
1363 #[inline]
1364 pub fn forwarding(&self) -> ::std::os::raw::c_uint {
1365 unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
1366 }
1367 #[inline]
1368 pub fn set_forwarding(&mut self, val: ::std::os::raw::c_uint) {
1369 unsafe {
1370 let val: u32 = ::std::mem::transmute(val);
1371 self._bitfield_1.set(2usize, 1u8, val as u64)
1372 }
1373 }
1374 #[inline]
1375 pub unsafe fn forwarding_raw(this: *const Self) -> ::std::os::raw::c_uint {
1376 unsafe {
1377 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
1378 ::std::ptr::addr_of!((*this)._bitfield_1),
1379 2usize,
1380 1u8,
1381 ) as u32)
1382 }
1383 }
1384 #[inline]
1385 pub unsafe fn set_forwarding_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1386 unsafe {
1387 let val: u32 = ::std::mem::transmute(val);
1388 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
1389 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1390 2usize,
1391 1u8,
1392 val as u64,
1393 )
1394 }
1395 }
1396 #[inline]
1397 pub fn new_bitfield_1(
1398 no_kwarg: ::std::os::raw::c_uint,
1399 ruby2_keywords: ::std::os::raw::c_uint,
1400 forwarding: ::std::os::raw::c_uint,
1401 ) -> __BindgenBitfieldUnit<[u8; 1usize]> {
1402 let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
1403 __bindgen_bitfield_unit.set(0usize, 1u8, {
1404 let no_kwarg: u32 = unsafe { ::std::mem::transmute(no_kwarg) };
1405 no_kwarg as u64
1406 });
1407 __bindgen_bitfield_unit.set(1usize, 1u8, {
1408 let ruby2_keywords: u32 = unsafe { ::std::mem::transmute(ruby2_keywords) };
1409 ruby2_keywords as u64
1410 });
1411 __bindgen_bitfield_unit.set(2usize, 1u8, {
1412 let forwarding: u32 = unsafe { ::std::mem::transmute(forwarding) };
1413 forwarding as u64
1414 });
1415 __bindgen_bitfield_unit
1416 }
1417}
1418#[repr(C)]
1419#[derive(Debug, Copy, Clone)]
1420pub struct rb_ary_pattern_info {
1421 pub pre_args: *mut NODE,
1422 pub rest_arg: *mut NODE,
1423 pub post_args: *mut NODE,
1424}
1425#[repr(C)]
1426#[derive(Debug, Copy, Clone)]
1427pub struct rb_fnd_pattern_info {
1428 pub pre_rest_arg: *mut NODE,
1429 pub args: *mut NODE,
1430 pub post_rest_arg: *mut NODE,
1431}
1432pub type rb_atomic_t = ::std::os::raw::c_uint;
1433pub type attr_index_t = u32;
1434pub type shape_id_t = u32;
1435#[repr(C)]
1436#[derive(Debug, Copy, Clone)]
1437pub struct rb_shape {
1438 pub edges: *mut rb_id_table,
1439 pub edge_name: ID,
1440 pub next_iv_index: attr_index_t,
1441 pub capacity: u32,
1442 pub type_: u8,
1443 pub size_pool_index: u8,
1444 pub parent_id: shape_id_t,
1445}
1446pub type rb_shape_t = rb_shape;
1447pub type rb_nativethread_id_t = pthread_t;
1448pub type rb_nativethread_lock_t = pthread_mutex_t;
1449pub type rb_nativethread_cond_t = pthread_cond_t;
1450#[repr(C)]
1451#[derive(Copy, Clone)]
1452pub struct rb_thread_sched_item {
1453 pub node: rb_thread_sched_item__bindgen_ty_1,
1454}
1455#[repr(C)]
1456#[derive(Copy, Clone)]
1457pub union rb_thread_sched_item__bindgen_ty_1 {
1458 pub ubf: ccan_list_node,
1459 pub readyq: ccan_list_node,
1460}
1461impl ::std::fmt::Debug for rb_thread_sched_item__bindgen_ty_1 {
1462 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1463 write!(f, "rb_thread_sched_item__bindgen_ty_1 {{ union }}")
1464 }
1465}
1466impl ::std::fmt::Debug for rb_thread_sched_item {
1467 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1468 write!(f, "rb_thread_sched_item {{ node: {:?} }}", self.node)
1469 }
1470}
1471#[repr(C)]
1472#[derive(Copy, Clone)]
1473pub struct rb_native_thread {
1474 pub id: ::std::os::raw::c_int,
1475 pub thread_id: rb_nativethread_id_t,
1476 pub tid: ::std::os::raw::c_int,
1477 pub running_thread: *mut rb_thread_struct,
1478 pub cond: rb_native_thread__bindgen_ty_1,
1479 pub altstack: *mut ::std::os::raw::c_void,
1480}
1481#[repr(C)]
1482#[derive(Copy, Clone)]
1483pub union rb_native_thread__bindgen_ty_1 {
1484 pub intr: rb_nativethread_cond_t,
1485 pub readyq: rb_nativethread_cond_t,
1486}
1487impl ::std::fmt::Debug for rb_native_thread__bindgen_ty_1 {
1488 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1489 write!(f, "rb_native_thread__bindgen_ty_1 {{ union }}")
1490 }
1491}
1492impl ::std::fmt::Debug for rb_native_thread {
1493 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1494 write ! (f , "rb_native_thread {{ id: {:?}, thread_id: {:?}, tid: {:?}, running_thread: {:?}, cond: {:?}, altstack: {:?} }}" , self . id , self . thread_id , self . tid , self . running_thread , self . cond , self . altstack)
1495 }
1496}
1497#[repr(C)]
1498#[derive(Copy, Clone)]
1499pub struct rb_thread_sched {
1500 pub running: *const rb_thread_struct,
1501 pub lock: rb_nativethread_lock_t,
1502 pub readyq: ccan_list_head,
1503 pub timer: *const rb_thread_struct,
1504 pub timer_err: ::std::os::raw::c_int,
1505 pub switch_cond: rb_nativethread_cond_t,
1506 pub switch_wait_cond: rb_nativethread_cond_t,
1507 pub need_yield: ::std::os::raw::c_int,
1508 pub wait_yield: ::std::os::raw::c_int,
1509}
1510impl ::std::fmt::Debug for rb_thread_sched {
1511 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1512 write ! (f , "rb_thread_sched {{ running: {:?}, lock: {:?}, readyq: {:?}, timer: {:?}, timer_err: {:?}, switch_cond: {:?}, switch_wait_cond: {:?}, need_yield: {:?}, wait_yield: {:?} }}" , self . running , self . lock , self . readyq , self . timer , self . timer_err , self . switch_cond , self . switch_wait_cond , self . need_yield , self . wait_yield)
1513 }
1514}
1515pub type rb_snum_t = ::std::os::raw::c_long;
1516pub const ruby_tag_type_RUBY_TAG_NONE: ruby_tag_type = 0;
1517pub const ruby_tag_type_RUBY_TAG_RETURN: ruby_tag_type = 1;
1518pub const ruby_tag_type_RUBY_TAG_BREAK: ruby_tag_type = 2;
1519pub const ruby_tag_type_RUBY_TAG_NEXT: ruby_tag_type = 3;
1520pub const ruby_tag_type_RUBY_TAG_RETRY: ruby_tag_type = 4;
1521pub const ruby_tag_type_RUBY_TAG_REDO: ruby_tag_type = 5;
1522pub const ruby_tag_type_RUBY_TAG_RAISE: ruby_tag_type = 6;
1523pub const ruby_tag_type_RUBY_TAG_THROW: ruby_tag_type = 7;
1524pub const ruby_tag_type_RUBY_TAG_FATAL: ruby_tag_type = 8;
1525pub const ruby_tag_type_RUBY_TAG_MASK: ruby_tag_type = 15;
1526pub type ruby_tag_type = ::std::os::raw::c_uint;
1527pub type rb_compile_option_t = rb_compile_option_struct;
1528#[repr(C)]
1529#[derive(Debug, Copy, Clone)]
1530pub struct iseq_inline_constant_cache_entry {
1531 pub flags: VALUE,
1532 pub value: VALUE,
1533 pub _unused1: VALUE,
1534 pub _unused2: VALUE,
1535 pub ic_cref: *const rb_cref_t,
1536}
1537#[repr(C)]
1538#[derive(Debug, Copy, Clone)]
1539pub struct iseq_inline_constant_cache {
1540 pub entry: *mut iseq_inline_constant_cache_entry,
1541 pub segments: *const ID,
1542}
1543#[repr(C)]
1544#[derive(Debug, Copy, Clone)]
1545pub struct iseq_inline_iv_cache_entry {
1546 pub value: usize,
1547 pub iv_set_name: ID,
1548}
1549#[repr(C)]
1550#[derive(Copy, Clone)]
1551pub union iseq_inline_storage_entry {
1552 pub once: iseq_inline_storage_entry__bindgen_ty_1,
1553 pub ic_cache: iseq_inline_constant_cache,
1554 pub iv_cache: iseq_inline_iv_cache_entry,
1555}
1556#[repr(C)]
1557#[derive(Debug, Copy, Clone)]
1558pub struct iseq_inline_storage_entry__bindgen_ty_1 {
1559 pub running_thread: *mut rb_thread_struct,
1560 pub value: VALUE,
1561}
1562impl ::std::fmt::Debug for iseq_inline_storage_entry {
1563 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
1564 write!(f, "iseq_inline_storage_entry {{ union }}")
1565 }
1566}
1567#[repr(C)]
1568#[derive(Debug, Copy, Clone)]
1569pub struct rb_calling_info {
1570 pub ci: *const rb_callinfo,
1571 pub cc: *const rb_callcache,
1572 pub block_handler: VALUE,
1573 pub recv: VALUE,
1574 pub argc: ::std::os::raw::c_int,
1575 pub kw_splat: ::std::os::raw::c_int,
1576}
1577#[repr(C)]
1578#[derive(Debug, Copy, Clone)]
1579pub struct rb_iseq_location_struct {
1580 pub pathobj: VALUE,
1581 pub base_label: VALUE,
1582 pub label: VALUE,
1583 pub first_lineno: ::std::os::raw::c_int,
1584 pub node_id: ::std::os::raw::c_int,
1585 pub code_location: rb_code_location_t,
1586}
1587pub type rb_iseq_location_t = rb_iseq_location_struct;
1588#[repr(C)]
1589#[derive(Debug, Copy, Clone)]
1590pub struct rb_mjit_unit {
1591 _unused: [u8; 0],
1592}
1593pub type iseq_bits_t = usize;
1594pub const rb_iseq_type_ISEQ_TYPE_TOP: rb_iseq_type = 0;
1595pub const rb_iseq_type_ISEQ_TYPE_METHOD: rb_iseq_type = 1;
1596pub const rb_iseq_type_ISEQ_TYPE_BLOCK: rb_iseq_type = 2;
1597pub const rb_iseq_type_ISEQ_TYPE_CLASS: rb_iseq_type = 3;
1598pub const rb_iseq_type_ISEQ_TYPE_RESCUE: rb_iseq_type = 4;
1599pub const rb_iseq_type_ISEQ_TYPE_ENSURE: rb_iseq_type = 5;
1600pub const rb_iseq_type_ISEQ_TYPE_EVAL: rb_iseq_type = 6;
1601pub const rb_iseq_type_ISEQ_TYPE_MAIN: rb_iseq_type = 7;
1602pub const rb_iseq_type_ISEQ_TYPE_PLAIN: rb_iseq_type = 8;
1603pub type rb_iseq_type = ::std::os::raw::c_uint;
1604#[repr(C)]
1605#[derive(Copy, Clone)]
1606pub struct rb_iseq_constant_body {
1607 pub type_: rb_iseq_type,
1608 pub iseq_size: ::std::os::raw::c_uint,
1609 pub iseq_encoded: *mut VALUE,
1610 pub param: rb_iseq_constant_body__bindgen_ty_1,
1611 pub location: rb_iseq_location_t,
1612 pub insns_info: rb_iseq_constant_body_iseq_insn_info,
1613 pub local_table: *const ID,
1614 pub catch_table: *mut iseq_catch_table,
1615 pub parent_iseq: *const rb_iseq_struct,
1616 pub local_iseq: *mut rb_iseq_struct,
1617 pub is_entries: *mut iseq_inline_storage_entry,
1618 pub call_data: *mut rb_call_data,
1619 pub variable: rb_iseq_constant_body__bindgen_ty_2,
1620 pub local_table_size: ::std::os::raw::c_uint,
1621 pub ic_size: ::std::os::raw::c_uint,
1622 pub ise_size: ::std::os::raw::c_uint,
1623 pub ivc_size: ::std::os::raw::c_uint,
1624 pub icvarc_size: ::std::os::raw::c_uint,
1625 pub ci_size: ::std::os::raw::c_uint,
1626 pub stack_max: ::std::os::raw::c_uint,
1627 pub catch_except_p: bool,
1628 pub builtin_inline_p: bool,
1629 pub mark_bits: rb_iseq_constant_body__bindgen_ty_3,
1630 pub outer_variables: *mut rb_id_table,
1631 pub mandatory_only_iseq: *const rb_iseq_t,
1632 pub jit_func: ::std::option::Option<
1633 unsafe extern "C" fn(
1634 arg1: *mut rb_execution_context_struct,
1635 arg2: *mut rb_control_frame_struct,
1636 ) -> VALUE,
1637 >,
1638 pub total_calls: ::std::os::raw::c_ulong,
1639 pub mjit_unit: *mut rb_mjit_unit,
1640 pub yjit_payload: *mut ::std::os::raw::c_void,
1641}
1642#[repr(C)]
1643#[derive(Debug, Copy, Clone)]
1644pub struct rb_iseq_constant_body__bindgen_ty_1 {
1645 pub flags: rb_iseq_constant_body__bindgen_ty_1__bindgen_ty_1,
1646 pub size: ::std::os::raw::c_uint,
1647 pub lead_num: ::std::os::raw::c_int,
1648 pub opt_num: ::std::os::raw::c_int,
1649 pub rest_start: ::std::os::raw::c_int,
1650 pub post_start: ::std::os::raw::c_int,
1651 pub post_num: ::std::os::raw::c_int,
1652 pub block_start: ::std::os::raw::c_int,
1653 pub opt_table: *const VALUE,
1654 pub keyword: *const rb_iseq_constant_body__bindgen_ty_1_rb_iseq_param_keyword,
1655}
1656#[repr(C)]
1657#[repr(align(4))]
1658#[derive(Debug, Copy, Clone)]
1659pub struct rb_iseq_constant_body__bindgen_ty_1__bindgen_ty_1 {
1660 pub _bitfield_align_1: [u8; 0],
1661 pub _bitfield_1: __BindgenBitfieldUnit<[u8; 2usize]>,
1662 pub __bindgen_padding_0: u16,
1663}
1664impl rb_iseq_constant_body__bindgen_ty_1__bindgen_ty_1 {
1665 #[inline]
1666 pub fn has_lead(&self) -> ::std::os::raw::c_uint {
1667 unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
1668 }
1669 #[inline]
1670 pub fn set_has_lead(&mut self, val: ::std::os::raw::c_uint) {
1671 unsafe {
1672 let val: u32 = ::std::mem::transmute(val);
1673 self._bitfield_1.set(0usize, 1u8, val as u64)
1674 }
1675 }
1676 #[inline]
1677 pub unsafe fn has_lead_raw(this: *const Self) -> ::std::os::raw::c_uint {
1678 unsafe {
1679 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1680 ::std::ptr::addr_of!((*this)._bitfield_1),
1681 0usize,
1682 1u8,
1683 ) as u32)
1684 }
1685 }
1686 #[inline]
1687 pub unsafe fn set_has_lead_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1688 unsafe {
1689 let val: u32 = ::std::mem::transmute(val);
1690 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1691 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1692 0usize,
1693 1u8,
1694 val as u64,
1695 )
1696 }
1697 }
1698 #[inline]
1699 pub fn has_opt(&self) -> ::std::os::raw::c_uint {
1700 unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
1701 }
1702 #[inline]
1703 pub fn set_has_opt(&mut self, val: ::std::os::raw::c_uint) {
1704 unsafe {
1705 let val: u32 = ::std::mem::transmute(val);
1706 self._bitfield_1.set(1usize, 1u8, val as u64)
1707 }
1708 }
1709 #[inline]
1710 pub unsafe fn has_opt_raw(this: *const Self) -> ::std::os::raw::c_uint {
1711 unsafe {
1712 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1713 ::std::ptr::addr_of!((*this)._bitfield_1),
1714 1usize,
1715 1u8,
1716 ) as u32)
1717 }
1718 }
1719 #[inline]
1720 pub unsafe fn set_has_opt_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1721 unsafe {
1722 let val: u32 = ::std::mem::transmute(val);
1723 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1724 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1725 1usize,
1726 1u8,
1727 val as u64,
1728 )
1729 }
1730 }
1731 #[inline]
1732 pub fn has_rest(&self) -> ::std::os::raw::c_uint {
1733 unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
1734 }
1735 #[inline]
1736 pub fn set_has_rest(&mut self, val: ::std::os::raw::c_uint) {
1737 unsafe {
1738 let val: u32 = ::std::mem::transmute(val);
1739 self._bitfield_1.set(2usize, 1u8, val as u64)
1740 }
1741 }
1742 #[inline]
1743 pub unsafe fn has_rest_raw(this: *const Self) -> ::std::os::raw::c_uint {
1744 unsafe {
1745 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1746 ::std::ptr::addr_of!((*this)._bitfield_1),
1747 2usize,
1748 1u8,
1749 ) as u32)
1750 }
1751 }
1752 #[inline]
1753 pub unsafe fn set_has_rest_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1754 unsafe {
1755 let val: u32 = ::std::mem::transmute(val);
1756 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1757 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1758 2usize,
1759 1u8,
1760 val as u64,
1761 )
1762 }
1763 }
1764 #[inline]
1765 pub fn has_post(&self) -> ::std::os::raw::c_uint {
1766 unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
1767 }
1768 #[inline]
1769 pub fn set_has_post(&mut self, val: ::std::os::raw::c_uint) {
1770 unsafe {
1771 let val: u32 = ::std::mem::transmute(val);
1772 self._bitfield_1.set(3usize, 1u8, val as u64)
1773 }
1774 }
1775 #[inline]
1776 pub unsafe fn has_post_raw(this: *const Self) -> ::std::os::raw::c_uint {
1777 unsafe {
1778 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1779 ::std::ptr::addr_of!((*this)._bitfield_1),
1780 3usize,
1781 1u8,
1782 ) as u32)
1783 }
1784 }
1785 #[inline]
1786 pub unsafe fn set_has_post_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1787 unsafe {
1788 let val: u32 = ::std::mem::transmute(val);
1789 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1790 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1791 3usize,
1792 1u8,
1793 val as u64,
1794 )
1795 }
1796 }
1797 #[inline]
1798 pub fn has_kw(&self) -> ::std::os::raw::c_uint {
1799 unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
1800 }
1801 #[inline]
1802 pub fn set_has_kw(&mut self, val: ::std::os::raw::c_uint) {
1803 unsafe {
1804 let val: u32 = ::std::mem::transmute(val);
1805 self._bitfield_1.set(4usize, 1u8, val as u64)
1806 }
1807 }
1808 #[inline]
1809 pub unsafe fn has_kw_raw(this: *const Self) -> ::std::os::raw::c_uint {
1810 unsafe {
1811 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1812 ::std::ptr::addr_of!((*this)._bitfield_1),
1813 4usize,
1814 1u8,
1815 ) as u32)
1816 }
1817 }
1818 #[inline]
1819 pub unsafe fn set_has_kw_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1820 unsafe {
1821 let val: u32 = ::std::mem::transmute(val);
1822 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1823 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1824 4usize,
1825 1u8,
1826 val as u64,
1827 )
1828 }
1829 }
1830 #[inline]
1831 pub fn has_kwrest(&self) -> ::std::os::raw::c_uint {
1832 unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
1833 }
1834 #[inline]
1835 pub fn set_has_kwrest(&mut self, val: ::std::os::raw::c_uint) {
1836 unsafe {
1837 let val: u32 = ::std::mem::transmute(val);
1838 self._bitfield_1.set(5usize, 1u8, val as u64)
1839 }
1840 }
1841 #[inline]
1842 pub unsafe fn has_kwrest_raw(this: *const Self) -> ::std::os::raw::c_uint {
1843 unsafe {
1844 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1845 ::std::ptr::addr_of!((*this)._bitfield_1),
1846 5usize,
1847 1u8,
1848 ) as u32)
1849 }
1850 }
1851 #[inline]
1852 pub unsafe fn set_has_kwrest_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1853 unsafe {
1854 let val: u32 = ::std::mem::transmute(val);
1855 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1856 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1857 5usize,
1858 1u8,
1859 val as u64,
1860 )
1861 }
1862 }
1863 #[inline]
1864 pub fn has_block(&self) -> ::std::os::raw::c_uint {
1865 unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
1866 }
1867 #[inline]
1868 pub fn set_has_block(&mut self, val: ::std::os::raw::c_uint) {
1869 unsafe {
1870 let val: u32 = ::std::mem::transmute(val);
1871 self._bitfield_1.set(6usize, 1u8, val as u64)
1872 }
1873 }
1874 #[inline]
1875 pub unsafe fn has_block_raw(this: *const Self) -> ::std::os::raw::c_uint {
1876 unsafe {
1877 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1878 ::std::ptr::addr_of!((*this)._bitfield_1),
1879 6usize,
1880 1u8,
1881 ) as u32)
1882 }
1883 }
1884 #[inline]
1885 pub unsafe fn set_has_block_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1886 unsafe {
1887 let val: u32 = ::std::mem::transmute(val);
1888 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1889 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1890 6usize,
1891 1u8,
1892 val as u64,
1893 )
1894 }
1895 }
1896 #[inline]
1897 pub fn ambiguous_param0(&self) -> ::std::os::raw::c_uint {
1898 unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
1899 }
1900 #[inline]
1901 pub fn set_ambiguous_param0(&mut self, val: ::std::os::raw::c_uint) {
1902 unsafe {
1903 let val: u32 = ::std::mem::transmute(val);
1904 self._bitfield_1.set(7usize, 1u8, val as u64)
1905 }
1906 }
1907 #[inline]
1908 pub unsafe fn ambiguous_param0_raw(this: *const Self) -> ::std::os::raw::c_uint {
1909 unsafe {
1910 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1911 ::std::ptr::addr_of!((*this)._bitfield_1),
1912 7usize,
1913 1u8,
1914 ) as u32)
1915 }
1916 }
1917 #[inline]
1918 pub unsafe fn set_ambiguous_param0_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1919 unsafe {
1920 let val: u32 = ::std::mem::transmute(val);
1921 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1922 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1923 7usize,
1924 1u8,
1925 val as u64,
1926 )
1927 }
1928 }
1929 #[inline]
1930 pub fn accepts_no_kwarg(&self) -> ::std::os::raw::c_uint {
1931 unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 1u8) as u32) }
1932 }
1933 #[inline]
1934 pub fn set_accepts_no_kwarg(&mut self, val: ::std::os::raw::c_uint) {
1935 unsafe {
1936 let val: u32 = ::std::mem::transmute(val);
1937 self._bitfield_1.set(8usize, 1u8, val as u64)
1938 }
1939 }
1940 #[inline]
1941 pub unsafe fn accepts_no_kwarg_raw(this: *const Self) -> ::std::os::raw::c_uint {
1942 unsafe {
1943 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1944 ::std::ptr::addr_of!((*this)._bitfield_1),
1945 8usize,
1946 1u8,
1947 ) as u32)
1948 }
1949 }
1950 #[inline]
1951 pub unsafe fn set_accepts_no_kwarg_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1952 unsafe {
1953 let val: u32 = ::std::mem::transmute(val);
1954 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1955 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1956 8usize,
1957 1u8,
1958 val as u64,
1959 )
1960 }
1961 }
1962 #[inline]
1963 pub fn ruby2_keywords(&self) -> ::std::os::raw::c_uint {
1964 unsafe { ::std::mem::transmute(self._bitfield_1.get(9usize, 1u8) as u32) }
1965 }
1966 #[inline]
1967 pub fn set_ruby2_keywords(&mut self, val: ::std::os::raw::c_uint) {
1968 unsafe {
1969 let val: u32 = ::std::mem::transmute(val);
1970 self._bitfield_1.set(9usize, 1u8, val as u64)
1971 }
1972 }
1973 #[inline]
1974 pub unsafe fn ruby2_keywords_raw(this: *const Self) -> ::std::os::raw::c_uint {
1975 unsafe {
1976 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
1977 ::std::ptr::addr_of!((*this)._bitfield_1),
1978 9usize,
1979 1u8,
1980 ) as u32)
1981 }
1982 }
1983 #[inline]
1984 pub unsafe fn set_ruby2_keywords_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
1985 unsafe {
1986 let val: u32 = ::std::mem::transmute(val);
1987 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
1988 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
1989 9usize,
1990 1u8,
1991 val as u64,
1992 )
1993 }
1994 }
1995 #[inline]
1996 pub fn new_bitfield_1(
1997 has_lead: ::std::os::raw::c_uint,
1998 has_opt: ::std::os::raw::c_uint,
1999 has_rest: ::std::os::raw::c_uint,
2000 has_post: ::std::os::raw::c_uint,
2001 has_kw: ::std::os::raw::c_uint,
2002 has_kwrest: ::std::os::raw::c_uint,
2003 has_block: ::std::os::raw::c_uint,
2004 ambiguous_param0: ::std::os::raw::c_uint,
2005 accepts_no_kwarg: ::std::os::raw::c_uint,
2006 ruby2_keywords: ::std::os::raw::c_uint,
2007 ) -> __BindgenBitfieldUnit<[u8; 2usize]> {
2008 let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 2usize]> = Default::default();
2009 __bindgen_bitfield_unit.set(0usize, 1u8, {
2010 let has_lead: u32 = unsafe { ::std::mem::transmute(has_lead) };
2011 has_lead as u64
2012 });
2013 __bindgen_bitfield_unit.set(1usize, 1u8, {
2014 let has_opt: u32 = unsafe { ::std::mem::transmute(has_opt) };
2015 has_opt as u64
2016 });
2017 __bindgen_bitfield_unit.set(2usize, 1u8, {
2018 let has_rest: u32 = unsafe { ::std::mem::transmute(has_rest) };
2019 has_rest as u64
2020 });
2021 __bindgen_bitfield_unit.set(3usize, 1u8, {
2022 let has_post: u32 = unsafe { ::std::mem::transmute(has_post) };
2023 has_post as u64
2024 });
2025 __bindgen_bitfield_unit.set(4usize, 1u8, {
2026 let has_kw: u32 = unsafe { ::std::mem::transmute(has_kw) };
2027 has_kw as u64
2028 });
2029 __bindgen_bitfield_unit.set(5usize, 1u8, {
2030 let has_kwrest: u32 = unsafe { ::std::mem::transmute(has_kwrest) };
2031 has_kwrest as u64
2032 });
2033 __bindgen_bitfield_unit.set(6usize, 1u8, {
2034 let has_block: u32 = unsafe { ::std::mem::transmute(has_block) };
2035 has_block as u64
2036 });
2037 __bindgen_bitfield_unit.set(7usize, 1u8, {
2038 let ambiguous_param0: u32 = unsafe { ::std::mem::transmute(ambiguous_param0) };
2039 ambiguous_param0 as u64
2040 });
2041 __bindgen_bitfield_unit.set(8usize, 1u8, {
2042 let accepts_no_kwarg: u32 = unsafe { ::std::mem::transmute(accepts_no_kwarg) };
2043 accepts_no_kwarg as u64
2044 });
2045 __bindgen_bitfield_unit.set(9usize, 1u8, {
2046 let ruby2_keywords: u32 = unsafe { ::std::mem::transmute(ruby2_keywords) };
2047 ruby2_keywords as u64
2048 });
2049 __bindgen_bitfield_unit
2050 }
2051}
2052#[repr(C)]
2053#[derive(Debug, Copy, Clone)]
2054pub struct rb_iseq_constant_body__bindgen_ty_1_rb_iseq_param_keyword {
2055 pub num: ::std::os::raw::c_int,
2056 pub required_num: ::std::os::raw::c_int,
2057 pub bits_start: ::std::os::raw::c_int,
2058 pub rest_start: ::std::os::raw::c_int,
2059 pub table: *const ID,
2060 pub default_values: *mut VALUE,
2061}
2062#[repr(C)]
2063#[derive(Debug, Copy, Clone)]
2064pub struct rb_iseq_constant_body_iseq_insn_info {
2065 pub body: *const iseq_insn_info_entry,
2066 pub positions: *mut ::std::os::raw::c_uint,
2067 pub size: ::std::os::raw::c_uint,
2068 pub succ_index_table: *mut succ_index_table,
2069}
2070#[repr(C)]
2071#[derive(Debug, Copy, Clone)]
2072pub struct rb_iseq_constant_body__bindgen_ty_2 {
2073 pub flip_count: rb_snum_t,
2074 pub script_lines: VALUE,
2075 pub coverage: VALUE,
2076 pub pc2branchindex: VALUE,
2077 pub original_iseq: *mut VALUE,
2078}
2079#[repr(C)]
2080#[derive(Copy, Clone)]
2081pub union rb_iseq_constant_body__bindgen_ty_3 {
2082 pub list: *mut iseq_bits_t,
2083 pub single: iseq_bits_t,
2084}
2085impl ::std::fmt::Debug for rb_iseq_constant_body__bindgen_ty_3 {
2086 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2087 write!(f, "rb_iseq_constant_body__bindgen_ty_3 {{ union }}")
2088 }
2089}
2090impl ::std::fmt::Debug for rb_iseq_constant_body {
2091 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2092 write ! (f , "rb_iseq_constant_body {{ type: {:?}, iseq_size: {:?}, iseq_encoded: {:?}, param: {:?}, location: {:?}, insns_info: {:?}, local_table: {:?}, catch_table: {:?}, parent_iseq: {:?}, local_iseq: {:?}, is_entries: {:?}, call_data: {:?}, variable: {:?}, local_table_size: {:?}, ic_size: {:?}, ise_size: {:?}, ivc_size: {:?}, icvarc_size: {:?}, ci_size: {:?}, stack_max: {:?}, catch_except_p: {:?}, builtin_inline_p: {:?}, mark_bits: {:?}, outer_variables: {:?}, mandatory_only_iseq: {:?}, jit_func: {:?}, total_calls: {:?}, mjit_unit: {:?}, yjit_payload: {:?} }}" , self . type_ , self . iseq_size , self . iseq_encoded , self . param , self . location , self . insns_info , self . local_table , self . catch_table , self . parent_iseq , self . local_iseq , self . is_entries , self . call_data , self . variable , self . local_table_size , self . ic_size , self . ise_size , self . ivc_size , self . icvarc_size , self . ci_size , self . stack_max , self . catch_except_p , self . builtin_inline_p , self . mark_bits , self . outer_variables , self . mandatory_only_iseq , self . jit_func , self . total_calls , self . mjit_unit , self . yjit_payload)
2093 }
2094}
2095#[repr(C)]
2096#[derive(Copy, Clone)]
2097pub struct rb_iseq_struct {
2098 pub flags: VALUE,
2099 pub wrapper: VALUE,
2100 pub body: *mut rb_iseq_constant_body,
2101 pub aux: rb_iseq_struct__bindgen_ty_1,
2102}
2103#[repr(C)]
2104#[derive(Copy, Clone)]
2105pub union rb_iseq_struct__bindgen_ty_1 {
2106 pub compile_data: *mut iseq_compile_data,
2107 pub loader: rb_iseq_struct__bindgen_ty_1__bindgen_ty_1,
2108 pub exec: rb_iseq_struct__bindgen_ty_1__bindgen_ty_2,
2109}
2110#[repr(C)]
2111#[derive(Debug, Copy, Clone)]
2112pub struct rb_iseq_struct__bindgen_ty_1__bindgen_ty_1 {
2113 pub obj: VALUE,
2114 pub index: ::std::os::raw::c_int,
2115}
2116#[repr(C)]
2117#[derive(Debug, Copy, Clone)]
2118pub struct rb_iseq_struct__bindgen_ty_1__bindgen_ty_2 {
2119 pub local_hooks: *mut rb_hook_list_struct,
2120 pub global_trace_events: rb_event_flag_t,
2121}
2122impl ::std::fmt::Debug for rb_iseq_struct__bindgen_ty_1 {
2123 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2124 write!(f, "rb_iseq_struct__bindgen_ty_1 {{ union }}")
2125 }
2126}
2127impl ::std::fmt::Debug for rb_iseq_struct {
2128 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2129 write!(
2130 f,
2131 "rb_iseq_struct {{ flags: {:?}, wrapper: {:?}, body: {:?}, aux: {:?} }}",
2132 self.flags, self.wrapper, self.body, self.aux
2133 )
2134 }
2135}
2136pub type rb_vm_at_exit_func = ::std::option::Option<unsafe extern "C" fn(arg1: *mut rb_vm_struct)>;
2137#[repr(C)]
2138#[derive(Debug, Copy, Clone)]
2139pub struct rb_at_exit_list {
2140 pub func: rb_vm_at_exit_func,
2141 pub next: *mut rb_at_exit_list,
2142}
2143#[repr(C)]
2144#[derive(Debug, Copy, Clone)]
2145pub struct rb_hook_list_struct {
2146 pub hooks: *mut rb_event_hook_struct,
2147 pub events: rb_event_flag_t,
2148 pub running: ::std::os::raw::c_uint,
2149 pub need_clean: bool,
2150 pub is_local: bool,
2151}
2152pub type rb_hook_list_t = rb_hook_list_struct;
2153#[repr(C)]
2154#[derive(Debug, Copy, Clone)]
2155pub struct rb_builtin_function {
2156 _unused: [u8; 0],
2157}
2158#[repr(C)]
2159#[derive(Copy, Clone)]
2160pub struct rb_vm_struct {
2161 pub self_: VALUE,
2162 pub ractor: rb_vm_struct__bindgen_ty_1,
2163 pub main_altstack: *mut ::std::os::raw::c_void,
2164 pub fork_gen: rb_serial_t,
2165 pub waitpid_lock: rb_nativethread_lock_t,
2166 pub waiting_pids: ccan_list_head,
2167 pub waiting_grps: ccan_list_head,
2168 pub waiting_fds: ccan_list_head,
2169 pub ubf_async_safe: ::std::os::raw::c_int,
2170 pub _bitfield_align_1: [u8; 0],
2171 pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
2172 pub mark_object_ary: VALUE,
2173 pub special_exceptions: [VALUE; 5usize],
2174 pub shape_list: *mut rb_shape_t,
2175 pub root_shape: *mut rb_shape_t,
2176 pub next_shape_id: shape_id_t,
2177 pub top_self: VALUE,
2178 pub load_path: VALUE,
2179 pub load_path_snapshot: VALUE,
2180 pub load_path_check_cache: VALUE,
2181 pub expanded_load_path: VALUE,
2182 pub loaded_features: VALUE,
2183 pub loaded_features_snapshot: VALUE,
2184 pub loaded_features_realpaths: VALUE,
2185 pub loaded_features_realpath_map: VALUE,
2186 pub loaded_features_index: *mut st_table,
2187 pub loading_table: *mut st_table,
2188 pub trap_list: rb_vm_struct__bindgen_ty_2,
2189 pub ensure_rollback_table: *mut st_table,
2190 pub postponed_job_buffer: *mut rb_postponed_job_struct,
2191 pub postponed_job_index: rb_atomic_t,
2192 pub src_encoding_index: ::std::os::raw::c_int,
2193 pub workqueue: ccan_list_head,
2194 pub workqueue_lock: rb_nativethread_lock_t,
2195 pub orig_progname: VALUE,
2196 pub progname: VALUE,
2197 pub coverages: VALUE,
2198 pub me2counter: VALUE,
2199 pub coverage_mode: ::std::os::raw::c_int,
2200 pub defined_module_hash: *mut st_table,
2201 pub objspace: *mut rb_objspace,
2202 pub at_exit: *mut rb_at_exit_list,
2203 pub frozen_strings: *mut st_table,
2204 pub builtin_function_table: *const rb_builtin_function,
2205 pub builtin_inline_index: ::std::os::raw::c_int,
2206 pub negative_cme_table: *mut rb_id_table,
2207 pub overloaded_cme_table: *mut st_table,
2208 pub constant_cache: *mut rb_id_table,
2209 pub global_cc_cache_table: [*const rb_callcache; 1023usize],
2210 pub default_params: rb_vm_struct__bindgen_ty_3,
2211}
2212#[repr(C)]
2213#[derive(Copy, Clone)]
2214pub struct rb_vm_struct__bindgen_ty_1 {
2215 pub set: ccan_list_head,
2216 pub cnt: ::std::os::raw::c_uint,
2217 pub blocking_cnt: ::std::os::raw::c_uint,
2218 pub main_ractor: *mut rb_ractor_struct,
2219 pub main_thread: *mut rb_thread_struct,
2220 pub sync: rb_vm_struct__bindgen_ty_1__bindgen_ty_1,
2221}
2222#[repr(C)]
2223#[derive(Copy, Clone)]
2224pub struct rb_vm_struct__bindgen_ty_1__bindgen_ty_1 {
2225 pub lock: rb_nativethread_lock_t,
2226 pub lock_owner: *mut rb_ractor_struct,
2227 pub lock_rec: ::std::os::raw::c_uint,
2228 pub barrier_waiting: bool,
2229 pub barrier_cnt: ::std::os::raw::c_uint,
2230 pub barrier_cond: rb_nativethread_cond_t,
2231 pub terminate_cond: rb_nativethread_cond_t,
2232 pub terminate_waiting: bool,
2233}
2234impl ::std::fmt::Debug for rb_vm_struct__bindgen_ty_1__bindgen_ty_1 {
2235 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2236 write ! (f , "rb_vm_struct__bindgen_ty_1__bindgen_ty_1 {{ lock: {:?}, lock_owner: {:?}, lock_rec: {:?}, barrier_waiting: {:?}, barrier_cnt: {:?}, barrier_cond: {:?}, terminate_cond: {:?}, terminate_waiting: {:?} }}" , self . lock , self . lock_owner , self . lock_rec , self . barrier_waiting , self . barrier_cnt , self . barrier_cond , self . terminate_cond , self . terminate_waiting)
2237 }
2238}
2239impl ::std::fmt::Debug for rb_vm_struct__bindgen_ty_1 {
2240 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2241 write ! (f , "rb_vm_struct__bindgen_ty_1 {{ set: {:?}, cnt: {:?}, blocking_cnt: {:?}, main_ractor: {:?}, main_thread: {:?}, sync: {:?} }}" , self . set , self . cnt , self . blocking_cnt , self . main_ractor , self . main_thread , self . sync)
2242 }
2243}
2244#[repr(C)]
2245#[derive(Debug, Copy, Clone)]
2246pub struct rb_vm_struct__bindgen_ty_2 {
2247 pub cmd: [VALUE; 65usize],
2248}
2249#[repr(C)]
2250#[derive(Debug, Copy, Clone)]
2251pub struct rb_vm_struct__bindgen_ty_3 {
2252 pub thread_vm_stack_size: usize,
2253 pub thread_machine_stack_size: usize,
2254 pub fiber_vm_stack_size: usize,
2255 pub fiber_machine_stack_size: usize,
2256}
2257impl ::std::fmt::Debug for rb_vm_struct {
2258 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2259 write ! (f , "rb_vm_struct {{ self: {:?}, ractor: {:?}, main_altstack: {:?}, fork_gen: {:?}, waitpid_lock: {:?}, waiting_pids: {:?}, waiting_grps: {:?}, waiting_fds: {:?}, ubf_async_safe: {:?}, running : {:?}, thread_abort_on_exception : {:?}, thread_report_on_exception : {:?}, thread_ignore_deadlock : {:?}, mark_object_ary: {:?}, special_exceptions: {:?}, shape_list: {:?}, root_shape: {:?}, top_self: {:?}, load_path: {:?}, load_path_snapshot: {:?}, load_path_check_cache: {:?}, expanded_load_path: {:?}, loaded_features: {:?}, loaded_features_snapshot: {:?}, loaded_features_realpaths: {:?}, loaded_features_realpath_map: {:?}, loaded_features_index: {:?}, loading_table: {:?}, trap_list: {:?}, ensure_rollback_table: {:?}, postponed_job_buffer: {:?}, postponed_job_index: {:?}, src_encoding_index: {:?}, workqueue: {:?}, workqueue_lock: {:?}, orig_progname: {:?}, progname: {:?}, coverages: {:?}, me2counter: {:?}, coverage_mode: {:?}, defined_module_hash: {:?}, objspace: {:?}, at_exit: {:?}, frozen_strings: {:?}, builtin_function_table: {:?}, builtin_inline_index: {:?}, negative_cme_table: {:?}, overloaded_cme_table: {:?}, constant_cache: {:?}, global_cc_cache_table: {:?}, default_params: {:?} }}" , self . self_ , self . ractor , self . main_altstack , self . fork_gen , self . waitpid_lock , self . waiting_pids , self . waiting_grps , self . waiting_fds , self . ubf_async_safe , self . running () , self . thread_abort_on_exception () , self . thread_report_on_exception () , self . thread_ignore_deadlock () , self . mark_object_ary , self . special_exceptions , self . shape_list , self . root_shape , self . top_self , self . load_path , self . load_path_snapshot , self . load_path_check_cache , self . expanded_load_path , self . loaded_features , self . loaded_features_snapshot , self . loaded_features_realpaths , self . loaded_features_realpath_map , self . loaded_features_index , self . loading_table , self . trap_list , self . ensure_rollback_table , self . postponed_job_buffer , self . postponed_job_index , self . src_encoding_index , self . workqueue , self . workqueue_lock , self . orig_progname , self . progname , self . coverages , self . me2counter , self . coverage_mode , self . defined_module_hash , self . objspace , self . at_exit , self . frozen_strings , self . builtin_function_table , self . builtin_inline_index , self . negative_cme_table , self . overloaded_cme_table , self . constant_cache , self . global_cc_cache_table , self . default_params)
2260 }
2261}
2262impl rb_vm_struct {
2263 #[inline]
2264 pub fn running(&self) -> ::std::os::raw::c_uint {
2265 unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
2266 }
2267 #[inline]
2268 pub fn set_running(&mut self, val: ::std::os::raw::c_uint) {
2269 unsafe {
2270 let val: u32 = ::std::mem::transmute(val);
2271 self._bitfield_1.set(0usize, 1u8, val as u64)
2272 }
2273 }
2274 #[inline]
2275 pub unsafe fn running_raw(this: *const Self) -> ::std::os::raw::c_uint {
2276 unsafe {
2277 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2278 ::std::ptr::addr_of!((*this)._bitfield_1),
2279 0usize,
2280 1u8,
2281 ) as u32)
2282 }
2283 }
2284 #[inline]
2285 pub unsafe fn set_running_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
2286 unsafe {
2287 let val: u32 = ::std::mem::transmute(val);
2288 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2289 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2290 0usize,
2291 1u8,
2292 val as u64,
2293 )
2294 }
2295 }
2296 #[inline]
2297 pub fn thread_abort_on_exception(&self) -> ::std::os::raw::c_uint {
2298 unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
2299 }
2300 #[inline]
2301 pub fn set_thread_abort_on_exception(&mut self, val: ::std::os::raw::c_uint) {
2302 unsafe {
2303 let val: u32 = ::std::mem::transmute(val);
2304 self._bitfield_1.set(1usize, 1u8, val as u64)
2305 }
2306 }
2307 #[inline]
2308 pub unsafe fn thread_abort_on_exception_raw(this: *const Self) -> ::std::os::raw::c_uint {
2309 unsafe {
2310 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2311 ::std::ptr::addr_of!((*this)._bitfield_1),
2312 1usize,
2313 1u8,
2314 ) as u32)
2315 }
2316 }
2317 #[inline]
2318 pub unsafe fn set_thread_abort_on_exception_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
2319 unsafe {
2320 let val: u32 = ::std::mem::transmute(val);
2321 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2322 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2323 1usize,
2324 1u8,
2325 val as u64,
2326 )
2327 }
2328 }
2329 #[inline]
2330 pub fn thread_report_on_exception(&self) -> ::std::os::raw::c_uint {
2331 unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
2332 }
2333 #[inline]
2334 pub fn set_thread_report_on_exception(&mut self, val: ::std::os::raw::c_uint) {
2335 unsafe {
2336 let val: u32 = ::std::mem::transmute(val);
2337 self._bitfield_1.set(2usize, 1u8, val as u64)
2338 }
2339 }
2340 #[inline]
2341 pub unsafe fn thread_report_on_exception_raw(this: *const Self) -> ::std::os::raw::c_uint {
2342 unsafe {
2343 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2344 ::std::ptr::addr_of!((*this)._bitfield_1),
2345 2usize,
2346 1u8,
2347 ) as u32)
2348 }
2349 }
2350 #[inline]
2351 pub unsafe fn set_thread_report_on_exception_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
2352 unsafe {
2353 let val: u32 = ::std::mem::transmute(val);
2354 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2355 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2356 2usize,
2357 1u8,
2358 val as u64,
2359 )
2360 }
2361 }
2362 #[inline]
2363 pub fn thread_ignore_deadlock(&self) -> ::std::os::raw::c_uint {
2364 unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
2365 }
2366 #[inline]
2367 pub fn set_thread_ignore_deadlock(&mut self, val: ::std::os::raw::c_uint) {
2368 unsafe {
2369 let val: u32 = ::std::mem::transmute(val);
2370 self._bitfield_1.set(3usize, 1u8, val as u64)
2371 }
2372 }
2373 #[inline]
2374 pub unsafe fn thread_ignore_deadlock_raw(this: *const Self) -> ::std::os::raw::c_uint {
2375 unsafe {
2376 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2377 ::std::ptr::addr_of!((*this)._bitfield_1),
2378 3usize,
2379 1u8,
2380 ) as u32)
2381 }
2382 }
2383 #[inline]
2384 pub unsafe fn set_thread_ignore_deadlock_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
2385 unsafe {
2386 let val: u32 = ::std::mem::transmute(val);
2387 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2388 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2389 3usize,
2390 1u8,
2391 val as u64,
2392 )
2393 }
2394 }
2395 #[inline]
2396 pub fn new_bitfield_1(
2397 running: ::std::os::raw::c_uint,
2398 thread_abort_on_exception: ::std::os::raw::c_uint,
2399 thread_report_on_exception: ::std::os::raw::c_uint,
2400 thread_ignore_deadlock: ::std::os::raw::c_uint,
2401 ) -> __BindgenBitfieldUnit<[u8; 1usize]> {
2402 let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
2403 __bindgen_bitfield_unit.set(0usize, 1u8, {
2404 let running: u32 = unsafe { ::std::mem::transmute(running) };
2405 running as u64
2406 });
2407 __bindgen_bitfield_unit.set(1usize, 1u8, {
2408 let thread_abort_on_exception: u32 =
2409 unsafe { ::std::mem::transmute(thread_abort_on_exception) };
2410 thread_abort_on_exception as u64
2411 });
2412 __bindgen_bitfield_unit.set(2usize, 1u8, {
2413 let thread_report_on_exception: u32 =
2414 unsafe { ::std::mem::transmute(thread_report_on_exception) };
2415 thread_report_on_exception as u64
2416 });
2417 __bindgen_bitfield_unit.set(3usize, 1u8, {
2418 let thread_ignore_deadlock: u32 =
2419 unsafe { ::std::mem::transmute(thread_ignore_deadlock) };
2420 thread_ignore_deadlock as u64
2421 });
2422 __bindgen_bitfield_unit
2423 }
2424}
2425pub type rb_vm_t = rb_vm_struct;
2426#[repr(C)]
2427#[derive(Debug, Copy, Clone)]
2428pub struct rb_control_frame_struct {
2429 pub pc: *const VALUE,
2430 pub sp: *mut VALUE,
2431 pub iseq: *const rb_iseq_t,
2432 pub self_: VALUE,
2433 pub ep: *const VALUE,
2434 pub block_code: *const ::std::os::raw::c_void,
2435 pub __bp__: *mut VALUE,
2436 pub jit_return: *mut ::std::os::raw::c_void,
2437}
2438pub type rb_control_frame_t = rb_control_frame_struct;
2439pub const rb_thread_status_THREAD_RUNNABLE: rb_thread_status = 0;
2440pub const rb_thread_status_THREAD_STOPPED: rb_thread_status = 1;
2441pub const rb_thread_status_THREAD_STOPPED_FOREVER: rb_thread_status = 2;
2442pub const rb_thread_status_THREAD_KILLED: rb_thread_status = 3;
2443pub type rb_thread_status = ::std::os::raw::c_uint;
2444pub type rb_jmpbuf_t = sigjmp_buf;
2445#[repr(C)]
2446#[derive(Debug, Copy, Clone)]
2447pub struct rb_vm_tag {
2448 pub tag: VALUE,
2449 pub retval: VALUE,
2450 pub buf: rb_jmpbuf_t,
2451 pub prev: *mut rb_vm_tag,
2452 pub state: ruby_tag_type,
2453 pub lock_rec: ::std::os::raw::c_uint,
2454}
2455#[repr(C)]
2456#[derive(Debug, Copy, Clone)]
2457pub struct rb_unblock_callback {
2458 pub func: rb_unblock_function_t,
2459 pub arg: *mut ::std::os::raw::c_void,
2460}
2461#[repr(C)]
2462#[derive(Debug, Copy, Clone)]
2463pub struct rb_mutex_struct {
2464 _unused: [u8; 0],
2465}
2466#[repr(C)]
2467#[derive(Debug, Copy, Clone)]
2468pub struct rb_ensure_entry {
2469 pub marker: VALUE,
2470 pub e_proc: ::std::option::Option<unsafe extern "C" fn(arg1: VALUE) -> VALUE>,
2471 pub data2: VALUE,
2472}
2473#[repr(C)]
2474#[derive(Debug, Copy, Clone)]
2475pub struct rb_ensure_list {
2476 pub next: *mut rb_ensure_list,
2477 pub entry: rb_ensure_entry,
2478}
2479pub type rb_ensure_list_t = rb_ensure_list;
2480#[repr(C)]
2481#[derive(Debug, Copy, Clone)]
2482pub struct rb_fiber_struct {
2483 _unused: [u8; 0],
2484}
2485pub type rb_fiber_t = rb_fiber_struct;
2486#[repr(C)]
2487#[derive(Debug, Copy, Clone)]
2488pub struct rb_waiting_list {
2489 pub next: *mut rb_waiting_list,
2490 pub thread: *mut rb_thread_struct,
2491 pub fiber: *mut rb_fiber_struct,
2492}
2493#[repr(C)]
2494#[derive(Debug, Copy, Clone)]
2495pub struct rb_execution_context_struct {
2496 pub vm_stack: *mut VALUE,
2497 pub vm_stack_size: usize,
2498 pub cfp: *mut rb_control_frame_t,
2499 pub tag: *mut rb_vm_tag,
2500 pub interrupt_flag: rb_atomic_t,
2501 pub interrupt_mask: rb_atomic_t,
2502 pub fiber_ptr: *mut rb_fiber_t,
2503 pub thread_ptr: *mut rb_thread_struct,
2504 pub local_storage: *mut rb_id_table,
2505 pub local_storage_recursive_hash: VALUE,
2506 pub local_storage_recursive_hash_for_trace: VALUE,
2507 pub storage: VALUE,
2508 pub root_lep: *const VALUE,
2509 pub root_svar: VALUE,
2510 pub ensure_list: *mut rb_ensure_list_t,
2511 pub trace_arg: *mut rb_trace_arg_struct,
2512 pub errinfo: VALUE,
2513 pub passed_block_handler: VALUE,
2514 pub raised_flag: u8,
2515 pub _bitfield_align_1: [u8; 0],
2516 pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
2517 pub private_const_reference: VALUE,
2518 pub machine: rb_execution_context_struct__bindgen_ty_1,
2519}
2520#[repr(C)]
2521#[derive(Debug, Copy, Clone)]
2522pub struct rb_execution_context_struct__bindgen_ty_1 {
2523 pub stack_start: *mut VALUE,
2524 pub stack_end: *mut VALUE,
2525 pub stack_maxsize: usize,
2526 pub regs: jmp_buf,
2527}
2528impl rb_execution_context_struct {
2529 #[inline]
2530 pub fn method_missing_reason(&self) -> method_missing_reason {
2531 unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 8u8) as u32) }
2532 }
2533 #[inline]
2534 pub fn set_method_missing_reason(&mut self, val: method_missing_reason) {
2535 unsafe {
2536 let val: u32 = ::std::mem::transmute(val);
2537 self._bitfield_1.set(0usize, 8u8, val as u64)
2538 }
2539 }
2540 #[inline]
2541 pub unsafe fn method_missing_reason_raw(this: *const Self) -> method_missing_reason {
2542 unsafe {
2543 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2544 ::std::ptr::addr_of!((*this)._bitfield_1),
2545 0usize,
2546 8u8,
2547 ) as u32)
2548 }
2549 }
2550 #[inline]
2551 pub unsafe fn set_method_missing_reason_raw(this: *mut Self, val: method_missing_reason) {
2552 unsafe {
2553 let val: u32 = ::std::mem::transmute(val);
2554 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2555 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2556 0usize,
2557 8u8,
2558 val as u64,
2559 )
2560 }
2561 }
2562 #[inline]
2563 pub fn new_bitfield_1(
2564 method_missing_reason: method_missing_reason,
2565 ) -> __BindgenBitfieldUnit<[u8; 1usize]> {
2566 let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
2567 __bindgen_bitfield_unit.set(0usize, 8u8, {
2568 let method_missing_reason: u32 =
2569 unsafe { ::std::mem::transmute(method_missing_reason) };
2570 method_missing_reason as u64
2571 });
2572 __bindgen_bitfield_unit
2573 }
2574}
2575pub type rb_execution_context_t = rb_execution_context_struct;
2576#[repr(C)]
2577#[derive(Debug, Copy, Clone)]
2578pub struct rb_ext_config {
2579 pub ractor_safe: bool,
2580}
2581pub type rb_ractor_t = rb_ractor_struct;
2582#[repr(C)]
2583#[derive(Copy, Clone)]
2584pub struct rb_thread_struct {
2585 pub lt_node: ccan_list_node,
2586 pub self_: VALUE,
2587 pub ractor: *mut rb_ractor_t,
2588 pub vm: *mut rb_vm_t,
2589 pub nt: *mut rb_native_thread,
2590 pub ec: *mut rb_execution_context_t,
2591 pub sched: rb_thread_sched_item,
2592 pub serial: rb_atomic_t,
2593 pub last_status: VALUE,
2594 pub calling: *mut rb_calling_info,
2595 pub top_self: VALUE,
2596 pub top_wrapper: VALUE,
2597 pub _bitfield_align_1: [u8; 0],
2598 pub _bitfield_1: __BindgenBitfieldUnit<[u8; 1usize]>,
2599 pub priority: i8,
2600 pub running_time_us: u32,
2601 pub blocking_region_buffer: *mut ::std::os::raw::c_void,
2602 pub thgroup: VALUE,
2603 pub value: VALUE,
2604 pub pending_interrupt_queue: VALUE,
2605 pub pending_interrupt_mask_stack: VALUE,
2606 pub interrupt_lock: rb_nativethread_lock_t,
2607 pub unblock: rb_unblock_callback,
2608 pub locking_mutex: VALUE,
2609 pub keeping_mutexes: *mut rb_mutex_struct,
2610 pub join_list: *mut rb_waiting_list,
2611 pub invoke_arg: rb_thread_struct__bindgen_ty_1,
2612 pub invoke_type: rb_thread_struct_thread_invoke_type,
2613 pub stat_insn_usage: VALUE,
2614 pub root_fiber: *mut rb_fiber_t,
2615 pub scheduler: VALUE,
2616 pub blocking: ::std::os::raw::c_uint,
2617 pub name: VALUE,
2618 pub ext_config: rb_ext_config,
2619}
2620#[repr(C)]
2621#[derive(Copy, Clone)]
2622pub union rb_thread_struct__bindgen_ty_1 {
2623 pub proc_: rb_thread_struct__bindgen_ty_1__bindgen_ty_1,
2624 pub func: rb_thread_struct__bindgen_ty_1__bindgen_ty_2,
2625}
2626#[repr(C)]
2627#[derive(Debug, Copy, Clone)]
2628pub struct rb_thread_struct__bindgen_ty_1__bindgen_ty_1 {
2629 pub proc_: VALUE,
2630 pub args: VALUE,
2631 pub kw_splat: ::std::os::raw::c_int,
2632}
2633#[repr(C)]
2634#[derive(Debug, Copy, Clone)]
2635pub struct rb_thread_struct__bindgen_ty_1__bindgen_ty_2 {
2636 pub func:
2637 ::std::option::Option<unsafe extern "C" fn(arg1: *mut ::std::os::raw::c_void) -> VALUE>,
2638 pub arg: *mut ::std::os::raw::c_void,
2639}
2640impl ::std::fmt::Debug for rb_thread_struct__bindgen_ty_1 {
2641 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2642 write!(f, "rb_thread_struct__bindgen_ty_1 {{ union }}")
2643 }
2644}
2645pub const rb_thread_struct_thread_invoke_type_thread_invoke_type_none:
2646 rb_thread_struct_thread_invoke_type = 0;
2647pub const rb_thread_struct_thread_invoke_type_thread_invoke_type_proc:
2648 rb_thread_struct_thread_invoke_type = 1;
2649pub const rb_thread_struct_thread_invoke_type_thread_invoke_type_ractor_proc:
2650 rb_thread_struct_thread_invoke_type = 2;
2651pub const rb_thread_struct_thread_invoke_type_thread_invoke_type_func:
2652 rb_thread_struct_thread_invoke_type = 3;
2653pub type rb_thread_struct_thread_invoke_type = ::std::os::raw::c_uint;
2654impl ::std::fmt::Debug for rb_thread_struct {
2655 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2656 write ! (f , "rb_thread_struct {{ lt_node: {:?}, self: {:?}, ractor: {:?}, vm: {:?}, nt: {:?}, ec: {:?}, sched: {:?}, serial: {:?}, last_status: {:?}, calling: {:?}, top_self: {:?}, top_wrapper: {:?}, status : {:?}, locking_native_thread : {:?}, to_kill : {:?}, abort_on_exception : {:?}, report_on_exception : {:?}, pending_interrupt_queue_checked : {:?}, blocking_region_buffer: {:?}, thgroup: {:?}, value: {:?}, pending_interrupt_queue: {:?}, pending_interrupt_mask_stack: {:?}, interrupt_lock: {:?}, unblock: {:?}, locking_mutex: {:?}, keeping_mutexes: {:?}, join_list: {:?}, invoke_arg: {:?}, invoke_type: {:?}, stat_insn_usage: {:?}, root_fiber: {:?}, scheduler: {:?}, blocking: {:?}, name: {:?}, ext_config: {:?} }}" , self . lt_node , self . self_ , self . ractor , self . vm , self . nt , self . ec , self . sched , self . serial , self . last_status , self . calling , self . top_self , self . top_wrapper , self . status () , self . locking_native_thread () , self . to_kill () , self . abort_on_exception () , self . report_on_exception () , self . pending_interrupt_queue_checked () , self . blocking_region_buffer , self . thgroup , self . value , self . pending_interrupt_queue , self . pending_interrupt_mask_stack , self . interrupt_lock , self . unblock , self . locking_mutex , self . keeping_mutexes , self . join_list , self . invoke_arg , self . invoke_type , self . stat_insn_usage , self . root_fiber , self . scheduler , self . blocking , self . name , self . ext_config)
2657 }
2658}
2659impl rb_thread_struct {
2660 #[inline]
2661 pub fn status(&self) -> rb_thread_status {
2662 unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 2u8) as u32) }
2663 }
2664 #[inline]
2665 pub fn set_status(&mut self, val: rb_thread_status) {
2666 unsafe {
2667 let val: u32 = ::std::mem::transmute(val);
2668 self._bitfield_1.set(0usize, 2u8, val as u64)
2669 }
2670 }
2671 #[inline]
2672 pub unsafe fn status_raw(this: *const Self) -> rb_thread_status {
2673 unsafe {
2674 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2675 ::std::ptr::addr_of!((*this)._bitfield_1),
2676 0usize,
2677 2u8,
2678 ) as u32)
2679 }
2680 }
2681 #[inline]
2682 pub unsafe fn set_status_raw(this: *mut Self, val: rb_thread_status) {
2683 unsafe {
2684 let val: u32 = ::std::mem::transmute(val);
2685 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2686 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2687 0usize,
2688 2u8,
2689 val as u64,
2690 )
2691 }
2692 }
2693 #[inline]
2694 pub fn locking_native_thread(&self) -> ::std::os::raw::c_uint {
2695 unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
2696 }
2697 #[inline]
2698 pub fn set_locking_native_thread(&mut self, val: ::std::os::raw::c_uint) {
2699 unsafe {
2700 let val: u32 = ::std::mem::transmute(val);
2701 self._bitfield_1.set(2usize, 1u8, val as u64)
2702 }
2703 }
2704 #[inline]
2705 pub unsafe fn locking_native_thread_raw(this: *const Self) -> ::std::os::raw::c_uint {
2706 unsafe {
2707 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2708 ::std::ptr::addr_of!((*this)._bitfield_1),
2709 2usize,
2710 1u8,
2711 ) as u32)
2712 }
2713 }
2714 #[inline]
2715 pub unsafe fn set_locking_native_thread_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
2716 unsafe {
2717 let val: u32 = ::std::mem::transmute(val);
2718 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2719 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2720 2usize,
2721 1u8,
2722 val as u64,
2723 )
2724 }
2725 }
2726 #[inline]
2727 pub fn to_kill(&self) -> ::std::os::raw::c_uint {
2728 unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
2729 }
2730 #[inline]
2731 pub fn set_to_kill(&mut self, val: ::std::os::raw::c_uint) {
2732 unsafe {
2733 let val: u32 = ::std::mem::transmute(val);
2734 self._bitfield_1.set(3usize, 1u8, val as u64)
2735 }
2736 }
2737 #[inline]
2738 pub unsafe fn to_kill_raw(this: *const Self) -> ::std::os::raw::c_uint {
2739 unsafe {
2740 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2741 ::std::ptr::addr_of!((*this)._bitfield_1),
2742 3usize,
2743 1u8,
2744 ) as u32)
2745 }
2746 }
2747 #[inline]
2748 pub unsafe fn set_to_kill_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
2749 unsafe {
2750 let val: u32 = ::std::mem::transmute(val);
2751 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2752 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2753 3usize,
2754 1u8,
2755 val as u64,
2756 )
2757 }
2758 }
2759 #[inline]
2760 pub fn abort_on_exception(&self) -> ::std::os::raw::c_uint {
2761 unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
2762 }
2763 #[inline]
2764 pub fn set_abort_on_exception(&mut self, val: ::std::os::raw::c_uint) {
2765 unsafe {
2766 let val: u32 = ::std::mem::transmute(val);
2767 self._bitfield_1.set(4usize, 1u8, val as u64)
2768 }
2769 }
2770 #[inline]
2771 pub unsafe fn abort_on_exception_raw(this: *const Self) -> ::std::os::raw::c_uint {
2772 unsafe {
2773 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2774 ::std::ptr::addr_of!((*this)._bitfield_1),
2775 4usize,
2776 1u8,
2777 ) as u32)
2778 }
2779 }
2780 #[inline]
2781 pub unsafe fn set_abort_on_exception_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
2782 unsafe {
2783 let val: u32 = ::std::mem::transmute(val);
2784 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2785 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2786 4usize,
2787 1u8,
2788 val as u64,
2789 )
2790 }
2791 }
2792 #[inline]
2793 pub fn report_on_exception(&self) -> ::std::os::raw::c_uint {
2794 unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
2795 }
2796 #[inline]
2797 pub fn set_report_on_exception(&mut self, val: ::std::os::raw::c_uint) {
2798 unsafe {
2799 let val: u32 = ::std::mem::transmute(val);
2800 self._bitfield_1.set(5usize, 1u8, val as u64)
2801 }
2802 }
2803 #[inline]
2804 pub unsafe fn report_on_exception_raw(this: *const Self) -> ::std::os::raw::c_uint {
2805 unsafe {
2806 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2807 ::std::ptr::addr_of!((*this)._bitfield_1),
2808 5usize,
2809 1u8,
2810 ) as u32)
2811 }
2812 }
2813 #[inline]
2814 pub unsafe fn set_report_on_exception_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
2815 unsafe {
2816 let val: u32 = ::std::mem::transmute(val);
2817 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2818 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2819 5usize,
2820 1u8,
2821 val as u64,
2822 )
2823 }
2824 }
2825 #[inline]
2826 pub fn pending_interrupt_queue_checked(&self) -> ::std::os::raw::c_uint {
2827 unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
2828 }
2829 #[inline]
2830 pub fn set_pending_interrupt_queue_checked(&mut self, val: ::std::os::raw::c_uint) {
2831 unsafe {
2832 let val: u32 = ::std::mem::transmute(val);
2833 self._bitfield_1.set(6usize, 1u8, val as u64)
2834 }
2835 }
2836 #[inline]
2837 pub unsafe fn pending_interrupt_queue_checked_raw(this: *const Self) -> ::std::os::raw::c_uint {
2838 unsafe {
2839 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 1usize]>>::raw_get(
2840 ::std::ptr::addr_of!((*this)._bitfield_1),
2841 6usize,
2842 1u8,
2843 ) as u32)
2844 }
2845 }
2846 #[inline]
2847 pub unsafe fn set_pending_interrupt_queue_checked_raw(
2848 this: *mut Self,
2849 val: ::std::os::raw::c_uint,
2850 ) {
2851 unsafe {
2852 let val: u32 = ::std::mem::transmute(val);
2853 <__BindgenBitfieldUnit<[u8; 1usize]>>::raw_set(
2854 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
2855 6usize,
2856 1u8,
2857 val as u64,
2858 )
2859 }
2860 }
2861 #[inline]
2862 pub fn new_bitfield_1(
2863 status: rb_thread_status,
2864 locking_native_thread: ::std::os::raw::c_uint,
2865 to_kill: ::std::os::raw::c_uint,
2866 abort_on_exception: ::std::os::raw::c_uint,
2867 report_on_exception: ::std::os::raw::c_uint,
2868 pending_interrupt_queue_checked: ::std::os::raw::c_uint,
2869 ) -> __BindgenBitfieldUnit<[u8; 1usize]> {
2870 let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 1usize]> = Default::default();
2871 __bindgen_bitfield_unit.set(0usize, 2u8, {
2872 let status: u32 = unsafe { ::std::mem::transmute(status) };
2873 status as u64
2874 });
2875 __bindgen_bitfield_unit.set(2usize, 1u8, {
2876 let locking_native_thread: u32 =
2877 unsafe { ::std::mem::transmute(locking_native_thread) };
2878 locking_native_thread as u64
2879 });
2880 __bindgen_bitfield_unit.set(3usize, 1u8, {
2881 let to_kill: u32 = unsafe { ::std::mem::transmute(to_kill) };
2882 to_kill as u64
2883 });
2884 __bindgen_bitfield_unit.set(4usize, 1u8, {
2885 let abort_on_exception: u32 = unsafe { ::std::mem::transmute(abort_on_exception) };
2886 abort_on_exception as u64
2887 });
2888 __bindgen_bitfield_unit.set(5usize, 1u8, {
2889 let report_on_exception: u32 = unsafe { ::std::mem::transmute(report_on_exception) };
2890 report_on_exception as u64
2891 });
2892 __bindgen_bitfield_unit.set(6usize, 1u8, {
2893 let pending_interrupt_queue_checked: u32 =
2894 unsafe { ::std::mem::transmute(pending_interrupt_queue_checked) };
2895 pending_interrupt_queue_checked as u64
2896 });
2897 __bindgen_bitfield_unit
2898 }
2899}
2900pub type rb_thread_t = rb_thread_struct;
2901#[repr(C)]
2902#[derive(Debug, Copy, Clone)]
2903pub struct rb_trace_arg_struct {
2904 pub event: rb_event_flag_t,
2905 pub ec: *mut rb_execution_context_t,
2906 pub cfp: *const rb_control_frame_t,
2907 pub self_: VALUE,
2908 pub id: ID,
2909 pub called_id: ID,
2910 pub klass: VALUE,
2911 pub data: VALUE,
2912 pub klass_solved: ::std::os::raw::c_int,
2913 pub lineno: ::std::os::raw::c_int,
2914 pub path: VALUE,
2915}
2916#[repr(C)]
2917#[derive(Debug, Copy, Clone)]
2918pub struct rb_ractor_pub {
2919 pub self_: VALUE,
2920 pub id: u32,
2921 pub hooks: rb_hook_list_t,
2922}
2923pub const rb_ractor_basket_type_basket_type_none: rb_ractor_basket_type = 0;
2924pub const rb_ractor_basket_type_basket_type_ref: rb_ractor_basket_type = 1;
2925pub const rb_ractor_basket_type_basket_type_copy: rb_ractor_basket_type = 2;
2926pub const rb_ractor_basket_type_basket_type_move: rb_ractor_basket_type = 3;
2927pub const rb_ractor_basket_type_basket_type_will: rb_ractor_basket_type = 4;
2928pub const rb_ractor_basket_type_basket_type_deleted: rb_ractor_basket_type = 5;
2929pub const rb_ractor_basket_type_basket_type_reserved: rb_ractor_basket_type = 6;
2930pub type rb_ractor_basket_type = ::std::os::raw::c_uint;
2931#[repr(C)]
2932#[derive(Debug, Copy, Clone)]
2933pub struct rb_ractor_basket {
2934 pub exception: bool,
2935 pub type_: rb_ractor_basket_type,
2936 pub v: VALUE,
2937 pub sender: VALUE,
2938}
2939#[repr(C)]
2940#[derive(Debug, Copy, Clone)]
2941pub struct rb_ractor_queue {
2942 pub baskets: *mut rb_ractor_basket,
2943 pub start: ::std::os::raw::c_int,
2944 pub cnt: ::std::os::raw::c_int,
2945 pub size: ::std::os::raw::c_int,
2946 pub serial: ::std::os::raw::c_uint,
2947 pub reserved_cnt: ::std::os::raw::c_uint,
2948}
2949#[repr(C)]
2950#[derive(Debug, Copy, Clone)]
2951pub struct rb_ractor_waiting_list {
2952 pub cnt: ::std::os::raw::c_int,
2953 pub size: ::std::os::raw::c_int,
2954 pub ractors: *mut *mut rb_ractor_t,
2955}
2956pub const rb_ractor_wait_status_wait_none: rb_ractor_wait_status = 0;
2957pub const rb_ractor_wait_status_wait_receiving: rb_ractor_wait_status = 1;
2958pub const rb_ractor_wait_status_wait_taking: rb_ractor_wait_status = 2;
2959pub const rb_ractor_wait_status_wait_yielding: rb_ractor_wait_status = 4;
2960pub const rb_ractor_wait_status_wait_moving: rb_ractor_wait_status = 8;
2961pub type rb_ractor_wait_status = ::std::os::raw::c_uint;
2962pub const rb_ractor_wakeup_status_wakeup_none: rb_ractor_wakeup_status = 0;
2963pub const rb_ractor_wakeup_status_wakeup_by_send: rb_ractor_wakeup_status = 1;
2964pub const rb_ractor_wakeup_status_wakeup_by_yield: rb_ractor_wakeup_status = 2;
2965pub const rb_ractor_wakeup_status_wakeup_by_take: rb_ractor_wakeup_status = 3;
2966pub const rb_ractor_wakeup_status_wakeup_by_close: rb_ractor_wakeup_status = 4;
2967pub const rb_ractor_wakeup_status_wakeup_by_interrupt: rb_ractor_wakeup_status = 5;
2968pub const rb_ractor_wakeup_status_wakeup_by_retry: rb_ractor_wakeup_status = 6;
2969pub type rb_ractor_wakeup_status = ::std::os::raw::c_uint;
2970#[repr(C)]
2971#[derive(Copy, Clone)]
2972pub struct rb_ractor_sync {
2973 pub lock: rb_nativethread_lock_t,
2974 pub cond: rb_nativethread_cond_t,
2975 pub incoming_queue: rb_ractor_queue,
2976 pub taking_ractors: rb_ractor_waiting_list,
2977 pub incoming_port_closed: bool,
2978 pub outgoing_port_closed: bool,
2979 pub wait: rb_ractor_sync_ractor_wait,
2980}
2981#[repr(C)]
2982#[derive(Debug, Copy, Clone)]
2983pub struct rb_ractor_sync_ractor_wait {
2984 pub status: rb_ractor_wait_status,
2985 pub wakeup_status: rb_ractor_wakeup_status,
2986 pub yielded_basket: rb_ractor_basket,
2987 pub taken_basket: rb_ractor_basket,
2988}
2989impl ::std::fmt::Debug for rb_ractor_sync {
2990 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
2991 write ! (f , "rb_ractor_sync {{ lock: {:?}, cond: {:?}, incoming_queue: {:?}, taking_ractors: {:?}, incoming_port_closed: {:?}, outgoing_port_closed: {:?}, wait: {:?} }}" , self . lock , self . cond , self . incoming_queue , self . taking_ractors , self . incoming_port_closed , self . outgoing_port_closed , self . wait)
2992 }
2993}
2994pub const ractor_status_ractor_created: ractor_status = 0;
2995pub const ractor_status_ractor_running: ractor_status = 1;
2996pub const ractor_status_ractor_blocking: ractor_status = 2;
2997pub const ractor_status_ractor_terminated: ractor_status = 3;
2998pub type ractor_status = ::std::os::raw::c_uint;
2999#[repr(C)]
3000#[derive(Copy, Clone)]
3001pub struct rb_ractor_struct {
3002 pub pub_: rb_ractor_pub,
3003 pub sync: rb_ractor_sync,
3004 pub receiving_mutex: VALUE,
3005 pub yield_atexit: bool,
3006 pub barrier_wait_cond: rb_nativethread_cond_t,
3007 pub threads: rb_ractor_struct__bindgen_ty_1,
3008 pub thgroup_default: VALUE,
3009 pub name: VALUE,
3010 pub loc: VALUE,
3011 pub status_: ractor_status,
3012 pub vmlr_node: ccan_list_node,
3013 pub local_storage: *mut st_table,
3014 pub idkey_local_storage: *mut rb_id_table,
3015 pub r_stdin: VALUE,
3016 pub r_stdout: VALUE,
3017 pub r_stderr: VALUE,
3018 pub verbose: VALUE,
3019 pub debug: VALUE,
3020 pub newobj_cache: rb_ractor_newobj_cache_t,
3021 pub mfd: *mut rb_ractor_struct_gc_mark_func_data_struct,
3022}
3023#[repr(C)]
3024#[derive(Copy, Clone)]
3025pub struct rb_ractor_struct__bindgen_ty_1 {
3026 pub set: ccan_list_head,
3027 pub cnt: ::std::os::raw::c_uint,
3028 pub blocking_cnt: ::std::os::raw::c_uint,
3029 pub sleeper: ::std::os::raw::c_uint,
3030 pub sched: rb_thread_sched,
3031 pub running_ec: *mut rb_execution_context_t,
3032 pub main: *mut rb_thread_t,
3033}
3034impl ::std::fmt::Debug for rb_ractor_struct__bindgen_ty_1 {
3035 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
3036 write ! (f , "rb_ractor_struct__bindgen_ty_1 {{ set: {:?}, cnt: {:?}, blocking_cnt: {:?}, sleeper: {:?}, sched: {:?}, running_ec: {:?}, main: {:?} }}" , self . set , self . cnt , self . blocking_cnt , self . sleeper , self . sched , self . running_ec , self . main)
3037 }
3038}
3039#[repr(C)]
3040#[derive(Debug, Copy, Clone)]
3041pub struct rb_ractor_struct_gc_mark_func_data_struct {
3042 pub data: *mut ::std::os::raw::c_void,
3043 pub mark_func:
3044 ::std::option::Option<unsafe extern "C" fn(v: VALUE, data: *mut ::std::os::raw::c_void)>,
3045}
3046impl ::std::fmt::Debug for rb_ractor_struct {
3047 fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
3048 write ! (f , "rb_ractor_struct {{ pub: {:?}, sync: {:?}, receiving_mutex: {:?}, yield_atexit: {:?}, barrier_wait_cond: {:?}, threads: {:?}, thgroup_default: {:?}, name: {:?}, loc: {:?}, status_: {:?}, vmlr_node: {:?}, local_storage: {:?}, idkey_local_storage: {:?}, r_stdin: {:?}, r_stdout: {:?}, r_stderr: {:?}, verbose: {:?}, debug: {:?}, newobj_cache: {:?}, mfd: {:?} }}" , self . pub_ , self . sync , self . receiving_mutex , self . yield_atexit , self . barrier_wait_cond , self . threads , self . thgroup_default , self . name , self . loc , self . status_ , self . vmlr_node , self . local_storage , self . idkey_local_storage , self . r_stdin , self . r_stdout , self . r_stderr , self . verbose , self . debug , self . newobj_cache , self . mfd)
3049 }
3050}
3051#[repr(C)]
3052#[derive(Debug, Copy, Clone)]
3053pub struct iseq_compile_data {
3054 pub err_info: VALUE,
3055 pub catch_table_ary: VALUE,
3056 pub start_label: *mut iseq_label_data,
3057 pub end_label: *mut iseq_label_data,
3058 pub redo_label: *mut iseq_label_data,
3059 pub current_block: *const rb_iseq_t,
3060 pub ensure_node_stack: *mut iseq_compile_data_ensure_node_stack,
3061 pub node: iseq_compile_data__bindgen_ty_1,
3062 pub insn: iseq_compile_data__bindgen_ty_2,
3063 pub in_rescue: bool,
3064 pub loopval_popped: ::std::os::raw::c_int,
3065 pub last_line: ::std::os::raw::c_int,
3066 pub label_no: ::std::os::raw::c_int,
3067 pub node_level: ::std::os::raw::c_int,
3068 pub isolated_depth: ::std::os::raw::c_int,
3069 pub ci_index: ::std::os::raw::c_uint,
3070 pub ic_index: ::std::os::raw::c_uint,
3071 pub option: *const rb_compile_option_t,
3072 pub ivar_cache_table: *mut rb_id_table,
3073 pub builtin_function_table: *const rb_builtin_function,
3074 pub root_node: *const NODE,
3075}
3076#[repr(C)]
3077#[derive(Debug, Copy, Clone)]
3078pub struct iseq_compile_data__bindgen_ty_1 {
3079 pub storage_head: *mut iseq_compile_data_storage,
3080 pub storage_current: *mut iseq_compile_data_storage,
3081}
3082#[repr(C)]
3083#[derive(Debug, Copy, Clone)]
3084pub struct iseq_compile_data__bindgen_ty_2 {
3085 pub storage_head: *mut iseq_compile_data_storage,
3086 pub storage_current: *mut iseq_compile_data_storage,
3087}
3088#[repr(C)]
3089#[derive(Debug, Copy, Clone)]
3090pub struct rb_compile_option_struct {
3091 pub _bitfield_align_1: [u8; 0],
3092 pub _bitfield_1: __BindgenBitfieldUnit<[u8; 2usize]>,
3093 pub debug_level: ::std::os::raw::c_int,
3094}
3095impl rb_compile_option_struct {
3096 #[inline]
3097 pub fn inline_const_cache(&self) -> ::std::os::raw::c_uint {
3098 unsafe { ::std::mem::transmute(self._bitfield_1.get(0usize, 1u8) as u32) }
3099 }
3100 #[inline]
3101 pub fn set_inline_const_cache(&mut self, val: ::std::os::raw::c_uint) {
3102 unsafe {
3103 let val: u32 = ::std::mem::transmute(val);
3104 self._bitfield_1.set(0usize, 1u8, val as u64)
3105 }
3106 }
3107 #[inline]
3108 pub unsafe fn inline_const_cache_raw(this: *const Self) -> ::std::os::raw::c_uint {
3109 unsafe {
3110 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3111 ::std::ptr::addr_of!((*this)._bitfield_1),
3112 0usize,
3113 1u8,
3114 ) as u32)
3115 }
3116 }
3117 #[inline]
3118 pub unsafe fn set_inline_const_cache_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
3119 unsafe {
3120 let val: u32 = ::std::mem::transmute(val);
3121 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3122 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3123 0usize,
3124 1u8,
3125 val as u64,
3126 )
3127 }
3128 }
3129 #[inline]
3130 pub fn peephole_optimization(&self) -> ::std::os::raw::c_uint {
3131 unsafe { ::std::mem::transmute(self._bitfield_1.get(1usize, 1u8) as u32) }
3132 }
3133 #[inline]
3134 pub fn set_peephole_optimization(&mut self, val: ::std::os::raw::c_uint) {
3135 unsafe {
3136 let val: u32 = ::std::mem::transmute(val);
3137 self._bitfield_1.set(1usize, 1u8, val as u64)
3138 }
3139 }
3140 #[inline]
3141 pub unsafe fn peephole_optimization_raw(this: *const Self) -> ::std::os::raw::c_uint {
3142 unsafe {
3143 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3144 ::std::ptr::addr_of!((*this)._bitfield_1),
3145 1usize,
3146 1u8,
3147 ) as u32)
3148 }
3149 }
3150 #[inline]
3151 pub unsafe fn set_peephole_optimization_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
3152 unsafe {
3153 let val: u32 = ::std::mem::transmute(val);
3154 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3155 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3156 1usize,
3157 1u8,
3158 val as u64,
3159 )
3160 }
3161 }
3162 #[inline]
3163 pub fn tailcall_optimization(&self) -> ::std::os::raw::c_uint {
3164 unsafe { ::std::mem::transmute(self._bitfield_1.get(2usize, 1u8) as u32) }
3165 }
3166 #[inline]
3167 pub fn set_tailcall_optimization(&mut self, val: ::std::os::raw::c_uint) {
3168 unsafe {
3169 let val: u32 = ::std::mem::transmute(val);
3170 self._bitfield_1.set(2usize, 1u8, val as u64)
3171 }
3172 }
3173 #[inline]
3174 pub unsafe fn tailcall_optimization_raw(this: *const Self) -> ::std::os::raw::c_uint {
3175 unsafe {
3176 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3177 ::std::ptr::addr_of!((*this)._bitfield_1),
3178 2usize,
3179 1u8,
3180 ) as u32)
3181 }
3182 }
3183 #[inline]
3184 pub unsafe fn set_tailcall_optimization_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
3185 unsafe {
3186 let val: u32 = ::std::mem::transmute(val);
3187 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3188 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3189 2usize,
3190 1u8,
3191 val as u64,
3192 )
3193 }
3194 }
3195 #[inline]
3196 pub fn specialized_instruction(&self) -> ::std::os::raw::c_uint {
3197 unsafe { ::std::mem::transmute(self._bitfield_1.get(3usize, 1u8) as u32) }
3198 }
3199 #[inline]
3200 pub fn set_specialized_instruction(&mut self, val: ::std::os::raw::c_uint) {
3201 unsafe {
3202 let val: u32 = ::std::mem::transmute(val);
3203 self._bitfield_1.set(3usize, 1u8, val as u64)
3204 }
3205 }
3206 #[inline]
3207 pub unsafe fn specialized_instruction_raw(this: *const Self) -> ::std::os::raw::c_uint {
3208 unsafe {
3209 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3210 ::std::ptr::addr_of!((*this)._bitfield_1),
3211 3usize,
3212 1u8,
3213 ) as u32)
3214 }
3215 }
3216 #[inline]
3217 pub unsafe fn set_specialized_instruction_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
3218 unsafe {
3219 let val: u32 = ::std::mem::transmute(val);
3220 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3221 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3222 3usize,
3223 1u8,
3224 val as u64,
3225 )
3226 }
3227 }
3228 #[inline]
3229 pub fn operands_unification(&self) -> ::std::os::raw::c_uint {
3230 unsafe { ::std::mem::transmute(self._bitfield_1.get(4usize, 1u8) as u32) }
3231 }
3232 #[inline]
3233 pub fn set_operands_unification(&mut self, val: ::std::os::raw::c_uint) {
3234 unsafe {
3235 let val: u32 = ::std::mem::transmute(val);
3236 self._bitfield_1.set(4usize, 1u8, val as u64)
3237 }
3238 }
3239 #[inline]
3240 pub unsafe fn operands_unification_raw(this: *const Self) -> ::std::os::raw::c_uint {
3241 unsafe {
3242 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3243 ::std::ptr::addr_of!((*this)._bitfield_1),
3244 4usize,
3245 1u8,
3246 ) as u32)
3247 }
3248 }
3249 #[inline]
3250 pub unsafe fn set_operands_unification_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
3251 unsafe {
3252 let val: u32 = ::std::mem::transmute(val);
3253 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3254 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3255 4usize,
3256 1u8,
3257 val as u64,
3258 )
3259 }
3260 }
3261 #[inline]
3262 pub fn instructions_unification(&self) -> ::std::os::raw::c_uint {
3263 unsafe { ::std::mem::transmute(self._bitfield_1.get(5usize, 1u8) as u32) }
3264 }
3265 #[inline]
3266 pub fn set_instructions_unification(&mut self, val: ::std::os::raw::c_uint) {
3267 unsafe {
3268 let val: u32 = ::std::mem::transmute(val);
3269 self._bitfield_1.set(5usize, 1u8, val as u64)
3270 }
3271 }
3272 #[inline]
3273 pub unsafe fn instructions_unification_raw(this: *const Self) -> ::std::os::raw::c_uint {
3274 unsafe {
3275 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3276 ::std::ptr::addr_of!((*this)._bitfield_1),
3277 5usize,
3278 1u8,
3279 ) as u32)
3280 }
3281 }
3282 #[inline]
3283 pub unsafe fn set_instructions_unification_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
3284 unsafe {
3285 let val: u32 = ::std::mem::transmute(val);
3286 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3287 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3288 5usize,
3289 1u8,
3290 val as u64,
3291 )
3292 }
3293 }
3294 #[inline]
3295 pub fn stack_caching(&self) -> ::std::os::raw::c_uint {
3296 unsafe { ::std::mem::transmute(self._bitfield_1.get(6usize, 1u8) as u32) }
3297 }
3298 #[inline]
3299 pub fn set_stack_caching(&mut self, val: ::std::os::raw::c_uint) {
3300 unsafe {
3301 let val: u32 = ::std::mem::transmute(val);
3302 self._bitfield_1.set(6usize, 1u8, val as u64)
3303 }
3304 }
3305 #[inline]
3306 pub unsafe fn stack_caching_raw(this: *const Self) -> ::std::os::raw::c_uint {
3307 unsafe {
3308 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3309 ::std::ptr::addr_of!((*this)._bitfield_1),
3310 6usize,
3311 1u8,
3312 ) as u32)
3313 }
3314 }
3315 #[inline]
3316 pub unsafe fn set_stack_caching_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
3317 unsafe {
3318 let val: u32 = ::std::mem::transmute(val);
3319 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3320 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3321 6usize,
3322 1u8,
3323 val as u64,
3324 )
3325 }
3326 }
3327 #[inline]
3328 pub fn frozen_string_literal(&self) -> ::std::os::raw::c_uint {
3329 unsafe { ::std::mem::transmute(self._bitfield_1.get(7usize, 1u8) as u32) }
3330 }
3331 #[inline]
3332 pub fn set_frozen_string_literal(&mut self, val: ::std::os::raw::c_uint) {
3333 unsafe {
3334 let val: u32 = ::std::mem::transmute(val);
3335 self._bitfield_1.set(7usize, 1u8, val as u64)
3336 }
3337 }
3338 #[inline]
3339 pub unsafe fn frozen_string_literal_raw(this: *const Self) -> ::std::os::raw::c_uint {
3340 unsafe {
3341 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3342 ::std::ptr::addr_of!((*this)._bitfield_1),
3343 7usize,
3344 1u8,
3345 ) as u32)
3346 }
3347 }
3348 #[inline]
3349 pub unsafe fn set_frozen_string_literal_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
3350 unsafe {
3351 let val: u32 = ::std::mem::transmute(val);
3352 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3353 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3354 7usize,
3355 1u8,
3356 val as u64,
3357 )
3358 }
3359 }
3360 #[inline]
3361 pub fn debug_frozen_string_literal(&self) -> ::std::os::raw::c_uint {
3362 unsafe { ::std::mem::transmute(self._bitfield_1.get(8usize, 1u8) as u32) }
3363 }
3364 #[inline]
3365 pub fn set_debug_frozen_string_literal(&mut self, val: ::std::os::raw::c_uint) {
3366 unsafe {
3367 let val: u32 = ::std::mem::transmute(val);
3368 self._bitfield_1.set(8usize, 1u8, val as u64)
3369 }
3370 }
3371 #[inline]
3372 pub unsafe fn debug_frozen_string_literal_raw(this: *const Self) -> ::std::os::raw::c_uint {
3373 unsafe {
3374 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3375 ::std::ptr::addr_of!((*this)._bitfield_1),
3376 8usize,
3377 1u8,
3378 ) as u32)
3379 }
3380 }
3381 #[inline]
3382 pub unsafe fn set_debug_frozen_string_literal_raw(
3383 this: *mut Self,
3384 val: ::std::os::raw::c_uint,
3385 ) {
3386 unsafe {
3387 let val: u32 = ::std::mem::transmute(val);
3388 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3389 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3390 8usize,
3391 1u8,
3392 val as u64,
3393 )
3394 }
3395 }
3396 #[inline]
3397 pub fn coverage_enabled(&self) -> ::std::os::raw::c_uint {
3398 unsafe { ::std::mem::transmute(self._bitfield_1.get(9usize, 1u8) as u32) }
3399 }
3400 #[inline]
3401 pub fn set_coverage_enabled(&mut self, val: ::std::os::raw::c_uint) {
3402 unsafe {
3403 let val: u32 = ::std::mem::transmute(val);
3404 self._bitfield_1.set(9usize, 1u8, val as u64)
3405 }
3406 }
3407 #[inline]
3408 pub unsafe fn coverage_enabled_raw(this: *const Self) -> ::std::os::raw::c_uint {
3409 unsafe {
3410 ::std::mem::transmute(<__BindgenBitfieldUnit<[u8; 2usize]>>::raw_get(
3411 ::std::ptr::addr_of!((*this)._bitfield_1),
3412 9usize,
3413 1u8,
3414 ) as u32)
3415 }
3416 }
3417 #[inline]
3418 pub unsafe fn set_coverage_enabled_raw(this: *mut Self, val: ::std::os::raw::c_uint) {
3419 unsafe {
3420 let val: u32 = ::std::mem::transmute(val);
3421 <__BindgenBitfieldUnit<[u8; 2usize]>>::raw_set(
3422 ::std::ptr::addr_of_mut!((*this)._bitfield_1),
3423 9usize,
3424 1u8,
3425 val as u64,
3426 )
3427 }
3428 }
3429 #[inline]
3430 pub fn new_bitfield_1(
3431 inline_const_cache: ::std::os::raw::c_uint,
3432 peephole_optimization: ::std::os::raw::c_uint,
3433 tailcall_optimization: ::std::os::raw::c_uint,
3434 specialized_instruction: ::std::os::raw::c_uint,
3435 operands_unification: ::std::os::raw::c_uint,
3436 instructions_unification: ::std::os::raw::c_uint,
3437 stack_caching: ::std::os::raw::c_uint,
3438 frozen_string_literal: ::std::os::raw::c_uint,
3439 debug_frozen_string_literal: ::std::os::raw::c_uint,
3440 coverage_enabled: ::std::os::raw::c_uint,
3441 ) -> __BindgenBitfieldUnit<[u8; 2usize]> {
3442 let mut __bindgen_bitfield_unit: __BindgenBitfieldUnit<[u8; 2usize]> = Default::default();
3443 __bindgen_bitfield_unit.set(0usize, 1u8, {
3444 let inline_const_cache: u32 = unsafe { ::std::mem::transmute(inline_const_cache) };
3445 inline_const_cache as u64
3446 });
3447 __bindgen_bitfield_unit.set(1usize, 1u8, {
3448 let peephole_optimization: u32 =
3449 unsafe { ::std::mem::transmute(peephole_optimization) };
3450 peephole_optimization as u64
3451 });
3452 __bindgen_bitfield_unit.set(2usize, 1u8, {
3453 let tailcall_optimization: u32 =
3454 unsafe { ::std::mem::transmute(tailcall_optimization) };
3455 tailcall_optimization as u64
3456 });
3457 __bindgen_bitfield_unit.set(3usize, 1u8, {
3458 let specialized_instruction: u32 =
3459 unsafe { ::std::mem::transmute(specialized_instruction) };
3460 specialized_instruction as u64
3461 });
3462 __bindgen_bitfield_unit.set(4usize, 1u8, {
3463 let operands_unification: u32 = unsafe { ::std::mem::transmute(operands_unification) };
3464 operands_unification as u64
3465 });
3466 __bindgen_bitfield_unit.set(5usize, 1u8, {
3467 let instructions_unification: u32 =
3468 unsafe { ::std::mem::transmute(instructions_unification) };
3469 instructions_unification as u64
3470 });
3471 __bindgen_bitfield_unit.set(6usize, 1u8, {
3472 let stack_caching: u32 = unsafe { ::std::mem::transmute(stack_caching) };
3473 stack_caching as u64
3474 });
3475 __bindgen_bitfield_unit.set(7usize, 1u8, {
3476 let frozen_string_literal: u32 =
3477 unsafe { ::std::mem::transmute(frozen_string_literal) };
3478 frozen_string_literal as u64
3479 });
3480 __bindgen_bitfield_unit.set(8usize, 1u8, {
3481 let debug_frozen_string_literal: u32 =
3482 unsafe { ::std::mem::transmute(debug_frozen_string_literal) };
3483 debug_frozen_string_literal as u64
3484 });
3485 __bindgen_bitfield_unit.set(9usize, 1u8, {
3486 let coverage_enabled: u32 = unsafe { ::std::mem::transmute(coverage_enabled) };
3487 coverage_enabled as u64
3488 });
3489 __bindgen_bitfield_unit
3490 }
3491}
3492#[repr(C)]
3493#[derive(Debug, Copy, Clone)]
3494pub struct iseq_insn_info_entry {
3495 pub line_no: ::std::os::raw::c_int,
3496 pub node_id: ::std::os::raw::c_int,
3497 pub events: rb_event_flag_t,
3498}
3499pub const rb_catch_type_CATCH_TYPE_RESCUE: rb_catch_type = 3;
3500pub const rb_catch_type_CATCH_TYPE_ENSURE: rb_catch_type = 5;
3501pub const rb_catch_type_CATCH_TYPE_RETRY: rb_catch_type = 7;
3502pub const rb_catch_type_CATCH_TYPE_BREAK: rb_catch_type = 9;
3503pub const rb_catch_type_CATCH_TYPE_REDO: rb_catch_type = 11;
3504pub const rb_catch_type_CATCH_TYPE_NEXT: rb_catch_type = 13;
3505pub type rb_catch_type = ::std::os::raw::c_uint;
3506#[repr(C)]
3507#[derive(Debug, Copy, Clone)]
3508pub struct iseq_catch_table_entry {
3509 pub type_: rb_catch_type,
3510 pub iseq: *mut rb_iseq_t,
3511 pub start: ::std::os::raw::c_uint,
3512 pub end: ::std::os::raw::c_uint,
3513 pub cont: ::std::os::raw::c_uint,
3514 pub sp: ::std::os::raw::c_uint,
3515}
3516#[repr(C, packed)]
3517pub struct iseq_catch_table {
3518 pub size: ::std::os::raw::c_uint,
3519 pub entries: __IncompleteArrayField<iseq_catch_table_entry>,
3520}
3521#[repr(C)]
3522#[derive(Debug)]
3523pub struct iseq_compile_data_storage {
3524 pub next: *mut iseq_compile_data_storage,
3525 pub pos: ::std::os::raw::c_uint,
3526 pub size: ::std::os::raw::c_uint,
3527 pub buff: __IncompleteArrayField<::std::os::raw::c_char>,
3528}
3529#[repr(C)]
3530#[derive(Debug, Copy, Clone)]
3531pub struct RVALUE {
3532 pub _address: u8,
3533}
3534#[repr(C)]
3535#[derive(Debug, Copy, Clone)]
3536pub struct heap_page {
3537 pub _address: u8,
3538}
3539#[repr(C)]
3540#[derive(Debug, Copy, Clone)]
3541pub struct succ_index_table {
3542 pub _address: u8,
3543}
3544#[repr(C)]
3545#[derive(Debug, Copy, Clone)]
3546pub struct rb_call_data {
3547 pub _address: u8,
3548}
3549#[repr(C)]
3550#[derive(Debug, Copy, Clone)]
3551pub struct rb_event_hook_struct {
3552 pub _address: u8,
3553}
3554#[repr(C)]
3555#[derive(Debug, Copy, Clone)]
3556pub struct rb_postponed_job_struct {
3557 pub _address: u8,
3558}
3559#[repr(C)]
3560#[derive(Debug, Copy, Clone)]
3561pub struct iseq_label_data {
3562 pub _address: u8,
3563}
3564#[repr(C)]
3565#[derive(Debug, Copy, Clone)]
3566pub struct iseq_compile_data_ensure_node_stack {
3567 pub _address: u8,
3568}