[−][src]Crate redis_lua
redis-lua is a Lua scripting helper for redis-rs
redis-lua allows to insert Redis Lua scripts in Rust code in safer manner. The key features of redis-lua are:
- Compile-time lint for Redis Lua scripts.
- Capturing Rust variables in Lua scripts.
- Safe argument substitution.
- Safely joining multiple Lua scripts.
Invoke a Lua script
lua
macro allows to create the Lua script. The script object implements Script
trait.
The return value from the script can be converted to any types which implement redis::FromRedisValue
.
use redis_lua::lua; let mut cli = redis::Client::open("redis://localhost").unwrap(); let script = lua!(return 1 + 2); let num: usize = script.invoke(&mut cli).unwrap(); assert_eq!(num, 3);
Any Lua syntax supported by Redis Lua is usable.
- if-else
lua!( if 3 > 1 then return 3 else return 1 end );
- for-loop
lua!( local sum = 0 for i=1,10 do sum = sum + i end return sum );
Error reporting
Errors in Lua scripts (such as undefined variables) are detected at compile time.
lua!( return a + 1 );
error: in lua: `a` is not defined (undefined_variable)
--> src/lib.rs:80:10
|
10 | return a + 1
| ^
error: aborting due to previous error
Capturing a variable
@
with an identifier allows to capture a Rust variable in the script. It allows to capture any types which implement serde::Serialize
.
let x = 10; let script = lua!(return @x + 2); let num: usize = script.invoke(&mut cli).unwrap(); assert_eq!(num, 12);
Argument substitution
$
with an identifier allows to substitute a variable before actually running the script. Same as @
, any types which implement serde::Serialize
can be substituted.
let script = lua!(return $x + 2); let num: usize = script.x(30).invoke(&mut cli).unwrap(); assert_eq!(num, 32);
The difference from @
is that the same script can be called multiple times with different values.
let script = lua!(return $x + 2); for i in 0..10 { let num: usize = script.clone().x(i).invoke(&mut cli).unwrap(); assert_eq!(num, i + 2); }
The script object is clonable if all the variables it captures are clonable or it captures no variables.
Type conversion
@
and $
allow to pass Rust variables to Lua scripts. Primitive types and strings are converted to
the corresponding primitive types/strings in Lua scripts.
Non-empty byte sequences (e.g. Vec<u8>
, &[u8]
) are converted to a Lua string.
If the sequence is empty, it's converted to an empty table.
Complicated types such as structs, tuples, maps and non-u8 vectors are converted to Lua tables. The name of struct members become the key of tables.
Limitation
- The comment
--
is available only in nightly. - The warnings are available only in nightly. All the warnings are treated as errors in stable.
Re-exports
pub use futures; |
pub use redis; |
pub use serde; |
Macros
lua | Macro to embed Lua script in Rust code. |
lua_s | Macro to convert Lua script to string. |
Structs
Info | Script information which is generated by proc-macro. |
ScriptJoin | Represents the set of two scripts which are joined. |
Traits
Script | Represents a complete invocable script which has a complete set of arguments. |
TakeScript | Take another script as the inner of the script. |
Functions
gen_script | Generate a script from a list of script information. |
script_arg |