Sourceforge |
|
JadeTeX |
This is a TeX macro package for processing the output from Jade/OpenJade in TeX (-t) mode. You can download it from Sourceforge; http://sourceforge.net/projects/jadetex/.
This documents is based on a note by FC describing his experience installing JadeTeX with OpenJade 1.3 and teTeX 1.06 (on Unix). It has since been expanded and checked by SR and SP. It is aimed to people who have perhaps some experience using TeX and LaTeX, enough to write up technical reports using simple macros, but know little or nothing about format files or the particulars of the TeX distribution structure, and consequently have a rough time with JadeTeX…
This document relates to JadeTeX version 2.11 or later.
To use JadeTeX, you first of all should compile and install
OpenJade. The resulting openjade executable, used
with the -t tex
flag, will format an
SGML/XML file and yield a TeX output file. Using
jadetex or pdfjadetex, you can
transform this into DVI or PDF;
from DVI, you can use a program like
dvips to get PostScript output. This note describes
how to build and install the former two programs,
jadetex and pdfjadetex.
The TeX output file uses a macro package, JadeTeX, built on
top of LaTeX, just as LaTeX is a macro package sitting on top of
plain TeX. It is probably possible to just stick an
\input
at the top of your
.tex
file and use the JadeTeX macros this
way, but that would be slow since TeX would need to parse and
compile the macro definitions every time you format your
.tex
file. So what we do instead is to use
TeX (actually, initex) to read in the LaTeX
format, followed by the JadeTeX package, once, and dump the
compiled image to what is called a
‘format file.’
This is the same way that LaTeX is usually employed. Once the
format file is built and installed, it is easy to arrange for
TeX to read it in quickly and automatically when you process a
.tex
file.
But, as ever, there are complications, relating to TeX's capacity restrictions. TeX is designed to use a fixed amount of resources to process documents; for example, there is a maximum number of strings that can be allocated, and a maximum stack size. If a processing run exceeds the default limits, TeX will complain and refuse to continue. Unfortunately, OpenJade's TeX backend tends to exceed these default limits.
Fortunately, though, there is no need to recompile your TeX
binary. If you are using teTeX (or any other Web2c-based
distribution) there will be a file called
texmf.cnf
in your installation which sets
the capacity parameters and is consulted every time TeX is
run. By adding the right parameter settings here, you can
ensure that JadeTeX will be unlikely to run out of memory.
Where is texmf.cnf
? You can find it in the
web2c
directory under
your texmf
tree... which begs the question, where
is texmf
? The most
straightforward way to find it is to make sure all the TeX executables
are in your PATH
; then do:
kpsewhich -expand-var '$TEXMFMAIN'
/usr/share/texmf/web2c/texmf.cnf
and it will
respond with the location of your texmf tree. As you can see, it is also
known as $TEXMFMAIN
, which is how I shall
refer to it in the sequel.
If for some reason kpsewhich is not in your
PATH
,
and you don't know where it is, here are some likely locations:
/usr/share/texmf
/usr/local/share/texmf
/usr/local/teTeX/texmf
/usr/local/lib/teTeX/texmf
/usr/local/lib/texmf
/usr/lib/texmf
/usr/lib/teTeX/texmf
In a minute we are going to modify texmf.cnf
to
increase the capacities, then build the JadeTeX format file and install
the JadeTeX executable(s). You may have a command
hugelatex, a version of latex with greater
capacity settings than the usual one, which is named simply
latex. If so, build your format file
using hugelatex rather than
latex, so that JadeTeX inherits the `huge'
settings. Otherwise, make sure your latex is big.
In addition, if you make any changes to the literate source of the
JadeTeX macro package (see below), a normal latex
may not do.
First we need to update texmf.cnf to ensure that latex really is huge. Take a look at the top of the file. It will probably say:
%original texmf.cnf -- runtime path configuration file for kpathsea. % (If you change or delete `original' on the previous line, the % distribution won't install its version over yours.)If it says
% TeX Live texmf.cnfthen you can skip all this and proceed to the next section, as TeX Live is already set up for JadeTeX
If you have an `original', follow those directions and delete the string
original
to ensure that
future upgrades won't obliterate your changes.
In the latter half of the file, you will find the capacity settings, which look something like this:
pool_size = 125000 pool_size.context = 750000Here,
pool_size
is the name of the parameter in
both cases, but the second one is qualified with
.context
, which indicates that this setting will be
preferred when using the ConTeXt macro package. We need to make similar
accomodations not only for latex but also
jadetex and pdfjadetex.
Unfortunately, we don't know the minimal required values for every
parameter and some of these values are probably
ridiculously high, but no matter ...
% latex settings main_memory.latex = 1100000 param_size.latex = 1500 stack_size.latex = 1500 hash_extra.latex = 15000 string_vacancies.latex = 45000 pool_free.latex = 47500 nest_size.latex = 500 save_size.latex = 5000 pool_size.latex = 500000 max_strings.latex = 55000 font_mem_size.latex= 400000 % jadetex & pdfjadetex main_memory.jadetex = 1500000 param_size.jadetex = 1500 stack_size.jadetex = 1500 hash_extra.jadetex = 50000 string_vacancies.jadetex = 45000 pool_free.jadetex = 47500 nest_size.jadetex = 500 save_size.jadetex = 5000 pool_size.jadetex = 500000 max_strings.jadetex = 55000 main_memory.pdfjadetex = 2500000 param_size.pdfjadetex = 1500 stack_size.pdfjadetex = 1500 hash_extra.pdfjadetex = 50000 string_vacancies.pdfjadetex = 45000 pool_free.pdfjadetex = 47500 nest_size.pdfjadetex = 500 save_size.pdfjadetex = 5000 pool_size.pdfjadetex = 500000 max_strings.pdfjadetex = 55000Add these to the end of the file, or wherever makes you happy.
Now let's build some format files. Under
$TEXMFMAIN/tex/latex/config
,
you will find the files necessary to rebuild latex.
Copy them somewhere temporary and go there:
cp -R /usr/share/texmf/tex/latex/config /tmp cd /tmp/configNow do this:
tex -ini -progname=latex latex.iniThis will produce a file
latex.fmt
in the same directory. Rename this to
latex.fmt
,
then become root and put it in
$TEXMFMAIN/web2c
. This
is where all the format files are kept. (You can delete the other copied
files from config
afterwards.)
mv latex.fmt /usr/share/texmf/web2c
Now just create a symbolic link from tex to latex:
ln -s /usr/bin/tex /usr/local/bin/latexWhen tex is invoked, it looks at the name
X
it was invoked with, then loads the format
file X.fmt
from
$TEXMFMAIN/web2c
before
it starts processing the document. So creating this symbolic link is all
that is needed to create the latex
executable.
Next, take a look at your OpenJade distribution. Under the directory
dsssl
you will find the files necessary to build
jadetex and pdfjadetex, including a Makefile. Now become root and just do:
make installThis creates
jadetex.fmt
and
pdfjadetex.fmt
, puts them in
$TEXMFMAIN/web2c
for you
(using kpsewhich to find
$TEXMFMAIN
), and installs a few other
auxiliary files under
$TEXMFMAIN/tex/jadetex
.
All that's left to do is to create the links:
ln -s /usr/bin/tex /usr/bin/jadetex ln -s /usr/bin/pdftex /usr/bin/pdfjadetex(changing the location of the binary directory to wherever your TeX is) and run mktexlsr so that your TeX distribution becomes aware of the newly installed files in
$TEXMFMAIN/tex/jadetex
.
mktexlsr
Finally, test your installation using the demonstration files in that directory:
openjade -t tex -d demo.dsl demo.sgm jadetex demo.tex pdfjadetex demo.texYou're done!
unicode.sty
(or
dsssl.def
, etc) can't be found. What did I do
wrong?
jadetex.dtx
. This is
the literate source for the format file and other files installed
under
$TEXMFMAIN/tex/jadetex
.
To format it, use latex:
latex jadetex.dtxYou will get tons of overfull hboxes but if you are using a nice big latex, it will work. Formatting the batch file
jadetex.ins
will produce stripped sources
(dsssl.def
and
jadetex.ltx
),
which can be compiled into format files as before:
latex jadetex.ins make -f Makefile.jadetex
quadding: #t
), hyphenation must be on,
hyphenation?: #t
, and a current language must
be selected (e.g., language: 'EN
) for JadeTeX
to perform hyphenation.
-V tex-backend
to
your openjade command-line.