LuaSandbox::registerLibrary
Register a set of PHP functions as a Lua library
Description
public void LuaSandbox::registerLibrary(string $libname, array $functions)
For more information about calling Lua functions and the return values,
see LuaSandboxFunction::call.
Parameters
-
libname
-
The name of the library. In the Lua state, the global variable of this
name will be set to the table of functions. If the table already exists,
the new functions will be added to it.
-
functions
-
An array, where each key is a function name, and each value is a
corresponding PHP callable.
Return Values
No value is returned.
Examples
Example #1 Registering PHP functions to call from Lua
<?php
// create a new LuaSandbox
$sandbox = new LuaSandbox();
// Register some functions in the Lua environment
function frobnosticate( $v ) {
return [ $v + 42 ];
}
$sandbox->registerLibrary( 'php', [
'frobnosticate' => 'frobnosticate',
'output' => function ( $string ) {
echo "$string\n";
},
'error' => function () {
throw new LuaSandboxRuntimeError( "Something is wrong" );
}
] );
?>
See Also
- LuaSandbox::loadString
- LuaSandbox::wrapPhpFunction