Forgotten optimization for `box_method_mut`

This commit is contained in:
Alex Orlenko 2021-07-09 23:25:48 +01:00
parent 3bffe1d7c3
commit 934aa3b65f
No known key found for this signature in database
GPG Key ID: 4C150C250863B96D
1 changed files with 9 additions and 4 deletions

View File

@ -2816,11 +2816,16 @@ impl<'lua, T: 'static + UserData> StaticUserDataMethods<'lua, T> {
let mut method = method let mut method = method
.try_borrow_mut() .try_borrow_mut()
.map_err(|_| Error::RecursiveMutCallback)?; .map_err(|_| Error::RecursiveMutCallback)?;
match userdata.type_id()? { // Try normal userdata first
id if id == TypeId::of::<T>() => { let err = match userdata.borrow_mut::<T>() {
let mut ud = userdata.borrow_mut::<T>()?; Ok(mut ud) => {
method(lua, &mut ud, A::from_lua_multi(args, lua)?)?.to_lua_multi(lua) return method(lua, &mut ud, A::from_lua_multi(args, lua)?)?
.to_lua_multi(lua)
} }
Err(err) => err,
};
match userdata.type_id()? {
id if id == TypeId::of::<T>() => Err(err),
#[cfg(not(feature = "send"))] #[cfg(not(feature = "send"))]
id if id == TypeId::of::<Rc<RefCell<T>>>() => { id if id == TypeId::of::<Rc<RefCell<T>>>() => {
let ud = userdata.borrow::<Rc<RefCell<T>>>()?; let ud = userdata.borrow::<Rc<RefCell<T>>>()?;