Enum mlua::MetaMethod

source ·
pub enum MetaMethod {
Show 28 variants Add, Sub, Mul, Div, Mod, Pow, Unm, IDiv, BAnd, BOr, BXor, BNot, Shl, Shr, Concat, Len, Eq, Lt, Le, Index, NewIndex, Call, ToString, Pairs, IPairs, Iter, Close, Custom(String),
}
Expand description

Kinds of metamethods that can be overridden.

Currently, this mechanism does not allow overriding the __gc metamethod, since there is generally no need to do so: UserData implementors can instead just implement Drop.

Variants§

§

Add

The + operator.

§

Sub

The - operator.

§

Mul

The * operator.

§

Div

The / operator.

§

Mod

The % operator.

§

Pow

The ^ operator.

§

Unm

The unary minus (-) operator.

§

IDiv

The floor division (//) operator. Requires feature = "lua54/lua53"

§

BAnd

The bitwise AND (&) operator. Requires feature = "lua54/lua53"

§

BOr

The bitwise OR (|) operator. Requires feature = "lua54/lua53"

§

BXor

The bitwise XOR (binary ~) operator. Requires feature = "lua54/lua53"

§

BNot

The bitwise NOT (unary ~) operator. Requires feature = "lua54/lua53"

§

Shl

The bitwise left shift (<<) operator.

§

Shr

The bitwise right shift (>>) operator.

§

Concat

The string concatenation operator ...

§

Len

The length operator #.

§

Eq

The == operator.

§

Lt

The < operator.

§

Le

The <= operator.

§

Index

Index access obj[key].

§

NewIndex

Index write access obj[key] = value.

§

Call

The call “operator” obj(arg1, args2, ...).

§

ToString

The __tostring metamethod.

This is not an operator, but will be called by methods such as tostring and print.

§

Pairs

The __pairs metamethod.

This is not an operator, but it will be called by the built-in pairs function.

Requires feature = "lua54/lua53/lua52"

§

IPairs

Available on crate features lua52 or luajit52 only.

The __ipairs metamethod.

This is not an operator, but it will be called by the built-in ipairs function.

Requires feature = "lua52"

§

Iter

Available on crate feature luau only.

The __iter metamethod.

Executed before the iteration begins, and should return an iterator function like next (or a custom one).

Requires feature = "lua"

§

Close

The __close metamethod.

Executed when a variable, that marked as to-be-closed, goes out of scope.

More information about to-be-closed variabled can be found in the Lua 5.4 documentation.

Requires feature = "lua54"

§

Custom(String)

A custom metamethod.

Must not be in the protected list: __gc, __metatable, __mlua*.

Implementations§

source§

impl MetaMethod

source

pub fn name(&self) -> &str

Returns Lua metamethod name, usually prefixed by two underscores.

Trait Implementations§

source§

impl Clone for MetaMethod

source§

fn clone(&self) -> MetaMethod

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for MetaMethod

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Display for MetaMethod

source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl From<&str> for MetaMethod

source§

fn from(name: &str) -> Self

Converts to this type from the input type.
source§

impl From<String> for MetaMethod

source§

fn from(name: StdString) -> Self

Converts to this type from the input type.
source§

impl Hash for MetaMethod

source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl PartialEq<MetaMethod> for MetaMethod

source§

fn eq(&self, other: &Self) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for MetaMethod

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for Twhere T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.