1 |
24 |
jeremybenn |
#! /bin/sh
|
2 |
|
|
# texi2dvi --- produce DVI (or PDF) files from Texinfo (or LaTeX) sources.
|
3 |
|
|
# $Id: texi2dvi,v 1.14 2003/02/05 00:42:33 karl Exp $
|
4 |
|
|
#
|
5 |
|
|
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2001,
|
6 |
|
|
# 2002, 2003 Free Software Foundation, Inc.
|
7 |
|
|
#
|
8 |
|
|
# This program is free software; you can redistribute it and/or modify
|
9 |
|
|
# it under the terms of the GNU General Public License as published by
|
10 |
|
|
# the Free Software Foundation; either version 2, or (at your option)
|
11 |
|
|
# any later version.
|
12 |
|
|
#
|
13 |
|
|
# This program is distributed in the hope that it will be useful,
|
14 |
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
15 |
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
16 |
|
|
# GNU General Public License for more details.
|
17 |
|
|
#
|
18 |
|
|
# You should have received a copy of the GNU General Public License
|
19 |
|
|
# along with this program; if not, you can either send email to this
|
20 |
|
|
# program's maintainer or write to: The Free Software Foundation,
|
21 |
|
|
# Inc.; 59 Temple Place, Suite 330; Boston, MA 02111-1307, USA.
|
22 |
|
|
#
|
23 |
|
|
# Original author: Noah Friedman .
|
24 |
|
|
#
|
25 |
|
|
# Please send bug reports, etc. to bug-texinfo@gnu.org.
|
26 |
|
|
# If possible, please send a copy of the output of the script called with
|
27 |
|
|
# the `--debug' option when making a bug report.
|
28 |
|
|
|
29 |
|
|
# This string is expanded by rcs automatically when this file is checked out.
|
30 |
|
|
rcs_revision='$Revision: 1.14 $'
|
31 |
|
|
rcs_version=`set - $rcs_revision; echo $2`
|
32 |
|
|
program=`echo $0 | sed -e 's!.*/!!'`
|
33 |
|
|
version="texi2dvi (GNU Texinfo 4.5) $rcs_version
|
34 |
|
|
|
35 |
|
|
Copyright (C) 2003 Free Software Foundation, Inc.
|
36 |
|
|
There is NO warranty. You may redistribute this software
|
37 |
|
|
under the terms of the GNU General Public License.
|
38 |
|
|
For more information about these matters, see the files named COPYING."
|
39 |
|
|
|
40 |
|
|
usage="Usage: $program [OPTION]... FILE...
|
41 |
|
|
|
42 |
|
|
Run each Texinfo or LaTeX FILE through TeX in turn until all
|
43 |
|
|
cross-references are resolved, building all indices. The directory
|
44 |
|
|
containing each FILE is searched for included files. The suffix of FILE
|
45 |
|
|
is used to determine its language (LaTeX or Texinfo).
|
46 |
|
|
|
47 |
|
|
Makeinfo is used to perform Texinfo macro expansion before running TeX
|
48 |
|
|
when needed.
|
49 |
|
|
|
50 |
|
|
Operation modes:
|
51 |
|
|
-b, --batch no interaction
|
52 |
|
|
-c, --clean remove all auxiliary files
|
53 |
|
|
-D, --debug turn on shell debugging (set -x)
|
54 |
|
|
-h, --help display this help and exit successfully
|
55 |
|
|
-o, --output=OFILE leave output in OFILE (implies --clean);
|
56 |
|
|
Only one input FILE may be specified in this case
|
57 |
|
|
-q, --quiet no output unless errors (implies --batch)
|
58 |
|
|
-s, --silent same as --quiet
|
59 |
|
|
-v, --version display version information and exit successfully
|
60 |
|
|
-V, --verbose report on what is done
|
61 |
|
|
|
62 |
|
|
TeX tuning:
|
63 |
|
|
-@ use @input instead of \input; for preloaded Texinfo
|
64 |
|
|
-e, -E, --expand force macro expansion using makeinfo
|
65 |
|
|
-I DIR search DIR for Texinfo files
|
66 |
|
|
-l, --language=LANG specify the LANG of FILE (LaTeX or Texinfo)
|
67 |
|
|
-p, --pdf use pdftex or pdflatex for processing
|
68 |
|
|
-t, --texinfo=CMD insert CMD after @setfilename in copy of input file
|
69 |
|
|
multiple values accumulate
|
70 |
|
|
|
71 |
|
|
The values of the BIBTEX, LATEX (or PDFLATEX), MAKEINDEX, MAKEINFO,
|
72 |
|
|
TEX (or PDFTEX), and TEXINDEX environment variables are used to run
|
73 |
|
|
those commands, if they are set.
|
74 |
|
|
|
75 |
|
|
Email bug reports to ,
|
76 |
|
|
general questions and discussion to .
|
77 |
|
|
Texinfo home page: http://www.gnu.org/software/texinfo/"
|
78 |
|
|
|
79 |
|
|
# Initialize variables for option overriding and otherwise.
|
80 |
|
|
# Don't use `unset' since old bourne shells don't have this command.
|
81 |
|
|
# Instead, assign them an empty value.
|
82 |
|
|
batch=false # eval for batch mode
|
83 |
|
|
clean=
|
84 |
|
|
debug=
|
85 |
|
|
escape='\'
|
86 |
|
|
expand= # t for expansion via makeinfo
|
87 |
|
|
miincludes= # makeinfo include path
|
88 |
|
|
oformat=dvi
|
89 |
|
|
oname= # --output
|
90 |
|
|
quiet= # by default let the tools' message be displayed
|
91 |
|
|
set_language=
|
92 |
|
|
textra=
|
93 |
|
|
tmpdir=${TMPDIR:-/tmp}/t2d$$ # avoid collisions on 8.3 filesystems.
|
94 |
|
|
txincludes= # TEXINPUTS extensions, with trailing colon
|
95 |
|
|
txiprereq=19990129 # minimum texinfo.tex version to have macro expansion
|
96 |
|
|
verbose=false # echo for verbose mode
|
97 |
|
|
|
98 |
|
|
orig_pwd=`pwd`
|
99 |
|
|
|
100 |
|
|
# Systems which define $COMSPEC or $ComSpec use semicolons to separate
|
101 |
|
|
# directories in TEXINPUTS.
|
102 |
|
|
if test -n "$COMSPEC$ComSpec"; then
|
103 |
|
|
path_sep=";"
|
104 |
|
|
else
|
105 |
|
|
path_sep=":"
|
106 |
|
|
fi
|
107 |
|
|
|
108 |
|
|
# Pacify verbose cds.
|
109 |
|
|
CDPATH=${ZSH_VERSION+.}$path_sep
|
110 |
|
|
|
111 |
|
|
# In case someone crazy insists on using grep -E.
|
112 |
|
|
: ${EGREP=egrep}
|
113 |
|
|
|
114 |
|
|
# Save this so we can construct a new TEXINPUTS path for each file.
|
115 |
|
|
TEXINPUTS_orig="$TEXINPUTS"
|
116 |
|
|
# Unfortunately makeindex does not read TEXINPUTS.
|
117 |
|
|
INDEXSTYLE_orig="$INDEXSTYLE"
|
118 |
|
|
export TEXINPUTS INDEXSTYLE
|
119 |
|
|
|
120 |
|
|
# Push a token among the arguments that will be used to notice when we
|
121 |
|
|
# ended options/arguments parsing.
|
122 |
|
|
# Use "set dummy ...; shift" rather than 'set - ..." because on
|
123 |
|
|
# Solaris set - turns off set -x (but keeps set -e).
|
124 |
|
|
# Use ${1+"$@"} rather than "$@" because Digital Unix and Ultrix 4.3
|
125 |
|
|
# still expand "$@" to a single argument (the empty string) rather
|
126 |
|
|
# than nothing at all.
|
127 |
|
|
arg_sep="$$--$$"
|
128 |
|
|
set dummy ${1+"$@"} "$arg_sep"; shift
|
129 |
|
|
|
130 |
|
|
#
|
131 |
|
|
# Parse command line arguments.
|
132 |
|
|
while test x"$1" != x"$arg_sep"; do
|
133 |
|
|
|
134 |
|
|
# Handle --option=value by splitting apart and putting back on argv.
|
135 |
|
|
case "$1" in
|
136 |
|
|
--*=*)
|
137 |
|
|
opt=`echo "$1" | sed -e 's/=.*//'`
|
138 |
|
|
val=`echo "$1" | sed -e 's/[^=]*=//'`
|
139 |
|
|
shift
|
140 |
|
|
set dummy "$opt" "$val" ${1+"$@"}; shift
|
141 |
|
|
;;
|
142 |
|
|
esac
|
143 |
|
|
|
144 |
|
|
# This recognizes --quark as --quiet. So what.
|
145 |
|
|
case "$1" in
|
146 |
|
|
-@ ) escape=@;;
|
147 |
|
|
# Silently and without documentation accept -b and --b[atch] as synonyms.
|
148 |
|
|
-b | --b*) batch=eval;;
|
149 |
|
|
-q | -s | --q* | --s*) quiet=t; batch=eval;;
|
150 |
|
|
-c | --c*) clean=t;;
|
151 |
|
|
-D | --d*) debug=t;;
|
152 |
|
|
-e | -E | --e*) expand=t;;
|
153 |
|
|
-h | --h*) echo "$usage"; exit 0;;
|
154 |
|
|
-I | --I*)
|
155 |
|
|
shift
|
156 |
|
|
miincludes="$miincludes -I $1"
|
157 |
|
|
txincludes="$txincludes$1$path_sep"
|
158 |
|
|
;;
|
159 |
|
|
-l | --l*) shift; set_language=$1;;
|
160 |
|
|
-o | --o*)
|
161 |
|
|
shift
|
162 |
|
|
clean=t
|
163 |
|
|
case "$1" in
|
164 |
|
|
/* | ?:/*) oname=$1;;
|
165 |
|
|
*) oname="$orig_pwd/$1";;
|
166 |
|
|
esac;;
|
167 |
|
|
-p | --p*) oformat=pdf;;
|
168 |
|
|
-t | --t*) shift; textra="$textra\\
|
169 |
|
|
$1";;
|
170 |
|
|
-v | --vers*) echo "$version"; exit 0;;
|
171 |
|
|
-V | --verb*) verbose=echo;;
|
172 |
|
|
--) # What remains are not options.
|
173 |
|
|
shift
|
174 |
|
|
while test x"$1" != x"$arg_sep"; do
|
175 |
|
|
set dummy ${1+"$@"} "$1"; shift
|
176 |
|
|
shift
|
177 |
|
|
done
|
178 |
|
|
break;;
|
179 |
|
|
-*)
|
180 |
|
|
echo "$0: Unknown or ambiguous option \`$1'." >&2
|
181 |
|
|
echo "$0: Try \`--help' for more information." >&2
|
182 |
|
|
exit 1;;
|
183 |
|
|
*) set dummy ${1+"$@"} "$1"; shift;;
|
184 |
|
|
esac
|
185 |
|
|
shift
|
186 |
|
|
done
|
187 |
|
|
# Pop the token
|
188 |
|
|
shift
|
189 |
|
|
|
190 |
|
|
# Interpret remaining command line args as filenames.
|
191 |
|
|
case $# in
|
192 |
|
|
0)
|
193 |
|
|
echo "$0: Missing file arguments." >&2
|
194 |
|
|
echo "$0: Try \`--help' for more information." >&2
|
195 |
|
|
exit 2
|
196 |
|
|
;;
|
197 |
|
|
1) ;;
|
198 |
|
|
*)
|
199 |
|
|
if test -n "$oname"; then
|
200 |
|
|
echo "$0: Can't use option \`--output' with more than one argument." >&2
|
201 |
|
|
exit 2
|
202 |
|
|
fi
|
203 |
|
|
;;
|
204 |
|
|
esac
|
205 |
|
|
|
206 |
|
|
# Prepare the temporary directory. Remove it at exit, unless debugging.
|
207 |
|
|
if test -z "$debug"; then
|
208 |
|
|
trap "cd / && rm -rf $tmpdir" 0 1 2 15
|
209 |
|
|
fi
|
210 |
|
|
|
211 |
|
|
# Create the temporary directory with strict rights
|
212 |
|
|
(umask 077 && mkdir $tmpdir) || exit 1
|
213 |
|
|
|
214 |
|
|
# Prepare the tools we might need. This may be extra work in some
|
215 |
|
|
# cases, but improves the readibility of the script.
|
216 |
|
|
utildir=$tmpdir/utils
|
217 |
|
|
mkdir $utildir || exit 1
|
218 |
|
|
|
219 |
|
|
# A sed script that preprocesses Texinfo sources in order to keep the
|
220 |
|
|
# iftex sections only. We want to remove non TeX sections, and
|
221 |
|
|
# comment (with `@c texi2dvi') TeX sections so that makeinfo does not
|
222 |
|
|
# try to parse them. Nevertheless, while commenting TeX sections,
|
223 |
|
|
# don't comment @macro/@end macro so that makeinfo does propagate
|
224 |
|
|
# them. Unfortunately makeinfo --iftex --no-ifhtml --no-ifinfo
|
225 |
|
|
# doesn't work well enough (yet) to use that, so work around with sed.
|
226 |
|
|
comment_iftex_sed=$utildir/comment.sed
|
227 |
|
|
cat <$comment_iftex_sed
|
228 |
|
|
/^@tex/,/^@end tex/{
|
229 |
|
|
s/^/@c texi2dvi/
|
230 |
|
|
}
|
231 |
|
|
/^@iftex/,/^@end iftex/{
|
232 |
|
|
s/^/@c texi2dvi/
|
233 |
|
|
/^@c texi2dvi@macro/,/^@c texi2dvi@end macro/{
|
234 |
|
|
s/^@c texi2dvi//
|
235 |
|
|
}
|
236 |
|
|
}
|
237 |
|
|
/^@html/,/^@end html/{
|
238 |
|
|
s/^/@c (texi2dvi)/
|
239 |
|
|
}
|
240 |
|
|
/^@ifhtml/,/^@end ifhtml/{
|
241 |
|
|
s/^/@c (texi2dvi)/
|
242 |
|
|
}
|
243 |
|
|
/^@ifnottex/,/^@end ifnottex/{
|
244 |
|
|
s/^/@c (texi2dvi)/
|
245 |
|
|
}
|
246 |
|
|
/^@ifinfo/,/^@end ifinfo/{
|
247 |
|
|
/^@node/p
|
248 |
|
|
/^@menu/,/^@end menu/p
|
249 |
|
|
t
|
250 |
|
|
s/^/@c (texi2dvi)/
|
251 |
|
|
}
|
252 |
|
|
s/^@ifnotinfo/@c texi2dvi@ifnotinfo/
|
253 |
|
|
s/^@end ifnotinfo/@c texi2dvi@end ifnotinfo/
|
254 |
|
|
EOF
|
255 |
|
|
# Uncommenting is simple: Remove any leading `@c texi2dvi'.
|
256 |
|
|
uncomment_iftex_sed=$utildir/uncomment.sed
|
257 |
|
|
cat <$uncomment_iftex_sed
|
258 |
|
|
s/^@c texi2dvi//
|
259 |
|
|
EOF
|
260 |
|
|
|
261 |
|
|
# A shell script that computes the list of xref files.
|
262 |
|
|
# Takes the filename (without extension) of which we look for xref
|
263 |
|
|
# files as argument. The index files must be reported last.
|
264 |
|
|
get_xref_files=$utildir/get_xref.sh
|
265 |
|
|
cat <<\EOF >$get_xref_files
|
266 |
|
|
#! /bin/sh
|
267 |
|
|
|
268 |
|
|
# Get list of xref files (indexes, tables and lists).
|
269 |
|
|
# Find all files having root filename with a two-letter extension,
|
270 |
|
|
# saves the ones that are really Texinfo-related files. .?o? catches
|
271 |
|
|
# many files: .toc, .log, LaTeX tables and lists, FiXme's .lox, maybe more.
|
272 |
|
|
for this_file in "$1".?o? "$1".aux "$1".?? "$1".idx; do
|
273 |
|
|
# If file is empty, skip it.
|
274 |
|
|
test -s "$this_file" || continue
|
275 |
|
|
# If the file is not suitable to be an index or xref file, don't
|
276 |
|
|
# process it. The file can't be if its first character is not a
|
277 |
|
|
# backslash or single quote.
|
278 |
|
|
first_character=`sed -n '1s/^\(.\).*$/\1/p;q' $this_file`
|
279 |
|
|
if test "x$first_character" = "x\\" \
|
280 |
|
|
|| test "x$first_character" = "x'"; then
|
281 |
|
|
xref_files="$xref_files ./$this_file"
|
282 |
|
|
fi
|
283 |
|
|
done
|
284 |
|
|
echo "$xref_files"
|
285 |
|
|
EOF
|
286 |
|
|
chmod 500 $get_xref_files
|
287 |
|
|
|
288 |
|
|
# File descriptor usage:
|
289 |
|
|
# 0 standard input
|
290 |
|
|
# 1 standard output (--verbose messages)
|
291 |
|
|
# 2 standard error
|
292 |
|
|
# 3 some systems may open it to /dev/tty
|
293 |
|
|
# 4 used on the Kubota Titan
|
294 |
|
|
# 5 tools output (turned off by --quiet)
|
295 |
|
|
|
296 |
|
|
# Tools' output. If quiet, discard, else redirect to the message flow.
|
297 |
|
|
if test "$quiet" = t; then
|
298 |
|
|
exec 5>/dev/null
|
299 |
|
|
else
|
300 |
|
|
exec 5>&1
|
301 |
|
|
fi
|
302 |
|
|
|
303 |
|
|
# Enable tracing
|
304 |
|
|
test "$debug" = t && set -x
|
305 |
|
|
|
306 |
|
|
#
|
307 |
|
|
# TeXify files.
|
308 |
|
|
|
309 |
|
|
for command_line_filename in ${1+"$@"}; do
|
310 |
|
|
$verbose "Processing $command_line_filename ..."
|
311 |
|
|
|
312 |
|
|
# If the COMMAND_LINE_FILENAME is not absolute (e.g., --debug.tex),
|
313 |
|
|
# prepend `./' in order to avoid that the tools take it as an option.
|
314 |
|
|
echo "$command_line_filename" | $EGREP '^(/|[A-z]:/)' >/dev/null \
|
315 |
|
|
|| command_line_filename="./$command_line_filename"
|
316 |
|
|
|
317 |
|
|
# See if the file exists. If it doesn't we're in trouble since, even
|
318 |
|
|
# though the user may be able to reenter a valid filename at the tex
|
319 |
|
|
# prompt (assuming they're attending the terminal), this script won't
|
320 |
|
|
# be able to find the right xref files and so forth.
|
321 |
|
|
if test ! -r "$command_line_filename"; then
|
322 |
|
|
echo "$0: Could not read $command_line_filename, skipping." >&2
|
323 |
|
|
continue
|
324 |
|
|
fi
|
325 |
|
|
|
326 |
|
|
# Get the name of the current directory. We want the full path
|
327 |
|
|
# because in clean mode we are in tmp, in which case a relative
|
328 |
|
|
# path has no meaning.
|
329 |
|
|
filename_dir=`echo $command_line_filename | sed 's!/[^/]*$!!;s!^$!.!'`
|
330 |
|
|
filename_dir=`cd "$filename_dir" >/dev/null && pwd`
|
331 |
|
|
|
332 |
|
|
# Strip directory part but leave extension.
|
333 |
|
|
filename_ext=`basename "$command_line_filename"`
|
334 |
|
|
# Strip extension.
|
335 |
|
|
filename_noext=`echo "$filename_ext" | sed 's/\.[^.]*$//'`
|
336 |
|
|
ext=`echo "$filename_ext" | sed 's/^.*\.//'`
|
337 |
|
|
|
338 |
|
|
# _src. Use same basename since we want to generate aux files with
|
339 |
|
|
# the same basename as the manual. If --expand, then output the
|
340 |
|
|
# macro-expanded file to here, else copy the original file.
|
341 |
|
|
tmpdir_src=$tmpdir/src
|
342 |
|
|
filename_src=$tmpdir_src/$filename_noext.$ext
|
343 |
|
|
|
344 |
|
|
# _xtr. The file with the user's extra commands.
|
345 |
|
|
tmpdir_xtr=$tmpdir/xtr
|
346 |
|
|
filename_xtr=$tmpdir_xtr/$filename_noext.$ext
|
347 |
|
|
|
348 |
|
|
# _bak. Copies of the previous xref files (another round is run if
|
349 |
|
|
# they differ from the new one).
|
350 |
|
|
tmpdir_bak=$tmpdir/bak
|
351 |
|
|
|
352 |
|
|
# Make all those directories and give up if we can't succeed.
|
353 |
|
|
mkdir $tmpdir_src $tmpdir_xtr $tmpdir_bak || exit 1
|
354 |
|
|
|
355 |
|
|
# Source file might include additional sources.
|
356 |
|
|
# We want `.:$orig_pwd' before anything else. (We'll add `.:' later
|
357 |
|
|
# after all other directories have been turned into absolute paths.)
|
358 |
|
|
# `.' goes first to ensure that any old .aux, .cps,
|
359 |
|
|
# etc. files in ${directory} don't get used in preference to fresher
|
360 |
|
|
# files in `.'. Include orig_pwd in case we are in clean mode, where
|
361 |
|
|
# we've cd'd to a temp directory.
|
362 |
|
|
common="$orig_pwd$path_sep$filename_dir$path_sep$txincludes"
|
363 |
|
|
TEXINPUTS="$common$TEXINPUTS_orig"
|
364 |
|
|
INDEXSTYLE="$common$INDEXSTYLE_orig"
|
365 |
|
|
|
366 |
|
|
# Convert relative paths to absolute paths, so we can run in another
|
367 |
|
|
# directory (e.g., in --clean mode, or during the macro-support
|
368 |
|
|
# detection.)
|
369 |
|
|
#
|
370 |
|
|
# Empty path components are meaningful to tex. We rewrite them
|
371 |
|
|
# as `EMPTY' so they don't get lost when we split on $path_sep.
|
372 |
|
|
TEXINPUTS=`echo $TEXINPUTS |sed 's/^:/EMPTY:/;s/:$/:EMPTY/;s/::/:EMPTY:/g'`
|
373 |
|
|
INDEXSTYLE=`echo $INDEXSTYLE |sed 's/^:/EMPTY:/;s/:$/:EMPTY/;s/::/:EMPTY:/g'`
|
374 |
|
|
save_IFS=$IFS
|
375 |
|
|
IFS=$path_sep
|
376 |
|
|
set x $TEXINPUTS; shift
|
377 |
|
|
TEXINPUTS=.
|
378 |
|
|
for dir
|
379 |
|
|
do
|
380 |
|
|
case $dir in
|
381 |
|
|
EMPTY)
|
382 |
|
|
TEXINPUTS=$TEXINPUTS$path_sep
|
383 |
|
|
;;
|
384 |
|
|
[\\/]* | ?:[\\/]*) # Absolute paths don't need to be expansed.
|
385 |
|
|
TEXINPUTS=$TEXINPUTS$path_sep$dir
|
386 |
|
|
;;
|
387 |
|
|
*)
|
388 |
|
|
abs=`cd "$dir" && pwd` && TEXINPUTS=$TEXINPUTS$path_sep$abs
|
389 |
|
|
;;
|
390 |
|
|
esac
|
391 |
|
|
done
|
392 |
|
|
set x $INDEXSTYLE; shift
|
393 |
|
|
INDEXSTYLE=.
|
394 |
|
|
for dir
|
395 |
|
|
do
|
396 |
|
|
case $dir in
|
397 |
|
|
EMPTY)
|
398 |
|
|
INDEXSTYLE=$INDEXSTYLE$path_sep
|
399 |
|
|
;;
|
400 |
|
|
[\\/]* | ?:[\\/]*) # Absolute paths don't need to be expansed.
|
401 |
|
|
INDEXSTYLE=$INDEXSTYLE$path_sep$dir
|
402 |
|
|
;;
|
403 |
|
|
*)
|
404 |
|
|
abs=`cd "$dir" && pwd` && INDEXSTYLE=$INDEXSTYLE$path_sep$abs
|
405 |
|
|
;;
|
406 |
|
|
esac
|
407 |
|
|
done
|
408 |
|
|
IFS=$save_IFS
|
409 |
|
|
|
410 |
|
|
# If the user explicitly specified the language, use that.
|
411 |
|
|
# Otherwise, if the first line is \input texinfo, assume it's texinfo.
|
412 |
|
|
# Otherwise, guess from the file extension.
|
413 |
|
|
if test -n "$set_language"; then
|
414 |
|
|
language=$set_language
|
415 |
|
|
elif sed 1q "$command_line_filename" | grep 'input texinfo' >/dev/null; then
|
416 |
|
|
language=texinfo
|
417 |
|
|
else
|
418 |
|
|
language=
|
419 |
|
|
fi
|
420 |
|
|
|
421 |
|
|
# Get the type of the file (latex or texinfo) from the given language
|
422 |
|
|
# we just guessed, or from the file extension if not set yet.
|
423 |
|
|
case ${language:-$filename_ext} in
|
424 |
|
|
[lL]a[tT]e[xX] | *.ltx | *.tex)
|
425 |
|
|
# Assume a LaTeX file. LaTeX needs bibtex and uses latex for
|
426 |
|
|
# compilation. No makeinfo.
|
427 |
|
|
bibtex=${BIBTEX:-bibtex}
|
428 |
|
|
makeinfo= # no point in running makeinfo on latex source.
|
429 |
|
|
texindex=${MAKEINDEX:-makeindex}
|
430 |
|
|
if test $oformat = dvi; then
|
431 |
|
|
tex=${LATEX:-latex}
|
432 |
|
|
else
|
433 |
|
|
tex=${PDFLATEX:-pdflatex}
|
434 |
|
|
fi
|
435 |
|
|
;;
|
436 |
|
|
|
437 |
|
|
*)
|
438 |
|
|
# Assume a Texinfo file. Texinfo files need makeinfo, texindex and tex.
|
439 |
|
|
bibtex=
|
440 |
|
|
texindex=${TEXINDEX:-texindex}
|
441 |
|
|
if test $oformat = dvi; then
|
442 |
|
|
tex=${TEX:-tex}
|
443 |
|
|
else
|
444 |
|
|
tex=${PDFTEX:-pdftex}
|
445 |
|
|
fi
|
446 |
|
|
# Unless required by the user, makeinfo expansion is wanted only
|
447 |
|
|
# if texinfo.tex is too old.
|
448 |
|
|
if test "$expand" = t; then
|
449 |
|
|
makeinfo=${MAKEINFO:-makeinfo}
|
450 |
|
|
else
|
451 |
|
|
# Check if texinfo.tex performs macro expansion by looking for
|
452 |
|
|
# its version. The version is a date of the form YEAR-MO-DA.
|
453 |
|
|
# We don't need to use [0-9] to match the digits since anyway
|
454 |
|
|
# the comparison with $txiprereq, a number, will fail with non
|
455 |
|
|
# digits.
|
456 |
|
|
txiversion_tex=txiversion.tex
|
457 |
|
|
echo '\input texinfo.tex @bye' >$tmpdir/$txiversion_tex
|
458 |
|
|
# Run in the tmpdir to avoid leaving files.
|
459 |
|
|
eval `cd $tmpdir >/dev/null &&
|
460 |
|
|
$tex $txiversion_tex 2>/dev/null |
|
461 |
|
|
sed -n 's/^.*\[\(.*\)version \(....\)-\(..\)-\(..\).*$/txiformat=\1 txiversion="\2\3\4"/p'`
|
462 |
|
|
$verbose "texinfo.tex preloaded as \`$txiformat', version is \`$txiversion' ..."
|
463 |
|
|
if test "$txiprereq" -le "$txiversion" >/dev/null 2>&1; then
|
464 |
|
|
makeinfo=
|
465 |
|
|
else
|
466 |
|
|
makeinfo=${MAKEINFO:-makeinfo}
|
467 |
|
|
fi
|
468 |
|
|
# As long as we had to run TeX, offer the user this convenience
|
469 |
|
|
if test "$txiformat" = Texinfo; then
|
470 |
|
|
escape=@
|
471 |
|
|
fi
|
472 |
|
|
fi
|
473 |
|
|
;;
|
474 |
|
|
esac
|
475 |
|
|
|
476 |
|
|
# Expand macro commands in the original source file using Makeinfo.
|
477 |
|
|
# Always use `end' footnote style, since the `separate' style
|
478 |
|
|
# generates different output (arguably this is a bug in -E).
|
479 |
|
|
# Discard main info output, the user asked to run TeX, not makeinfo.
|
480 |
|
|
if test -n "$makeinfo"; then
|
481 |
|
|
$verbose "Macro-expanding $command_line_filename to $filename_src ..."
|
482 |
|
|
sed -f $comment_iftex_sed "$command_line_filename" \
|
483 |
|
|
| $makeinfo --footnote-style=end -I "$filename_dir" $miincludes \
|
484 |
|
|
-o /dev/null --macro-expand=- \
|
485 |
|
|
| sed -f $uncomment_iftex_sed >"$filename_src"
|
486 |
|
|
filename_input=$filename_src
|
487 |
|
|
fi
|
488 |
|
|
|
489 |
|
|
# If makeinfo failed (or was not even run), use the original file as input.
|
490 |
|
|
if test $? -ne 0 \
|
491 |
|
|
|| test ! -r "$filename_src"; then
|
492 |
|
|
$verbose "Reverting to $command_line_filename ..."
|
493 |
|
|
filename_input=$filename_dir/$filename_ext
|
494 |
|
|
fi
|
495 |
|
|
|
496 |
|
|
# Used most commonly for @finalout, @smallbook, etc.
|
497 |
|
|
if test -n "$textra"; then
|
498 |
|
|
$verbose "Inserting extra commands: $textra"
|
499 |
|
|
sed '/^@setfilename/a\
|
500 |
|
|
'"$textra" "$filename_input" >$filename_xtr
|
501 |
|
|
filename_input=$filename_xtr
|
502 |
|
|
fi
|
503 |
|
|
|
504 |
|
|
# If clean mode was specified, then move to the temporary directory.
|
505 |
|
|
if test "$clean" = t; then
|
506 |
|
|
$verbose "cd $tmpdir_src"
|
507 |
|
|
cd "$tmpdir_src" || exit 1
|
508 |
|
|
fi
|
509 |
|
|
|
510 |
|
|
while :; do # will break out of loop below
|
511 |
|
|
orig_xref_files=`$get_xref_files "$filename_noext"`
|
512 |
|
|
|
513 |
|
|
# Save copies of originals for later comparison.
|
514 |
|
|
if test -n "$orig_xref_files"; then
|
515 |
|
|
$verbose "Backing up xref files: `echo $orig_xref_files | sed 's|\./||g'`"
|
516 |
|
|
cp $orig_xref_files $tmpdir_bak
|
517 |
|
|
fi
|
518 |
|
|
|
519 |
|
|
# Run bibtex on current file.
|
520 |
|
|
# - If its input (AUX) exists.
|
521 |
|
|
# - If AUX contains both `\bibdata' and `\bibstyle'.
|
522 |
|
|
# - If some citations are missing (LOG contains `Citation').
|
523 |
|
|
# or the LOG complains of a missing .bbl
|
524 |
|
|
#
|
525 |
|
|
# We run bibtex first, because I can see reasons for the indexes
|
526 |
|
|
# to change after bibtex is run, but I see no reason for the
|
527 |
|
|
# converse.
|
528 |
|
|
#
|
529 |
|
|
# Don't try to be too smart. Running bibtex only if the bbl file
|
530 |
|
|
# exists and is older than the LaTeX file is wrong, since the
|
531 |
|
|
# document might include files that have changed. Because there
|
532 |
|
|
# can be several AUX (if there are \include's), but a single LOG,
|
533 |
|
|
# looking for missing citations in LOG is easier, though we take
|
534 |
|
|
# the risk to match false messages.
|
535 |
|
|
if test -n "$bibtex" \
|
536 |
|
|
&& test -r "$filename_noext.aux" \
|
537 |
|
|
&& test -r "$filename_noext.log" \
|
538 |
|
|
&& (grep '^\\bibdata[{]' "$filename_noext.aux" \
|
539 |
|
|
&& grep '^\\bibstyle[{]' "$filename_noext.aux" \
|
540 |
|
|
&& (grep 'Warning:.*Citation.*undefined' "$filename_noext.log" \
|
541 |
|
|
|| grep 'No file .*\.bbl\.' "$filename_noext.log")) \
|
542 |
|
|
>/dev/null 2>&1; \
|
543 |
|
|
then
|
544 |
|
|
$verbose "Running $bibtex $filename_noext ..."
|
545 |
|
|
if $bibtex "$filename_noext" >&5; then :; else
|
546 |
|
|
echo "$0: $bibtex exited with bad status, quitting." >&2
|
547 |
|
|
exit 1
|
548 |
|
|
fi
|
549 |
|
|
fi
|
550 |
|
|
|
551 |
|
|
# What we'll run texindex on -- exclude non-index files.
|
552 |
|
|
# Since we know index files are last, it is correct to remove everything
|
553 |
|
|
# before .aux and .?o?. But don't really do o
|
554 |
|
|
# -- don't match whitespace as .
|
555 |
|
|
# Otherwise, if orig_xref_files contains something like
|
556 |
|
|
# foo.xo foo.whatever
|
557 |
|
|
# the space after the o will get matched.
|
558 |
|
|
index_files=`echo "$orig_xref_files" \
|
559 |
|
|
| sed "s!.*\.aux!!g;
|
560 |
|
|
s!./$filename_noext\.[^ ]o[^ ]!!g;
|
561 |
|
|
s/^[ ]*//;s/[ ]*$//"`
|
562 |
|
|
# Run texindex (or makeindex) on current index files. If they
|
563 |
|
|
# already exist, and after running TeX a first time the index
|
564 |
|
|
# files don't change, then there's no reason to run TeX again.
|
565 |
|
|
# But we won't know that if the index files are out of date or
|
566 |
|
|
# nonexistent.
|
567 |
|
|
if test -n "$texindex" && test -n "$index_files"; then
|
568 |
|
|
$verbose "Running $texindex $index_files ..."
|
569 |
|
|
if $texindex $index_files 2>&5 1>&2; then :; else
|
570 |
|
|
echo "$0: $texindex exited with bad status, quitting." >&2
|
571 |
|
|
exit 1
|
572 |
|
|
fi
|
573 |
|
|
fi
|
574 |
|
|
|
575 |
|
|
# Finally, run TeX.
|
576 |
|
|
# Prevent $ESCAPE from being interpreted by the shell if it happens
|
577 |
|
|
# to be `/'.
|
578 |
|
|
$batch tex_args="\\${escape}nonstopmode\ \\${escape}input"
|
579 |
|
|
cmd="$tex $tex_args $filename_input"
|
580 |
|
|
$verbose "Running $cmd ..."
|
581 |
|
|
if $cmd >&5; then :; else
|
582 |
|
|
echo "$0: $tex exited with bad status, quitting." >&2
|
583 |
|
|
echo "$0: see $filename_noext.log for errors." >&2
|
584 |
|
|
test "$clean" = t \
|
585 |
|
|
&& cp "$filename_noext.log" "$orig_pwd"
|
586 |
|
|
exit 1
|
587 |
|
|
fi
|
588 |
|
|
|
589 |
|
|
|
590 |
|
|
# Decide if looping again is needed.
|
591 |
|
|
finished=t
|
592 |
|
|
|
593 |
|
|
# LaTeX (and the package changebar) report in the LOG file if it
|
594 |
|
|
# should be rerun. This is needed for files included from
|
595 |
|
|
# subdirs, since texi2dvi does not try to compare xref files in
|
596 |
|
|
# subdirs. Performing xref files test is still good since LaTeX
|
597 |
|
|
# does not report changes in xref files.
|
598 |
|
|
if grep "Rerun to get" "$filename_noext.log" >/dev/null 2>&1; then
|
599 |
|
|
finished=
|
600 |
|
|
fi
|
601 |
|
|
|
602 |
|
|
# Check if xref files changed.
|
603 |
|
|
new_xref_files=`$get_xref_files "$filename_noext"`
|
604 |
|
|
$verbose "Original xref files = `echo $orig_xref_files | sed 's|\./||g'`"
|
605 |
|
|
$verbose "New xref files = `echo $new_xref_files | sed 's|\./||g'`"
|
606 |
|
|
|
607 |
|
|
# If old and new lists don't at least have the same file list,
|
608 |
|
|
# then one file or another has definitely changed.
|
609 |
|
|
test "x$orig_xref_files" != "x$new_xref_files" && finished=
|
610 |
|
|
|
611 |
|
|
# File list is the same. We must compare each file until we find
|
612 |
|
|
# a difference.
|
613 |
|
|
if test -n "$finished"; then
|
614 |
|
|
for this_file in $new_xref_files; do
|
615 |
|
|
$verbose "Comparing xref file `echo $this_file | sed 's|\./||g'` ..."
|
616 |
|
|
# cmp -s returns nonzero exit status if files differ.
|
617 |
|
|
if cmp -s "$this_file" "$tmpdir_bak/$this_file"; then :; else
|
618 |
|
|
# We only need to keep comparing until we find one that
|
619 |
|
|
# differs, because we'll have to run texindex & tex again no
|
620 |
|
|
# matter how many more there might be.
|
621 |
|
|
finished=
|
622 |
|
|
$verbose "xref file `echo $this_file | sed 's|\./||g'` differed ..."
|
623 |
|
|
test "$debug" = t && diff -c "$tmpdir_bak/$this_file" "$this_file"
|
624 |
|
|
break
|
625 |
|
|
fi
|
626 |
|
|
done
|
627 |
|
|
fi
|
628 |
|
|
|
629 |
|
|
# If finished, exit the loop, else rerun the loop.
|
630 |
|
|
test -n "$finished" && break
|
631 |
|
|
done
|
632 |
|
|
|
633 |
|
|
# If we were in clean mode, compilation was in a tmp directory.
|
634 |
|
|
# Copy the DVI (or PDF) file into the directory where the compilation
|
635 |
|
|
# has been done. (The temp dir is about to get removed anyway.)
|
636 |
|
|
# We also return to the original directory so that
|
637 |
|
|
# - the next file is processed in correct conditions
|
638 |
|
|
# - the temporary file can be removed
|
639 |
|
|
if test -n "$clean"; then
|
640 |
|
|
if test -n "$oname"; then
|
641 |
|
|
dest=$oname
|
642 |
|
|
else
|
643 |
|
|
dest=$orig_pwd
|
644 |
|
|
fi
|
645 |
|
|
$verbose "Copying $oformat file from `pwd` to $dest"
|
646 |
|
|
cp -p "./$filename_noext.$oformat" "$dest"
|
647 |
|
|
cd / # in case $orig_pwd is on a different drive (for DOS)
|
648 |
|
|
cd $orig_pwd || exit 1
|
649 |
|
|
fi
|
650 |
|
|
|
651 |
|
|
# Remove temporary files.
|
652 |
|
|
if test "x$debug" = "x"; then
|
653 |
|
|
$verbose "Removing $tmpdir_src $tmpdir_xtr $tmpdir_bak ..."
|
654 |
|
|
cd /
|
655 |
|
|
rm -rf $tmpdir_src $tmpdir_xtr $tmpdir_bak
|
656 |
|
|
fi
|
657 |
|
|
done
|
658 |
|
|
|
659 |
|
|
$verbose "$0 done."
|
660 |
|
|
exit 0 # exit successfully, not however we ended the loop.
|