use crate::functions::lua_f_closeupval::luaF_closeupval;
use crate::macros::gcvalue::gcvalue;
use crate::macros::isblack::isblack;
use crate::macros::iscollectable::iscollectable;
use crate::macros::isgray::isgray;
use crate::macros::iswhite::iswhite;
use crate::macros::upisopen::upisopen;
use crate::records::gc_object::GCObject;
use crate::records::up_val::UpVal;
use crate::type_aliases::lua_state::lua_State;
use luaur_common::macros::luau_assert::LUAU_ASSERT;
#[allow(non_snake_case)]
pub(crate) unsafe fn clearupvals(l: *mut lua_State) -> usize {
let g = (*l).global;
let mut work: usize = 0;
let uvhead = core::ptr::addr_of_mut!((*g).uvhead);
let mut uv = (*g).uvhead.u.open.next;
while uv != uvhead {
work += core::mem::size_of::<UpVal>();
LUAU_ASSERT!(upisopen!(uv));
LUAU_ASSERT!(
(*(*uv).u.open.next).u.open.prev == uv && (*(*uv).u.open.prev).u.open.next == uv
);
LUAU_ASSERT!(!isblack!(uv as *mut GCObject));
LUAU_ASSERT!(
iswhite!(uv as *mut GCObject)
|| !iscollectable!((*uv).v)
|| !iswhite!(gcvalue!((*uv).v))
);
if (*uv).markedopen != 0 {
LUAU_ASSERT!(isgray!(uv as *mut GCObject));
(*uv).markedopen = 0; uv = (*uv).u.open.next;
} else {
let next = (*uv).u.open.next;
luaF_closeupval(l, uv, iswhite!(uv as *mut GCObject));
uv = next;
}
}
work
}