Trait UserDataFields

Source
pub trait UserDataFields<'lua, T: UserData> {
    // Required methods
    fn add_field_method_get<S, R, M>(&mut self, name: &S, method: M)
       where S: AsRef<[u8]> + ?Sized,
             R: ToLua<'lua>,
             M: 'static + MaybeSend + Fn(&'lua Lua, &T) -> Result<R>;
    fn add_field_method_set<S, A, M>(&mut self, name: &S, method: M)
       where S: AsRef<[u8]> + ?Sized,
             A: FromLua<'lua>,
             M: 'static + MaybeSend + FnMut(&'lua Lua, &mut T, A) -> Result<()>;
    fn add_field_function_get<S, R, F>(&mut self, name: &S, function: F)
       where S: AsRef<[u8]> + ?Sized,
             R: ToLua<'lua>,
             F: 'static + MaybeSend + Fn(&'lua Lua, AnyUserData<'lua>) -> Result<R>;
    fn add_field_function_set<S, A, F>(&mut self, name: &S, function: F)
       where S: AsRef<[u8]> + ?Sized,
             A: FromLua<'lua>,
             F: 'static + MaybeSend + FnMut(&'lua Lua, AnyUserData<'lua>, A) -> Result<()>;
    fn add_meta_field_with<S, R, F>(&mut self, meta: S, f: F)
       where S: Into<MetaMethod>,
             F: 'static + MaybeSend + Fn(&'lua Lua) -> Result<R>,
             R: ToLua<'lua>;
}
Expand description

Field registry for UserData implementors.

Required Methods§

Source

fn add_field_method_get<S, R, M>(&mut self, name: &S, method: M)
where S: AsRef<[u8]> + ?Sized, R: ToLua<'lua>, M: 'static + MaybeSend + Fn(&'lua Lua, &T) -> Result<R>,

Add a regular field getter as a method which accepts a &T as the parameter.

Regular field getters are implemented by overriding the __index metamethod and returning the accessed field. This allows them to be used with the expected userdata.field syntax.

If add_meta_method is used to set the __index metamethod, the __index metamethod will be used as a fall-back if no regular field or method are found.

Source

fn add_field_method_set<S, A, M>(&mut self, name: &S, method: M)
where S: AsRef<[u8]> + ?Sized, A: FromLua<'lua>, M: 'static + MaybeSend + FnMut(&'lua Lua, &mut T, A) -> Result<()>,

Add a regular field setter as a method which accepts a &mut T as the first parameter.

Regular field setters are implemented by overriding the __newindex metamethod and setting the accessed field. This allows them to be used with the expected userdata.field = value syntax.

If add_meta_method is used to set the __newindex metamethod, the __newindex metamethod will be used as a fall-back if no regular field is found.

Source

fn add_field_function_get<S, R, F>(&mut self, name: &S, function: F)
where S: AsRef<[u8]> + ?Sized, R: ToLua<'lua>, F: 'static + MaybeSend + Fn(&'lua Lua, AnyUserData<'lua>) -> Result<R>,

Add a regular field getter as a function which accepts a generic AnyUserData of type T argument.

Prefer to use add_field_method_get as it is easier to use.

Source

fn add_field_function_set<S, A, F>(&mut self, name: &S, function: F)
where S: AsRef<[u8]> + ?Sized, A: FromLua<'lua>, F: 'static + MaybeSend + FnMut(&'lua Lua, AnyUserData<'lua>, A) -> Result<()>,

Add a regular field setter as a function which accepts a generic AnyUserData of type T first argument.

Prefer to use add_field_method_set as it is easier to use.

Source

fn add_meta_field_with<S, R, F>(&mut self, meta: S, f: F)
where S: Into<MetaMethod>, F: 'static + MaybeSend + Fn(&'lua Lua) -> Result<R>, R: ToLua<'lua>,

Add a metamethod value computed from f.

This will initialize the metamethod value from f on UserData creation.

§Note

mlua will trigger an error on an attempt to define a protected metamethod, like __gc or __metatable.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§