texlua
LUATEX(1) General Commands Manual LUATEX(1)
NAME
luatex, dviluatex, luajittex, texlua, texluac - An extended version of
pdfTeX using Lua as an embedded scripting language
SYNOPSIS
luatex [--lua=FILE] [OPTION]... [TEXNAME[.tex]] [COMMANDS]
luatex [--lua=FILE] [OPTION]... \FIRST-LINE
luatex [--lua=FILE] [OPTION]... &FMT [ARGS]
DESCRIPTION
Run the luaTeX typesetter on TEXNAME, usually creating TEXNAME.pdf.
Any remaining COMMANDS are processed as luaTeX input, after TEXNAME is
read.
Alternatively, if the first non-option argument begins with a back-
slash, interpret all non-option arguments as a line of luaTeX input.
Alternatively, if the first non-option argument begins with a &, the
next word is taken as the FMT to read, overriding all else. Any remain-
ing arguments are processed as above.
If no arguments or options are specified, prompt for input.
If called as texlua it acts as lua interpreter. If called as texluac
it acts as lua bytecode compiler.
LuaTeX is an extended version of pdfTeX with Unicode and OpenType font
support, embedded Lua scripting language, the e-TeX and Omega exten-
sions, as well as integrated MetaPost engine, that can create PDF files
as well as DVI files. For more information about luatex, see
http://www.luatex.org, you can read LuaTeX manual using texdoc utility
(texdoc luatex).
All LuaTeX text input and output is considered to be Unicode text.
In DVI mode, luaTeX can be used as a complete replacement for the TeX
engine.
In PDF mode, luaTeX can natively handle the PDF, JPG, JBIG2, and PNG
graphics formats. luaTeX cannot include PostScript or Encapsulated
PostScript (EPS) graphics files; first convert them to PDF using epsto-
pdf (1).
OPTIONS
When the LuaTeX executable starts, it looks for the --lua command-line
option. If there is no --lua option, the command line is interpreted
in a similar fashion as in traditional pdfTeX and Aleph. But if the op-
tion is present, LuaTeX will enter an alternative mode of command-line
parsing in comparison to the standard web2c programs. The presence of
--lua makes most of other options unreliable, because the lua initial-
ization file can disable kpathsea and/or hook functions into various
callbacks.
--lua=FILE
The lua initialization file.
The following two options alter the executable behaviour:
--luaonly
Start LuaTeX as a Lua interpreter. In this mode, it will set
Lua's arg[0] to the found script name, pushing preceding options
in negative values and the rest of the command line in the posi-
tive values, just like the Lua interpreter. LuaTeX will exit im-
mediately after executing the specified Lua script.
--luaconly
Start LuaTeX as a Lua byte compiler. In this mode, LuaTeX is ex-
actly like luac from the standalone Lua distribution, except
that it does not have the -l switch, and that it accepts (but
ignores) the --luaconly switch.
Then the regular web2c options:
--debug-format
Debug format loading.
--draftmode
Sets \pdfdraftmode so luaTeX doesn't write a PDF and doesn't
read any included images, thus speeding up execution.
--enable-write18
Synonym for --shell-escape.
--disable-write18
Synonym for --no-shell-escape.
--shell-escape
Enable the \write18{command} construct, and Lua functions os.ex-
ecute(), os.exec(), os.spawn(), and io.popen(). The command can
be any shell command. This construct is normally disallowed for
security reasons.
--no-shell-escape
Disable the \write18{command} construct and the other Lua func-
tions, even if it is enabled in the texmf.cnf file.
--shell-restricted
Enable restricted version of \write18, os.execute(), os.exec(),
os.spawn(), and io.popen(), only commands listed in texmf.cnf
file are allowed.
--file-line-error
Print error messages in the form file:line:error which is simi-
lar to the way many compilers format them.
--no-file-line-error
Disable printing error messages in the file:line:error style.
--fmt=FORMAT
Use FORMAT as the name of the format to be used, instead of the
name by which luaTeX was called or a %& line.
--help Print help message and exit.
--ini Start in INI mode, which is used to dump formats. The INI mode
can be used for typesetting, but no format is preloaded, and ba-
sic initializations like setting catcodes may be required.
--interaction=MODE
Sets the interaction mode. The MODE can be either batchmode,
nonstopmode, scrollmode, and errorstopmode. The meaning of
these modes is the same as that of the corresponding \commands.
--jobname=NAME
Use NAME for the job name, instead of deriving it from the name
of the input file.
--kpathsea-debug=BITMASK
Sets path searching debugging flags according to the BITMASK.
See the Kpathsea manual for details.
--mktex=FMT
Enable mktexFMT generation, where FMT must be either tex or tfm.
--nosocket
Disable the luasocket (network) library.
--output-comment=STRING
In DVI mode, use STRING for the DVI file comment instead of the
date. This option is ignored inPDF mode.
--output-directory=DIRECTORY
Write output files in DIRECTORY instead of the current direc-
tory. Look up input files in DIRECTORY first, then along the
normal search path.
--output-format=FORMAT
Set the output format mode, where FORMAT must be either pdf or
dvi. This also influences the set of graphics formats under-
stood by luaTeX.
--progname=NAME
Pretend to be program NAME (only for kpathsea).
--recorder
Enable the filename recorder. This leaves a trace of the files
opened for input and output in a file with extension .fls.
--safer
Disable some Lua commands that can easily be abused by a mali-
cious document.
--synctex=NUMBER
Enable/disable SyncTeX extension.
--version
Print version information and exit.
--credits
Print credits and version details.
The following options are ignored:
--8bit, --etex, --parse-first-line, --no-parse-first-line
These are always on.
--default-translate-file=TCXNAME, --translate-file=TCXNAME
These are always off.
SEE ALSO
pdftex(1), etex(1), aleph(1), lua(1).
AUTHORS
The primary authors of LuaTeX are Taco Hoekwater, Hartmut Henkel, Hans
Hagen, and Luigi Scarso, with help from Martin Schroder, Karel Skoupy,
and Han The Thanh.
TeX was designed by Donald E. Knuth, who implemented it using his Web
system for Pascal programs. It was ported to Unix at Stanford by
Howard Trickey, and at Cornell by Pavel Curtis. The version now of-
fered with the Unix TeX distribution is that generated by the Web to C
system (web2c), originally written by Tomas Rokicki and Tim Morgan.
The LuaTeX home page is http://luatex.org.
Web2C 2019 27 May 2018 LUATEX(1)
Man Pages Copyright Respective Owners. Site Copyright (C) 1994 - 2025
Hurricane Electric.
All Rights Reserved.