Lua eXtended
luax is a Lua interpreter and REPL based on Lua 5.4.4, augmented with
some useful packages. luax can also produces standalone executables
from Lua scripts.
luax runs on several platforms with no dependency:
- Linux (x86_64, i386, aarch64)
- MacOS (x86_64, aarch64)
- Windows (x86_64, i386)
luax can cross-compile scripts from and to any of these platforms.
Compilation
luax is written in C and Lua and uses the Zig build system. Just
download luax (https://github.com/CDSoft/luax) and run make:
$ git clone https://github.com/CDSoft/luax
$ cd luax
$ make # compile and testNote: make will download a Zig compiler.
Installation
Installation of luax for the current host only
$ make install # install luax to ~/.local/bin or ~/bin
$ make install PREFIX=/usr # install luax to /usr/binluax is a single autonomous executable. It does not need to be
installed and can be copied anywhere you want.
Installation of luax for all supported platforms (cross compilation support)
$ make install-all # install luax to ~/.local/bin or ~/bin
$ make install-all PREFIX=/usr # install luax to /usr/binLuaX artifacts
make install and make install-all install:
$PREFIX/bin/luax: symbolic link to the LuaX binary for the host$PREFIX/bin/luax-<ARCH>-<OS>-<LIBC>: LuaX binary for a specific platform$PREFIX/bin/luax-pandoc: LuaX run in a Pandoc Lua interpreter$PREFIX/bin/luax-lua: a pure Lua REPL reimplementing some LuaX libraries, usable in any Lua 5.4 interpreter (e.g.: lua, pandoc lua, …)$PREFIX/lib/libluax-<ARCH>-<OS>-<LIBC>.so: Linux LuaX shared libraries$PREFIX/lib/libluax-<ARCH>-<OS>-<LIBC>.dylib: MacOS LuaX shared libraries$PREFIX/lib/libluax-<ARCH>-<OS>-<LIBC>.dll: Windows LuaX shared libraries$PREFIX/lib/luax.lua: a pure Lua reimplementation of some LuaX libraries, usable in any Lua 5.4 interpreter.
Precompiled binaries
It is usually highly recommended to build luax from sources. The
latest binaries are available here:
luax.tar.xz.
The Linux and Raspberry Pi binaries are linked statically with musl and are not dynamic executables. They should work on any Linux distributions.
Warning: There are Linux binaries linked with musl and glibc. The musl binaries are platform independent but can not load shared libraries. The glibc binaries can load shared libraries but may depend on some specific glibc versions on the host.
Usage
luax is very similar to lua and adds more options to compile
scripts:
usage: luax [options] [script [args]]
General options:
-h show this help
-v show version information
-- stop handling options
Lua options:
-e stat execute string 'stat'
-i enter interactive mode after executing
'script'
-l name require library 'name' into global 'name'
- stop handling options and execute stdin
(incompatible with -i)
Compilation options:
-t target name of the targetted platform
-t all compile for all available LuaX targets
-t list list available targets
-t list-luax list available native LuaX targets
-t list-lua list available Lua/Pandoc targets
-o file name the executable file to create
-r use rlwrap (Lua/Pandoc targets only)
Scripts for compilation:
file name name of a Lua package to add to the binary
Lua and Compilation options can not be mixed.
Environment variables:
LUA_INIT_5_4, LUA_INIT
code executed before handling command line
options and scripts (not in compilation
mode). When LUA_INIT_5_4 is defined,
LUA_INIT is ignored.
PATH PATH shall contain the bin directory where
LuaX is installed
LUA_PATH LUA_PATH shall point to the lib directory
where the Lua implementation of LuaX
lbraries are installed
LUA_CPATH LUA_CPATH shall point to the lib directory
where LuaX shared libraries are installed
PATH, LUA_PATH and LUA_CPATH can be set in .bashrc or .zshrc
with « luax env ».
E.g.: eval $(luax env)
When compiling scripts (options -t and -o), the scripts shall
contain tags (e.g. in comments) showing how the script is used by LuaX:
--@MAIN: main script (must be unique)--@LOAD: library that isrequire’d before the main script is run and stored in a global variable--@LIB: library that must be explicitlyrequire’d by the main script--@NAME=<new module name>: library that isrequire’d with<new module name>instead of the source filename.
Scripts without tags are classified using a simplistic heuristic:
- if the last non empty line starts with
returnthen it is a library (as if it contained a@LIBtag) - otherwise it is the main script (as if it contained the
@MAINtag).
This heuristic should work for most of the Lua scripts but explicit tags are recommended.
Examples
# Native compilation (luax is a symlink to the luax binary of the host)
$ luax -o executable main.lua lib1.lua lib2.lua
$ ./executable # equivalent to luax main.lua
# Cross compilation to MacOS x86_64
$ luax -o executable -t x86_64-macos-gnu main.lua lib1.lua lib2.lua
# Available targets
$ luax -t list
Targets producing standalone LuaX executables:
aarch64-linux-gnu path/luax-aarch64-linux-gnu
aarch64-linux-musl path/luax-aarch64-linux-musl
aarch64-macos-gnu path/luax-aarch64-macos-gnu
i386-linux-gnu path/luax-i386-linux-gnu
i386-linux-musl path/luax-i386-linux-musl
i386-windows-gnu path/luax-i386-windows-gnu.exe
x86_64-linux-gnu path/luax-x86_64-linux-gnu
x86_64-linux-musl path/luax-x86_64-linux-musl
x86_64-macos-gnu path/luax-x86_64-macos-gnu
x86_64-windows-gnu path/luax-x86_64-windows-gnu.exe
Targets based on an external Lua interpreter:
lua path/lua
lua-lua path/lua
lua-luax path/lua
luax path/luax
luax-luax path/luax
pandoc path/pandoc
pandoc-lua path/pandoc
pandoc-luax path/pandocBuilt-in modules
The luax runtime comes with a few builtin modules.
Some modules are heavily inspired by BonaLuna and lapp.
- LuaX interactive usage: improved Lua REPL
- F: functional programming inspired functions
- L:
pandoc.Listmodule from the Pandoc Lua interpreter - fs: file system management
- sh: shell command execution
- mathx: complete math library for Lua
- imath: arbitrary precision integer and rational arithmetic library
- qmath: rational number library
- complex: math library for complex numbers based on C99
- ps: Process management module
- sys: System module
- term: Terminal manipulation module
- crypt: cryptography module
- lz4: Extremely Fast Compression algorithm
- lpeg: Parsing Expression Grammars For Lua
- linenoise: light readline alternative
- prompt: minimalistic readline alternative (to be used
with
rlwrap) - luasocket: Network support for the Lua language
- argparse: Feature-rich command line parser for Lua
- inspect: Human-readable representation of Lua tables
- serpent: Lua serializer and pretty printer
Shared libraries
LuaX is also available as a shared library. This shared library is a Lua
module that can be loaded with require. It provides the same modules
than the LuaX executable and can be used by a regular Lua interpreter
(e.g.: lua, pandoc, …).
E.g.:
$ lua -l luax-x86_64-linux-gnu
Lua 5.4.4 Copyright (C) 1994-2022 Lua.org, PUC-Rio
> F = require "F"
> F.range(100):sum()
5050
> F.show({x=1, y=2})
{x=1, y=2}
> F.show({x=1, y=2}, {indent=4})
{
x = 1,
y = 2,
}
Pure Lua modules
Some modules have been reimplemented in pure Lua (no LuaX dependency).
The script lib/luax.lua can be reused in pure Lua programs:
- luax.lua:
fun,fs,sh,ps,sysreimplemented in pure Lua
License
luax is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
luax is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with luax. If not, see <https://www.gnu.org/licenses/>.
For further information about luax you can visit
http://cdelord.fr/luax
luax uses other third party softwares:
- Zig 0.9.1: General-purpose programming language and toolchain for maintaining robust, optimal, and reusable software. (MIT license)
- Lua 5.4: Copyright (C) 1994-2022 Lua.org, PUC-Rio (MIT license)
- Lpeg: Parsing Expression Grammars For Lua (MIT license)
- luasocket: Network support for the Lua language (LuaSocket 3.0 license)
- linenoise: A small self-contained alternative to readline and libedit (BSD-2-Clause license)
- inspect: Human-readable representation of Lua tables (MIT license)
- serpent: Lua serializer and pretty printer. (MIT license)
- TinyCrypt: tinycrypt is a library of cryptographic algorithms with a focus on small, simple implementation (License)
- LZ4: Extremely Fast Compression algorithm (License)
- Argparse: a feature-rich command line parser for Lua (MIT license)