install-tl - TeX Live cross-platform installer


install-tl [option]...

install-tl-windows.bat [option]...

install-tl-advanced.bat [option]...


This installer creates a runnable TeX Live installation from various media, including over the network, from local hard disk, a DVD, etc. The installer works across all platforms supported by TeX Live. For information on initially downloading the TeX Live, see

The basic idea of TeX Live installation is for you to choose one of the top-level schemes, each of which is defined as a different set of collections and packages, where a collection is a set of packages, and a package is what contains actual files.

Within the installer, you can choose a scheme, and further customize the set of collections to install, but not the set of the packages. To work at the package level, use tlmgr (reference just below) after the initial installation is complete.

The default is scheme-full, which installs everything, and this is highly recommended.


Post-installation configuration, package updates, and much more, are handled through tlmgr(1), the TeX Live Manager (

The most up-to-date version of this installer documentation is on the Internet at

For the full documentation of TeX Live, see


As usual, all options can be specified in any order, and with either a leading - or --. An argument value can be separated from its option by either a space or =.

-gui [[=]module]

If no module is given, starts the perltk (see below) GUI installer.

If module is given loads the given installer module. Currently the following modules are supported:


The text mode user interface (default on Unix systems). Same as the -no-gui option.


The wizard mode user interface (default on Windows), asking only minimal questions before installing all of TeX Live.


The expert GUI installer, providing access to more options. Can also be invoked on Windows by running install-tl-advanced.bat.

The perltk and wizard modules, and thus also when calling with bare -gui (with no module), require the Perl/Tk module (; if Perl/Tk is not available, installation continues in text mode.


Use the text mode installer (default except on Windows).

-lang llcode

By default, the GUI tries to deduce your language from the environment (on Windows via the registry, on Unix via LC_MESSAGES). If that fails you can select a different language by giving this option with a language code (based on ISO 639-1). Currently supported (but not necessarily completely translated) are: English (en, default), Czech (cs), German (de), French (fr), Italian (it), Japanese (ja), Dutch (nl), Polish (pl), Brazilian Portuguese (pt_BR), Russian (ru), Slovak (sk), Slovenian (sl), Serbian (sr), Ukrainian (uk), Vietnamese (vi), simplified Chinese (zh_CN), and traditional Chinese (zh_TW).

-repository url|path

Specify the package repository to be used as the source of the installation, either a local directory via /path/to/directory or a file:/ url, or a network location via a http://, https://, or ftp:// url. (No other protocols are supported, and https:// may not work on all platforms.)

The default is to pick a mirror automatically, using; the chosen mirror is used for the entire download. You can use the special argument ctan as an abbreviation for this. See for more about CTAN and its mirrors.

If the repository is on the network, trailing / characters and/or trailing /tlpkg and /archive components are ignored. For example, you could choose a particular CTAN mirror with something like this:


Of course a real hostname and its particular top-level CTAN directory have to be specified. The list of CTAN mirrors is available at

If the repository is local, the installation type (compressed or live) is automatically determined, by checking for the presence of a archive directory relative to the root. Compressed is preferred if both are available, since it is faster. Here's an example of using a local directory:

  -repository /local/TL/repository

After installation is complete, you can use that installation as the repository for another installation. If you chose to install less than the full scheme containing all packages, the list of available schemes will be adjusted accordingly.

For backward compatibility and convenience, --location and --repo are accepted as aliases for this option.


This option allows manual selection of a mirror from the current list of active CTAN mirrors. This option is supported in all installer modes (text, wizard, perltk), and will also offer to install from local media if available, or from a repository specified on the command line (see above). It's useful when the (default) automatic redirection does not choose a good host for you.


Normally options not relevant to the current platform are not shown (e.g., when running on Unix, Windows-specific options are omitted). Giving this command line option allows configuring such "foreign" settings.

-custom-bin path

If you have built your own set of TeX Live binaries (perhaps because your platform was not supported by TeX Live out of the box), this option allows you to specify the path to a directory where the binaries for the current system are present. The installation will continue as usual, but at the end all files from path are copied over to bin/custom/ under your installation directory and this bin/custom/ directory is what will be added to the path for the post-install actions. To install multiple custom binary sets, manully rename custom before doing each.

For more information on custom binaries, see For general information on building TeX Live, see


In GUI mode, this switch makes tlmgr report any missing, or more likely untranslated, messages to standard error. Helpful for translators to see what remains to be done.

-force-platform platform

Instead of auto-detecting the current platform, use platform. Binaries for this platform must be present and they must actually be runnable, or installation will fail. -force-arch is a synonym.

-help, --help, -?

Display this help and exit. (This help is on the web at Sometimes the perldoc and/or PAGER programs on the system have problems, possibly resulting in control characters being literally output. This can't always be detected, but you can set the NOPERLDOC environment variable and perldoc will not be used.


This is a quick-and-dirty installation option in case you already have an rsync or svn checkout of TeX Live. It will use the checkout as-is and will just do the necessary post-install. Be warned that the file tlpkg/texlive.tlpdb may be rewritten, that removal has to be done manually, and that the only realistic way to maintain this installation is to redo it from time to time. This option is not available via the installer interfaces. USE AT YOUR OWN RISK.

-init-from-profile profile_file

Similar to -profile (see "PROFILES" below), but only initializes the installation configuration from profile_file and then starts the interactive session.

-logfile file

Write both all messages (informational, debugging, warnings) to file, in addition to standard output or standard error.

If this option is not given, the installer will create a log file in the root of the writable installation tree, for example, /usr/local/texlive/YYYY/install-tl.log for the YYYY release.


For the text mode installer only: do not clear the screen when entering a new menu (for debugging purposes).


For Windows only: configure for the current user, not for all users.


For network installs, activating this option makes the installer try to set up a persistent connection using the Net::LWP Perl module. This opens only one connection between your computer and the server per session and reuses it, instead of initiating a new download for each package, which typically yields a significant speed-up.

This option is turned on by default, and the installation program will fall back to using wget if this is not possible. To disable usage of LWP and persistent connections, use -no-persistent-downloads.


By default, if a GnuPG gpg binary is found in PATH, downloads are verified against a cryptographic signature. This option disables such verification. The full description is in the Crytographic Verification section of the tlmgr documentation, e.g.,


Install for portable use, e.g., on a USB stick. Also selectable from within the perltk and text installers.

Print the TeX Live identifier for the detected platform (hardware/operating system) combination to standard output, and exit. -print-arch is a synonym.

-profile profile_file

Load profile_file and do the installation with no user interaction, that is, a batch (unattended) install. See "PROFILES" below.


Omit normal informational messages.

-scheme scheme

Schemes are the highest level of package grouping in TeX Live; the default is to use the full scheme, which includes everything. This option overrides that default. You can change the scheme again before the actual installation with the usual menu. The scheme argument may optionally have a prefix scheme-. The list of supported scheme names depends on what your package repository provides; see the interactive menu list.


Include verbose debugging messages; repeat for maximum debugging: -v -v. (Further repeats are accepted but ignored.)

-version, --version

Output version information and exit. If -v has also been given the revisions of the used modules are reported, too.


A profile file contains all the values needed to perform an installation. After a normal installation has finished, a profile for that exact installation is written to the file tlpkg/texlive.profile. In addition, from the text menu one can select P to save the current setup as a profile at any time. Such a profile file can be given as the argument to -profile, for example to redo the exact same installation on a different system. Alternatively, you can use a custom profile, most easily created by starting from a generated one and changing values, or an empty file, which will take all the defaults.

Within a profile file, each line consists of

variable [value]

except for comment lines starting with #. The possible variable names are listed below. Values, when present, are either 0 or 1 for booleans, or strings (which must be specified without any quote characters). Leading whitespace is ignored.

If the variable selected_scheme is defined and no collection variables at all are defined, then the collections required by the specified scheme (which might change over time) are installed, without explicitly listing them. This eases maintenance of profile files. If any collections are specified in a profile, though, then all desired collections must be given explicitly.

For example, a line

  selected_scheme scheme-small

along with definitions for the installation directories (given below under "path options") suffices to install the "small" scheme with all default options. The schemes are described in the S menu in the text installer, or equivalent.

Besides selected_scheme, here is the list of variable names supported in a profile:

collection options (prefix collection-)

Collections are specified with a variable name with the prefix collection- followed by a collection name; there is no value. For instance, collection-basic. The collections are described in the C menu.

Schemes and collections (and packages) are ultimately defined by the files in the tlpkg/tlpsrc/ source directory.

path options

It is best to define all of these, even though they may not be used in the installation, so as to avoid unintentionally getting a default value that could cause problems later.


installer options (prefix instopt_)

instopt_adjustpath (default 0 on Unix, 1 on Windows)

Adjust PATH environment variable.

instopt_adjustrepo (default 1)

Set remote repository to a multiplexed CTAN mirror after installation; see -repository above.

instopt_letter (default 0)

Set letter size paper as the default, instead of a4.

instopt_portable (default 0)

Install for portable use, e.g., on a USB stick.

instopt_write18_restricted (default 1)

Enable \write18 for a restricted set of programs.

tlpdb options (prefix tlpdbopt_)

The definitive list is given in tlpkg/TeXLive/, in %TeXLive::TLConfig::TLPDBOptions, together with explanations. All items given there except for tlpdbopt_location can be specified. Here is the current list:


platform options (prefix binary_)

For each supported platform in TeX Live (directories under bin/), the variable binary_PLATFORM can be set. For example:


If no binary_ variable is specified, the default is whatever the current machine is running.

In releases before 2017, many profile variables had different names (not documented here; see the install-tl source). They are accepted and transformed to the names given above. When a profile is written, the names above are always used.

For more details on all of the above options, consult the TeX Live installation manual, linked from


For ease in scripting and debugging, install-tl will look for the following environment variables. They are not of interest for normal user installations.


Omit the check for environment variables containing the string tex. People developing TeX-related software are likely to have many such variables.


Omit creating the ConTeXt cache. This is useful for redistributors.


Omit printing the welcome message after successful installation, e.g., for testing.


Specify the respective directories. TEXLIVE_INSTALL_PREFIX defaults to /usr/local/texlive, while TEXLIVE_INSTALL_TEXDIR defaults to the release directory within that prefix, e.g., /usr/local/texlive/2016. All the defaults can be seen by running the installer interactively and then typing D for the directory menu.


Don't try to run the --help message through perldoc.


This script and its documentation were written for the TeX Live distribution ( and both are licensed under the GNU General Public License Version 2 or later.

$Id: install-tl 44019 2017-04-24 18:25:41Z karl $