https://wiki.archlinux.org/api.php?action=feedcontributions&user=Pank&feedformat=atomArchWiki - User contributions [en]2024-03-28T13:35:03ZUser contributionsMediaWiki 1.41.0https://wiki.archlinux.org/index.php?title=TeX_Live/FAQ&diff=77660TeX Live/FAQ2009-10-12T17:13:21Z<p>Pank: /* Q: I want to read more! More! I said more! */</p>
<hr />
<div>[[Category:FAQs (English)]]<br />
[[Category:Software (English)]]<br />
[[Category:Office (English)]]<br />
<br />
This FAQ contains answers to some TeXlive related questions that have appeared on the forums, as well as some other info that might be useful.<br />
<br />
= General questions: Where should I start? Resources? =<br />
<br />
For an introduction to LaTeX, I recommend "The not so Short Introduction to LaTeX" by Tobias Oetiker. Originally German, this document is translated to many languages, especially to the lingua franca of the Internet, English. Downloadable from CTAN [http://www.ctan.org/tex-archive/info/lshort/ here].<br />
<br />
==Q: How can I access texlive documentation?==<br />
'''A:''' Provided that you installed appropriate texlive-*-doc packages,<br />
texdoc <packagename><br />
can probably (i.e. in many cases) do the job. Unfortunately some package authors do not name their documentation equally to their package. So asking for documentation in Forums or mailing lists not always is silly.<br />
<br />
==Q: I want latex to do something special, and I'm pretty sure someone before me had to have the same problem.==<br />
'''A:''' There is an excellent [http://www.tex.ac.uk/cgi-bin/texfaq2html TeX FAQ] on the web. Typical latex problems (special headers, different page layout, tricks with tables, etc..) are all covered there. Searchable!<br />
<br />
==Q: I want to read more! More! I said more!==<br />
'''A:''' Andy Roberts (arooaroo) has a couple of tricks on his website [http://www.andy-roberts.net/misc/latex/index.html Getting to grips with LaTeX], which has been used as a basis for [http://en.wikibooks.org/wiki/LaTeX LaTeX wikibook]. You could also check out [http://www.ctan.org/tex-archive/info/lshort/ The not so Short Introduction to LaTeX] which is available in many languages.<br />
<br />
= Tricks with LaTeX =<br />
<br />
==Q: I need/want to use some funky bibliography/references format.==<br />
'''A:''' [http://www.ctan.org/tex-archive/help/Catalogue/entries/biblatex.html biblatex] is then the thing you are looking for (it's in AUR). It has an enhancement [http://www.ctan.org/tex-archive/help/Catalogue/entries/biblatex-dw.html biblatex-dw], also in AUR, which is especially valuable for the special issues in the Humanities.<br />
<br />
= TeXlive directory structure and important files =<br />
<br />
==Q: What's up with all these dirs /usr/share/{texmf,texmf-dist,texmf-var,texmf-config}?==<br />
'''A:''' TeX uses several "source trees"; they have the same internal structure, and can "overlap". This is to allow users to modify files provided system-wide without having to access files they're not supposed to access. Here's the portion of the main config file which lists all these dirs with some explanations ($SELFAUTODIR=/usr/share):<br />
% The tree containing the runtime files closely related to the specific<br />
% program version used:<br />
TEXMFMAIN = $SELFAUTODIR/texmf<br />
% The main distribution tree:<br />
TEXMFDIST = $SELFAUTODIR/texmf-dist<br />
% A place for local additions to a "standard" texmf tree.<br />
% This tree is not used for local configuration maintained by<br />
% texconfig, it uses TEXMFCONFIG below.<br />
TEXMFLOCAL = $SELFAUTODIR/texmf-local<br />
% TEXMFSYSVAR, where texconfig-sys stores variable runtime data.<br />
TEXMFSYSVAR = $SELFAUTODIR/texmf-var<br />
% TEXMFSYSCONFIG, where texconfig-sys stores configuration data.<br />
TEXMFSYSCONFIG = $SELFAUTODIR/texmf-config<br />
% User texmf trees are allowed as follows.<br />
TEXMFHOME = $HOME/texmf<br />
% TEXMFVAR, where texconfig stores variable runtime data.<br />
TEXMFVAR = $HOME/.texmf-var<br />
% TEXMFCONFIG, where texconfig stores configuration data.<br />
TEXMFCONFIG = $HOME/.texmf-config<br />
Note that they are searched in the reverse order that they are listed above (I think). So when some problems pops up, search the trees in the proper order ;)<br />
<br />
One more remark: if you install something just for you, it should go to your home texmf tree. However, on desktops, you might not want to clutter your home dir; then it should go to texmf-local tree (which should be writable by the "tex" group).<br />
<br />
==Q: I want to have some configuration app!==<br />
'''A:''' Run<br />
texconfig<br />
Careful! When you run this as a user, you modify settings for that user. If you want to modify system-wide settings, run<br />
texconfig-sys<br />
as root instead.<br />
<br />
==Q: I want to edit textfiles! Where are some configuration files?==<br />
'''A:''' Keeping in mind the above directory structure (<texmfroot> refers to one of the dirs above), here you go:<br />
The main config file:<br />
<texmfroot>/web2c/texmf.cnf<br />
List of formats generated:<br />
<texmfroot>/web2c/fmtutil.cnf<br />
Settings with which are e.g. bitmap fonts generated<br />
<texmfroot>/web2c/mktex.cnf<br />
Which and how type1 fonts are used instead of metafont generated bitmap ones?<br />
<texmfroot>/web2c/updmap.cfg<br />
<br />
= Common problems with TeXlive =<br />
<br />
==Q: I just updated texlive and it stopped working.==<br />
'''A:''' While this can be caused by many things, the most common reason for troubles of this sort is the following mechanism of how texlive works: there can be more than one "tree of tex files" which are put "on top of each other" as far as TeX is concerned (see question 3.1 above), and so there can be more copies of "the same" config file around on the disk, and only one of them is used. In particular, if a user makes some config changes, or generates some formats, the resulting "changes" are saved in the local user's tree (~/.texlive/texmf-{var,config}), and while these exist, they are '''always''' preferred over the system files. This implies that even if the system files are updated on texlive update, when a user runs tex, it still uses the "old" files that are in ~/.texlive.<br />
<br />
Hence, if you suspect that this might be the cause of the problem, you can<br />
* backup your ~/.texlive dir somewhere and try again. If the problem persists, with big probability it's a problem with some texlive-* package.<br />
* there is a tool with which one can check which file with a particular name is "seen" by tex. Namely<br />
kpsewhich <filename><br />
returns the full path to file of that name that would tex use.<br />
<br />
Finally, the most usual troubles that span from this behavior are:<br />
* after upgrade, tex "stops working" with the following error message:<br />
Fatal format file error; I'm stymied.<br />
What one should understand is that TeX system "precompiles" formats (that is, takes the macros which constitute for instance the latex format, and creates a binary thing (file latex.fmt), which is then used when you call "latex <somefile>"). Now when the tex binary itself is updated, all the precompiled formats need to be recompiled as well. While pacman does that for you for system-wide formats, the info above implies that if a user (or some program like LyX) ever compiled the formats by himself, that user needs to recompile the formats manually. The command for that is<br />
fmtutil --all<br />
(as a user). (Btw, the location of *.fmt files is <texmfroot>/texmf-var/web2c.) The other option is to delete the *.fmt files from the local tree (~/.texlive/texmf-var/web2c/*.fmt) and use the system-wide generated formats (which can be regenerated by "sudo fmtutil-sys --all").<br />
* after upgrade, some fonts stop being used properly; or there is an error that tex can't find some font. This is related to the question 4.4 below - you most probably have a local 'updmap.cfg' file (check by "kpsewhich updmap.cfg") which doesn't reflect changes in *.map files and fonts which came with the upgrade. In this case, apply the methods from the question 4.4.<br />
<br />
==Q: I want use ConTeXt.==<br />
'''A:''' (English) ConTeXt should be enabled automatically. Remember that the ruby wrapper to be used with ConTeXt is<br />
texexec<br />
If ConTeXt is not enabled (or you want to use localized version), use<br />
texconfig<br />
to edit the configuration file with formats, and uncomment the appropriate lines.<br />
To set up the new MarkIV implementation of ConTeXt, see http://wiki.contextgarden.net/Running_Mark_IV<br />
<br />
==Q: I've just installed some .sty files, but tex doesn't seem to see them.==<br />
'''A:''' TeXlive (and tetex) uses its own directory indexes (files named ls-R), and you need to refresh them after you copy something into one of the TeX trees. Magic command:<br />
mktexlsr<br />
or<br />
texhash<br />
or<br />
texconfig[-sys] rehash<br />
A command line program to search through these indexes is<br />
kpsewhich<br />
Hence you can check that TeX can find a particular file by running<br />
kpsewhich <filename><br />
The output should be full path to that file.<br />
<br />
==Q: Pdftex and/or dvips uses bitmap fonts instead of type1 postscript fonts (aka "when I zoom my pdf/ps file, fonts are really pixelated" aka "everytime I run tex, it takes a long time because it generates fonts with metafont" aka "at the end of my logfile generated by pdftex I see that it includes *.pk fonts instead of *.pfb)==<br />
'''A:''' This takes a bit of time to explain. Now it's important that you understand how does the system work, so that you know what you're doing.<br />
<br />
* Files which tell pdftex/dvips which fonts are to be included as type1 fonts (instead of traditional bitmap fonts) have suffix .map and reside somewhere in <texmfroot>/fonts/map/{pdftex,dvips}/updmap/{pdftex.map,psfonts.map}.<br />
* You '''don't''' want to edit these files manually; they're good for checking if your favorite type1 font which causes troubles is sitting there properly.<br />
* These files are automatically generated, when you run<br />
updmap<br />
as user (or<br />
updmap-sys<br />
as root for system-wide changes)<br />
* What you need to do to have your favorite fonts (for instance kpfonts) properly used as type1 fonts in pdf and ps files is to locate the .map file that goes with the package (e.g. kpfonts.map; you don't need to actually *do* anything with the file, just know that it's there somewhere), edit updmap.cfg by running<br />
updmap --edit<br />
as user (or "updmap-sys --edit" as root) and add the line<br />
Map kpfonts.map<br />
or the line<br />
MixedMap kpfonts.map<br />
(MixedMap indicates that fonts are also available as bitmap fonts.), and exit the editor. At this point, you should see the messages which indicate that updmap is regenerating {pdftex,psfonts}.map files.<br />
* This should be sufficient, and your next run of pdftex/dvips should be already including the type1 versions of fonts.<br />
<br />
= Useful apps to use with (any TeX installation) =<br />
<br />
==Q: Editors? ==<br />
'''A:''' Great for beginners (errr...) are [http://kile.sourceforge.net/ kile] (depends on kde though) or [http://winefish.berlios.de/ winefish]. <br />
<br />
For serious work, especially scientic papers, more especially in the humanities, I strongly recommend emacs with reftex and [http://www.gnu.org/software/auctex/ auctex]. Reftex helps very much with references within big documents.<br />
<br />
Also (g)vim with [http://vim-latex.sourceforge.net/ vim-latex] (although I had some problems with it with vim-7.* versions) might be a good solution. If you have problems with vim-latex, try [http://www.vim.org/scripts/script.php?script_id=162 auctex.vim], which has much of the same functionality. If you are more WYSIWIG oriented, then perhaps [http://www.lyx.org/Home lyx] (just be aware that transitions "lyx <-> manual source editing" is not always seamless, and using your own macros is a bit awkward of course); or [http://www.texmacs.org/ texmacs] (with which I have no experience, and it seems a bit outdated).<br />
<br />
==Q: Pictures with LaTeX labels?==<br />
'''A:''' Apart from some latex in-source macros (which are a bit of a PITA to write), there are excellent "picture programming languages" [http://cm.bell-labs.com/who/hobby/MetaPost.html metapost] and its (more-less) successor [http://asymptote.sourceforge.net asymptote]. They are pretty powerful, but have similar approach as tex itself - you write down what you want to have and how are the things related, and compiler then produces the picture. The target format is postscript for metapost; and eps/pdf/png for asymptote.<br />
<br />
Even closer incorporated to TeX itself - i.e. to Plain TeX, LaTeX or Context, there are layers for each of this formats - is the relatively new PGF package with its language named [http://www.fauskes.net/pgftikzexamples/ TIKZ].<br />
<br />
The Python library [http://pyx.sourceforge.net/ PyX] (named python-pyx in AUR) gives the possibillity to use Python to program pictures, and it uses TeX for the typesetting.<br />
<br />
Last but not least: [http://tug.org/PSTricks/main.cgi/ PSTricks], which gives an interface for direct inclusion of Postscript-code into TeX ([http://pages.cs.wisc.edu/~ghost/doc/AFPL/6.50/Ps2pdf.htm ps2pdf]). There are some hurdles to climb if you want to have pdf-output, because PSTricks is not compatible to pdftex.<br />
<br />
==Q: Pictures with LaTeX labels - I want GUI! - I want pictures fast!==<br />
'''A:''' The "grandfather" of vector editors - xfig is able to produce some output relevant to tex. I had relatively good experience with [http://tclab.kaist.ac.kr/ipe/ ipe] recently (saves eps/pdf). Inkscape is a good choice too.</div>Pank