It sometimes happens that you need a new version of some macro package or font, but that the machine you use is maintained by someone who’s unwilling to update and won’t give you privileges to do the job yourself. A “temporary” installation is sometimes the correct approach, but if there’s the slightest chance that the installation will be needed on more than one project, temporary installations aren’t right.
In circumstances where you have plenty of quota on backed-up media, or adequate local scratch space, the correct approach is to create a private installation of (La)TeX which includes the new stuff you need; this is the ideal, but is not generally possible.
So, since you can’t install into the public texmf
tree, you
have to install into a texmf of your own; fortunately, the
TDS standard allows for this, and teTeX 2.0 actually makes
provision for it, defining an internal variable HOMETEXMF
which points to the directory $HOME/texmf. (TeTeX 1.0 had
the definition, but suppressed it with comment markers.)
So, install your new package (or whatever) in the correct place in a tree based on $HOME/texmf, and generate an index of that tree
texhash $HOME/texmf
(the argument specifies which tree you are indexing: it’s necessary since you don’t, by hypothesis, have access to the main tree, and texhash without the argument would try to write the main tree.
There are two wrinkles to this simple formula: first, the installation
you’re using may not define HOMETEXMF
(teTeX 1.0
didn’t, for example), and second, there may be some obstruction to
using $HOME/texmf as the default name. In either case, a good
solution is to have your own texmf.cnf — an idea that sounds
more frightening that it actually is. The installation’s existing
file may be located with the command:
kpsewhich texmf.cnf
Take a copy of the file and put it into a directory of your own; this could be any directory, but an obvious choice is the web2c directory of the tree you want to create, i.e., $HOME/texmf/web2c or the like. Make an environment variable to point to this directory:
TEXMFCNF=$HOME/texmf/web2c export TEXMFCNF
(for a Bourne shell style system), or
setenv TEXMFCNF $HOME/texmf/web2c
(for a C-shell style system). Now edit the copy of texmf.cnf
There will be a line in the existing file that defines the tree where everything searches; the simplest form of the line is:
TEXMF = !!$TEXMFMAIN
but, as teTeX 1.0 is distributed, there are several alternative
settings behind comment markers (“%
”), and the
person who
installed your system may have left them there. Whatever, you need to
modify the line that’s in effect: change the above to three lines:
HOMETEXMF = $HOME/texmf TEXMF = {$HOMETEXMF,!!$TEXMFMAIN} % TEXMF = !!$TEXMFMAIN
the important point being that $HOMETEXMF
must come before whatever
was there before, inside the braces. For example, if the original was
TEXMF = {!!$LOCALTEXMF,!!$TEXMFMAIN}
it should be converted to:
HOMETEXMF = $HOME/texmf TEXMF = {$HOMETEXMF,!!$LOCALTEXMF,!!$TEXMFMAIN} % TEXMF = {!!$LOCALTEXMF,!!$TEXMFMAIN}
(retaining the original, as a comment, is merely an aide-memoir in
case you need to make another change, later). The !!
signs
tell the file-searching library that it should insist on a
texhash-ed directory tree; if you can count on yourself
remembering to run texhash on your new tree every time you
change it, then it’s worth adding the marks to your tree:
TEXMF = {!!$HOMETEXMF,!!$LOCALTEXMF,!!$TEXMFMAIN}
as this will make (La)TeX find its files marginally faster.
Having made all these changes, (La)TeX should “just use” files in your new tree, in preference to anything in the main tree — you can use it for updates to packages in the main tree, as well as for installing new versions of things.
This question on the Web: http://www.tex.ac.uk/cgi-bin/texfaq2html?label=privinst