To build the executable programs included in TeX Live, there are usual steps of downloading the sources, configuring, compiling, and installing. But there are some peculiarities, briefly described here.
TeX Live, unlike many other projects, ships precompiled binaries to TeX users. This web page is especially for the volunteers who contribute those binaries, but anyone who wants to build TeX Live from source may find it useful.
We have a mailing list specifically for discussion of build issues: tlbuild@tug.org. Feel free to join or peruse the archives if you are interested.
On this page: downloading - building - deployment/testing - xz - xindy - asymptote - volunteers.
A separate page describes the ways to get the development sources. If all you want to do is compile the sources (as opposed to having a complete runnable TeX system), you can use rsync -a --delete --exclude=.svn tug.org::tldevsrc/Build/source/ /your/dir/
All the components of the TeX Live release, including the program sources, are also available as a tarball.
The simplest way is to configure, compile, and install in one step using the top-level Build script. Use Build --debug to compile without optimization. (The unstripped binaries will be left in the compilation directory.) Other options are passed to configure.
The prerequisites for a default build are fairly minimal, but you may want to check through them.
If you want to exclude certain programs from the build, use --disable-progname. Run configure --help to see the list.
Most everything that Build does can be overridden with environment variables; take a look. Alternatively, what Build boils down to is configure && make world, where make world is the same as make install strip. Adapt as desired. Run make check for a few minimal tests of what was built.
When making the TL-distributed executables, please use Build or otherwise arrange for the binaries to be stripped. (The targets world and strip in the top-level Makefile will do this.)
When making executables for an independent distro, we request/encourage adding a suffix to the banner, via adding something like this to the configure arguments: --with-banner-add='/MyDistro'. When using the Build script, that would be TL_CONFIGURE_ARGS=--with-banner-add=....
The result of the TL make install is a directory such as Build/source/inst/bin/i686-pc-linux-gnu full of executables, but they can't be directly run from there. (The data files created by make install under inst/ aren't directly useful for anything. Ignore them.)
The easiest way to test the newly-built binaries is to copy/move that bindir to the existing Master/bin/archname in a full TL checkout, where archname is the TL platform name, such as i386-linux. (This is different than the result of the build.)
Then run, e.g., latex small2e; the latex.fmt file should be automatically built and you should end up with a small2e.dvi file that you can, for example, view with xdvi or convert with dvips.
For the TL-distributed executables, when you are happy with the results, either post a tarball of the bindir (preferably with no top level directory) on the web somewhere and email karl@tug.org, or commit them to the TL repository yourself. If you like to do it youself, you may find the tl-update-bindir script useful. (It takes care of Subversion housekeeping chores mostly related to symbolic links.)
For deploying and testing your own builds, you may find the TeX Live tarballs convenient. For instance, if you have run configure with --disable-multiplatform --prefix=/somewhere/texlive, then unpack at least the texmf and texmf-dist tarballs under /somewhere.
You can also use the TeX Live installer with the -custom-bin option to test installation.
xz is a compression format (essentially zip with improved parameters), which compresses both better and faster than bzip2. We are using it for packages as of TeX Live 2009. (We used xz's predecessor, lzma, in 2008.)
For convenience, there is a copy of the current sources in the TL repository. It is not built by default, because we do not want the xz executables in our normal bin directories. All we want are the stripped xz and xzdec binaries in Master/tlpkg/installer/xz, with the platform name as a suffix, e.g., xz.i386-linux.
So, for the TL-distributed executables, something like this:
The `tlmgr -print-arch` is just a generic short cut to get
the platform name as known to TeX Live—the names of the
directories under Master/bin/ in the source repository.  You
can also just type in the string :).
Special considerations for xindy
We include Joachim Schrod's xindy indexing program in TeX Live. However, xindy requires GNU CLISP; therefore, it is disabled by default in the Build script.
For the TL-distributed executables, to enable xindy, first compile clisp, as explained in the instructions for setting up clisp. (This info is at the end of source/utils/README; you can ignore the notes about the other programs.) There is no need to install clisp anywhere. Then, specify the path to the clisp binary built in your clisp source tree to Build or configure, as in --enable-xindy CLISP=/path/to/clisp/binary.
The reason for building our own clisp to use for the TL compilation is to minimize shared library dependencies. Although some systems come with clisp, using the system version will almost certainly result in pulling in many other libraries, resulting in an xindy executable that's unlikely to work for many TL users.
We include the asymptote 3d graphics software in TeX Live. However, due to the complexity of its build process, it is not enabled in the Build script. Instead, you have to do it by hand:
You can test the various libraries with the asytestlibs.asy file available in the source tree. Running make check will run many more tests.
Then, send karl@tug.org a url to the resulting asy executable. If you want to commit it yourself, also commit a symlink named xasy, pointing to ../../texmf/asymptote/GUI/xasy.py.
Explanations:
This web page isn't the place to write in depth about how TeX and friends are compiled in TeX Live. In brief, Knuth's original sources are implemented as literate programs using Pascal, and TL's web2c process converts them to C for compilation.
Here is a list of platforms and their respective builders, to the best of our knowledge. Volunteers for other systems are most welcome.
Please send corrections to the tlbuild list.