[−][src]Struct actix_lua::dev::rlua::prelude::LuaTable
Handle to an internal Lua table.
Methods
impl<'lua> Table<'lua>
[src]
impl<'lua> Table<'lua>
pub fn set<K, V>(&self, key: K, value: V) -> Result<(), Error> where | [src] |
Sets a key-value pair in the table.
If the value is nil
, this will effectively remove the pair.
This might invoke the __newindex
metamethod. Use the raw_set
method if that is not
desired.
Examples
Export a value as a global to make it usable from Lua:
let lua = Lua::new(); let globals = lua.globals(); globals.set("assertions", cfg!(debug_assertions))?; lua.exec::<_, ()>(r#" if assertions == true then -- ... elseif assertions == false then -- ... else error("assertions neither on nor off?") end "#, None)?;
pub fn get<K, V>(&self, key: K) -> Result<V, Error> where | [src] |
Gets the value associated to key
from the table.
If no value is associated to key
, returns the nil
value.
This might invoke the __index
metamethod. Use the raw_get
method if that is not
desired.
Examples
Query the version of the Lua interpreter:
let lua = Lua::new(); let globals = lua.globals(); let version: String = globals.get("_VERSION")?; println!("Lua version: {}", version);
pub fn contains_key<K>(&self, key: K) -> Result<bool, Error> where | [src] |
Checks whether the table contains a non-nil value for key
.
pub fn raw_set<K, V>(&self, key: K, value: V) -> Result<(), Error> where | [src] |
Sets a key-value pair without invoking metamethods.
pub fn raw_get<K, V>(&self, key: K) -> Result<V, Error> where | [src] |
Gets the value associated to key
without invoking metamethods.
pub fn len(&self) -> Result<i64, Error> | [src] |
Returns the result of the Lua #
operator.
This might invoke the __len
metamethod. Use the raw_len
method if that is not desired.
pub fn raw_len(&self) -> i64 | [src] |
Returns the result of the Lua #
operator, without invoking the __len
metamethod.
pub fn get_metatable(&self) -> Option<Table<'lua>> | [src] |
Returns a reference to the metatable of this table, or None
if no metatable is set.
Unlike the getmetatable
Lua function, this method ignores the __metatable
field.
pub fn set_metatable(&self, metatable: Option<Table<'lua>>) | [src] |
Sets or removes the metatable of this table.
If metatable
is None
, the metatable is removed (if no metatable is set, this does
nothing).
ⓘImportant traits for TablePairs<'lua, K, V>
pub fn pairs<K, V>(self) -> TablePairs<'lua, K, V> where | [src] |
Consume this table and return an iterator over the pairs of the table.
This works like the Lua pairs
function, but does not invoke the __pairs
metamethod.
The pairs are wrapped in a Result
, since they are lazily converted to K
and V
types.
Note
While this method consumes the Table
object, it can not prevent code from mutating the
table while the iteration is in progress. Refer to the Lua manual for information about
the consequences of such mutation.
Examples
Iterate over all globals:
let lua = Lua::new(); let globals = lua.globals(); for pair in globals.pairs::<Value, Value>() { let (key, value) = pair?; // ... }
ⓘImportant traits for TableSequence<'lua, V>
pub fn sequence_values<V>(self) -> TableSequence<'lua, V> where | [src] |
Consume this table and return an iterator over all values in the sequence part of the table.
The iterator will yield all values t[1]
, t[2]
, and so on, until a nil
value is
encountered. This mirrors the behaviour of Lua's ipairs
function and will invoke the
__index
metamethod according to the usual rules. However, the deprecated __ipairs
metatable will not be called.
Just like pairs
, the values are wrapped in a Result
.
Note
While this method consumes the Table
object, it can not prevent code from mutating the
table while the iteration is in progress. Refer to the Lua manual for information about
the consequences of such mutation.
Examples
let lua = Lua::new(); let my_table: Table = lua.eval("{ [1] = 4, [2] = 5, [4] = 7, key = 2 }", None)?; let expected = [4, 5]; for (&expected, got) in expected.iter().zip(my_table.sequence_values::<u32>()) { assert_eq!(expected, got?); }
Trait Implementations
impl<'lua> Debug for Table<'lua>
[src]
impl<'lua> Debug for Table<'lua>
impl<'lua> Clone for Table<'lua>
[src]
impl<'lua> Clone for Table<'lua>
fn clone(&self) -> Table<'lua> | [src] |
fn clone_from(&mut self, source: &Self) | 1.0.0 [src] |
Performs copy-assignment from source
. Read more
impl<'lua> FromLua<'lua> for Table<'lua>
[src]
impl<'lua> FromLua<'lua> for Table<'lua>
impl<'lua> ToLua<'lua> for Table<'lua>
[src]
impl<'lua> ToLua<'lua> for Table<'lua>
Auto Trait Implementations
Blanket Implementations
impl<T> From for T
[src]
impl<T> From for T
impl<T, U> Into for T where
U: From<T>,
[src]
impl<T, U> Into for T where
U: From<T>,
impl<T> ToOwned for T where
T: Clone,
[src]
impl<T> ToOwned for T where
T: Clone,
impl<T, U> TryFrom for T where
T: From<U>,
[src]
impl<T, U> TryFrom for T where
T: From<U>,
type Error = !
try_from
)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error> | [src] |
impl<T> Borrow for T where
T: ?Sized,
[src]
impl<T> Borrow for T where
T: ?Sized,
impl<T> BorrowMut for T where
T: ?Sized,
[src]
impl<T> BorrowMut for T where
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T | [src] |
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
impl<T, U> TryInto for T where
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
try_from
)The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error> | [src] |
impl<T> Any for T where
T: 'static + ?Sized,
[src]
impl<T> Any for T where
T: 'static + ?Sized,
fn get_type_id(&self) -> TypeId | [src] |
impl<T> Erased for T
impl<T> Erased for T
impl<'lua, T> FromLua for T where
T: 'static + UserData + Clone,
[src]
impl<'lua, T> FromLua for T where
T: 'static + UserData + Clone,
impl<'lua, T> ToLua for T where
T: 'static + UserData + Send,
[src]
impl<'lua, T> ToLua for T where
T: 'static + UserData + Send,
impl<'lua, T> ToLuaMulti for T where
T: ToLua<'lua>,
[src]
impl<'lua, T> ToLuaMulti for T where
T: ToLua<'lua>,
fn to_lua_multi(self, lua: &'lua Lua) -> Result<MultiValue<'lua>, Error> | [src] |
impl<'lua, T> FromLuaMulti for T where
T: FromLua<'lua>,
[src]
impl<'lua, T> FromLuaMulti for T where
T: FromLua<'lua>,
fn from_lua_multi(values: MultiValue<'lua>, lua: &'lua Lua) -> Result<T, Error> | [src] |