use crate::functions::currentpc::currentpc;
use crate::functions::getluaproto::get_lua_proto;
use crate::functions::lua_a_pushvalue::luaA_pushvalue;
use crate::functions::lua_f_getlocal::luaF_getlocal;
use crate::macros::getstr::getstr;
use crate::macros::lua_c_threadbarrier::luaC_threadbarrier;
use crate::macros::lua_callinfo_native::LUA_CALLINFO_NATIVE;
use crate::records::call_info::CallInfo;
use crate::records::loc_var::LocVar;
use crate::records::lua_state::lua_State;
use crate::type_aliases::proto::Proto;
#[no_mangle]
pub unsafe fn lua_getlocal(
L: *mut lua_State,
level: core::ffi::c_int,
n: core::ffi::c_int,
) -> *const core::ffi::c_char {
if (level as u32) >= ((*L).ci.offset_from((*L).base_ci) as u32) {
return core::ptr::null();
}
let ci: *mut CallInfo = (*L).ci.offset(-(level as isize));
if ((*ci).flags & LUA_CALLINFO_NATIVE as u32) != 0 {
return core::ptr::null();
}
let fp: *mut Proto = get_lua_proto(ci);
let var: *const LocVar = if !fp.is_null() {
luaF_getlocal(fp, n, currentpc(L, ci))
} else {
core::ptr::null()
};
if !var.is_null() {
luaC_threadbarrier!(L);
luaA_pushvalue(L, (*ci).base.offset((*var).reg as isize));
}
if !var.is_null() {
getstr((*var).varname)
} else {
core::ptr::null()
}
}