Extension:Lua

What can this extension do?
The Lua parser extensions allow you to embed blocks of Lua code into your pages and templates to be parsed and expanded by MediaWiki.

Traditionally, extensions such as ParserFunctions have offered some degree of programmability to MediaWiki's template system; however, this was not originally its intended purpose, and its syntax and utility have proven to be rather cumbersome and limited. As an alternative approach, this extension brings the full power of the Lua programming language to wikitext - including features such as variables with lexical scoping, data control structures and functions, and mathematical and string processing.

This extension requires either the Lua PHP extension from PECL or external Lua interpreter binaries (e.g. from LuaBinaries, or the "lua" package in most modern UNIX-like distributions) be installed to function.

A test wiki for this extension is currently live - all are encouraged to try out the extension and report any problems or suggestions!

Usage
The  tag is used to embed blocks of Lua code into wikitext, which are then executed. Arguments to the  tag will be available as variables to the embedded code; the standard Lua functions print and io.write may be used to pass output back to the parser.

The  parser function may be used to embed a single Lua expression which will be immediately printed to the parser as if it were wrapped in a   statement. Its semantics are thus quite similar to the ParserFunctions  function.

All variables and function declarations persist from one block/expression to the next, throughout the page. Complicated expressions and calculations can thus easily be separated from their presentation. For example,

All Lua code is executed in a secure sandbox environment. Nearly all of the Lua standard library is exposed to this environment, necessarily minus OS, filesystem, and debug facilities; most functions have been removed from io and os tables, for example. Hard limits on code execution are also in place to prevent infinite loops and stack overflow; see below for details on their configuration.

Download instructions
You can download this extension via the MediaWiki extension distribution system, or via Wikimedia SVN.

Installation
This extension may be configured in two separate ways, using either an external Lua interpreter or the PHP Lua extension from PECL.

Using an external Lua interpreter
First, download and install the Lua interpreter. Most modern UNIX-like distributions will have this in their repositories under e.g. "lua" or "lua5.1"; precompiled binaries for several operating systems are also available from the LuaBinaries project at LuaForge.

Extract the extension files to your MediaWiki extensions/ folder. Then add the following to LocalSettings.php, replacing  with the actual path to your Lua binary:

Using the Lua PHP extension from PECL
First, download, compile, and install the "lua" package from PECL. Unfortunately, as it is still in a pre-alpha stage, this entails checking out a copy from CVS and compiling it yourself.

Then, to install this extension, extract the extension files to your MediaWiki extensions/ folder, and add the following to LocalSettings.php:

Configuration parameters

 *   &mdash; Path to the external  binary to use. If   or unset, attempt to use the Lua PHP extension instead.
 *   &mdash; Optional path to an external  binary to use - if present, the wrapper library will be bytecode compiled for quicker execution.
 *   &mdash; Hard limit on lines of Lua code to execute, to stop malfunctioning or malicious scripts from draining server resources. The default is.
 *   &mdash; Hard limit on recursion in Lua code, to stop malfunctioning or malicious scripts from draining server resources. The default is.
 *   &mdash; Hard limit on Lua code execution time in seconds. The default is.