summaryrefslogtreecommitdiff
path: root/editors/mule/patches
diff options
context:
space:
mode:
authorkei <kei@pkgsrc.org>2000-11-21 05:21:08 +0000
committerkei <kei@pkgsrc.org>2000-11-21 05:21:08 +0000
commit4dab7cd0577cc80792cba346365766ac50e7d281 (patch)
treeb0f070ceaacc542fc04a930e30bf2c48bc77ba8a /editors/mule/patches
parentdba2e544a7858938cc37cdd6e48dd41b92330ee4 (diff)
downloadpkgsrc-4dab7cd0577cc80792cba346365766ac50e7d281.tar.gz
Import of "Mule" package:
Multilingual GNU editing macros (editor) It was based on Mule ports of FreeBSD and Emacs ports of NetBSD originally, lots of changes are adapted as a result of discussion on tech-pkg-ja@jp.NetBSD.ORG mailing list.
Diffstat (limited to 'editors/mule/patches')
-rw-r--r--editors/mule/patches/patch-aa80
-rw-r--r--editors/mule/patches/patch-ab1115
-rw-r--r--editors/mule/patches/patch-ac22
-rw-r--r--editors/mule/patches/patch-ad12
-rw-r--r--editors/mule/patches/patch-ae173
-rw-r--r--editors/mule/patches/patch-af15
-rw-r--r--editors/mule/patches/patch-ag13
-rw-r--r--editors/mule/patches/patch-ah30
-rw-r--r--editors/mule/patches/patch-ai13
-rw-r--r--editors/mule/patches/patch-aj15
-rw-r--r--editors/mule/patches/patch-ak13
-rw-r--r--editors/mule/patches/patch-al16
-rw-r--r--editors/mule/patches/patch-am13
-rw-r--r--editors/mule/patches/patch-an38
-rw-r--r--editors/mule/patches/patch-ao46
-rw-r--r--editors/mule/patches/patch-ar18
-rw-r--r--editors/mule/patches/patch-as86
-rw-r--r--editors/mule/patches/patch-au24
-rw-r--r--editors/mule/patches/patch-av19
-rw-r--r--editors/mule/patches/patch-aw19
-rw-r--r--editors/mule/patches/patch-az20
-rw-r--r--editors/mule/patches/patch-ba18
-rw-r--r--editors/mule/patches/patch-bb4272
23 files changed, 6090 insertions, 0 deletions
diff --git a/editors/mule/patches/patch-aa b/editors/mule/patches/patch-aa
new file mode 100644
index 00000000000..57d1b1480c7
--- /dev/null
+++ b/editors/mule/patches/patch-aa
@@ -0,0 +1,80 @@
+$NetBSD: patch-aa,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- src/s/netbsd.h.orig Thu Oct 12 19:53:15 1995
++++ src/s/netbsd.h Sun Sep 19 12:36:05 1999
+@@ -3,6 +3,10 @@
+ /* Get most of the stuff from bsd4.3 */
+ #include "bsd4-3.h"
+
++#if defined (__alpha__) && !defined (__ELF__)
++#define NO_SHARED_LIBS
++#endif
++
+ /* For mem-limits.h. */
+ #define BSD4_2
+
+@@ -30,8 +34,8 @@
+ #define NO_TERMIO
+
+ #define LIBS_DEBUG
+-/* -lutil is not needed for NetBSD >0.9. */
+-#define LIBS_SYSTEM -lutil -lcrypt
++#define LIBS_SYSTEM -lcrypt
++
+ #define LIBS_TERMCAP -ltermcap
+
+ #define NEED_ERRNO
+@@ -40,7 +44,9 @@
+ /* Netbsd has POSIX-style pgrp behavior. */
+ #undef BSD_PGRPS
+
+-#ifndef NO_SHARED_LIBS
++#define GETPGRP_NO_ARG
++
++#if !defined (NO_SHARED_LIBS) && ! defined (__ELF__)
+ /* These definitions should work for either dynamic or static linking,
+ whichever is the default for `cc -nostdlib'. */
+ #define HAVE_TEXT_START /* No need to define `start_of_text'. */
+@@ -54,14 +60,34 @@
+ #define N_BSSADDR(x) (N_ALIGN(x, N_DATADDR(x)+x.a_data))
+ #define N_TRELOFF(x) N_RELOFF(x)
+ #endif
+-#endif /* not NO_SHARED_LIBS */
+-
+-/* Reread the time zone on startup. */
+-#define LOCALTIME_CACHE
++#endif /* not NO_SHARED_LIBS and not ELF */
+
+ #define HAVE_WAIT_HEADER
++#define WAIT_USE_INT
+
+-/* 94.7.29 by T.Sakakibara <tomo@axis.co.jp> */
+-#ifdef emacs
+-#include <sys/types.h>
+-#endif
++#define NO_MATHERR
++
++#define AMPERSAND_FULL_NAME
++
++#ifdef __ELF__
++/* Here is how to find X Windows. LD_SWITCH_X_SITE_AUX gives an -R option
++ says where to find X windows at run time. We convert it to a -rpath option
++ which is what OSF1 uses. */
++#define LD_SWITCH_SYSTEM `echo LD_SWITCH_X_SITE_AUX | sed -e 's/-R/-Wl,-rpath,/'`
++
++#define HAVE_TEXT_START /* No need to define `start_of_text'. */
++#define UNEXEC unexelf.o
++#define ORDINARY_LINK
++
++#if defined(__i386__)
++#define DATA_SEG_BITS 0x08000000
++#endif /* __i386__ */
++
++#endif /* __ELF__ */
++
++/* On post 1.3 releases of NetBSD, gcc -nostdlib also clears
++ the library search parth, i.e. it won't search /usr/lib
++ for libc and friends. Using -nostartfiles instead avoids
++ this problem, and will also work on earlier NetBSD releases */
++
++#define LINKER $(CC) -nostartfiles
diff --git a/editors/mule/patches/patch-ab b/editors/mule/patches/patch-ab
new file mode 100644
index 00000000000..ec4ee710b21
--- /dev/null
+++ b/editors/mule/patches/patch-ab
@@ -0,0 +1,1115 @@
+$NetBSD: patch-ab,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- src/unexelf.c.orig Fri Oct 21 13:21:00 1994
++++ src/unexelf.c Sat May 13 14:04:55 2000
+@@ -1,19 +1,22 @@
+ /* Copyright (C) 1985, 1986, 1987, 1988, 1990, 1992
+ Free Software Foundation, Inc.
+
+- This program is free software; you can redistribute it and/or modify
+- it under the terms of the GNU General Public License as published by
+- the Free Software Foundation; either version 2, or (at your option)
+- any later version.
+-
+- This program is distributed in the hope that it will be useful,
+- but WITHOUT ANY WARRANTY; without even the implied warranty of
+- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+- GNU General Public License for more details.
+-
+- You should have received a copy of the GNU General Public License
+- along with this program; if not, write to the Free Software
+- Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
++This file is part of GNU Emacs.
++
++GNU Emacs is free software; you can redistribute it and/or modify
++it under the terms of the GNU General Public License as published by
++the Free Software Foundation; either version 2, or (at your option)
++any later version.
++
++GNU Emacs is distributed in the hope that it will be useful,
++but WITHOUT ANY WARRANTY; without even the implied warranty of
++MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
++GNU General Public License for more details.
++
++You should have received a copy of the GNU General Public License
++along with GNU Emacs; see the file COPYING. If not, write to
++the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
++Boston, MA 02111-1307, USA.
+
+ In other words, you are welcome to use, share and improve this program.
+ You are forbidden to forbid anyone else to use, share and improve
+@@ -30,14 +33,14 @@
+ * Modified heavily since then.
+ *
+ * Synopsis:
+- * unexec (new_name, a_name, data_start, bss_start, entry_address)
+- * char *new_name, *a_name;
++ * unexec (new_name, old_name, data_start, bss_start, entry_address)
++ * char *new_name, *old_name;
+ * unsigned data_start, bss_start, entry_address;
+ *
+ * Takes a snapshot of the program and makes an a.out format file in the
+ * file named by the string argument new_name.
+- * If a_name is non-NULL, the symbol table will be taken from the given file.
+- * On some machines, an existing a_name file is required.
++ * If old_name is non-NULL, the symbol table will be taken from the given file.
++ * On some machines, an existing old_name file is required.
+ *
+ * The boundaries within the a.out file may be adjusted with the data_start
+ * and bss_start arguments. Either or both may be given as 0 for defaults.
+@@ -98,64 +101,64 @@
+ Link Info Adralgn Entsize
+
+ [1] 1 2 0x80480d4 0xd4 0x13 .interp
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [2] 5 2 0x80480e8 0xe8 0x388 .hash
+- 3 0 0x4 0x4
++ 3 0 0x4 0x4
+
+ [3] 11 2 0x8048470 0x470 0x7f0 .dynsym
+- 4 1 0x4 0x10
++ 4 1 0x4 0x10
+
+ [4] 3 2 0x8048c60 0xc60 0x3ad .dynstr
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [5] 9 2 0x8049010 0x1010 0x338 .rel.plt
+- 3 7 0x4 0x8
++ 3 7 0x4 0x8
+
+ [6] 1 6 0x8049348 0x1348 0x3 .init
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [7] 1 6 0x804934c 0x134c 0x680 .plt
+- 0 0 0x4 0x4
++ 0 0 0x4 0x4
+
+ [8] 1 6 0x80499cc 0x19cc 0x3c56f .text
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [9] 1 6 0x8085f3c 0x3df3c 0x3 .fini
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [10] 1 2 0x8085f40 0x3df40 0x69c .rodata
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [11] 1 2 0x80865dc 0x3e5dc 0xd51 .rodata1
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [12] 1 3 0x8088330 0x3f330 0x20afc .data
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [13] 1 3 0x80a8e2c 0x5fe2c 0x89d .data1
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [14] 1 3 0x80a96cc 0x606cc 0x1a8 .got
+- 0 0 0x4 0x4
++ 0 0 0x4 0x4
+
+ [15] 6 3 0x80a9874 0x60874 0x80 .dynamic
+- 4 0 0x4 0x8
++ 4 0 0x4 0x8
+
+ [16] 8 3 0x80a98f4 0x608f4 0x449c .bss
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [17] 2 0 0 0x608f4 0x9b90 .symtab
+- 18 371 0x4 0x10
++ 18 371 0x4 0x10
+
+ [18] 3 0 0 0x6a484 0x8526 .strtab
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [19] 3 0 0 0x729aa 0x93 .shstrtab
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [20] 1 0 0 0x72a3d 0x68b7 .comment
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ raid:/nfs/raid/src/dist-18.56/src> dump -h xemacs
+
+@@ -166,67 +169,67 @@
+ Link Info Adralgn Entsize
+
+ [1] 1 2 0x80480d4 0xd4 0x13 .interp
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [2] 5 2 0x80480e8 0xe8 0x388 .hash
+- 3 0 0x4 0x4
++ 3 0 0x4 0x4
+
+ [3] 11 2 0x8048470 0x470 0x7f0 .dynsym
+- 4 1 0x4 0x10
++ 4 1 0x4 0x10
+
+ [4] 3 2 0x8048c60 0xc60 0x3ad .dynstr
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [5] 9 2 0x8049010 0x1010 0x338 .rel.plt
+- 3 7 0x4 0x8
++ 3 7 0x4 0x8
+
+ [6] 1 6 0x8049348 0x1348 0x3 .init
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [7] 1 6 0x804934c 0x134c 0x680 .plt
+- 0 0 0x4 0x4
++ 0 0 0x4 0x4
+
+ [8] 1 6 0x80499cc 0x19cc 0x3c56f .text
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [9] 1 6 0x8085f3c 0x3df3c 0x3 .fini
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [10] 1 2 0x8085f40 0x3df40 0x69c .rodata
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [11] 1 2 0x80865dc 0x3e5dc 0xd51 .rodata1
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [12] 1 3 0x8088330 0x3f330 0x20afc .data
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [13] 1 3 0x80a8e2c 0x5fe2c 0x89d .data1
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [14] 1 3 0x80a96cc 0x606cc 0x1a8 .got
+- 0 0 0x4 0x4
++ 0 0 0x4 0x4
+
+ [15] 6 3 0x80a9874 0x60874 0x80 .dynamic
+- 4 0 0x4 0x8
++ 4 0 0x4 0x8
+
+ [16] 8 3 0x80c6800 0x7d800 0 .bss
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [17] 2 0 0 0x7d800 0x9b90 .symtab
+- 18 371 0x4 0x10
++ 18 371 0x4 0x10
+
+ [18] 3 0 0 0x87390 0x8526 .strtab
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [19] 3 0 0 0x8f8b6 0x93 .shstrtab
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [20] 1 0 0 0x8f949 0x68b7 .comment
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [21] 1 3 0x80a98f4 0x608f4 0x1cf0c .data
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ * This is an example of how the file header is changed. "Shoff" is
+ * the section header offset within the file. Since that table is
+@@ -276,20 +279,20 @@
+ Type Offset Vaddr Paddr
+ Filesz Memsz Flags Align
+
+-6 0x34 0x8048034 0
+-0xa0 0xa0 5 0
++6 0x34 0x8048034 0
++0xa0 0xa0 5 0
+
+-3 0xd4 0 0
+-0x13 0 4 0
++3 0xd4 0 0
++0x13 0 4 0
+
+-1 0x34 0x8048034 0
+-0x3f2f9 0x3f2f9 5 0x1000
++1 0x34 0x8048034 0
++0x3f2f9 0x3f2f9 5 0x1000
+
+-1 0x3f330 0x8088330 0
+-0x215c4 0x25a60 7 0x1000
++1 0x3f330 0x8088330 0
++0x215c4 0x25a60 7 0x1000
+
+-2 0x60874 0x80a9874 0
+-0x80 0 7 0
++2 0x60874 0x80a9874 0
++0x80 0 7 0
+
+ raid:/nfs/raid/src/dist-18.56/src> dump -o xemacs
+
+@@ -298,42 +301,42 @@
+ Type Offset Vaddr Paddr
+ Filesz Memsz Flags Align
+
+-6 0x34 0x8048034 0
+-0xa0 0xa0 5 0
++6 0x34 0x8048034 0
++0xa0 0xa0 5 0
+
+-3 0xd4 0 0
+-0x13 0 4 0
++3 0xd4 0 0
++0x13 0 4 0
+
+-1 0x34 0x8048034 0
+-0x3f2f9 0x3f2f9 5 0x1000
++1 0x34 0x8048034 0
++0x3f2f9 0x3f2f9 5 0x1000
+
+-1 0x3f330 0x8088330 0
+-0x3e4d0 0x3e4d0 7 0x1000
++1 0x3f330 0x8088330 0
++0x3e4d0 0x3e4d0 7 0x1000
+
+-2 0x60874 0x80a9874 0
+-0x80 0 7 0
++2 0x60874 0x80a9874 0
++0x80 0 7 0
+
+
+ */
+
+-/* Modified by wtien@urbana.mcd.mot.com of Motorola Inc.
+- *
++/* Modified by wtien@urbana.mcd.mot.com of Motorola Inc.
++ *
+ * The above mechanism does not work if the unexeced ELF file is being
+- * re-layout by other applications (such as `strip'). All the applications
++ * re-layout by other applications (such as `strip'). All the applications
+ * that re-layout the internal of ELF will layout all sections in ascending
+- * order of their file offsets. After the re-layout, the data2 section will
+- * still be the LAST section in the section header vector, but its file offset
++ * order of their file offsets. After the re-layout, the data2 section will
++ * still be the LAST section in the section header vector, but its file offset
+ * is now being pushed far away down, and causes part of it not to be mapped
+- * in (ie. not covered by the load segment entry in PHDR vector), therefore
++ * in (ie. not covered by the load segment entry in PHDR vector), therefore
+ * causes the new binary to fail.
+ *
+ * The solution is to modify the unexec algorithm to insert the new data2
+ * section header right before the new bss section header, so their file
+- * offsets will be in the ascending order. Since some of the section's (all
+- * sections AFTER the bss section) indexes are now changed, we also need to
+- * modify some fields to make them point to the right sections. This is done
++ * offsets will be in the ascending order. Since some of the section's (all
++ * sections AFTER the bss section) indexes are now changed, we also need to
++ * modify some fields to make them point to the right sections. This is done
+ * by macro PATCH_INDEX. All the fields that need to be patched are:
+- *
++ *
+ * 1. ELF header e_shstrndx field.
+ * 2. section header sh_link and sh_info field.
+ * 3. symbol table entry st_shndx field.
+@@ -345,67 +348,67 @@
+ Link Info Adralgn Entsize
+
+ [1] 1 2 0x80480d4 0xd4 0x13 .interp
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [2] 5 2 0x80480e8 0xe8 0x388 .hash
+- 3 0 0x4 0x4
++ 3 0 0x4 0x4
+
+ [3] 11 2 0x8048470 0x470 0x7f0 .dynsym
+- 4 1 0x4 0x10
++ 4 1 0x4 0x10
+
+ [4] 3 2 0x8048c60 0xc60 0x3ad .dynstr
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [5] 9 2 0x8049010 0x1010 0x338 .rel.plt
+- 3 7 0x4 0x8
++ 3 7 0x4 0x8
+
+ [6] 1 6 0x8049348 0x1348 0x3 .init
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [7] 1 6 0x804934c 0x134c 0x680 .plt
+- 0 0 0x4 0x4
++ 0 0 0x4 0x4
+
+ [8] 1 6 0x80499cc 0x19cc 0x3c56f .text
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [9] 1 6 0x8085f3c 0x3df3c 0x3 .fini
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [10] 1 2 0x8085f40 0x3df40 0x69c .rodata
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [11] 1 2 0x80865dc 0x3e5dc 0xd51 .rodata1
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [12] 1 3 0x8088330 0x3f330 0x20afc .data
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [13] 1 3 0x80a8e2c 0x5fe2c 0x89d .data1
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [14] 1 3 0x80a96cc 0x606cc 0x1a8 .got
+- 0 0 0x4 0x4
++ 0 0 0x4 0x4
+
+ [15] 6 3 0x80a9874 0x60874 0x80 .dynamic
+- 4 0 0x4 0x8
++ 4 0 0x4 0x8
+
+ [16] 1 3 0x80a98f4 0x608f4 0x1cf0c .data
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [17] 8 3 0x80c6800 0x7d800 0 .bss
+- 0 0 0x4 0
++ 0 0 0x4 0
+
+ [18] 2 0 0 0x7d800 0x9b90 .symtab
+- 19 371 0x4 0x10
++ 19 371 0x4 0x10
+
+ [19] 3 0 0 0x87390 0x8526 .strtab
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [20] 3 0 0 0x8f8b6 0x93 .shstrtab
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ [21] 1 0 0 0x8f949 0x68b7 .comment
+- 0 0 0x1 0
++ 0 0 0x1 0
+
+ */
+
+@@ -417,15 +420,130 @@
+ #include <errno.h>
+ #include <unistd.h>
+ #include <fcntl.h>
++#if !defined (__NetBSD__) && !defined (__OpenBSD__)
+ #include <elf.h>
++#endif
+ #include <sys/mman.h>
++#if defined (__sony_news) && defined (_SYSTYPE_SYSV)
++#include <sys/elf_mips.h>
++#include <sym.h>
++#endif /* __sony_news && _SYSTYPE_SYSV */
++
++#if defined (__alpha__) && !defined (__NetBSD__) && !defined (__OpenBSD__)
++/* Declare COFF debugging symbol table. This used to be in
++ /usr/include/sym.h, but this file is no longer included in Red Hat
++ 5.0 and presumably in any other glibc 2.x based distribution. */
++typedef struct {
++ short magic;
++ short vstamp;
++ int ilineMax;
++ int idnMax;
++ int ipdMax;
++ int isymMax;
++ int ioptMax;
++ int iauxMax;
++ int issMax;
++ int issExtMax;
++ int ifdMax;
++ int crfd;
++ int iextMax;
++ long cbLine;
++ long cbLineOffset;
++ long cbDnOffset;
++ long cbPdOffset;
++ long cbSymOffset;
++ long cbOptOffset;
++ long cbAuxOffset;
++ long cbSsOffset;
++ long cbSsExtOffset;
++ long cbFdOffset;
++ long cbRfdOffset;
++ long cbExtOffset;
++} HDRR, *pHDRR;
++#define cbHDRR sizeof(HDRR)
++#define hdrNil ((pHDRR)0)
++#endif
++
++#ifdef __NetBSD__
++/*
++ * NetBSD does not have normal-looking user-land ELF support.
++ */
++# ifdef __alpha__
++# define ELFSIZE 64
++# else
++# define ELFSIZE 32
++# endif
++# include <sys/exec_elf.h>
++
++#ifndef PT_LOAD
++# define PT_LOAD Elf_pt_load
++# define SHT_SYMTAB Elf_sht_symtab
++# define SHT_DYNSYM Elf_sht_dynsym
++# define SHT_NULL Elf_sht_null
++# define SHT_NOBITS Elf_sht_nobits
++# define SHT_REL Elf_sht_rel
++# define SHT_RELA Elf_sht_rela
++
++# define SHN_UNDEF Elf_eshn_undefined
++# define SHN_ABS Elf_eshn_absolute
++# define SHN_COMMON Elf_eshn_common
++#endif
++
++/*
++ * The magic of picking the right size types is handled by the ELFSIZE
++ * definition above.
++ */
++# ifdef __STDC__
++# define ElfW(type) Elf_##type
++# else
++# define ElfW(type) Elf_/**/type
++# endif
++
++# ifdef __alpha__
++# include <sys/exec_ecoff.h>
++# define HDRR struct ecoff_symhdr
++# define pHDRR HDRR *
++# endif /* __alpha__*/
++
++# ifdef __mips__
++# define SHT_MIPS_DEBUG DT_MIPS_FLAGS
++# define HDRR struct Elf_Shdr
++# endif /* __mips__ */
++
++#endif /* __NetBSD__ */
++
++
++#ifdef __OpenBSD__
++# include <sys/exec_elf.h>
++#endif
++
++#if __GNU_LIBRARY__ - 0 >= 6
++# include <link.h> /* get ElfW etc */
++#endif
++
++#ifndef ElfW
++# ifdef __STDC__
++# define ElfW(type) Elf32_##type
++# else
++# define ElfW(type) Elf32_/**/type
++# endif
++#endif
+
+ #ifndef emacs
+ #define fatal(a, b, c) fprintf (stderr, a, b, c), exit (1)
+ #else
++#include <config.h>
+ extern void fatal (char *, ...);
+ #endif
+
++#if defined ( __sony_news) && defined (_SYSTYPE_SYSV)
++# define HAVE_MIPS_SBSS
++#endif
++
++#if (defined (__mips__) || defined (__powerpc__)) && (defined(__NetBSD__) || defined(__OpenBSD__))
++# define HAVE_MIPS_SBSS
++#endif
++
+ #ifndef ELF_BSS_SECTION_NAME
+ #define ELF_BSS_SECTION_NAME ".bss"
+ #endif
+@@ -433,15 +551,38 @@
+ /* Get the address of a particular section or program header entry,
+ * accounting for the size of the entries.
+ */
++/*
++ On PPC Reference Platform running Solaris 2.5.1
++ the plt section is also of type NOBI like the bss section.
++ (not really stored) and therefore sections after the bss
++ section start at the plt offset. The plt section is always
++ the one just before the bss section.
++ Thus, we modify the test from
++ if (NEW_SECTION_H (nn).sh_offset >= new_data2_offset)
++ to
++ if (NEW_SECTION_H (nn).sh_offset >=
++ OLD_SECTION_H (old_bss_index-1).sh_offset)
++ This is just a hack. We should put the new data section
++ before the .plt section.
++ And we should not have this routine at all but use
++ the libelf library to read the old file and create the new
++ file.
++ The changed code is minimal and depends on prep set in m/prep.h
++ Erik Deumens
++ Quantum Theory Project
++ University of Florida
++ deumens@qtp.ufl.edu
++ Apr 23, 1996
++ */
+
+ #define OLD_SECTION_H(n) \
+- (*(Elf32_Shdr *) ((byte *) old_section_h + old_file_h->e_shentsize * (n)))
++ (*(ElfW(Shdr) *) ((byte *) old_section_h + old_file_h->e_shentsize * (n)))
+ #define NEW_SECTION_H(n) \
+- (*(Elf32_Shdr *) ((byte *) new_section_h + new_file_h->e_shentsize * (n)))
++ (*(ElfW(Shdr) *) ((byte *) new_section_h + new_file_h->e_shentsize * (n)))
+ #define OLD_PROGRAM_H(n) \
+- (*(Elf32_Phdr *) ((byte *) old_program_h + old_file_h->e_phentsize * (n)))
++ (*(ElfW(Phdr) *) ((byte *) old_program_h + old_file_h->e_phentsize * (n)))
+ #define NEW_PROGRAM_H(n) \
+- (*(Elf32_Phdr *) ((byte *) new_program_h + new_file_h->e_phentsize * (n)))
++ (*(ElfW(Phdr) *) ((byte *) new_program_h + new_file_h->e_phentsize * (n)))
+
+ #define PATCH_INDEX(n) \
+ do { \
+@@ -451,9 +592,9 @@
+
+ /* Round X up to a multiple of Y. */
+
+-int
++ElfW(Addr)
+ round_up (x, y)
+- int x, y;
++ ElfW(Addr) x, y;
+ {
+ int rem = x % y;
+ if (rem == 0)
+@@ -461,6 +602,47 @@
+ return x - rem + y;
+ }
+
++#if defined(__alpha__) || (defined ( __sony_news) && defined (_SYSTYPE_SYSV))
++/* We are using ECOFF symbols embedded in ELF. */
++
++void
++relocate_ecoff_symhdr(symhdr, diff)
++ HDRR *symhdr;
++ ElfW(Word) diff;
++{
++ symhdr->cbLineOffset += diff;
++ symhdr->cbDnOffset += diff;
++ symhdr->cbPdOffset += diff;
++ symhdr->cbSymOffset += diff;
++ symhdr->cbOptOffset += diff;
++ symhdr->cbAuxOffset += diff;
++ symhdr->cbSsOffset += diff;
++ symhdr->cbSsExtOffset += diff;
++ symhdr->cbFdOffset += diff;
++ symhdr->cbRfdOffset += diff;
++ symhdr->cbExtOffset += diff;
++}
++#endif /* __alpha__ or __sony_news and systype_sysv */
++
++#ifdef notyet
++void
++relocate_elf_proghdr(p, diff)
++ HDRR *symhdr;
++ ElfW(Word) diff;
++{
++ phdr->sh_name += diff;
++ phdr->sh_type += diff;
++ phdr->sh_flags += diff;
++ phdr->sh_addr += diff;
++ phdr->sh_offset += diff;
++ phdr->sh_size += diff;
++ phdr->sh_link += diff;
++ phdr->sh_info += diff;
++ phdr->sh_addralign += diff;
++ phdr->sh_entsize += diff;
++};
++#endif /* notyet */
++
+ /* ****************************************************************
+ * unexec
+ *
+@@ -483,19 +665,23 @@
+ /* Pointers to the file, program and section headers for the old and new
+ * files.
+ */
+- Elf32_Ehdr *old_file_h, *new_file_h;
+- Elf32_Phdr *old_program_h, *new_program_h;
+- Elf32_Shdr *old_section_h, *new_section_h;
++ ElfW(Ehdr) *old_file_h, *new_file_h;
++ ElfW(Phdr) *old_program_h, *new_program_h;
++ ElfW(Shdr) *old_section_h, *new_section_h;
+
+ /* Point to the section name table in the old file */
+ char *old_section_names;
+
+- Elf32_Addr old_bss_addr, new_bss_addr;
+- Elf32_Word old_bss_size, new_data2_size;
+- Elf32_Off new_data2_offset;
+- Elf32_Addr new_data2_addr;
++ ElfW(Addr) old_bss_addr, new_bss_addr;
++ ElfW(Word) old_bss_size, new_data2_size;
++ ElfW(Off) new_data2_offset;
++ ElfW(Addr) new_data2_addr;
+
+ int n, nn, old_bss_index, old_data_index, new_data2_index;
++#ifdef HAVE_MIPS_SBSS
++ int old_sbss_index, old_mdebug_index;
++ int bss_phdr_index;
++#endif /* HAVE_MIPS_SBSS */
+ struct stat stat_buf;
+
+ /* Open the old file & map it into the address space. */
+@@ -508,7 +694,8 @@
+ if (fstat (old_file, &stat_buf) == -1)
+ fatal ("Can't fstat (%s): errno %d\n", old_name, errno);
+
+- old_base = mmap (0, stat_buf.st_size, PROT_READ, MAP_SHARED, old_file, 0);
++ old_base = mmap ((caddr_t) 0, stat_buf.st_size, PROT_READ, MAP_SHARED,
++ old_file, 0);
+
+ if (old_base == (caddr_t) -1)
+ fatal ("Can't mmap (%s): errno %d\n", old_name, errno);
+@@ -520,9 +707,9 @@
+
+ /* Get pointers to headers & section names */
+
+- old_file_h = (Elf32_Ehdr *) old_base;
+- old_program_h = (Elf32_Phdr *) ((byte *) old_base + old_file_h->e_phoff);
+- old_section_h = (Elf32_Shdr *) ((byte *) old_base + old_file_h->e_shoff);
++ old_file_h = (ElfW(Ehdr) *) old_base;
++ old_program_h = (ElfW(Phdr) *) ((byte *) old_base + old_file_h->e_phoff);
++ old_section_h = (ElfW(Shdr) *) ((byte *) old_base + old_file_h->e_shoff);
+ old_section_names = (char *) old_base
+ + OLD_SECTION_H (old_file_h->e_shstrndx).sh_offset;
+
+@@ -544,16 +731,61 @@
+ if (old_bss_index == old_file_h->e_shnum)
+ fatal ("Can't find .bss in %s.\n", old_name, 0);
+
++#ifdef HAVE_MIPS_SBSS
++ for (old_sbss_index = 1; old_sbss_index < (int) old_file_h->e_shnum;
++ old_sbss_index++)
++ {
++#ifdef DEBUG
++ fprintf (stderr, "Looking for .sbss - found %s\n",
++ old_section_names + OLD_SECTION_H (old_sbss_index).sh_name);
++#endif
++ if (!strcmp (old_section_names + OLD_SECTION_H (old_sbss_index).sh_name,
++ ".sbss"))
++ break;
++ }
++ if (old_sbss_index == old_file_h->e_shnum)
++ {
++ old_bss_addr = OLD_SECTION_H(old_bss_index).sh_addr;
++ old_bss_size = OLD_SECTION_H(old_bss_index).sh_size;
++ new_data2_offset = OLD_SECTION_H(old_bss_index).sh_offset;
++ new_data2_index = old_bss_index;
++ }
++ else
++ {
++ old_bss_addr = OLD_SECTION_H(old_sbss_index).sh_addr;
++ old_bss_size = OLD_SECTION_H(old_bss_index).sh_size
++ + OLD_SECTION_H(old_sbss_index).sh_size;
++ new_data2_offset = OLD_SECTION_H(old_sbss_index).sh_offset;
++ new_data2_index = old_sbss_index;
++ }
++
++ for (old_mdebug_index = 1; old_mdebug_index < (int) old_file_h->e_shnum;
++ old_mdebug_index++)
++ {
++#ifdef DEBUG
++ fprintf (stderr, "Looking for .mdebug - found %s\n",
++ old_section_names + OLD_SECTION_H (old_mdebug_index).sh_name);
++#endif
++ if (!strcmp (old_section_names + OLD_SECTION_H (old_mdebug_index).sh_name,
++ ".mdebug"))
++ break;
++ }
++ if (old_mdebug_index == old_file_h->e_shnum)
++ old_mdebug_index = 0;
++#else /* not HAVE_MIPS_SBSS */
+ old_bss_addr = OLD_SECTION_H (old_bss_index).sh_addr;
+ old_bss_size = OLD_SECTION_H (old_bss_index).sh_size;
+-#if defined(emacs) || !defined(DEBUG)
+- new_bss_addr = (Elf32_Addr) sbrk (0);
++#endif /* not HAVE_MIPS_SBSS */
++#if defined (emacs) || !defined (DEBUG)
++ new_bss_addr = (ElfW(Addr)) sbrk (0);
+ #else
+ new_bss_addr = old_bss_addr + old_bss_size + 0x1234;
+ #endif
+ new_data2_addr = old_bss_addr;
+ new_data2_size = new_bss_addr - old_bss_addr;
++#ifndef HAVE_MIPS_SBSS
+ new_data2_offset = OLD_SECTION_H (old_bss_index).sh_offset;
++#endif /* not HAVE_MIPS_SBSS */
+
+ #ifdef DEBUG
+ fprintf (stderr, "old_bss_index %d\n", old_bss_index);
+@@ -582,15 +814,20 @@
+ if (ftruncate (new_file, new_file_size))
+ fatal ("Can't ftruncate (%s): errno %d\n", new_name, errno);
+
+- new_base = mmap (0, new_file_size, PROT_READ | PROT_WRITE, MAP_SHARED,
+- new_file, 0);
++#ifdef UNEXEC_USE_MAP_PRIVATE
++ new_base = mmap ((caddr_t) 0, new_file_size, PROT_READ | PROT_WRITE,
++ MAP_PRIVATE, new_file, 0);
++#else
++ new_base = mmap ((caddr_t) 0, new_file_size, PROT_READ | PROT_WRITE,
++ MAP_SHARED, new_file, 0);
++#endif
+
+ if (new_base == (caddr_t) -1)
+ fatal ("Can't mmap (%s): errno %d\n", new_name, errno);
+
+- new_file_h = (Elf32_Ehdr *) new_base;
+- new_program_h = (Elf32_Phdr *) ((byte *) new_base + old_file_h->e_phoff);
+- new_section_h = (Elf32_Shdr *)
++ new_file_h = (ElfW(Ehdr) *) new_base;
++ new_program_h = (ElfW(Phdr) *) ((byte *) new_base + old_file_h->e_phoff);
++ new_section_h = (ElfW(Shdr) *)
+ ((byte *) new_base + old_file_h->e_shoff + new_data2_size);
+
+ /* Make our new file, program and section headers as copies of the
+@@ -633,8 +870,14 @@
+ if ((OLD_SECTION_H (old_bss_index)).sh_addralign > alignment)
+ alignment = OLD_SECTION_H (old_bss_index).sh_addralign;
+
++#ifdef HAVE_MIPS_SBSS
++ if (NEW_PROGRAM_H (n).p_vaddr + NEW_PROGRAM_H (n).p_filesz
++ > round_up (old_bss_addr, alignment))
++ fatal ("Program segment above .bss in %s\n", old_name, 0);
++#else /* not HAVE_MIPS_SBSS */
+ if (NEW_PROGRAM_H (n).p_vaddr + NEW_PROGRAM_H (n).p_filesz > old_bss_addr)
+ fatal ("Program segment above .bss in %s\n", old_name, 0);
++#endif /* not HAVE_MIPS_SBSS */
+
+ if (NEW_PROGRAM_H (n).p_type == PT_LOAD
+ && (round_up ((NEW_PROGRAM_H (n)).p_vaddr
+@@ -646,9 +889,16 @@
+ if (n < 0)
+ fatal ("Couldn't find segment next to .bss in %s\n", old_name, 0);
+
+- NEW_PROGRAM_H (n).p_filesz += new_data2_size;
++#ifdef HAVE_MIPS_SBSS
++ bss_phdr_index = n;
++#endif
++
++ /* Make sure that the size includes any padding before the old .bss
++ section. */
++ NEW_PROGRAM_H (n).p_filesz = new_bss_addr - NEW_PROGRAM_H (n).p_vaddr;
+ NEW_PROGRAM_H (n).p_memsz = NEW_PROGRAM_H (n).p_filesz;
+
++
+ #if 0 /* Maybe allow section after data2 - does this ever happen? */
+ for (n = new_file_h->e_phnum - 1; n >= 0; n--)
+ {
+@@ -675,18 +925,27 @@
+ if (old_data_index == old_file_h->e_shnum)
+ fatal ("Can't find .data in %s.\n", old_name, 0);
+
+- /* Walk through all section headers, insert the new data2 section right
++ /* Walk through all section headers, insert the new data2 section right
+ before the new bss section. */
+ for (n = 1, nn = 1; n < (int) old_file_h->e_shnum; n++, nn++)
+ {
+ caddr_t src;
+- /* If it is bss section, insert the new data2 section before it. */
+- if (n == old_bss_index)
++ int temp_index;
++#ifdef HAVE_MIPS_SBSS
++ /* If it is (s)bss section, insert the new data2 section before it. */
++ /* new_data2_index is the index of either old_sbss or old_bss, that was
++ chosen as a section for new_data2. */
++ temp_index = new_data2_index;
++#else /* not HAVE_MIPS_SBSS */
++ /* If it is bss section, insert the new data2 section before it. */
++ temp_index = old_bss_index;
++#endif /* not HAVE_MIPS_SBSS */
++ if (n == temp_index)
+ {
+ /* Steal the data section header for this data2 section. */
+ memcpy (&NEW_SECTION_H (nn), &OLD_SECTION_H (old_data_index),
+ new_file_h->e_shentsize);
+-
++
+ NEW_SECTION_H (nn).sh_addr = new_data2_addr;
+ NEW_SECTION_H (nn).sh_offset = new_data2_offset;
+ NEW_SECTION_H (nn).sh_size = new_data2_size;
+@@ -696,37 +955,87 @@
+ NEW_SECTION_H (nn).sh_addralign = OLD_SECTION_H (n).sh_addralign;
+
+ /* Now copy over what we have in the memory now. */
+- memcpy (NEW_SECTION_H (nn).sh_offset + new_base,
+- (caddr_t) OLD_SECTION_H (n).sh_addr,
++ memcpy (NEW_SECTION_H (nn).sh_offset + new_base,
++ (caddr_t) OLD_SECTION_H (n).sh_addr,
+ new_data2_size);
+ nn++;
+ }
+-
+- memcpy (&NEW_SECTION_H (nn), &OLD_SECTION_H (n),
++
++ memcpy (&NEW_SECTION_H (nn), &OLD_SECTION_H (n),
+ old_file_h->e_shentsize);
+
+- /* The new bss section's size is zero, and its file offset and virtual
+- address should be off by NEW_DATA2_SIZE. */
+- if (n == old_bss_index)
++ if (n == old_bss_index
++#ifdef HAVE_MIPS_SBSS
++ /* The new bss and sbss section's size is zero, and its file offset
++ and virtual address should be off by NEW_DATA2_SIZE. */
++ || n == old_sbss_index
++#endif /* HAVE_MIPS_SBSS */
++ )
+ {
+ /* NN should be `old_bss_index + 1' at this point. */
+ NEW_SECTION_H (nn).sh_offset += new_data2_size;
+ NEW_SECTION_H (nn).sh_addr += new_data2_size;
+ /* Let the new bss section address alignment be the same as the
+- section address alignment followed the old bss section, so
++ section address alignment followed the old bss section, so
+ this section will be placed in exactly the same place. */
+ NEW_SECTION_H (nn).sh_addralign = OLD_SECTION_H (nn).sh_addralign;
+ NEW_SECTION_H (nn).sh_size = 0;
++
++#ifdef HAVE_MIPS_SBSS
++ /* On ELF mips, the new data section replaces both .sbss and .bss
++ (we have, after all, written to them.). Adding new_data2_size
++ to the sh_addr and sh_offset of sbss puts sbss at the end of
++ the new data section. setting the size to zero makes it empty.
++ But then, adding the new_data2_size to the bss address puts
++ its start beyond the end of the original bss. If the sbss size
++ was bigger than a page, the bss ends up not covered by the
++ program header. This breaks strip. Since both sbss and bss
++ are zero-sized, just use the same address and file offset for
++ both, guaranteeing other tools will assign them to the same
++ program section (asssuming no sections are loaded at higher
++ offsets.) */
++ if (n == old_bss_index) {
++ int new_sbss_bss_padding = NEW_SECTION_H(nn).sh_addr -
++ NEW_SECTION_H(nn - 1).sh_addr;
++ printf("sbss to bss offset =0x%x\n", new_sbss_bss_padding);
++ NEW_SECTION_H(nn).sh_addr =NEW_SECTION_H(nn - 1).sh_addr;
++ NEW_SECTION_H(nn).sh_offset =NEW_SECTION_H(nn - 1).sh_offset;
++ }
++#endif /* HAVE_MIPS_SBSS */
+ }
+- /* Any section that was original placed AFTER the bss section should now
+- be off by NEW_DATA2_SIZE. */
+- else if (NEW_SECTION_H (nn).sh_offset >= new_data2_offset)
+- NEW_SECTION_H (nn).sh_offset += new_data2_size;
+-
++ else
++ {
++ /* Any section that was original placed AFTER the bss
++ section should now be off by NEW_DATA2_SIZE. */
++#ifdef SOLARIS_POWERPC
++ /* On PPC Reference Platform running Solaris 2.5.1
++ the plt section is also of type NOBI like the bss section.
++ (not really stored) and therefore sections after the bss
++ section start at the plt offset. The plt section is always
++ the one just before the bss section.
++ It would be better to put the new data section before
++ the .plt section, or use libelf instead.
++ Erik Deumens, deumens@qtp.ufl.edu. */
++ if (NEW_SECTION_H (nn).sh_offset
++ >= OLD_SECTION_H (old_bss_index-1).sh_offset)
++ NEW_SECTION_H (nn).sh_offset += new_data2_size;
++#else
++ if (round_up (NEW_SECTION_H (nn).sh_offset,
++ OLD_SECTION_H (old_bss_index).sh_addralign)
++ >= new_data2_offset)
++ NEW_SECTION_H (nn).sh_offset += new_data2_size;
++#endif
++ /* Any section that was originally placed after the section
++ header table should now be off by the size of one section
++ header table entry. */
++ if (NEW_SECTION_H (nn).sh_offset > new_file_h->e_shoff)
++ NEW_SECTION_H (nn).sh_offset += new_file_h->e_shentsize;
++ }
++
+ /* If any section hdr refers to the section after the new .data
+- section, make it refer to next one because we have inserted
++ section, make it refer to next one because we have inserted
+ a new section in between. */
+-
++
+ PATCH_INDEX (NEW_SECTION_H (nn).sh_link);
+ /* For symbol tables, info is a symbol table index,
+ so don't change it. */
+@@ -738,7 +1047,7 @@
+ if (NEW_SECTION_H (nn).sh_type == SHT_NULL
+ || NEW_SECTION_H (nn).sh_type == SHT_NOBITS)
+ continue;
+-
++
+ /* Write out the sections. .data and .data1 (and data2, called
+ ".data" in the strings table) get copied from the current process
+ instead of the old file. */
+@@ -747,22 +1056,54 @@
+ || !strcmp ((old_section_names + NEW_SECTION_H(n).sh_name),
+ ".sdata")
+ #endif
++#ifdef HAVE_MIPS_SBSS
++ || !strcmp ((old_section_names + NEW_SECTION_H (n).sh_name),
++ ".sdata")
++ || !strcmp ((old_section_names + NEW_SECTION_H (n).sh_name),
++ ".lit4")
++ || !strcmp ((old_section_names + NEW_SECTION_H (n).sh_name),
++ ".lit8")
++#endif /* HAVE_MIPS_SBSS */
+ || !strcmp ((old_section_names + NEW_SECTION_H (n).sh_name),
+ ".data1"))
+ src = (caddr_t) OLD_SECTION_H (n).sh_addr;
+ else
+ src = old_base + OLD_SECTION_H (n).sh_offset;
+-
++
+ memcpy (NEW_SECTION_H (nn).sh_offset + new_base, src,
+ NEW_SECTION_H (nn).sh_size);
+
++#ifdef __alpha__
++ /* Update Alpha COFF symbol table: */
++ if (strcmp (old_section_names + OLD_SECTION_H (n).sh_name, ".mdebug")
++ == 0)
++ {
++ pHDRR symhdr = (pHDRR) (NEW_SECTION_H (nn).sh_offset + new_base);
++ relocate_ecoff_symhdr(symhdr, new_data2_size);
++ }
++#endif /* __alpha__ */
++
++#if defined (__sony_news) && defined (_SYSTYPE_SYSV)
++ if (NEW_SECTION_H (nn).sh_type == SHT_MIPS_DEBUG && old_mdebug_index)
++ {
++ int diff = NEW_SECTION_H(nn).sh_offset
++ - OLD_SECTION_H(old_mdebug_index).sh_offset;
++ HDRR *phdr = (HDRR *)(NEW_SECTION_H (nn).sh_offset + new_base);
++
++ if (diff)
++ {
++ relocate_ecoff_symhdr(phdr, diff);
++ }
++ }
++#endif /* __sony_news and systype_sysv */
++
+ /* If it is the symbol table, its st_shndx field needs to be patched. */
+ if (NEW_SECTION_H (nn).sh_type == SHT_SYMTAB
+ || NEW_SECTION_H (nn).sh_type == SHT_DYNSYM)
+ {
+- Elf32_Shdr *spt = &NEW_SECTION_H (nn);
++ ElfW(Shdr) *spt = &NEW_SECTION_H (nn);
+ unsigned int num = spt->sh_size / spt->sh_entsize;
+- Elf32_Sym * sym = (Elf32_Sym *) (NEW_SECTION_H (nn).sh_offset +
++ ElfW(Sym) * sym = (ElfW(Sym) *) (NEW_SECTION_H (nn).sh_offset +
+ new_base);
+ for (; num--; sym++)
+ {
+@@ -770,7 +1111,7 @@
+ || (sym->st_shndx == SHN_ABS)
+ || (sym->st_shndx == SHN_COMMON))
+ continue;
+-
++
+ PATCH_INDEX (sym->st_shndx);
+ }
+ }
+@@ -780,21 +1121,71 @@
+ for (n = new_file_h->e_shnum - 1; n; n--)
+ {
+ byte *symnames;
+- Elf32_Sym *symp, *symendp;
++ ElfW(Sym) *symp, *symendp;
+
+ if (NEW_SECTION_H (n).sh_type != SHT_DYNSYM
+ && NEW_SECTION_H (n).sh_type != SHT_SYMTAB)
+ continue;
+
+- symnames = NEW_SECTION_H (NEW_SECTION_H (n).sh_link).sh_offset + new_base;
+- symp = (Elf32_Sym *) (NEW_SECTION_H (n).sh_offset + new_base);
+- symendp = (Elf32_Sym *) ((byte *)symp + NEW_SECTION_H (n).sh_size);
++ symnames = ((byte *) new_base
++ + NEW_SECTION_H (NEW_SECTION_H (n).sh_link).sh_offset);
++ symp = (ElfW(Sym) *) (NEW_SECTION_H (n).sh_offset + new_base);
++ symendp = (ElfW(Sym) *) ((byte *)symp + NEW_SECTION_H (n).sh_size);
+
+ for (; symp < symendp; symp ++)
+ if (strcmp ((char *) (symnames + symp->st_name), "_end") == 0
+- || strcmp ((char *) (symnames + symp->st_name), "_edata") == 0)
++ || strcmp ((char *) (symnames + symp->st_name), "end") == 0
++ || strcmp ((char *) (symnames + symp->st_name), "_edata") == 0
++ || strcmp ((char *) (symnames + symp->st_name), "edata") == 0)
+ memcpy (&symp->st_value, &new_bss_addr, sizeof (new_bss_addr));
+ }
++
++ /* This loop seeks out relocation sections for the data section, so
++ that it can undo relocations performed by the runtime linker. */
++ for (n = new_file_h->e_shnum - 1; n; n--)
++ {
++ ElfW(Shdr) section = NEW_SECTION_H (n);
++ switch (section.sh_type) {
++ default:
++ break;
++ case SHT_REL:
++ case SHT_RELA:
++ /* This code handles two different size structs, but there should
++ be no harm in that provided that r_offset is always the first
++ member. */
++ nn = section.sh_info;
++ if (!strcmp (old_section_names + NEW_SECTION_H (nn).sh_name, ".data")
++ || !strcmp ((old_section_names + NEW_SECTION_H (nn).sh_name),
++ ".data1"))
++ {
++ ElfW(Addr) offset = NEW_SECTION_H (nn).sh_addr -
++ NEW_SECTION_H (nn).sh_offset;
++ caddr_t reloc = old_base + section.sh_offset, end;
++ for (end = reloc + section.sh_size; reloc < end;
++ reloc += section.sh_entsize)
++ {
++ ElfW(Addr) addr = ((ElfW(Rel) *) reloc)->r_offset - offset;
++#ifdef __alpha__
++ /* The Alpha ELF binutils currently have a bug that
++ sometimes results in relocs that contain all
++ zeroes. Work around this for now... */
++ if (((ElfW(Rel) *) reloc)->r_offset == 0)
++ continue;
++#endif
++ memcpy (new_base + addr, old_base + addr, sizeof(ElfW(Addr)));
++ }
++ }
++ break;
++ }
++ }
++
++#ifdef UNEXEC_USE_MAP_PRIVATE
++ if (lseek (new_file, 0, SEEK_SET) == -1)
++ fatal ("Can't rewind (%s): errno %d\n", new_name, errno);
++
++ if (write (new_file, new_base, new_file_size) != new_file_size)
++ fatal ("Can't write (%s): errno %d\n", new_name, errno);
++#endif
+
+ /* Close the files and make the new file executable. */
+
diff --git a/editors/mule/patches/patch-ac b/editors/mule/patches/patch-ac
new file mode 100644
index 00000000000..002845572a8
--- /dev/null
+++ b/editors/mule/patches/patch-ac
@@ -0,0 +1,22 @@
+$NetBSD: patch-ac,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- lib-src/Makefile.in.in.orig Mon Dec 19 13:13:45 1994
++++ lib-src/Makefile.in.in Sun Sep 27 19:22:21 1998
+@@ -206,7 +206,7 @@
+ if [ `(cd ${archlibdir} && /bin/pwd)` \
+ != `(cd ${srcdir} && /bin/pwd)` ]; then \
+ for file in ${SCRIPTS}; do \
+- (cd ..; $(INSTALL_PROGRAM) ${srcdir}/$$file ${archlibdir}/$$file); \
++ (cd ..; $(INSTALL) ${srcdir}/$$file ${archlibdir}/$$file); \
+ done ; \
+ fi
+
+@@ -219,7 +219,7 @@
+ (cd ..; $(INSTALL_PROGRAM) lib-src/$${file} ${bindir}/$${file}) ; \
+ done
+ for file in ${INSTALLABLE_SCRIPTS} ; do \
+- (cd ..; $(INSTALL_PROGRAM) ${srcdir}/$${file} ${bindir}/$${file}) ; \
++ (cd ..; $(INSTALL) ${srcdir}/$${file} ${bindir}/$${file}) ; \
+ done
+
+ uninstall:
diff --git a/editors/mule/patches/patch-ad b/editors/mule/patches/patch-ad
new file mode 100644
index 00000000000..376ecbb7c3d
--- /dev/null
+++ b/editors/mule/patches/patch-ad
@@ -0,0 +1,12 @@
+$NetBSD: patch-ad,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- configure.orig Mon Sep 20 13:03:01 1999
++++ configure Mon Sep 20 13:35:04 1999
+@@ -587,6 +587,7 @@
+ machine=hp9000s300 ;;
+ mips-*-netbsd*) machine=pmax ;;
+ ns32k-*-netbsd*) machine=ns32000 ;;
++ powerpc-*-netbsd*) machine=powerpc ;;
+ sparc-*-netbsd*) machine=sparc ;;
+ esac
+ ;;
diff --git a/editors/mule/patches/patch-ae b/editors/mule/patches/patch-ae
new file mode 100644
index 00000000000..cb5215fd4da
--- /dev/null
+++ b/editors/mule/patches/patch-ae
@@ -0,0 +1,173 @@
+$NetBSD: patch-ae,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+NetBSD patch-bd,v 1.2 1999/06/04 04:15:44 mycroft Exp
+original patch from editors/emacs pkg.
+
+--- /dev/null Mon Sep 20 13:51:57 1999
++++ src/m/powerpc.h Mon Sep 20 23:21:37 1999
+@@ -0,0 +1,165 @@
++/* machine description file For the PowerPC chip.
++ Copyright (C) 1994, 1997 Free Software Foundation, Inc.
++
++This file is part of GNU Emacs.
++
++GNU Emacs is free software; you can redistribute it and/or modify
++it under the terms of the GNU General Public License as published by
++the Free Software Foundation; either version 1, or (at your option)
++any later version.
++
++GNU Emacs is distributed in the hope that it will be useful,
++but WITHOUT ANY WARRANTY; without even the implied warranty of
++MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
++GNU General Public License for more details.
++
++You should have received a copy of the GNU General Public License
++along with GNU Emacs; see the file COPYING. If not, write to
++the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
++Boston, MA 02111-1307, USA. */
++
++/* The following three symbols give information on
++ the size of various data types. */
++
++#define SHORTBITS 16 /* Number of bits in a short */
++
++#define INTBITS 32 /* Number of bits in an int */
++
++#define LONGBITS 32 /* Number of bits in a long */
++
++/* Define WORDS_BIG_ENDIAN iff lowest-numbered byte in a word
++ is the most significant byte. */
++
++#define WORDS_BIG_ENDIAN
++
++/* Define NO_ARG_ARRAY if you cannot take the address of the first of a
++ * group of arguments and treat it as an array of the arguments. */
++
++#define NO_ARG_ARRAY
++
++/* Define WORD_MACHINE if addresses and such have
++ * to be corrected before they can be used as byte counts. */
++
++/* #define WORD_MACHINE */
++
++/* Now define a symbol for the cpu type, if your compiler
++ does not define it automatically:
++ Ones defined so far include vax, m68000, ns16000, pyramid,
++ orion, tahoe, APOLLO and many others */
++
++/* __powerpc__ defined automatically */
++
++
++/* Use type EMACS_INT rather than a union, to represent Lisp_Object */
++/* This is desirable for most machines. */
++
++#define NO_UNION_TYPE
++
++/* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend
++ the 24-bit bit field into an int. In other words, if bit fields
++ are always unsigned.
++
++ If you use NO_UNION_TYPE, this flag does not matter. */
++
++#define EXPLICIT_SIGN_EXTEND
++
++/* Data type of load average, as read out of kmem. */
++
++#define LOAD_AVE_TYPE long
++
++/* Convert that into an integer that is 100 for a load average of 1.0 */
++
++#define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0 / FSCALE)
++
++/* Define CANNOT_DUMP on machines where unexec does not work.
++ Then the function dump-emacs will not be defined
++ and temacs will do (load "loadup") automatically unless told otherwise. */
++
++/* #define CANNOT_DUMP */
++
++/* Define VIRT_ADDR_VARIES if the virtual addresses of
++ pure and impure space as loaded can vary, and even their
++ relative order cannot be relied on.
++
++ Otherwise Emacs assumes that text space precedes data space,
++ numerically. */
++
++/* #define VIRT_ADDR_VARIES */
++
++/* Define C_ALLOCA if this machine does not support a true alloca
++ and the one written in C should be used instead.
++ Define HAVE_ALLOCA to say that the system provides a properly
++ working alloca function and it should be used.
++ Define neither one if an assembler-language alloca
++ in the file alloca.s should be used. */
++
++#define HAVE_ALLOCA
++
++/* GNU malloc and the relocating allocator do not work together
++ with X. [Who wrote that?] */
++
++/* May 1995: reportedly [Rainer Schoepf <schoepf@uni-mainz.de>] both the
++ system and the gnu malloc system work with "alpha-dec-osf3.0" and
++ "alpha-dec-osf3.2". */
++
++/* May 1995: it seems to me [Morten Welinder <terra@diku.dk>] that both
++ mallocs work with "alpha-dec-osf2.0", but I daren't break anything
++ right now. Feel free to play if you want. */
++
++/* #define SYSTEM_MALLOC */
++
++/* Define NO_REMAP if memory segmentation makes it not work well
++ to change the boundary between the text section and data section
++ when Emacs is dumped. If you define this, the preloaded Lisp
++ code will not be sharable; but that's better than failing completely. */
++
++#define NO_REMAP
++
++/* Some really obscure 4.2-based systems (like Sequent DYNIX)
++ * do not support asynchronous I/O (using SIGIO) on sockets,
++ * even though it works fine on tty's. If you have one of
++ * these systems, define the following, and then use it in
++ * config.h (or elsewhere) to decide when (not) to use SIGIO.
++ *
++ * You'd think this would go in an operating-system description file,
++ * but since it only occurs on some, but not all, BSD systems, the
++ * reasonable place to select for it is in the machine description
++ * file.
++ */
++
++/* #define NO_SOCK_SIGIO */
++
++
++#ifdef __ELF__
++/* With ELF, make sure that all common symbols get allocated to in the
++ data section. Otherwise, the dump of temacs may miss variables in
++ the shared library that have been initialized. For example, with
++ GNU libc, __malloc_initialized would normally be resolved to the
++ shared library's .bss section, which is fatal. */
++# ifdef __GNUC__
++# define C_SWITCH_MACHINE -fno-common
++# else
++# error What gives? Fix me if DEC Unix supports ELF now.
++# endif
++#endif
++
++#if defined(__NetBSD__) || defined(__OpenBSD__)
++#define ORDINARY_LINK
++#endif
++
++#ifdef __ELF__
++#undef UNEXEC
++#define UNEXEC unexelf.o
++#endif
++
++/* On the Alpha it's best to avoid including TERMIO since struct
++ termio and struct termios are mutually incompatible. */
++#define NO_TERMIO
++
++#if defined (LINUX) || defined (__NetBSD__) || defined (__OpenBSD__)
++# define TEXT_END ({ extern int _etext; &_etext; })
++#endif
++
++#if (defined (__NetBSD__) || defined (__OpenBSD__)) && defined (__ELF__)
++#define HAVE_TEXT_START
++#endif
diff --git a/editors/mule/patches/patch-af b/editors/mule/patches/patch-af
new file mode 100644
index 00000000000..a4cc8b29f35
--- /dev/null
+++ b/editors/mule/patches/patch-af
@@ -0,0 +1,15 @@
+$NetBSD: patch-af,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- src/lisp.h.orig Mon Sep 20 13:42:34 1999
++++ src/lisp.h Mon Sep 20 13:43:50 1999
+@@ -30,6 +30,10 @@
+ /* 93.1.15 modified for Mule Ver.0.9.7.1 by Y.Akiba <akiba@cbs.canon.co.jp>
+ Patch for NeXT is updated. */
+
++#if defined(__NetBSD__)
++#include <machine/limits.h> /* for DBLL_DIG */
++#endif
++
+ /* Define the fundamental Lisp data structures */
+
+ /* Define an integer type with the same size as Lisp_Object.
diff --git a/editors/mule/patches/patch-ag b/editors/mule/patches/patch-ag
new file mode 100644
index 00000000000..7dc741a734f
--- /dev/null
+++ b/editors/mule/patches/patch-ag
@@ -0,0 +1,13 @@
+$NetBSD: patch-ag,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- src/coding.c.orig Mon Sep 20 23:39:02 1999
++++ src/coding.c Mon Sep 20 23:39:41 1999
+@@ -154,7 +154,7 @@
+ /* 92.4.3, 92.12.18 by K.Handa */
+ Lisp_Object Qcoding_system, Qcoding_system_p, Qnon_nil_coding_system_p;
+ Lisp_Object Qeol_type;
+-Lisp_Object Qpriority;
++extern Lisp_Object Qpriority;
+ /* end of patch */
+ #endif /* emacs */
+
diff --git a/editors/mule/patches/patch-ah b/editors/mule/patches/patch-ah
new file mode 100644
index 00000000000..407b467b33d
--- /dev/null
+++ b/editors/mule/patches/patch-ah
@@ -0,0 +1,30 @@
+$NetBSD: patch-ah,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- src/fileio.c.orig Mon Sep 20 23:29:04 1999
++++ src/fileio.c Mon Sep 20 23:30:03 1999
+@@ -2604,8 +2604,6 @@
+ return value;
+ }
+
+-#ifdef unix
+-
+ DEFUN ("unix-sync", Funix_sync, Sunix_sync, 0, 0, "",
+ "Tell Unix to finish all pending disk updates.")
+ ()
+@@ -2614,8 +2612,6 @@
+ return Qnil;
+ }
+
+-#endif /* unix */
+-
+ DEFUN ("file-newer-than-file-p", Ffile_newer_than_file_p, Sfile_newer_than_file_p, 2, 2, 0,
+ "Return t if file FILE1 is newer than file FILE2.\n\
+ If FILE1 does not exist, the answer is nil;\n\
+@@ -4507,7 +4503,5 @@
+ defsubr (&Sread_file_name_internal);
+ defsubr (&Sread_file_name);
+
+-#ifdef unix
+ defsubr (&Sunix_sync);
+-#endif
+ }
diff --git a/editors/mule/patches/patch-ai b/editors/mule/patches/patch-ai
new file mode 100644
index 00000000000..d327e9285d3
--- /dev/null
+++ b/editors/mule/patches/patch-ai
@@ -0,0 +1,13 @@
+$NetBSD: patch-ai,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- src/floatfns.c.orig Mon Sep 20 23:43:32 1999
++++ src/floatfns.c Mon Sep 20 23:43:41 1999
+@@ -49,7 +49,7 @@
+ #include "lisp.h"
+ #include "syssignal.h"
+
+-Lisp_Object Qarith_error;
++extern Lisp_Object Qarith_error;
+
+ #ifdef LISP_FLOAT_TYPE
+
diff --git a/editors/mule/patches/patch-aj b/editors/mule/patches/patch-aj
new file mode 100644
index 00000000000..470f93a4dbe
--- /dev/null
+++ b/editors/mule/patches/patch-aj
@@ -0,0 +1,15 @@
+$NetBSD: patch-aj,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- src/getloadavg.c.orig Mon Sep 20 23:29:10 1999
++++ src/getloadavg.c Mon Sep 20 23:30:54 1999
+@@ -64,10 +64,7 @@
+ /* Both the Emacs and non-Emacs sections want this. Some
+ configuration files' definitions for the LOAD_AVE_CVT macro (like
+ sparc.h's) use macros like FSCALE, defined here. */
+-#ifdef unix
+ #include <sys/param.h>
+-#endif
+-
+
+ #ifdef HAVE_CONFIG_H
+ #if defined (emacs) || defined (CONFIG_BROKETS)
diff --git a/editors/mule/patches/patch-ak b/editors/mule/patches/patch-ak
new file mode 100644
index 00000000000..ec169fd83ea
--- /dev/null
+++ b/editors/mule/patches/patch-ak
@@ -0,0 +1,13 @@
+$NetBSD: patch-ak,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- src/keyboard.c.orig Mon Sep 20 23:36:21 1999
++++ src/keyboard.c Mon Sep 20 23:37:10 1999
+@@ -301,7 +301,7 @@
+
+ /* The timestamp of the last input event we received from the X server.
+ X Windows wants this for selection ownership. */
+-unsigned long last_event_timestamp;
++extern unsigned long last_event_timestamp;
+
+ Lisp_Object Qself_insert_command;
+ Lisp_Object Qforward_char;
diff --git a/editors/mule/patches/patch-al b/editors/mule/patches/patch-al
new file mode 100644
index 00000000000..5df6659b576
--- /dev/null
+++ b/editors/mule/patches/patch-al
@@ -0,0 +1,16 @@
+$NetBSD: patch-al,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+--- src/lread.c.orig Mon Sep 20 23:44:46 1999
++++ src/lread.c Mon Sep 20 23:45:25 1999
+@@ -86,9 +86,9 @@
+
+ Lisp_Object Qread_char, Qget_file_char, Qstandard_input, Qcurrent_load_list;
+ Lisp_Object Qvariable_documentation, Vvalues, Vstandard_input, Vafter_load_alist;
+-Lisp_Object Qascii_character, Qload;
++Lisp_Object Qascii_character;
+
+-extern Lisp_Object Qevent_symbol_element_mask;
++extern Lisp_Object Qload, Qevent_symbol_element_mask;
+
+ /* non-zero if inside `load' */
+ int load_in_progress;
diff --git a/editors/mule/patches/patch-am b/editors/mule/patches/patch-am
new file mode 100644
index 00000000000..249b95150cc
--- /dev/null
+++ b/editors/mule/patches/patch-am
@@ -0,0 +1,13 @@
+$NetBSD: patch-am,v 1.1.1.1 2000/11/21 05:21:09 kei Exp $
+
+--- src/xfns.c.orig Tue Sep 21 00:13:59 1999
++++ src/xfns.c Tue Sep 21 00:14:42 1999
+@@ -226,7 +226,7 @@
+ Lisp_Object Qbox;
+ Lisp_Object Qcursor_color;
+ Lisp_Object Qcursor_type;
+-Lisp_Object Qfont;
++extern Lisp_Object Qfont;
+ Lisp_Object Qforeground_color;
+ Lisp_Object Qgeometry;
+ /* Lisp_Object Qicon; */
diff --git a/editors/mule/patches/patch-an b/editors/mule/patches/patch-an
new file mode 100644
index 00000000000..d0a2ee24fa1
--- /dev/null
+++ b/editors/mule/patches/patch-an
@@ -0,0 +1,38 @@
+$NetBSD: patch-an,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+*** Makefile.in.orig Tue Dec 20 11:01:54 1994
+--- Makefile.in Fri Nov 17 15:29:34 2000
+***************
+*** 186,192 ****
+ # Subdirectories to make recursively. `lisp' is not included
+ # because the compiled lisp files are part of the distribution
+ # and you cannot remake them without installing Emacs first.
+! SUBDIR = lib-src src
+
+ # The makefiles of the directories in $SUBDIR.
+ SUBDIR_MAKEFILES = lib-src/Makefile src/Makefile oldXMenu/Makefile lwlib/Makefile
+--- 186,192 ----
+ # Subdirectories to make recursively. `lisp' is not included
+ # because the compiled lisp files are part of the distribution
+ # and you cannot remake them without installing Emacs first.
+! SUBDIR = lib-src src man
+
+ # The makefiles of the directories in $SUBDIR.
+ SUBDIR_MAKEFILES = lib-src/Makefile src/Makefile oldXMenu/Makefile lwlib/Makefile
+***************
+*** 341,347 ****
+ if [ ! -f ${infodir}/dir ] && [ -f dir ]; then \
+ (cd $${thisdir}; ${INSTALL_DATA} ${srcdir}/info/dir ${infodir}/dir); \
+ fi ; \
+! for f in cl* dired-x* emacs* forms* gnus* info* sc* vip* \
+ antenews* canna* egg* languages* m2ps* mule* kbd-trans* \
+ quail* terminology* CCL* ISO2022* R2L* XFONT*; do \
+ (cd $${thisdir}; ${INSTALL_DATA} ${srcdir}/info/$$f ${infodir}/$$f); \
+--- 341,347 ----
+ if [ ! -f ${infodir}/dir ] && [ -f dir ]; then \
+ (cd $${thisdir}; ${INSTALL_DATA} ${srcdir}/info/dir ${infodir}/dir); \
+ fi ; \
+! for f in cl* dired-x* emacs* forms* gnus* sc* vip* \
+ antenews* canna* egg* languages* m2ps* mule* kbd-trans* \
+ quail* terminology* CCL* ISO2022* R2L* XFONT*; do \
+ (cd $${thisdir}; ${INSTALL_DATA} ${srcdir}/info/$$f ${infodir}/$$f); \
diff --git a/editors/mule/patches/patch-ao b/editors/mule/patches/patch-ao
new file mode 100644
index 00000000000..98c613162f2
--- /dev/null
+++ b/editors/mule/patches/patch-ao
@@ -0,0 +1,46 @@
+$NetBSD: patch-ao,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+*** man/Makefile.orig Sun Jul 3 06:35:17 1994
+--- man/Makefile Fri Nov 17 20:49:09 2000
+***************
+*** 4,10 ****
+ MAKEINFO = makeinfo
+ TEXINDEX_OBJS = texindex.o getopt.o
+ INFO_TARGETS = ../info/emacs ../info/cl ../info/forms ../info/vip \
+! ../info/gnus ../info/sc ../info/info ../info/dired-x
+ DVI_TARGETS = emacs.dvi cl.dvi forms.dvi vip.dvi gnus.dvi sc.dvi dired-x.dvi
+ INFOSOURCES = info.texi info-stnd.texi
+
+--- 4,10 ----
+ MAKEINFO = makeinfo
+ TEXINDEX_OBJS = texindex.o getopt.o
+ INFO_TARGETS = ../info/emacs ../info/cl ../info/forms ../info/vip \
+! ../info/gnus ../info/sc ../info/dired-x
+ DVI_TARGETS = emacs.dvi cl.dvi forms.dvi vip.dvi gnus.dvi sc.dvi dired-x.dvi
+ INFOSOURCES = info.texi info-stnd.texi
+
+***************
+*** 54,59 ****
+--- 54,60 ----
+ gnu1.texi \
+ glossary.texi
+
++ all: info
+ info: $(INFO_TARGETS)
+
+ dvi: $(DVI_TARGETS)
+***************
+*** 66,77 ****
+
+ getopt.o: getopt.c
+ $(CC) -Demacs -I../src -I../lib-src -c getopt.c
+-
+- ../info/info: ${INFOSOURCES}
+- $(MAKEINFO) --no-split info.texi
+-
+- info.dvi: texindex ${INFOSOURCES}
+- $(TEXI2DVI) info.texi
+
+ ../info/emacs: ${EMACSSOURCES}
+ $(MAKEINFO) emacs.texi
+--- 67,72 ----
diff --git a/editors/mule/patches/patch-ar b/editors/mule/patches/patch-ar
new file mode 100644
index 00000000000..6715838ad8a
--- /dev/null
+++ b/editors/mule/patches/patch-ar
@@ -0,0 +1,18 @@
+$NetBSD: patch-ar,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+*** man/cl.texi.orig Fri Nov 17 13:56:11 2000
+--- man/cl.texi Fri Nov 17 14:09:59 2000
+***************
+*** 2,7 ****
+--- 2,12 ----
+ @setfilename ../info/cl
+ @settitle Common Lisp Extensions
+
++ @dircategory Editors
++ @direntry
++ * CL: (cl). Partial Common Lisp support for Emacs Lisp.
++ @end direntry
++
+ @iftex
+ @finalout
+ @end iftex
diff --git a/editors/mule/patches/patch-as b/editors/mule/patches/patch-as
new file mode 100644
index 00000000000..27a8e0e95e2
--- /dev/null
+++ b/editors/mule/patches/patch-as
@@ -0,0 +1,86 @@
+$NetBSD: patch-as,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+*** man/dired-x.texi.orig Sun Aug 14 01:58:50 1994
+--- man/dired-x.texi Fri Nov 17 21:38:37 2000
+***************
+*** 18,23 ****
+--- 18,29 ----
+ @setfilename ../info/dired-x
+ @c dired-x.el REVISION NUMBER
+ @settitle Dired Extra Version 2 User's Manual
++
++ @dircategory Editors
++ @direntry
++ * Dired-X: (dired-x). Dired Extra Features.
++ @end direntry
++
+ @iftex
+ @finalout
+ @end iftex
+***************
+*** 196,227 ****
+ @enumerate
+ @item
+ Omitting of uninteresting files from dired listing.
+! @itemize
+ @xref{Omitting Files in Dired}
+ @end itemize
+ @item
+ Local variables for dired directories.
+! @itemize
+ @xref{Local Variables}
+ @end itemize
+ @item
+ Guessing shell commands in dired buffers.
+! @itemize
+ @xref{Shell Command Guessing}
+ @end itemize
+ @item
+ Running dired command in non-dired buffers.
+! @itemize
+ @xref{Virtual Dired}
+ @end itemize
+ @item
+ Finding a file mentioned in a buffer
+! @itemize
+ @xref{Find File At Point}
+ @end itemize
+ @item
+ Commands using file marking.
+! @itemize
+ @xref{Advanced Mark Commands}
+ @end itemize
+ @end enumerate
+--- 202,233 ----
+ @enumerate
+ @item
+ Omitting of uninteresting files from dired listing.
+! @itemize @bullet
+ @xref{Omitting Files in Dired}
+ @end itemize
+ @item
+ Local variables for dired directories.
+! @itemize @bullet
+ @xref{Local Variables}
+ @end itemize
+ @item
+ Guessing shell commands in dired buffers.
+! @itemize @bullet
+ @xref{Shell Command Guessing}
+ @end itemize
+ @item
+ Running dired command in non-dired buffers.
+! @itemize @bullet
+ @xref{Virtual Dired}
+ @end itemize
+ @item
+ Finding a file mentioned in a buffer
+! @itemize @bullet
+ @xref{Find File At Point}
+ @end itemize
+ @item
+ Commands using file marking.
+! @itemize @bullet
+ @xref{Advanced Mark Commands}
+ @end itemize
+ @end enumerate
diff --git a/editors/mule/patches/patch-au b/editors/mule/patches/patch-au
new file mode 100644
index 00000000000..026c11a4c0f
--- /dev/null
+++ b/editors/mule/patches/patch-au
@@ -0,0 +1,24 @@
+$NetBSD: patch-au,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+*** man/emacs.texi.orig Fri Nov 4 20:08:52 1994
+--- man/emacs.texi Fri Nov 17 20:35:02 2000
+***************
+*** 1,10 ****
+--- 1,17 ----
+ \input texinfo
+
++ @setfilename ../info/emacs
++
+ @ifinfo
+ @c The edition number appears in several places in this file
+ This corresponds to the tenth edition of the @cite{GNU Emacs Manual},
+ for Emacs version 19.28.
+ @c Please REMEMBER to update edition number in *three* places in this file.
++
++ @dircategory Editors
++ @direntry
++ * Emacs: (emacs). The extensible self-documenting text editor.
++ @end direntry
+
+ Published by the Free Software Foundation
+ 675 Massachusetts Avenue
diff --git a/editors/mule/patches/patch-av b/editors/mule/patches/patch-av
new file mode 100644
index 00000000000..88908272402
--- /dev/null
+++ b/editors/mule/patches/patch-av
@@ -0,0 +1,19 @@
+$NetBSD: patch-av,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+*** man/forms.texi.orig Fri Nov 17 13:56:59 2000
+--- man/forms.texi Fri Nov 17 14:15:09 2000
+***************
+*** 16,21 ****
+--- 16,27 ----
+ @c @smallbook
+ @comment %**end of header (This is for running Texinfo on a region.)
+
++ @dircategory Editors
++ @direntry
++ * Forms: (forms). Emacs package for editing data bases
++ by filling in forms.
++ @end direntry
++
+ @ifinfo
+ This file documents Forms mode, a form-editing major mode for GNU Emacs.
+
diff --git a/editors/mule/patches/patch-aw b/editors/mule/patches/patch-aw
new file mode 100644
index 00000000000..bf40370b7ef
--- /dev/null
+++ b/editors/mule/patches/patch-aw
@@ -0,0 +1,19 @@
+$NetBSD: patch-aw,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+*** man/gnus.texi.orig Fri Nov 17 13:57:09 2000
+--- man/gnus.texi Fri Nov 17 15:09:32 2000
+***************
+*** 3,8 ****
+--- 3,14 ----
+ @comment %**start of header (This is for running Texinfo on a region.)
+ @setfilename ../info/gnus
+ @settitle GNUS 3.15 Manual
++
++ @dircategory Editors
++ @direntry
++ * GNUS: (gnus). The newsreader GNUS.
++ @end direntry
++
+ @iftex
+ @finalout
+ @end iftex
diff --git a/editors/mule/patches/patch-az b/editors/mule/patches/patch-az
new file mode 100644
index 00000000000..ef4e1022e21
--- /dev/null
+++ b/editors/mule/patches/patch-az
@@ -0,0 +1,20 @@
+$NetBSD: patch-az,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+*** man/sc.texi.orig Fri Nov 17 13:58:18 2000
+--- man/sc.texi Fri Nov 17 14:57:08 2000
+***************
+*** 6,11 ****
+--- 6,18 ----
+ @iftex
+ @finalout
+ @end iftex
++
++ @dircategory Editors
++ @direntry
++ * SC: (sc). Supercite lets you cite parts of messages you're
++ replying to, in flexible ways.
++ @end direntry
++
+ @c @setchapternewpage odd % For book style double sided manual.
+ @comment %**end of header (This is for running Texinfo on a region.)
+ @c @smallbook
diff --git a/editors/mule/patches/patch-ba b/editors/mule/patches/patch-ba
new file mode 100644
index 00000000000..a4ae126716e
--- /dev/null
+++ b/editors/mule/patches/patch-ba
@@ -0,0 +1,18 @@
+$NetBSD: patch-ba,v 1.1.1.1 2000/11/21 05:21:10 kei Exp $
+
+*** man/vip.texi.orig Fri Nov 17 13:58:36 2000
+--- man/vip.texi Fri Nov 17 14:58:20 2000
+***************
+*** 25,30 ****
+--- 25,35 ----
+ @setfilename ../info/vip
+ @settitle VIP
+
++ @dircategory Editors
++ @direntry
++ * VIP: (vip). An VI-emulation for Emacs.
++ @end direntry
++
+ @iftex
+ @finalout
+ @end iftex
diff --git a/editors/mule/patches/patch-bb b/editors/mule/patches/patch-bb
new file mode 100644
index 00000000000..2fd6dbec669
--- /dev/null
+++ b/editors/mule/patches/patch-bb
@@ -0,0 +1,4272 @@
+$NetBSD: patch-bb,v 1.1.1.1 2000/11/21 05:21:14 kei Exp $
+
+*** man/texinfo.tex.orig Fri Nov 17 16:10:16 2000
+--- man/texinfo.tex Fri Nov 17 20:00:13 2000
+***************
+*** 1,6 ****
+! %% TeX macros to handle texinfo files
+
+! % Copyright (C) 1985, 86, 88, 90, 91, 92, 93, 1994 Free Software Foundation, Inc.
+
+ %This texinfo.tex file is free software; you can redistribute it and/or
+ %modify it under the terms of the GNU General Public License as
+--- 1,8 ----
+! %% TeX macros to handle Texinfo files.
+! %% Id: texinfo.tex,v 1.1.1.2 1997/09/24 19:26:42 gwr Exp
+
+! % Copyright (C) 1985, 86, 88, 90, 91, 92, 93,
+! % 94, 95, 96, 97 Free Software Foundation, Inc.
+
+ %This texinfo.tex file is free software; you can redistribute it and/or
+ %modify it under the terms of the GNU General Public License as
+***************
+*** 14,51 ****
+
+ %You should have received a copy of the GNU General Public License
+ %along with this texinfo.tex file; see the file COPYING. If not, write
+! %to the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139,
+! %USA.
+
+
+ %In other words, you are welcome to use, share and improve this program.
+ %You are forbidden to forbid anyone else to use, share and improve
+ %what you give them. Help stamp out software-hoarding!
+
+ % This automatically updates the version number based on RCS.
+ \def\deftexinfoversion$#1: #2 ${\def\texinfoversion{#2}}
+! \deftexinfoversion Revision: 2.133
+ \message{Loading texinfo package [Version \texinfoversion]:}
+
+! % Print the version number if in a .fmt file.
+! \everyjob{\message{[Texinfo version \texinfoversion]}\message{}}
+
+ % Save some parts of plain tex whose names we will redefine.
+
+- \let\ptextilde=\~
+- \let\ptexlbrace=\{
+- \let\ptexrbrace=\}
+- \let\ptexdots=\dots
+- \let\ptexdot=\.
+- \let\ptexstar=\*
+- \let\ptexend=\end
+- \let\ptexbullet=\bullet
+ \let\ptexb=\b
+ \let\ptexc=\c
+ \let\ptexi=\i
+ \let\ptext=\t
+- \let\ptexl=\l
+- \let\ptexL=\L
+
+ % Be sure we're in horizontal mode when doing a tie, since we make space
+ % equivalent to this in @example-like environments. Otherwise, a space
+--- 16,65 ----
+
+ %You should have received a copy of the GNU General Public License
+ %along with this texinfo.tex file; see the file COPYING. If not, write
+! %to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+! %Boston, MA 02111-1307, USA.
+
+
+ %In other words, you are welcome to use, share and improve this program.
+ %You are forbidden to forbid anyone else to use, share and improve
+ %what you give them. Help stamp out software-hoarding!
+
++
++ % Send bug reports to bug-texinfo@prep.ai.mit.edu.
++ % Please include a *precise* test case in each bug report.
++
++
++ % Make it possible to create a .fmt file just by loading this file:
++ % if the underlying format is not loaded, start by loading it now.
++ % Added by gildea November 1993.
++ \expandafter\ifx\csname fmtname\endcsname\relax\input plain\fi
++
+ % This automatically updates the version number based on RCS.
+ \def\deftexinfoversion$#1: #2 ${\def\texinfoversion{#2}}
+! \deftexinfoversion Revision: 1.1.1.2
+ \message{Loading texinfo package [Version \texinfoversion]:}
+
+! % If in a .fmt file, print the version number
+! % and turn on active characters that we couldn't do earlier because
+! % they might have appeared in the input file name.
+! \everyjob{\message{[Texinfo version \texinfoversion]}\message{}
+! \catcode`+=\active \catcode`\_=\active}
+
+ % Save some parts of plain tex whose names we will redefine.
+
+ \let\ptexb=\b
++ \let\ptexbullet=\bullet
+ \let\ptexc=\c
++ \let\ptexcomma=\,
++ \let\ptexdot=\.
++ \let\ptexdots=\dots
++ \let\ptexend=\end
++ \let\ptexequiv = \equiv
+ \let\ptexi=\i
++ \let\ptexlbrace=\{
++ \let\ptexrbrace=\}
++ \let\ptexstar=\*
+ \let\ptext=\t
+
+ % Be sure we're in horizontal mode when doing a tie, since we make space
+ % equivalent to this in @example-like environments. Otherwise, a space
+***************
+*** 53,61 ****
+ % since \penalty is valid in vertical mode, we'd end up putting the
+ % penalty on the vertical list instead of in the new paragraph.
+ {\catcode`@ = 11
+! \gdef\tie{\leavevmode\penalty\@M\ }
+ }
+! \let\~ = \tie % And make it available as @~.
+
+ \message{Basics,}
+ \chardef\other=12
+--- 67,78 ----
+ % since \penalty is valid in vertical mode, we'd end up putting the
+ % penalty on the vertical list instead of in the new paragraph.
+ {\catcode`@ = 11
+! % Avoid using \@M directly, because that causes trouble
+! % if the definition is written into an index file.
+! \global\let\tiepenalty = \@M
+! \gdef\tie{\leavevmode\penalty\tiepenalty\ }
+ }
+!
+
+ \message{Basics,}
+ \chardef\other=12
+***************
+*** 86,95 ****
+ \hyphenation{eshell}
+
+ % Margin to add to right of even pages, to left of odd pages.
+! \newdimen \bindingoffset \bindingoffset=0pt
+! \newdimen \normaloffset \normaloffset=\hoffset
+ \newdimen\pagewidth \newdimen\pageheight
+- \pagewidth=\hsize \pageheight=\vsize
+
+ % Sometimes it is convenient to have everything in the transcript file
+ % and nothing on the terminal. We don't just call \tracingall here,
+--- 103,111 ----
+ \hyphenation{eshell}
+
+ % Margin to add to right of even pages, to left of odd pages.
+! \newdimen \bindingoffset
+! \newdimen \normaloffset
+ \newdimen\pagewidth \newdimen\pageheight
+
+ % Sometimes it is convenient to have everything in the transcript file
+ % and nothing on the terminal. We don't just call \tracingall here,
+***************
+*** 102,182 ****
+ \showboxbreadth\maxdimen\showboxdepth\maxdimen
+ }%
+
+! %---------------------Begin change-----------------------
+ %
+! %%%% For @cropmarks command.
+! % Dimensions to add cropmarks at corners Added by P. A. MacKay, 12 Nov. 1986
+ %
+ \newdimen\cornerlong \newdimen\cornerthick
+! \newdimen \topandbottommargin
+! \newdimen \outerhsize \newdimen \outervsize
+! \cornerlong=1pc\cornerthick=.3pt % These set size of cropmarks
+ \outerhsize=7in
+ %\outervsize=9.5in
+ % Alternative @smallbook page size is 9.25in
+ \outervsize=9.25in
+ \topandbottommargin=.75in
+! %
+! %---------------------End change-----------------------
+
+ % \onepageout takes a vbox as an argument. Note that \pagecontents
+! % does insertions itself, but you have to call it yourself.
+! \chardef\PAGE=255 \output={\onepageout{\pagecontents\PAGE}}
+! \def\onepageout#1{\hoffset=\normaloffset
+! \ifodd\pageno \advance\hoffset by \bindingoffset
+! \else \advance\hoffset by -\bindingoffset\fi
+! {\escapechar=`\\\relax % makes sure backslash is used in output files.
+! \shipout\vbox{{\let\hsize=\pagewidth \makeheadline} \pagebody{#1}%
+! {\let\hsize=\pagewidth \makefootline}}}%
+! \advancepageno \ifnum\outputpenalty>-20000 \else\dosupereject\fi}
+!
+! %%%% For @cropmarks command %%%%
+!
+! % Here is a modification of the main output routine for Near East Publications
+! % This provides right-angle cropmarks at all four corners.
+! % The contents of the page are centerlined into the cropmarks,
+! % and any desired binding offset is added as an \hskip on either
+! % site of the centerlined box. (P. A. MacKay, 12 November, 1986)
+! %
+! \def\croppageout#1{\hoffset=0pt % make sure this doesn't mess things up
+! {\escapechar=`\\\relax % makes sure backslash is used in output files.
+! \shipout
+! \vbox to \outervsize{\hsize=\outerhsize
+! \vbox{\line{\ewtop\hfill\ewtop}}
+! \nointerlineskip
+! \line{\vbox{\moveleft\cornerthick\nstop}
+! \hfill
+! \vbox{\moveright\cornerthick\nstop}}
+! \vskip \topandbottommargin
+! \centerline{\ifodd\pageno\hskip\bindingoffset\fi
+! \vbox{
+! {\let\hsize=\pagewidth \makeheadline}
+! \pagebody{#1}
+! {\let\hsize=\pagewidth \makefootline}}
+! \ifodd\pageno\else\hskip\bindingoffset\fi}
+! \vskip \topandbottommargin plus1fill minus1fill
+! \boxmaxdepth\cornerthick
+! \line{\vbox{\moveleft\cornerthick\nsbot}
+! \hfill
+! \vbox{\moveright\cornerthick\nsbot}}
+! \nointerlineskip
+! \vbox{\line{\ewbot\hfill\ewbot}}
+! }}
+ \advancepageno
+! \ifnum\outputpenalty>-20000 \else\dosupereject\fi}
+! %
+! % Do @cropmarks to get crop marks
+! \def\cropmarks{\let\onepageout=\croppageout }
+
+ \def\pagebody#1{\vbox to\pageheight{\boxmaxdepth=\maxdepth #1}}
+ {\catcode`\@ =11
+ \gdef\pagecontents#1{\ifvoid\topins\else\unvbox\topins\fi
+ \dimen@=\dp#1 \unvbox#1
+ \ifvoid\footins\else\vskip\skip\footins\footnoterule \unvbox\footins\fi
+ \ifr@ggedbottom \kern-\dimen@ \vfil \fi}
+ }
+
+- %
+ % Here are the rules for the cropmarks. Note that they are
+ % offset so that the space between them is truly \outerhsize or \outervsize
+ % (P. A. MacKay, 12 November, 1986)
+--- 118,225 ----
+ \showboxbreadth\maxdimen\showboxdepth\maxdimen
+ }%
+
+! % For @cropmarks command.
+! % Do @cropmarks to get crop marks.
+! %
+! \newif\ifcropmarks
+! \let\cropmarks = \cropmarkstrue
+ %
+! % Dimensions to add cropmarks at corners.
+! % Added by P. A. MacKay, 12 Nov. 1986
+ %
+ \newdimen\cornerlong \newdimen\cornerthick
+! \newdimen\topandbottommargin
+! \newdimen\outerhsize \newdimen\outervsize
+! \cornerlong=1pc\cornerthick=.3pt % These set size of cropmarks
+ \outerhsize=7in
+ %\outervsize=9.5in
+ % Alternative @smallbook page size is 9.25in
+ \outervsize=9.25in
+ \topandbottommargin=.75in
+!
+! % Main output routine.
+! \chardef\PAGE = 255
+! \output = {\onepageout{\pagecontents\PAGE}}
+!
+! \newbox\headlinebox
+! \newbox\footlinebox
+
+ % \onepageout takes a vbox as an argument. Note that \pagecontents
+! % does insertions, but you have to call it yourself.
+! \def\onepageout#1{%
+! \ifcropmarks \hoffset=0pt \else \hoffset=\normaloffset \fi
+! %
+! \ifodd\pageno \advance\hoffset by \bindingoffset
+! \else \advance\hoffset by -\bindingoffset\fi
+! %
+! % Do this outside of the \shipout so @code etc. will be expanded in
+! % the headline as they should be, not taken literally (outputting ''code).
+! \setbox\headlinebox = \vbox{\let\hsize=\pagewidth \makeheadline}%
+! \setbox\footlinebox = \vbox{\let\hsize=\pagewidth \makefootline}%
+! %
+! {%
+! % Have to do this stuff outside the \shipout because we want it to
+! % take effect in \write's, yet the group defined by the \vbox ends
+! % before the \shipout runs.
+! %
+! \escapechar = `\\ % use backslash in output files.
+! \indexdummies % don't expand commands in the output.
+! \normalturnoffactive % \ in index entries must not stay \, e.g., if
+! % the page break happens to be in the middle of an example.
+! \shipout\vbox{%
+! \ifcropmarks \vbox to \outervsize\bgroup
+! \hsize = \outerhsize
+! \line{\ewtop\hfil\ewtop}%
+! \nointerlineskip
+! \line{%
+! \vbox{\moveleft\cornerthick\nstop}%
+! \hfill
+! \vbox{\moveright\cornerthick\nstop}%
+! }%
+! \vskip\topandbottommargin
+! \line\bgroup
+! \hfil % center the page within the outer (page) hsize.
+! \ifodd\pageno\hskip\bindingoffset\fi
+! \vbox\bgroup
+! \fi
+! %
+! \unvbox\headlinebox
+! \pagebody{#1}%
+! \unvbox\footlinebox
+! %
+! \ifcropmarks
+! \egroup % end of \vbox\bgroup
+! \hfil\egroup % end of (centering) \line\bgroup
+! \vskip\topandbottommargin plus1fill minus1fill
+! \boxmaxdepth = \cornerthick
+! \line{%
+! \vbox{\moveleft\cornerthick\nsbot}%
+! \hfill
+! \vbox{\moveright\cornerthick\nsbot}%
+! }%
+! \nointerlineskip
+! \line{\ewbot\hfil\ewbot}%
+! \egroup % \vbox from first cropmarks clause
+! \fi
+! }% end of \shipout\vbox
+! }% end of group with \turnoffactive
+ \advancepageno
+! \ifnum\outputpenalty>-20000 \else\dosupereject\fi
+! }
+!
+! \newinsert\margin \dimen\margin=\maxdimen
+
+ \def\pagebody#1{\vbox to\pageheight{\boxmaxdepth=\maxdepth #1}}
+ {\catcode`\@ =11
+ \gdef\pagecontents#1{\ifvoid\topins\else\unvbox\topins\fi
++ % marginal hacks, juha@viisa.uucp (Juha Takala)
++ \ifvoid\margin\else % marginal info is present
++ \rlap{\kern\hsize\vbox to\z@{\kern1pt\box\margin \vss}}\fi
+ \dimen@=\dp#1 \unvbox#1
+ \ifvoid\footins\else\vskip\skip\footins\footnoterule \unvbox\footins\fi
+ \ifr@ggedbottom \kern-\dimen@ \vfil \fi}
+ }
+
+ % Here are the rules for the cropmarks. Note that they are
+ % offset so that the space between them is truly \outerhsize or \outervsize
+ % (P. A. MacKay, 12 November, 1986)
+***************
+*** 344,354 ****
+ %\def\'{{'}}
+
+ % Used to generate quoted braces.
+-
+ \def\mylbrace {{\tt \char '173}}
+ \def\myrbrace {{\tt \char '175}}
+ \let\{=\mylbrace
+ \let\}=\myrbrace
+
+ % @: forces normal size whitespace following.
+ \def\:{\spacefactor=1000 }
+--- 387,429 ----
+ %\def\'{{'}}
+
+ % Used to generate quoted braces.
+ \def\mylbrace {{\tt \char '173}}
+ \def\myrbrace {{\tt \char '175}}
+ \let\{=\mylbrace
+ \let\}=\myrbrace
++ \begingroup
++ % Definitions to produce actual \{ & \} command in an index.
++ \catcode`\{ = 12 \catcode`\} = 12
++ \catcode`\[ = 1 \catcode`\] = 2
++ \catcode`\@ = 0 \catcode`\\ = 12
++ @gdef@lbracecmd[\{]%
++ @gdef@rbracecmd[\}]%
++ @endgroup
++
++ % Accents: @, @dotaccent @ringaccent @ubaraccent @udotaccent
++ % Others are defined by plain TeX: @` @' @" @^ @~ @= @v @H.
++ \let\, = \c
++ \let\dotaccent = \.
++ \def\ringaccent#1{{\accent23 #1}}
++ \let\tieaccent = \t
++ \let\ubaraccent = \b
++ \let\udotaccent = \d
++
++ % Other special characters: @questiondown @exclamdown
++ % Plain TeX defines: @AA @AE @O @OE @L (and lowercase versions) @ss.
++ \def\questiondown{?`}
++ \def\exclamdown{!`}
++
++ % Dotless i and dotless j, used for accents.
++ \def\imacro{i}
++ \def\jmacro{j}
++ \def\dotless#1{%
++ \def\temp{#1}%
++ \ifx\temp\imacro \ptexi
++ \else\ifx\temp\jmacro \j
++ \else \errmessage{@dotless can be used only with i or j}%
++ \fi\fi
++ }
+
+ % @: forces normal size whitespace following.
+ \def\:{\spacefactor=1000 }
+***************
+*** 359,364 ****
+--- 434,448 ----
+ % @. is an end-of-sentence period.
+ \def\.{.\spacefactor=3000 }
+
++ % @enddots{} is an end-of-sentence ellipsis.
++ \gdef\enddots{$\mathinner{\ldotp\ldotp\ldotp\ldotp}$\spacefactor=3000}
++
++ % @! is an end-of-sentence bang.
++ \gdef\!{!\spacefactor=3000 }
++
++ % @? is an end-of-sentence query.
++ \gdef\?{?\spacefactor=3000 }
++
+ % @w prevents a word break. Without the \leavevmode, @w at the
+ % beginning of a paragraph, when TeX is still in vertical mode, would
+ % produce a whole line of output instead of starting the paragraph.
+***************
+*** 506,522 ****
+ \def\nofillexdentyyy #1{{\advance \leftskip by -\exdentamount
+ \leftline{\hskip\leftskip{\rm#1}}}}
+
+ %\hbox{{\rm#1}}\hfil\break}}
+
+ % @include file insert text of that file as input.
+!
+! \def\include{\parsearg\includezzz}
+! %Use \input\thisfile to avoid blank after \input, which may be an active
+! %char (in which case the blank would become the \input argument).
+! %The grouping keeps the value of \thisfile correct even when @include
+! %is nested.
+! \def\includezzz #1{\begingroup
+! \def\thisfile{#1}\input\thisfile
+ \endgroup}
+
+ \def\thisfile{}
+--- 590,623 ----
+ \def\nofillexdentyyy #1{{\advance \leftskip by -\exdentamount
+ \leftline{\hskip\leftskip{\rm#1}}}}
+
++ % @inmargin{TEXT} puts TEXT in the margin next to the current paragraph.
++
++ \def\inmargin#1{%
++ \strut\vadjust{\nobreak\kern-\strutdepth
++ \vtop to \strutdepth{\baselineskip\strutdepth\vss
++ \llap{\rightskip=\inmarginspacing \vbox{\noindent #1}}\null}}}
++ \newskip\inmarginspacing \inmarginspacing=1cm
++ \def\strutdepth{\dp\strutbox}
++
+ %\hbox{{\rm#1}}\hfil\break}}
+
+ % @include file insert text of that file as input.
+! % Allow normal characters that we make active in the argument (a file name).
+! \def\include{\begingroup
+! \catcode`\\=12
+! \catcode`~=12
+! \catcode`^=12
+! \catcode`_=12
+! \catcode`|=12
+! \catcode`<=12
+! \catcode`>=12
+! \catcode`+=12
+! \parsearg\includezzz}
+! % Restore active chars for included file.
+! \def\includezzz#1{\endgroup\begingroup
+! % Read the included file in a group so nested @include's work.
+! \def\thisfile{#1}%
+! \input\thisfile
+ \endgroup}
+
+ \def\thisfile{}
+***************
+*** 531,537 ****
+ % @sp n outputs n lines of vertical space
+
+ \def\sp{\parsearg\spxxx}
+! \def\spxxx #1{\par \vskip #1\baselineskip}
+
+ % @comment ...line which is ignored...
+ % @c is the same as @comment
+--- 632,638 ----
+ % @sp n outputs n lines of vertical space
+
+ \def\sp{\parsearg\spxxx}
+! \def\spxxx #1{\vskip #1\baselineskip}
+
+ % @comment ...line which is ignored...
+ % @c is the same as @comment
+***************
+*** 544,549 ****
+--- 645,653 ----
+
+ \let\c=\comment
+
++ % @paragraphindent is defined for the Info formatting commands only.
++ \let\paragraphindent=\comment
++
+ % Prevent errors for section commands.
+ % Used in @ignore and in failing conditionals.
+ \def\ignoresections{%
+***************
+*** 578,583 ****
+--- 682,688 ----
+ % incorrectly.
+ %
+ \def\ignoremorecommands{%
++ \let\defcodeindex = \relax
+ \let\defcv = \relax
+ \let\deffn = \relax
+ \let\deffnx = \relax
+***************
+*** 601,606 ****
+--- 706,720 ----
+ \let\printindex = \relax
+ \let\pxref = \relax
+ \let\settitle = \relax
++ \let\setchapternewpage = \relax
++ \let\setchapterstyle = \relax
++ \let\everyheading = \relax
++ \let\evenheading = \relax
++ \let\oddheading = \relax
++ \let\everyfooting = \relax
++ \let\evenfooting = \relax
++ \let\oddfooting = \relax
++ \let\headings = \relax
+ \let\include = \relax
+ \let\lowersections = \relax
+ \let\down = \relax
+***************
+*** 609,627 ****
+ \let\set = \relax
+ \let\clear = \relax
+ \let\item = \relax
+- \let\message = \relax
+ }
+
+ % Ignore @ignore ... @end ignore.
+ %
+ \def\ignore{\doignore{ignore}}
+
+! % Also ignore @ifinfo, @menu, and @direntry text.
+ %
+ \def\ifinfo{\doignore{ifinfo}}
+ \def\menu{\doignore{menu}}
+ \def\direntry{\doignore{direntry}}
+
+ % Ignore text until a line `@end #1'.
+ %
+ \def\doignore#1{\begingroup
+--- 723,752 ----
+ \let\set = \relax
+ \let\clear = \relax
+ \let\item = \relax
+ }
+
+ % Ignore @ignore ... @end ignore.
+ %
+ \def\ignore{\doignore{ignore}}
+
+! % Also ignore @ifinfo, @ifhtml, @html, @menu, and @direntry text.
+ %
+ \def\ifinfo{\doignore{ifinfo}}
++ \def\ifhtml{\doignore{ifhtml}}
++ \def\html{\doignore{html}}
+ \def\menu{\doignore{menu}}
+ \def\direntry{\doignore{direntry}}
+
++ % Also ignore @macro ... @end macro. The user must run texi2dvi,
++ % which runs makeinfo to do macro expansion. Ignore @unmacro, too.
++ \def\macro{\doignore{macro}}
++ \let\unmacro = \comment
++
++
++ % @dircategory CATEGORY -- specify a category of the dir file
++ % which this file should belong to. Ignore this in TeX.
++ \let\dircategory = \comment
++
+ % Ignore text until a line `@end #1'.
+ %
+ \def\doignore#1{\begingroup
+***************
+*** 653,663 ****
+ \immediate\write16{If you are running another version of TeX, relax.}
+ \immediate\write16{If you are running Unix TeX 3.0, kill this TeX process.}
+ \immediate\write16{ Then upgrade your TeX installation if you can.}
+ \immediate\write16{If you are stuck with version 3.0, run the}
+ \immediate\write16{ script ``tex3patch'' from the Texinfo distribution}
+ \immediate\write16{ to use a workaround.}
+ \immediate\write16{}
+! \warnedobstrue
+ \fi
+ }
+
+--- 778,789 ----
+ \immediate\write16{If you are running another version of TeX, relax.}
+ \immediate\write16{If you are running Unix TeX 3.0, kill this TeX process.}
+ \immediate\write16{ Then upgrade your TeX installation if you can.}
++ \immediate\write16{ (See ftp://ftp.gnu.ai.mit.edu/pub/gnu/TeX.README.)}
+ \immediate\write16{If you are stuck with version 3.0, run the}
+ \immediate\write16{ script ``tex3patch'' from the Texinfo distribution}
+ \immediate\write16{ to use a workaround.}
+ \immediate\write16{}
+! \global\warnedobstrue
+ \fi
+ }
+
+***************
+*** 733,749 ****
+ % Since we want to separate VAR from REST-OF-LINE (which might be
+ % empty), we can't just use \parsearg; we have to insert a space of our
+ % own to delimit the rest of the line, and then take it out again if we
+! % didn't need it.
+ %
+! \def\set{\parsearg\setxxx}
+ \def\setxxx#1{\setyyy#1 \endsetyyy}
+ \def\setyyy#1 #2\endsetyyy{%
+ \def\temp{#2}%
+ \ifx\temp\empty \global\expandafter\let\csname SET#1\endcsname = \empty
+ \else \setzzz{#1}#2\endsetzzz % Remove the trailing space \setxxx inserted.
+ \fi
+ }
+! \def\setzzz#1#2 \endsetzzz{\expandafter\xdef\csname SET#1\endcsname{#2}}
+
+ % @clear VAR clears (i.e., unsets) the variable VAR.
+ %
+--- 859,882 ----
+ % Since we want to separate VAR from REST-OF-LINE (which might be
+ % empty), we can't just use \parsearg; we have to insert a space of our
+ % own to delimit the rest of the line, and then take it out again if we
+! % didn't need it. Make sure the catcode of space is correct to avoid
+! % losing inside @example, for instance.
+ %
+! \def\set{\begingroup\catcode` =10
+! \catcode`\-=12 \catcode`\_=12 % Allow - and _ in VAR.
+! \parsearg\setxxx}
+ \def\setxxx#1{\setyyy#1 \endsetyyy}
+ \def\setyyy#1 #2\endsetyyy{%
+ \def\temp{#2}%
+ \ifx\temp\empty \global\expandafter\let\csname SET#1\endcsname = \empty
+ \else \setzzz{#1}#2\endsetzzz % Remove the trailing space \setxxx inserted.
+ \fi
++ \endgroup
+ }
+! % Can't use \xdef to pre-expand #2 and save some time, since \temp or
+! % \next or other control sequences that we've defined might get us into
+! % an infinite loop. Consider `@set foo @cite{bar}'.
+! \def\setzzz#1#2 \endsetzzz{\expandafter\gdef\csname SET#1\endcsname{#2}}
+
+ % @clear VAR clears (i.e., unsets) the variable VAR.
+ %
+***************
+*** 752,761 ****
+
+ % @value{foo} gets the text saved in variable foo.
+ %
+! \def\value#1{\expandafter
+! \ifx\csname SET#1\endcsname\relax
+! {\{No value for ``#1''\}}
+! \else \csname SET#1\endcsname \fi}
+
+ % @ifset VAR ... @end ifset reads the `...' iff VAR has been defined
+ % with @set.
+--- 885,900 ----
+
+ % @value{foo} gets the text saved in variable foo.
+ %
+! \def\value{\begingroup
+! \catcode`\-=12 \catcode`\_=12 % Allow - and _ in VAR.
+! \valuexxx}
+! \def\valuexxx#1{%
+! \expandafter\ifx\csname SET#1\endcsname\relax
+! {\{No value for ``#1''\}}%
+! \else
+! \csname SET#1\endcsname
+! \fi
+! \endgroup}
+
+ % @ifset VAR ... @end ifset reads the `...' iff VAR has been defined
+ % with @set.
+***************
+*** 855,860 ****
+--- 994,1000 ----
+ \expandafter\expandafter\expandafter\appendixsetref{\lastnode}\fi
+ \global\let\lastnode=\relax}
+
++ % @refill is a no-op.
+ \let\refill=\relax
+
+ % @setfilename is done at the beginning of every texinfo file.
+***************
+*** 869,879 ****
+ \comment % Ignore the actual filename.
+ }
+
+ \outer\def\bye{\pagealignmacro\tracingstats=1\ptexend}
+
+! \def\inforef #1{\inforefzzz #1,,,,**}
+! \def\inforefzzz #1,#2,#3,#4**{\putwordSee{} \putwordInfo{} \putwordfile{} \file{\ignorespaces #3{}},
+! node \samp{\ignorespaces#1{}}}
+
+ \message{fonts,}
+
+--- 1009,1032 ----
+ \comment % Ignore the actual filename.
+ }
+
++ % @bye.
+ \outer\def\bye{\pagealignmacro\tracingstats=1\ptexend}
+
+! % \def\macro#1{\begingroup\ignoresections\catcode`\#=6\def\macrotemp{#1}\parsearg\macroxxx}
+! % \def\macroxxx#1#2 \end macro{%
+! % \expandafter\gdef\macrotemp#1{#2}%
+! % \endgroup}
+!
+! %\def\linemacro#1{\begingroup\ignoresections\catcode`\#=6\def\macrotemp{#1}\parsearg\linemacroxxx}
+! %\def\linemacroxxx#1#2 \end linemacro{%
+! %\let\parsearg=\relax
+! %\edef\macrotempx{\csname M\butfirst\expandafter\string\macrotemp\endcsname}%
+! %\expandafter\xdef\macrotemp{\parsearg\macrotempx}%
+! %\expandafter\gdef\macrotempx#1{#2}%
+! %\endgroup}
+!
+! %\def\butfirst#1{}
+!
+
+ \message{fonts,}
+
+***************
+*** 885,982 ****
+ \def\sf{\fam=\sffam \tensf}
+ \let\li = \sf % Sometimes we call it \li, not \sf.
+
+ %% Try out Computer Modern fonts at \magstephalf
+ \let\mainmagstep=\magstephalf
+
+ \ifx\bigger\relax
+ \let\mainmagstep=\magstep1
+! \font\textrm=cmr12
+! \font\texttt=cmtt12
+ \else
+! \font\textrm=cmr10 scaled \mainmagstep
+! \font\texttt=cmtt10 scaled \mainmagstep
+ \fi
+ % Instead of cmb10, you many want to use cmbx10.
+ % cmbx10 is a prettier font on its own, but cmb10
+ % looks better when embedded in a line with cmr10.
+! \font\textbf=cmb10 scaled \mainmagstep
+! \font\textit=cmti10 scaled \mainmagstep
+! \font\textsl=cmsl10 scaled \mainmagstep
+! \font\textsf=cmss10 scaled \mainmagstep
+! \font\textsc=cmcsc10 scaled \mainmagstep
+ \font\texti=cmmi10 scaled \mainmagstep
+ \font\textsy=cmsy10 scaled \mainmagstep
+
+ % A few fonts for @defun, etc.
+! \font\defbf=cmbx10 scaled \magstep1 %was 1314
+! \font\deftt=cmtt10 scaled \magstep1
+ \def\df{\let\tentt=\deftt \let\tenbf = \defbf \bf}
+
+! % Fonts for indices and small examples.
+ % We actually use the slanted font rather than the italic,
+ % because texinfo normally uses the slanted fonts for that.
+ % Do not make many font distinctions in general in the index, since they
+ % aren't very useful.
+! \font\ninett=cmtt9
+! \font\indrm=cmr9
+! \font\indit=cmsl9
+ \let\indsl=\indit
+ \let\indtt=\ninett
+ \let\indsf=\indrm
+ \let\indbf=\indrm
+! \let\indsc=\indrm
+ \font\indi=cmmi9
+ \font\indsy=cmsy9
+
+! % Fonts for headings
+! \font\chaprm=cmbx12 scaled \magstep2
+! \font\chapit=cmti12 scaled \magstep2
+! \font\chapsl=cmsl12 scaled \magstep2
+! \font\chaptt=cmtt12 scaled \magstep2
+! \font\chapsf=cmss12 scaled \magstep2
+ \let\chapbf=\chaprm
+! \font\chapsc=cmcsc10 scaled\magstep3
+ \font\chapi=cmmi12 scaled \magstep2
+ \font\chapsy=cmsy10 scaled \magstep3
+
+! \font\secrm=cmbx12 scaled \magstep1
+! \font\secit=cmti12 scaled \magstep1
+! \font\secsl=cmsl12 scaled \magstep1
+! \font\sectt=cmtt12 scaled \magstep1
+! \font\secsf=cmss12 scaled \magstep1
+! \font\secbf=cmbx12 scaled \magstep1
+! \font\secsc=cmcsc10 scaled\magstep2
+ \font\seci=cmmi12 scaled \magstep1
+ \font\secsy=cmsy10 scaled \magstep2
+
+! % \font\ssecrm=cmbx10 scaled \magstep1 % This size an font looked bad.
+! % \font\ssecit=cmti10 scaled \magstep1 % The letters were too crowded.
+! % \font\ssecsl=cmsl10 scaled \magstep1
+! % \font\ssectt=cmtt10 scaled \magstep1
+! % \font\ssecsf=cmss10 scaled \magstep1
+!
+! %\font\ssecrm=cmb10 scaled 1315 % Note the use of cmb rather than cmbx.
+! %\font\ssecit=cmti10 scaled 1315 % Also, the size is a little larger than
+! %\font\ssecsl=cmsl10 scaled 1315 % being scaled magstep1.
+! %\font\ssectt=cmtt10 scaled 1315
+! %\font\ssecsf=cmss10 scaled 1315
+
+ %\let\ssecbf=\ssecrm
+
+! \font\ssecrm=cmbx12 scaled \magstephalf
+! \font\ssecit=cmti12 scaled \magstephalf
+! \font\ssecsl=cmsl12 scaled \magstephalf
+! \font\ssectt=cmtt12 scaled \magstephalf
+! \font\ssecsf=cmss12 scaled \magstephalf
+! \font\ssecbf=cmbx12 scaled \magstephalf
+! \font\ssecsc=cmcsc10 scaled \magstep1
+ \font\sseci=cmmi12 scaled \magstephalf
+ \font\ssecsy=cmsy10 scaled \magstep1
+ % The smallcaps and symbol fonts should actually be scaled \magstep1.5,
+ % but that is not a standard magnification.
+
+ % Fonts for title page:
+! \font\titlerm = cmbx12 scaled \magstep3
+ \let\authorrm = \secrm
+
+ % In order for the font changes to affect most math symbols and letters,
+--- 1038,1173 ----
+ \def\sf{\fam=\sffam \tensf}
+ \let\li = \sf % Sometimes we call it \li, not \sf.
+
++ % We don't need math for this one.
++ \def\ttsl{\tenttsl}
++
+ %% Try out Computer Modern fonts at \magstephalf
+ \let\mainmagstep=\magstephalf
+
++ % Set the font macro #1 to the font named #2, adding on the
++ % specified font prefix (normally `cm').
++ % #3 is the font's design size, #4 is a scale factor
++ \def\setfont#1#2#3#4{\font#1=\fontprefix#2#3 scaled #4}
++
++ % Use cm as the default font prefix.
++ % To specify the font prefix, you must define \fontprefix
++ % before you read in texinfo.tex.
++ \ifx\fontprefix\undefined
++ \def\fontprefix{cm}
++ \fi
++ % Support font families that don't use the same naming scheme as CM.
++ \def\rmshape{r}
++ \def\rmbshape{bx} %where the normal face is bold
++ \def\bfshape{b}
++ \def\bxshape{bx}
++ \def\ttshape{tt}
++ \def\ttbshape{tt}
++ \def\ttslshape{sltt}
++ \def\itshape{ti}
++ \def\itbshape{bxti}
++ \def\slshape{sl}
++ \def\slbshape{bxsl}
++ \def\sfshape{ss}
++ \def\sfbshape{ss}
++ \def\scshape{csc}
++ \def\scbshape{csc}
++
+ \ifx\bigger\relax
+ \let\mainmagstep=\magstep1
+! \setfont\textrm\rmshape{12}{1000}
+! \setfont\texttt\ttshape{12}{1000}
+ \else
+! \setfont\textrm\rmshape{10}{\mainmagstep}
+! \setfont\texttt\ttshape{10}{\mainmagstep}
+ \fi
+ % Instead of cmb10, you many want to use cmbx10.
+ % cmbx10 is a prettier font on its own, but cmb10
+ % looks better when embedded in a line with cmr10.
+! \setfont\textbf\bfshape{10}{\mainmagstep}
+! \setfont\textit\itshape{10}{\mainmagstep}
+! \setfont\textsl\slshape{10}{\mainmagstep}
+! \setfont\textsf\sfshape{10}{\mainmagstep}
+! \setfont\textsc\scshape{10}{\mainmagstep}
+! \setfont\textttsl\ttslshape{10}{\mainmagstep}
+ \font\texti=cmmi10 scaled \mainmagstep
+ \font\textsy=cmsy10 scaled \mainmagstep
+
+ % A few fonts for @defun, etc.
+! \setfont\defbf\bxshape{10}{\magstep1} %was 1314
+! \setfont\deftt\ttshape{10}{\magstep1}
+ \def\df{\let\tentt=\deftt \let\tenbf = \defbf \bf}
+
+! % Fonts for indices and small examples (9pt).
+ % We actually use the slanted font rather than the italic,
+ % because texinfo normally uses the slanted fonts for that.
+ % Do not make many font distinctions in general in the index, since they
+ % aren't very useful.
+! \setfont\ninett\ttshape{9}{1000}
+! \setfont\indrm\rmshape{9}{1000}
+! \setfont\indit\slshape{9}{1000}
+ \let\indsl=\indit
+ \let\indtt=\ninett
++ \let\indttsl=\ninett
+ \let\indsf=\indrm
+ \let\indbf=\indrm
+! \setfont\indsc\scshape{10}{900}
+ \font\indi=cmmi9
+ \font\indsy=cmsy9
+
+! % Chapter (and unnumbered) fonts (17.28pt).
+! \setfont\chaprm\rmbshape{12}{\magstep2}
+! \setfont\chapit\itbshape{10}{\magstep3}
+! \setfont\chapsl\slbshape{10}{\magstep3}
+! \setfont\chaptt\ttbshape{12}{\magstep2}
+! \setfont\chapttsl\ttslshape{10}{\magstep3}
+! \setfont\chapsf\sfbshape{12}{\magstep2}
+ \let\chapbf=\chaprm
+! \setfont\chapsc\scbshape{10}{\magstep3}
+ \font\chapi=cmmi12 scaled \magstep2
+ \font\chapsy=cmsy10 scaled \magstep3
+
+! % Section fonts (14.4pt).
+! \setfont\secrm\rmbshape{12}{\magstep1}
+! \setfont\secit\itbshape{10}{\magstep2}
+! \setfont\secsl\slbshape{10}{\magstep2}
+! \setfont\sectt\ttbshape{12}{\magstep1}
+! \setfont\secttsl\ttslshape{10}{\magstep2}
+! \setfont\secsf\sfbshape{12}{\magstep1}
+! \let\secbf\secrm
+! \setfont\secsc\scbshape{10}{\magstep2}
+ \font\seci=cmmi12 scaled \magstep1
+ \font\secsy=cmsy10 scaled \magstep2
+
+! % \setfont\ssecrm\bxshape{10}{\magstep1} % This size an font looked bad.
+! % \setfont\ssecit\itshape{10}{\magstep1} % The letters were too crowded.
+! % \setfont\ssecsl\slshape{10}{\magstep1}
+! % \setfont\ssectt\ttshape{10}{\magstep1}
+! % \setfont\ssecsf\sfshape{10}{\magstep1}
+!
+! %\setfont\ssecrm\bfshape{10}{1315} % Note the use of cmb rather than cmbx.
+! %\setfont\ssecit\itshape{10}{1315} % Also, the size is a little larger than
+! %\setfont\ssecsl\slshape{10}{1315} % being scaled magstep1.
+! %\setfont\ssectt\ttshape{10}{1315}
+! %\setfont\ssecsf\sfshape{10}{1315}
+
+ %\let\ssecbf=\ssecrm
+
+! % Subsection fonts (13.15pt).
+! \setfont\ssecrm\rmbshape{12}{\magstephalf}
+! \setfont\ssecit\itbshape{10}{1315}
+! \setfont\ssecsl\slbshape{10}{1315}
+! \setfont\ssectt\ttbshape{12}{\magstephalf}
+! \setfont\ssecttsl\ttslshape{10}{\magstep1}
+! \setfont\ssecsf\sfbshape{12}{\magstephalf}
+! \let\ssecbf\ssecrm
+! \setfont\ssecsc\scbshape{10}{\magstep1}
+ \font\sseci=cmmi12 scaled \magstephalf
+ \font\ssecsy=cmsy10 scaled \magstep1
+ % The smallcaps and symbol fonts should actually be scaled \magstep1.5,
+ % but that is not a standard magnification.
+
+ % Fonts for title page:
+! \setfont\titlerm\rmbshape{12}{\magstep3}
+ \let\authorrm = \secrm
+
+ % In order for the font changes to affect most math symbols and letters,
+***************
+*** 995,1028 ****
+ % The font-changing commands redefine the meanings of \tenSTYLE, instead
+ % of just \STYLE. We do this so that font changes will continue to work
+ % in math mode, where it is the current \fam that is relevant in most
+! % cases, not the current. Plain TeX does, for example,
+! % \def\bf{\fam=\bffam \tenbf} By redefining \tenbf, we obviate the need
+! % to redefine \bf itself.
+ \def\textfonts{%
+ \let\tenrm=\textrm \let\tenit=\textit \let\tensl=\textsl
+ \let\tenbf=\textbf \let\tentt=\texttt \let\smallcaps=\textsc
+! \let\tensf=\textsf \let\teni=\texti \let\tensy=\textsy
+ \resetmathfonts}
+ \def\chapfonts{%
+ \let\tenrm=\chaprm \let\tenit=\chapit \let\tensl=\chapsl
+ \let\tenbf=\chapbf \let\tentt=\chaptt \let\smallcaps=\chapsc
+! \let\tensf=\chapsf \let\teni=\chapi \let\tensy=\chapsy
+! \resetmathfonts}
+ \def\secfonts{%
+ \let\tenrm=\secrm \let\tenit=\secit \let\tensl=\secsl
+ \let\tenbf=\secbf \let\tentt=\sectt \let\smallcaps=\secsc
+! \let\tensf=\secsf \let\teni=\seci \let\tensy=\secsy
+! \resetmathfonts}
+ \def\subsecfonts{%
+ \let\tenrm=\ssecrm \let\tenit=\ssecit \let\tensl=\ssecsl
+ \let\tenbf=\ssecbf \let\tentt=\ssectt \let\smallcaps=\ssecsc
+! \let\tensf=\ssecsf \let\teni=\sseci \let\tensy=\ssecsy
+! \resetmathfonts}
+ \def\indexfonts{%
+ \let\tenrm=\indrm \let\tenit=\indit \let\tensl=\indsl
+ \let\tenbf=\indbf \let\tentt=\indtt \let\smallcaps=\indsc
+! \let\tensf=\indsf \let\teni=\indi \let\tensy=\indsy
+! \resetmathfonts}
+
+ % Set up the default fonts, so we can use them for creating boxes.
+ %
+--- 1186,1220 ----
+ % The font-changing commands redefine the meanings of \tenSTYLE, instead
+ % of just \STYLE. We do this so that font changes will continue to work
+ % in math mode, where it is the current \fam that is relevant in most
+! % cases, not the current font. Plain TeX does \def\bf{\fam=\bffam
+! % \tenbf}, for example. By redefining \tenbf, we obviate the need to
+! % redefine \bf itself.
+ \def\textfonts{%
+ \let\tenrm=\textrm \let\tenit=\textit \let\tensl=\textsl
+ \let\tenbf=\textbf \let\tentt=\texttt \let\smallcaps=\textsc
+! \let\tensf=\textsf \let\teni=\texti \let\tensy=\textsy \let\tenttsl=\textttsl
+ \resetmathfonts}
+ \def\chapfonts{%
+ \let\tenrm=\chaprm \let\tenit=\chapit \let\tensl=\chapsl
+ \let\tenbf=\chapbf \let\tentt=\chaptt \let\smallcaps=\chapsc
+! \let\tensf=\chapsf \let\teni=\chapi \let\tensy=\chapsy \let\tenttsl=\chapttsl
+! \resetmathfonts \setleading{19pt}}
+ \def\secfonts{%
+ \let\tenrm=\secrm \let\tenit=\secit \let\tensl=\secsl
+ \let\tenbf=\secbf \let\tentt=\sectt \let\smallcaps=\secsc
+! \let\tensf=\secsf \let\teni=\seci \let\tensy=\secsy \let\tenttsl=\secttsl
+! \resetmathfonts \setleading{16pt}}
+ \def\subsecfonts{%
+ \let\tenrm=\ssecrm \let\tenit=\ssecit \let\tensl=\ssecsl
+ \let\tenbf=\ssecbf \let\tentt=\ssectt \let\smallcaps=\ssecsc
+! \let\tensf=\ssecsf \let\teni=\sseci \let\tensy=\ssecsy \let\tenttsl=\ssecttsl
+! \resetmathfonts \setleading{15pt}}
+! \let\subsubsecfonts = \subsecfonts % Maybe make sssec fonts scaled magstephalf?
+ \def\indexfonts{%
+ \let\tenrm=\indrm \let\tenit=\indit \let\tensl=\indsl
+ \let\tenbf=\indbf \let\tentt=\indtt \let\smallcaps=\indsc
+! \let\tensf=\indsf \let\teni=\indi \let\tensy=\indsy \let\tenttsl=\indttsl
+! \resetmathfonts \setleading{12pt}}
+
+ % Set up the default fonts, so we can use them for creating boxes.
+ %
+***************
+*** 1032,1040 ****
+ \newcount\fontdepth \fontdepth=0
+
+ % Fonts for short table of contents.
+! \font\shortcontrm=cmr12
+! \font\shortcontbf=cmbx12
+! \font\shortcontsl=cmsl12
+
+ %% Add scribe-like font environments, plus @l for inline lisp (usually sans
+ %% serif) and @ii for TeX italic
+--- 1224,1232 ----
+ \newcount\fontdepth \fontdepth=0
+
+ % Fonts for short table of contents.
+! \setfont\shortcontrm\rmshape{12}{1000}
+! \setfont\shortcontbf\bxshape{12}{1000}
+! \setfont\shortcontsl\slshape{12}{1000}
+
+ %% Add scribe-like font environments, plus @l for inline lisp (usually sans
+ %% serif) and @ii for TeX italic
+***************
+*** 1061,1073 ****
+ \def\restorehyphenation{\hyphenchar\font = `- }
+
+ \def\t#1{%
+! {\tt \nohyphenation \rawbackslash \frenchspacing #1}%
+ \null
+ }
+! \let\ttfont = \t
+! %\def\samp #1{`{\tt \rawbackslash \frenchspacing #1}'\null}
+ \def\samp #1{`\tclose{#1}'\null}
+! \def\key #1{{\tt \nohyphenation \uppercase{#1}}\null}
+ \def\ctrl #1{{\tt \rawbackslash \hat}#1}
+
+ \let\file=\samp
+--- 1253,1273 ----
+ \def\restorehyphenation{\hyphenchar\font = `- }
+
+ \def\t#1{%
+! {\tt \rawbackslash \frenchspacing #1}%
+ \null
+ }
+! \let\ttfont=\t
+ \def\samp #1{`\tclose{#1}'\null}
+! \setfont\smallrm\rmshape{8}{1000}
+! \font\smallsy=cmsy9
+! \def\key#1{{\smallrm\textfont2=\smallsy \leavevmode\hbox{%
+! \raise0.4pt\hbox{$\langle$}\kern-.08em\vtop{%
+! \vbox{\hrule\kern-0.4pt
+! \hbox{\raise0.4pt\hbox{\vphantom{$\langle$}}#1}}%
+! \kern-0.4pt\hrule}%
+! \kern-.06em\raise0.4pt\hbox{$\rangle$}}}}
+! % The old definition, with no lozenge:
+! %\def\key #1{{\ttsl \nohyphenation \uppercase{#1}}\null}
+ \def\ctrl #1{{\tt \rawbackslash \hat}#1}
+
+ \let\file=\samp
+***************
+*** 1096,1135 ****
+ }
+
+ % We *must* turn on hyphenation at `-' and `_' in \code.
+! % Otherwise, it is too hard to avoid overful hboxes
+ % in the Emacs manual, the Library manual, etc.
+
+ % Unfortunately, TeX uses one parameter (\hyphenchar) to control
+ % both hyphenation at - and hyphenation within words.
+ % We must therefore turn them both off (\tclose does that)
+! % and arrange explicitly to hyphenate an a dash.
+ % -- rms.
+ {
+ \catcode`\-=\active
+ \catcode`\_=\active
+ \global\def\code{\begingroup \catcode`\-=\active \let-\codedash \catcode`\_=\active \let_\codeunder \codex}
+ % The following is used by \doprintindex to insure that long function names
+ % wrap around. It is necessary for - and _ to be active before the index is
+ % read from the file, as \entry parses the arguments long before \code is
+ % ever called. -- mycroft
+! \global\def\indexbreaks{\catcode`\-=\active \let-\realdash \catcode`\_=\active \let_\realunder}
+ }
+ \def\realdash{-}
+- \def\realunder{_}
+ \def\codedash{-\discretionary{}{}{}}
+! \def\codeunder{\normalunderscore\discretionary{}{}{}}
+ \def\codex #1{\tclose{#1}\endgroup}
+
+ %\let\exp=\tclose %Was temporary
+
+ % @kbd is like @code, except that if the argument is just one @key command,
+ % then @kbd has no effect.
+!
+ \def\xkey{\key}
+ \def\kbdfoo#1#2#3\par{\def\one{#1}\def\three{#3}\def\threex{??}%
+ \ifx\one\xkey\ifx\threex\three \key{#2}%
+! \else\tclose{\look}\fi
+! \else\tclose{\look}\fi}
+
+ % Typeset a dimension, e.g., `in' or `pt'. The only reason for the
+ % argument is to make the input look right: @dmn{pt} instead of
+--- 1296,1354 ----
+ }
+
+ % We *must* turn on hyphenation at `-' and `_' in \code.
+! % Otherwise, it is too hard to avoid overfull hboxes
+ % in the Emacs manual, the Library manual, etc.
+
+ % Unfortunately, TeX uses one parameter (\hyphenchar) to control
+ % both hyphenation at - and hyphenation within words.
+ % We must therefore turn them both off (\tclose does that)
+! % and arrange explicitly to hyphenate at a dash.
+ % -- rms.
+ {
+ \catcode`\-=\active
+ \catcode`\_=\active
++ \catcode`\|=\active
+ \global\def\code{\begingroup \catcode`\-=\active \let-\codedash \catcode`\_=\active \let_\codeunder \codex}
+ % The following is used by \doprintindex to insure that long function names
+ % wrap around. It is necessary for - and _ to be active before the index is
+ % read from the file, as \entry parses the arguments long before \code is
+ % ever called. -- mycroft
+! % _ is always active; and it shouldn't be \let = to an _ that is a
+! % subscript character anyway. Then, @cindex @samp{_} (for example)
+! % fails. --karl
+! \global\def\indexbreaks{%
+! \catcode`\-=\active \let-\realdash
+ }
++ }
++
+ \def\realdash{-}
+ \def\codedash{-\discretionary{}{}{}}
+! \def\codeunder{\ifusingtt{\normalunderscore\discretionary{}{}{}}{\_}}
+ \def\codex #1{\tclose{#1}\endgroup}
+
+ %\let\exp=\tclose %Was temporary
+
+ % @kbd is like @code, except that if the argument is just one @key command,
+ % then @kbd has no effect.
+! %
+ \def\xkey{\key}
+ \def\kbdfoo#1#2#3\par{\def\one{#1}\def\three{#3}\def\threex{??}%
+ \ifx\one\xkey\ifx\threex\three \key{#2}%
+! \else{\tclose{\ttsl\look}}\fi
+! \else{\tclose{\ttsl\look}}\fi}
+!
+! % @url, @email. Quotes do not seem necessary.
+! \let\url=\code % perhaps include a hypertex \special eventually
+! % rms does not like the angle brackets --karl, 17may97.
+! %\def\email#1{$\langle${\tt #1}$\rangle$}
+! \let\email=\code
+!
+! % Check if we are currently using a typewriter font. Since all the
+! % Computer Modern typewriter fonts have zero interword stretch (and
+! % shrink), and it is reasonable to expect all typewriter fonts to have
+! % this property, we can check that font parameter.
+! %
+! \def\ifmonospace{\ifdim\fontdimen3\font=0pt }
+
+ % Typeset a dimension, e.g., `in' or `pt'. The only reason for the
+ % argument is to make the input look right: @dmn{pt} instead of
+***************
+*** 1139,1150 ****
+
+ \def\kbd#1{\def\look{#1}\expandafter\kbdfoo\look??\par}
+
+! \def\l#1{{\li #1}\null} %
+
+! \def\r#1{{\rm #1}} % roman font
+ % Use of \lowercase was suggested.
+! \def\sc#1{{\smallcaps#1}} % smallcaps font
+! \def\ii#1{{\it #1}} % italic font
+
+ \message{page headings,}
+
+--- 1358,1376 ----
+
+ \def\kbd#1{\def\look{#1}\expandafter\kbdfoo\look??\par}
+
+! % @l was never documented to mean ``switch to the Lisp font'',
+! % and it is not used as such in any manual I can find. We need it for
+! % Polish suppressed-l. --karl, 22sep96.
+! %\def\l#1{{\li #1}\null}
+
+! \def\r#1{{\rm #1}} % roman font
+ % Use of \lowercase was suggested.
+! \def\sc#1{{\smallcaps#1}} % smallcaps font
+! \def\ii#1{{\it #1}} % italic font
+!
+! % @pounds{} is a sterling sign.
+! \def\pounds{{\it\$}}
+!
+
+ \message{page headings,}
+
+***************
+*** 1159,1165 ****
+
+ \def\shorttitlepage{\parsearg\shorttitlepagezzz}
+ \def\shorttitlepagezzz #1{\begingroup\hbox{}\vskip 1.5in \chaprm \centerline{#1}%
+! \endgroup\page\hbox{}\page}
+
+ \def\titlepage{\begingroup \parindent=0pt \textfonts
+ \let\subtitlerm=\tenrm
+--- 1385,1391 ----
+
+ \def\shorttitlepage{\parsearg\shorttitlepagezzz}
+ \def\shorttitlepagezzz #1{\begingroup\hbox{}\vskip 1.5in \chaprm \centerline{#1}%
+! \endgroup\page\hbox{}\page}
+
+ \def\titlepage{\begingroup \parindent=0pt \textfonts
+ \let\subtitlerm=\tenrm
+***************
+*** 1176,1184 ****
+ % Now you can print the title using @title.
+ \def\title{\parsearg\titlezzz}%
+ \def\titlezzz##1{\leftline{\titlefont{##1}}
+! % print a rule at the page bottom also.
+! \finishedtitlepagefalse
+! \vskip4pt \hrule height 4pt width \hsize \vskip4pt}%
+ % No rule at page bottom unless we print one at the top with @title.
+ \finishedtitlepagetrue
+ %
+--- 1402,1410 ----
+ % Now you can print the title using @title.
+ \def\title{\parsearg\titlezzz}%
+ \def\titlezzz##1{\leftline{\titlefont{##1}}
+! % print a rule at the page bottom also.
+! \finishedtitlepagefalse
+! \vskip4pt \hrule height 4pt width \hsize \vskip4pt}%
+ % No rule at page bottom unless we print one at the top with @title.
+ \finishedtitlepagetrue
+ %
+***************
+*** 1196,1202 ****
+ \let\oldpage = \page
+ \def\page{%
+ \iffinishedtitlepage\else
+! \finishtitlepage
+ \fi
+ \oldpage
+ \let\page = \oldpage
+--- 1422,1428 ----
+ \let\oldpage = \page
+ \def\page{%
+ \iffinishedtitlepage\else
+! \finishtitlepage
+ \fi
+ \oldpage
+ \let\page = \oldpage
+***************
+*** 1284,1297 ****
+ %
+ }% unbind the catcode of @.
+
+! % @headings double turns headings on for double-sided printing.
+! % @headings single turns headings on for single-sided printing.
+! % @headings off turns them off.
+! % @headings on same as @headings double, retained for compatibility.
+! % @headings after turns on double-sided headings after this page.
+! % @headings doubleafter turns on double-sided headings after this page.
+ % @headings singleafter turns on single-sided headings after this page.
+! % By default, they are off.
+
+ \def\headings #1 {\csname HEADINGS#1\endcsname}
+
+--- 1510,1524 ----
+ %
+ }% unbind the catcode of @.
+
+! % @headings double turns headings on for double-sided printing.
+! % @headings single turns headings on for single-sided printing.
+! % @headings off turns them off.
+! % @headings on same as @headings double, retained for compatibility.
+! % @headings after turns on double-sided headings after this page.
+! % @headings doubleafter turns on double-sided headings after this page.
+ % @headings singleafter turns on single-sided headings after this page.
+! % By default, they are off at the start of a document,
+! % and turned `on' after @end titlepage.
+
+ \def\headings #1 {\csname HEADINGS#1\endcsname}
+
+***************
+*** 1305,1326 ****
+ % title on inside top of left hand pages, and page numbers on outside top
+ % edge of all pages.
+ \def\HEADINGSdouble{
+- %\pagealignmacro
+ \global\pageno=1
+ \global\evenfootline={\hfil}
+ \global\oddfootline={\hfil}
+ \global\evenheadline={\line{\folio\hfil\thistitle}}
+ \global\oddheadline={\line{\thischapter\hfil\folio}}
+ }
+ % For single-sided printing, chapter title goes across top left of page,
+ % page number on top right.
+ \def\HEADINGSsingle{
+- %\pagealignmacro
+ \global\pageno=1
+ \global\evenfootline={\hfil}
+ \global\oddfootline={\hfil}
+ \global\evenheadline={\line{\thischapter\hfil\folio}}
+ \global\oddheadline={\line{\thischapter\hfil\folio}}
+ }
+ \def\HEADINGSon{\HEADINGSdouble}
+
+--- 1532,1555 ----
+ % title on inside top of left hand pages, and page numbers on outside top
+ % edge of all pages.
+ \def\HEADINGSdouble{
+ \global\pageno=1
+ \global\evenfootline={\hfil}
+ \global\oddfootline={\hfil}
+ \global\evenheadline={\line{\folio\hfil\thistitle}}
+ \global\oddheadline={\line{\thischapter\hfil\folio}}
++ \global\let\contentsalignmacro = \chapoddpage
+ }
++ \let\contentsalignmacro = \chappager
++
+ % For single-sided printing, chapter title goes across top left of page,
+ % page number on top right.
+ \def\HEADINGSsingle{
+ \global\pageno=1
+ \global\evenfootline={\hfil}
+ \global\oddfootline={\hfil}
+ \global\evenheadline={\line{\thischapter\hfil\folio}}
+ \global\oddheadline={\line{\thischapter\hfil\folio}}
++ \global\let\contentsalignmacro = \chappager
+ }
+ \def\HEADINGSon{\HEADINGSdouble}
+
+***************
+*** 1331,1336 ****
+--- 1560,1566 ----
+ \global\oddfootline={\hfil}
+ \global\evenheadline={\line{\folio\hfil\thistitle}}
+ \global\oddheadline={\line{\thischapter\hfil\folio}}
++ \global\let\contentsalignmacro = \chapoddpage
+ }
+
+ \def\HEADINGSsingleafter{\let\HEADINGShook=\HEADINGSsinglex}
+***************
+*** 1339,1344 ****
+--- 1569,1575 ----
+ \global\oddfootline={\hfil}
+ \global\evenheadline={\line{\thischapter\hfil\folio}}
+ \global\oddheadline={\line{\thischapter\hfil\folio}}
++ \global\let\contentsalignmacro = \chappager
+ }
+
+ % Subroutines used in generating headings
+***************
+*** 1362,1367 ****
+--- 1593,1599 ----
+ \def\settitle{\parsearg\settitlezzz}
+ \def\settitlezzz #1{\gdef\thistitle{#1}}
+
++
+ \message{tables,}
+
+ % @tabs -- simple alignment
+***************
+*** 1394,1400 ****
+
+ \newif\ifitemxneedsnegativevskip
+
+! \def\itemxpar{\par\ifitemxneedsnegativevskip\vskip-\parskip\nobreak\fi}
+
+ \def\internalBitem{\smallbreak \parsearg\itemzzz}
+ \def\internalBitemx{\itemxpar \parsearg\itemzzz}
+--- 1626,1632 ----
+
+ \newif\ifitemxneedsnegativevskip
+
+! \def\itemxpar{\par\ifitemxneedsnegativevskip\nobreak\vskip-\parskip\nobreak\fi}
+
+ \def\internalBitem{\smallbreak \parsearg\itemzzz}
+ \def\internalBitemx{\itemxpar \parsearg\itemzzz}
+***************
+*** 1501,1507 ****
+ \def\tablez #1#2#3#4#5#6{%
+ \aboveenvbreak %
+ \begingroup %
+! \def\Edescription{\Etable}% Neccessary kludge.
+ \let\itemindex=#1%
+ \ifnum 0#3>0 \advance \leftskip by #3\mil \fi %
+ \ifnum 0#4>0 \tableindent=#4\mil \fi %
+--- 1733,1739 ----
+ \def\tablez #1#2#3#4#5#6{%
+ \aboveenvbreak %
+ \begingroup %
+! \def\Edescription{\Etable}% Necessary kludge.
+ \let\itemindex=#1%
+ \ifnum 0#3>0 \advance \leftskip by #3\mil \fi %
+ \ifnum 0#4>0 \tableindent=#4\mil \fi %
+***************
+*** 1658,1674 ****
+ \def\itemizeitem{%
+ \advance\itemno by 1
+ {\let\par=\endgraf \smallbreak}%
+! \ifhmode \errmessage{\in hmode at itemizeitem}\fi
+ {\parskip=0in \hskip 0pt
+ \hbox to 0pt{\hss \itemcontents\hskip \itemmargin}%
+ \vadjust{\penalty 1200}}%
+ \flushcr}
+
+ % @multitable macros
+! % Amy Hendrickson, 8/18/94
+ %
+! % @multitable ... @endmultitable will make as many columns as desired.
+! % Contents of each column will wrap at width given in preamble. Width
+ % can be specified either with sample text given in a template line,
+ % or in percent of \hsize, the current width of text on page.
+
+--- 1890,1906 ----
+ \def\itemizeitem{%
+ \advance\itemno by 1
+ {\let\par=\endgraf \smallbreak}%
+! \ifhmode \errmessage{In hmode at itemizeitem}\fi
+ {\parskip=0in \hskip 0pt
+ \hbox to 0pt{\hss \itemcontents\hskip \itemmargin}%
+ \vadjust{\penalty 1200}}%
+ \flushcr}
+
+ % @multitable macros
+! % Amy Hendrickson, 8/18/94, 3/6/96
+ %
+! % @multitable ... @end multitable will make as many columns as desired.
+! % Contents of each column will wrap at width given in preamble. Width
+ % can be specified either with sample text given in a template line,
+ % or in percent of \hsize, the current width of text on page.
+
+***************
+*** 1676,1796 ****
+
+ % To make preamble:
+ %
+! % Either define widths of columns in terms of percent of \hsize:
+! % @multitable @percentofhsize .2 .3 .5
+ % @item ...
+ %
+! % Numbers following @percentofhsize are the percent of the total
+ % current hsize to be used for each column. You may use as many
+ % columns as desired.
+
+ % Or use a template:
+ % @multitable {Column 1 template} {Column 2 template} {Column 3 template}
+ % @item ...
+ % using the widest term desired in each column.
+
+!
+! % Each new table line starts with @item, each subsequent new column
+ % starts with @tab. Empty columns may be produced by supplying @tab's
+ % with nothing between them for as many times as empty columns are needed,
+ % ie, @tab@tab@tab will produce two empty columns.
+
+! % @item, @tab, @multicolumn or @endmulticolumn do not need to be on their
+ % own lines, but it will not hurt if they are.
+
+ % Sample multitable:
+
+ % @multitable {Column 1 template} {Column 2 template} {Column 3 template}
+ % @item first col stuff @tab second col stuff @tab third col
+! % @item
+! % first col stuff
+! % @tab
+! % second col stuff
+! % @tab
+! % third col
+! % @item first col stuff @tab second col stuff
+ % @tab Many paragraphs of text may be used in any column.
+! %
+ % They will wrap at the width determined by the template.
+ % @item@tab@tab This will be in third column.
+! % @endmultitable
+
+ % Default dimensions may be reset by user.
+! % @intableparskip will set vertical space between paragraphs in table.
+! % @intableparindent will set paragraph indent in table.
+! % @spacebetweencols will set horizontal space to be left between columns.
+! % @spacebetweenlines will set vertical space to be left between lines.
+
+ %%%%
+! % Dimensions
+
+! \newdimen\intableparskip
+! \newdimen\intableparindent
+! \newdimen\spacebetweencols
+! \newdimen\spacebetweenlines
+! \intableparskip=0pt
+! \intableparindent=6pt
+! \spacebetweencols=12pt
+! \spacebetweenlines=12pt
+
+ %%%%
+ % Macros used to set up halign preamble:
+ \let\endsetuptable\relax
+ \def\xendsetuptable{\endsetuptable}
+! \let\percentofhsize\relax
+! \def\xpercentofhsize{\percentofhsize}
+ \newif\ifsetpercent
+
+ \newcount\colcount
+ \def\setuptable#1{\def\firstarg{#1}%
+ \ifx\firstarg\xendsetuptable\let\go\relax%
+ \else
+! \ifx\firstarg\xpercentofhsize\global\setpercenttrue%
+ \else
+ \ifsetpercent
+! \if#1.\else%
+! \global\advance\colcount by1 %
+! \expandafter\xdef\csname col\the\colcount\endcsname{.#1\hsize}%
+! \fi
+ \else
+ \global\advance\colcount by1
+! \setbox0=\hbox{#1}%
+ \expandafter\xdef\csname col\the\colcount\endcsname{\the\wd0}%
+ \fi%
+ \fi%
+! \let\go\setuptable%
+ \fi\go}
+ %%%%
+ % multitable syntax
+! \def\tab{&}
+
+ %%%%
+! % @multitable ... @endmultitable definitions:
+
+! \def\multitable#1\item{\bgroup
+ \let\item\cr
+ \tolerance=9500
+ \hbadness=9500
+! \parskip=\intableparskip
+! \parindent=\intableparindent
+ \overfullrule=0pt
+ \global\colcount=0\relax%
+ \def\Emultitable{\global\setpercentfalse\global\everycr{}\cr\egroup\egroup}%
+ % To parse everything between @multitable and @item :
+! \def\one{#1}\expandafter\setuptable\one\endsetuptable
+ % Need to reset this to 0 after \setuptable.
+! \global\colcount=0\relax%
+ %
+ % This preamble sets up a generic column definition, which will
+ % be used as many times as user calls for columns.
+! % \vtop will set a single line and will also let text wrap and
+ % continue for many paragraphs if desired.
+ \halign\bgroup&\global\advance\colcount by 1\relax%
+! \vtop{\hsize=\expandafter\csname col\the\colcount\endcsname
+ % In order to keep entries from bumping into each other
+! % we will add a \leftskip of \spacebetweencols to all columns after
+ % the first one.
+! % If a template has been used, we will add \spacebetweencols
+ % to the width of each template entry.
+ % If user has set preamble in terms of percent of \hsize
+ % we will use that dimension as the width of the column, and
+--- 1908,2053 ----
+
+ % To make preamble:
+ %
+! % Either define widths of columns in terms of percent of \hsize:
+! % @multitable @columnfractions .25 .3 .45
+ % @item ...
+ %
+! % Numbers following @columnfractions are the percent of the total
+ % current hsize to be used for each column. You may use as many
+ % columns as desired.
+
++
+ % Or use a template:
+ % @multitable {Column 1 template} {Column 2 template} {Column 3 template}
+ % @item ...
+ % using the widest term desired in each column.
++ %
++ % For those who want to use more than one line's worth of words in
++ % the preamble, break the line within one argument and it
++ % will parse correctly, i.e.,
++ %
++ % @multitable {Column 1 template} {Column 2 template} {Column 3
++ % template}
++ % Not:
++ % @multitable {Column 1 template} {Column 2 template}
++ % {Column 3 template}
+
+! % Each new table line starts with @item, each subsequent new column
+ % starts with @tab. Empty columns may be produced by supplying @tab's
+ % with nothing between them for as many times as empty columns are needed,
+ % ie, @tab@tab@tab will produce two empty columns.
+
+! % @item, @tab, @multitable or @end multitable do not need to be on their
+ % own lines, but it will not hurt if they are.
+
+ % Sample multitable:
+
+ % @multitable {Column 1 template} {Column 2 template} {Column 3 template}
+ % @item first col stuff @tab second col stuff @tab third col
+! % @item
+! % first col stuff
+! % @tab
+! % second col stuff
+! % @tab
+! % third col
+! % @item first col stuff @tab second col stuff
+ % @tab Many paragraphs of text may be used in any column.
+! %
+ % They will wrap at the width determined by the template.
+ % @item@tab@tab This will be in third column.
+! % @end multitable
+
+ % Default dimensions may be reset by user.
+! % @multitableparskip is vertical space between paragraphs in table.
+! % @multitableparindent is paragraph indent in table.
+! % @multitablecolmargin is horizontal space to be left between columns.
+! % @multitablelinespace is space to leave between table items, baseline
+! % to baseline.
+! % 0pt means it depends on current normal line spacing.
+
+ %%%%
+! % Dimensions
+
+! \newskip\multitableparskip
+! \newskip\multitableparindent
+! \newdimen\multitablecolspace
+! \newskip\multitablelinespace
+! \multitableparskip=0pt
+! \multitableparindent=6pt
+! \multitablecolspace=12pt
+! \multitablelinespace=0pt
+
+ %%%%
+ % Macros used to set up halign preamble:
+ \let\endsetuptable\relax
+ \def\xendsetuptable{\endsetuptable}
+! \let\columnfractions\relax
+! \def\xcolumnfractions{\columnfractions}
+ \newif\ifsetpercent
+
++ %% 2/1/96, to allow fractions to be given with more than one digit.
++ \def\pickupwholefraction#1 {\global\advance\colcount by1 %
++ \expandafter\xdef\csname col\the\colcount\endcsname{.#1\hsize}%
++ \setuptable}
++
+ \newcount\colcount
+ \def\setuptable#1{\def\firstarg{#1}%
+ \ifx\firstarg\xendsetuptable\let\go\relax%
+ \else
+! \ifx\firstarg\xcolumnfractions\global\setpercenttrue%
+ \else
+ \ifsetpercent
+! \let\go\pickupwholefraction % In this case arg of setuptable
+! % is the decimal point before the
+! % number given in percent of hsize.
+! % We don't need this so we don't use it.
+ \else
+ \global\advance\colcount by1
+! \setbox0=\hbox{#1 }% Add a normal word space as a separator;
+! % typically that is always in the input, anyway.
+ \expandafter\xdef\csname col\the\colcount\endcsname{\the\wd0}%
+ \fi%
+ \fi%
+! \ifx\go\pickupwholefraction\else\let\go\setuptable\fi%
+ \fi\go}
++
+ %%%%
+ % multitable syntax
+! \def\tab{&\hskip1sp\relax} % 2/2/96
+! % tiny skip here makes sure this column space is
+! % maintained, even if it is never used.
+!
+
+ %%%%
+! % @multitable ... @end multitable definitions:
+!
+! \def\multitable{\parsearg\dotable}
+
+! \def\dotable#1{\bgroup
+ \let\item\cr
+ \tolerance=9500
+ \hbadness=9500
+! \setmultitablespacing
+! \parskip=\multitableparskip
+! \parindent=\multitableparindent
+ \overfullrule=0pt
+ \global\colcount=0\relax%
+ \def\Emultitable{\global\setpercentfalse\global\everycr{}\cr\egroup\egroup}%
+ % To parse everything between @multitable and @item :
+! \setuptable#1 \endsetuptable
+ % Need to reset this to 0 after \setuptable.
+! \global\colcount=0\relax%
+ %
+ % This preamble sets up a generic column definition, which will
+ % be used as many times as user calls for columns.
+! % \vtop will set a single line and will also let text wrap and
+ % continue for many paragraphs if desired.
+ \halign\bgroup&\global\advance\colcount by 1\relax%
+! \multistrut\vtop{\hsize=\expandafter\csname col\the\colcount\endcsname
+ % In order to keep entries from bumping into each other
+! % we will add a \leftskip of \multitablecolspace to all columns after
+ % the first one.
+! % If a template has been used, we will add \multitablecolspace
+ % to the width of each template entry.
+ % If user has set preamble in terms of percent of \hsize
+ % we will use that dimension as the width of the column, and
+***************
+*** 1802,1821 ****
+ \ifsetpercent
+ \else
+ % If user has <not> set preamble in terms of percent of \hsize
+! % we will advance \hsize by \spacebetweencols
+! \advance\hsize by \spacebetweencols
+ \fi
+! % In either case we will make \leftskip=\spacebetweencols:
+! \leftskip=\spacebetweencols
+ \fi
+! \noindent##}\cr%
+ % \everycr will reset column counter, \colcount, at the end of
+! % each line. Every column entry will cause \colcount to advance by one.
+ % The table preamble
+ % looks at the current \colcount to find the correct column width.
+! \global\everycr{\noalign{\nointerlineskip\vskip\spacebetweenlines
+! \filbreak%% keeps underfull box messages off when table breaks over pages.
+! \global\colcount=0\relax}}}
+
+ \message{indexing,}
+ % Index generation facilities
+--- 2059,2116 ----
+ \ifsetpercent
+ \else
+ % If user has <not> set preamble in terms of percent of \hsize
+! % we will advance \hsize by \multitablecolspace
+! \advance\hsize by \multitablecolspace
+ \fi
+! % In either case we will make \leftskip=\multitablecolspace:
+! \leftskip=\multitablecolspace
+ \fi
+! % Ignoring space at the beginning and end avoids an occasional spurious
+! % blank line, when TeX decides to break the line at the space before the
+! % box from the multistrut, so the strut ends up on a line by itself.
+! % For example:
+! % @multitable @columnfractions .11 .89
+! % @item @code{#}
+! % @tab Legal holiday which is valid in major parts of the whole country.
+! % Is automatically provided with highlighting sequences respectively marking
+! % characters.
+! \noindent\ignorespaces##\unskip\multistrut}\cr
+ % \everycr will reset column counter, \colcount, at the end of
+! % each line. Every column entry will cause \colcount to advance by one.
+ % The table preamble
+ % looks at the current \colcount to find the correct column width.
+! \global\everycr{\noalign{%
+! % \filbreak%% keeps underfull box messages off when table breaks over pages.
+! % Maybe so, but it also creates really weird page breaks when the table
+! % breaks over pages Wouldn't \vfil be better? Wait until the problem
+! % manifests itself, so it can be fixed for real --karl.
+! \global\colcount=0\relax}}
+! }
+!
+! \def\setmultitablespacing{% test to see if user has set \multitablelinespace.
+! % If so, do nothing. If not, give it an appropriate dimension based on
+! % current baselineskip.
+! \ifdim\multitablelinespace=0pt
+! %% strut to put in table in case some entry doesn't have descenders,
+! %% to keep lines equally spaced
+! \let\multistrut = \strut
+! %% Test to see if parskip is larger than space between lines of
+! %% table. If not, do nothing.
+! %% If so, set to same dimension as multitablelinespace.
+! \else
+! \gdef\multistrut{\vrule height\multitablelinespace depth\dp0
+! width0pt\relax} \fi
+! \ifdim\multitableparskip>\multitablelinespace
+! \global\multitableparskip=\multitablelinespace
+! \global\advance\multitableparskip-7pt %% to keep parskip somewhat smaller
+! %% than skip between lines in the table.
+! \fi%
+! \ifdim\multitableparskip=0pt
+! \global\multitableparskip=\multitablelinespace
+! \global\advance\multitableparskip-7pt %% to keep parskip somewhat smaller
+! %% than skip between lines in the table.
+! \fi}
+!
+
+ \message{indexing,}
+ % Index generation facilities
+***************
+*** 1829,1842 ****
+ % It automatically defines \fooindex such that
+ % \fooindex ...rest of line... puts an entry in the index foo.
+ % It also defines \fooindfile to be the number of the output channel for
+! % the file that accumulates this index. The file's extension is foo.
+ % The name of an index should be no more than 2 characters long
+ % for the sake of vms.
+
+ \def\newindex #1{
+ \expandafter\newwrite \csname#1indfile\endcsname% Define number for output file
+! \openout \csname#1indfile\endcsname \jobname.#1 % Open the file
+! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex
+ \noexpand\doindex {#1}}
+ }
+
+--- 2124,2137 ----
+ % It automatically defines \fooindex such that
+ % \fooindex ...rest of line... puts an entry in the index foo.
+ % It also defines \fooindfile to be the number of the output channel for
+! % the file that accumulates this index. The file's extension is foo.
+ % The name of an index should be no more than 2 characters long
+ % for the sake of vms.
+
+ \def\newindex #1{
+ \expandafter\newwrite \csname#1indfile\endcsname% Define number for output file
+! \openout \csname#1indfile\endcsname \jobname.#1 % Open the file
+! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex
+ \noexpand\doindex {#1}}
+ }
+
+***************
+*** 1848,1855 ****
+
+ \def\newcodeindex #1{
+ \expandafter\newwrite \csname#1indfile\endcsname% Define number for output file
+! \openout \csname#1indfile\endcsname \jobname.#1 % Open the file
+! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex
+ \noexpand\docodeindex {#1}}
+ }
+
+--- 2143,2150 ----
+
+ \def\newcodeindex #1{
+ \expandafter\newwrite \csname#1indfile\endcsname% Define number for output file
+! \openout \csname#1indfile\endcsname \jobname.#1 % Open the file
+! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex
+ \noexpand\docodeindex {#1}}
+ }
+
+***************
+*** 1860,1866 ****
+ \def\synindex #1 #2 {%
+ \expandafter\let\expandafter\synindexfoo\expandafter=\csname#2indfile\endcsname
+ \expandafter\let\csname#1indfile\endcsname=\synindexfoo
+! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex
+ \noexpand\doindex {#2}}%
+ }
+
+--- 2155,2161 ----
+ \def\synindex #1 #2 {%
+ \expandafter\let\expandafter\synindexfoo\expandafter=\csname#2indfile\endcsname
+ \expandafter\let\csname#1indfile\endcsname=\synindexfoo
+! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex
+ \noexpand\doindex {#2}}%
+ }
+
+***************
+*** 1869,1875 ****
+ \def\syncodeindex #1 #2 {%
+ \expandafter\let\expandafter\synindexfoo\expandafter=\csname#2indfile\endcsname
+ \expandafter\let\csname#1indfile\endcsname=\synindexfoo
+! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex
+ \noexpand\docodeindex {#2}}%
+ }
+
+--- 2164,2170 ----
+ \def\syncodeindex #1 #2 {%
+ \expandafter\let\expandafter\synindexfoo\expandafter=\csname#2indfile\endcsname
+ \expandafter\let\csname#1indfile\endcsname=\synindexfoo
+! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex
+ \noexpand\docodeindex {#2}}%
+ }
+
+***************
+*** 1917,1943 ****
+ \def\L{\realbackslash L}%
+ \def\ss{\realbackslash ss}%
+ % Take care of texinfo commands likely to appear in an index entry.
+ \def\_{{\realbackslash _}}%
+ \def\w{\realbackslash w }%
+ \def\bf{\realbackslash bf }%
+! \def\rm{\realbackslash rm }%
+ \def\sl{\realbackslash sl }%
+ \def\sf{\realbackslash sf}%
+ \def\tt{\realbackslash tt}%
+ \def\gtr{\realbackslash gtr}%
+ \def\less{\realbackslash less}%
+ \def\hat{\realbackslash hat}%
+! \def\char{\realbackslash char}%
+ \def\TeX{\realbackslash TeX}%
+ \def\dots{\realbackslash dots }%
+ \def\copyright{\realbackslash copyright }%
+ \def\tclose##1{\realbackslash tclose {##1}}%
+ \def\code##1{\realbackslash code {##1}}%
+ \def\samp##1{\realbackslash samp {##1}}%
+! \def\t##1{\realbackslash r {##1}}%
+ \def\r##1{\realbackslash r {##1}}%
+ \def\i##1{\realbackslash i {##1}}%
+ \def\b##1{\realbackslash b {##1}}%
+ \def\cite##1{\realbackslash cite {##1}}%
+ \def\key##1{\realbackslash key {##1}}%
+ \def\file##1{\realbackslash file {##1}}%
+--- 2212,2246 ----
+ \def\L{\realbackslash L}%
+ \def\ss{\realbackslash ss}%
+ % Take care of texinfo commands likely to appear in an index entry.
++ % (Must be a way to avoid doing expansion at all, and thus not have to
++ % laboriously list every single command here.)
++ \def\@{@}% will be @@ when we switch to @ as escape char.
++ %\let\{ = \lbracecmd
++ %\let\} = \rbracecmd
+ \def\_{{\realbackslash _}}%
+ \def\w{\realbackslash w }%
+ \def\bf{\realbackslash bf }%
+! %\def\rm{\realbackslash rm }%
+ \def\sl{\realbackslash sl }%
+ \def\sf{\realbackslash sf}%
+ \def\tt{\realbackslash tt}%
+ \def\gtr{\realbackslash gtr}%
+ \def\less{\realbackslash less}%
+ \def\hat{\realbackslash hat}%
+! %\def\char{\realbackslash char}%
+ \def\TeX{\realbackslash TeX}%
+ \def\dots{\realbackslash dots }%
+ \def\copyright{\realbackslash copyright }%
+ \def\tclose##1{\realbackslash tclose {##1}}%
+ \def\code##1{\realbackslash code {##1}}%
++ \def\dotless##1{\realbackslash dotless {##1}}%
+ \def\samp##1{\realbackslash samp {##1}}%
+! \def\,##1{\realbackslash ,{##1}}%
+! \def\t##1{\realbackslash t {##1}}%
+ \def\r##1{\realbackslash r {##1}}%
+ \def\i##1{\realbackslash i {##1}}%
+ \def\b##1{\realbackslash b {##1}}%
++ \def\sc##1{\realbackslash sc {##1}}%
+ \def\cite##1{\realbackslash cite {##1}}%
+ \def\key##1{\realbackslash key {##1}}%
+ \def\file##1{\realbackslash file {##1}}%
+***************
+*** 1945,1952 ****
+--- 2248,2262 ----
+ \def\kbd##1{\realbackslash kbd {##1}}%
+ \def\dfn##1{\realbackslash dfn {##1}}%
+ \def\emph##1{\realbackslash emph {##1}}%
++ \unsepspaces
+ }
+
++ % If an index command is used in an @example environment, any spaces
++ % therein should become regular spaces in the raw index file, not the
++ % expansion of \tie (\\leavevmode \penalty \@M \ ).
++ {\obeyspaces
++ \gdef\unsepspaces{\obeyspaces\let =\space}}
++
+ % \indexnofonts no-ops all font-change commands.
+ % This is used when outputting the strings to sort the index by.
+ \def\indexdummyfont#1{#1}
+***************
+*** 1955,1960 ****
+--- 2265,2271 ----
+
+ \def\indexnofonts{%
+ % Just ignore accents.
++ \let\,=\indexdummyfont
+ \let\"=\indexdummyfont
+ \let\`=\indexdummyfont
+ \let\'=\indexdummyfont
+***************
+*** 1967,1972 ****
+--- 2278,2284 ----
+ \let\u=\indexdummyfont
+ \let\v=\indexdummyfont
+ \let\H=\indexdummyfont
++ \let\dotless=\indexdummyfont
+ % Take care of the plain tex special European modified letters.
+ \def\oe{oe}%
+ \def\ae{ae}%
+***************
+*** 2000,2005 ****
+--- 2312,2318 ----
+ \let\var=\indexdummyfont
+ \let\TeX=\indexdummytex
+ \let\dots=\indexdummydots
++ \def\@{@}%
+ }
+
+ % To define \realbackslash, we must make \ not be an escape.
+***************
+*** 2011,2036 ****
+
+ \let\indexbackslash=0 %overridden during \printindex.
+
+ \def\doind #1#2{%
+! {\count10=\lastpenalty %
+! {\indexdummies % Must do this here, since \bf, etc expand at this stage
+! \escapechar=`\\%
+! {\let\folio=0% Expand all macros now EXCEPT \folio
+! \def\rawbackslashxx{\indexbackslash}% \indexbackslash isn't defined now
+! % so it will be output as is; and it will print as backslash in the indx.
+! %
+! % Now process the index-string once, with all font commands turned off,
+! % to get the string to sort the index by.
+! {\indexnofonts
+! \xdef\temp1{#2}%
+! }%
+! % Now produce the complete index entry. We process the index-string again,
+! % this time with font commands expanded, to get what to print in the index.
+! \edef\temp{%
+! \write \csname#1indfile\endcsname{%
+! \realbackslash entry {\temp1}{\folio}{#2}}}%
+! \temp }%
+! }\penalty\count10}}
+
+ \def\dosubind #1#2#3{%
+ {\count10=\lastpenalty %
+--- 2324,2364 ----
+
+ \let\indexbackslash=0 %overridden during \printindex.
+
++ \let\SETmarginindex=\relax %initialize!
++ % workhorse for all \fooindexes
++ % #1 is name of index, #2 is stuff to put there
+ \def\doind #1#2{%
+! % Put the index entry in the margin if desired.
+! \ifx\SETmarginindex\relax\else
+! \insert\margin{\hbox{\vrule height8pt depth3pt width0pt #2}}%
+! \fi
+! {%
+! \count255=\lastpenalty
+! {%
+! \indexdummies % Must do this here, since \bf, etc expand at this stage
+! \escapechar=`\\
+! {%
+! \let\folio=0% We will expand all macros now EXCEPT \folio.
+! \def\rawbackslashxx{\indexbackslash}% \indexbackslash isn't defined now
+! % so it will be output as is; and it will print as backslash.
+! %
+! % First process the index-string with all font commands turned off
+! % to get the string to sort by.
+! {\indexnofonts \xdef\indexsorttmp{#2}}%
+! %
+! % Now produce the complete index entry, with both the sort key and the
+! % original text, including any font commands.
+! \toks0 = {#2}%
+! \edef\temp{%
+! \write\csname#1indfile\endcsname{%
+! \realbackslash entry{\indexsorttmp}{\folio}{\the\toks0}}%
+! }%
+! \temp
+! }%
+! }%
+! \penalty\count255
+! }%
+! }
+
+ \def\dosubind #1#2#3{%
+ {\count10=\lastpenalty %
+***************
+*** 2084,2117 ****
+
+ % Define the macros used in formatting output of the sorted index material.
+
+! % This is what you call to cause a particular index to get printed.
+! % Write
+! % @unnumbered Function Index
+! % @printindex fn
+!
+ \def\printindex{\parsearg\doprintindex}
+!
+! \def\doprintindex#1{%
+! \tex
+! \dobreak \chapheadingskip {10000}
+! \catcode`\%=\other\catcode`\&=\other\catcode`\#=\other
+! \catcode`\$=\other
+! \catcode`\~=\other
+! \indexbreaks
+ %
+! % The following don't help, since the chars were translated
+! % when the raw index was written, and their fonts were discarded
+! % due to \indexnofonts.
+! %\catcode`\"=\active
+! %\catcode`\^=\active
+! %\catcode`\_=\active
+! %\catcode`\|=\active
+! %\catcode`\<=\active
+! %\catcode`\>=\active
+! % %
+! \def\indexbackslash{\rawbackslashxx}
+! \indexfonts\rm \tolerance=9500 \advance\baselineskip -1pt
+! \begindoublecolumns
+ %
+ % See if the index file exists and is nonempty.
+ \openin 1 \jobname.#1s
+--- 2412,2427 ----
+
+ % Define the macros used in formatting output of the sorted index material.
+
+! % @printindex causes a particular index (the ??s file) to get printed.
+! % It does not print any chapter heading (usually an @unnumbered).
+! %
+ \def\printindex{\parsearg\doprintindex}
+! \def\doprintindex#1{\begingroup
+! \dobreak \chapheadingskip{10000}%
+ %
+! \indexfonts \rm
+! \tolerance = 9500
+! \indexbreaks
+ %
+ % See if the index file exists and is nonempty.
+ \openin 1 \jobname.#1s
+***************
+*** 2121,2127 ****
+ % index. The easiest way to prevent this problem is to make sure
+ % there is some text.
+ (Index is nonexistent)
+! \else
+ %
+ % If the index file exists but is empty, then \openin leaves \ifeof
+ % false. We have to make TeX try to read something from the file, so
+--- 2431,2437 ----
+ % index. The easiest way to prevent this problem is to make sure
+ % there is some text.
+ (Index is nonexistent)
+! \else
+ %
+ % If the index file exists but is empty, then \openin leaves \ifeof
+ % false. We have to make TeX try to read something from the file, so
+***************
+*** 2130,2142 ****
+ \ifeof 1
+ (Index is empty)
+ \else
+ \input \jobname.#1s
+ \fi
+ \fi
+ \closein 1
+! \enddoublecolumns
+! \Etex
+! }
+
+ % These macros are used by the sorted index file itself.
+ % Change them to control the appearance of the index.
+--- 2440,2459 ----
+ \ifeof 1
+ (Index is empty)
+ \else
++ % Index files are almost Texinfo source, but we use \ as the escape
++ % character. It would be better to use @, but that's too big a change
++ % to make right now.
++ \def\indexbackslash{\rawbackslashxx}%
++ \catcode`\\ = 0
++ \catcode`\@ = 11
++ \escapechar = `\\
++ \begindoublecolumns
+ \input \jobname.#1s
++ \enddoublecolumns
+ \fi
+ \fi
+ \closein 1
+! \endgroup}
+
+ % These macros are used by the sorted index file itself.
+ % Change them to control the appearance of the index.
+***************
+*** 2190,2196 ****
+ %
+ % Insert the text of the index entry. TeX will do line-breaking on it.
+ #1%
+! % The following is kluged to not output a line of dots in the index if
+ % there are no page numbers. The next person who breaks this will be
+ % cursed by a Unix daemon.
+ \def\tempa{{\rm }}%
+--- 2507,2513 ----
+ %
+ % Insert the text of the index entry. TeX will do line-breaking on it.
+ #1%
+! % The following is kludged to not output a line of dots in the index if
+ % there are no page numbers. The next person who breaks this will be
+ % cursed by a Unix daemon.
+ \def\tempa{{\rm }}%
+***************
+*** 2227,2260 ****
+ \noindent\hskip\secondaryindent\hbox{#1}\indexdotfill #2\par
+ }}
+
+! %% Define two-column mode, which is used in indexes.
+! %% Adapted from the TeXbook, page 416.
+! \catcode `\@=11
+
+ \newbox\partialpage
+-
+ \newdimen\doublecolumnhsize
+
+! \def\begindoublecolumns{\begingroup
+ % Grab any single-column material above us.
+! \output = {\global\setbox\partialpage
+! =\vbox{\unvbox255\kern -\topskip \kern \baselineskip}}%
+ \eject
+ %
+! % Now switch to the double-column output routine.
+! \output={\doublecolumnout}%
+ %
+ % Change the page size parameters. We could do this once outside this
+ % routine, in each of @smallbook, @afourpaper, and the default 8.5x11
+ % format, but then we repeat the same computation. Repeating a couple
+ % of assignments once per index is clearly meaningless for the
+! % execution time, so we may as well do it once.
+ %
+ % First we halve the line length, less a little for the gutter between
+ % the columns. We compute the gutter based on the line length, so it
+ % changes automatically with the paper format. The magic constant
+! % below is chosen so that the gutter has the same value (well, +- <
+! % 1pt) as it did when we hard-coded it.
+ %
+ % We put the result in a separate register, \doublecolumhsize, so we
+ % can restore it in \pagesofar, after \hsize itself has (potentially)
+--- 2544,2592 ----
+ \noindent\hskip\secondaryindent\hbox{#1}\indexdotfill #2\par
+ }}
+
+! % Define two-column mode, which we use to typeset indexes.
+! % Adapted from the TeXbook, page 416, which is to say,
+! % the manmac.tex format used to print the TeXbook itself.
+! \catcode`\@=11
+
+ \newbox\partialpage
+ \newdimen\doublecolumnhsize
+
+! \def\begindoublecolumns{\begingroup % ended by \enddoublecolumns
+ % Grab any single-column material above us.
+! \output = {\global\setbox\partialpage = \vbox{%
+! %
+! % Here is a possibility not foreseen in manmac: if we accumulate a
+! % whole lot of material, we might end up calling this \output
+! % routine twice in a row (see the doublecol-lose test, which is
+! % essentially a couple of indexes with @setchapternewpage off). In
+! % that case, we must prevent the second \partialpage from
+! % simply overwriting the first, causing us to lose the page.
+! % This will preserve it until a real output routine can ship it
+! % out. Generally, \partialpage will be empty when this runs and
+! % this will be a no-op.
+! \unvbox\partialpage
+! %
+! % Unvbox the main output page.
+! \unvbox255
+! \kern-\topskip \kern\baselineskip
+! }}%
+ \eject
+ %
+! % Use the double-column output routine for subsequent pages.
+! \output = {\doublecolumnout}%
+ %
+ % Change the page size parameters. We could do this once outside this
+ % routine, in each of @smallbook, @afourpaper, and the default 8.5x11
+ % format, but then we repeat the same computation. Repeating a couple
+ % of assignments once per index is clearly meaningless for the
+! % execution time, so we may as well do it in one place.
+ %
+ % First we halve the line length, less a little for the gutter between
+ % the columns. We compute the gutter based on the line length, so it
+ % changes automatically with the paper format. The magic constant
+! % below is chosen so that the gutter has the same value (well, +-<1pt)
+! % as it did when we hard-coded it.
+ %
+ % We put the result in a separate register, \doublecolumhsize, so we
+ % can restore it in \pagesofar, after \hsize itself has (potentially)
+***************
+*** 2268,2374 ****
+ % Double the \vsize as well. (We don't need a separate register here,
+ % since nobody clobbers \vsize.)
+ \vsize = 2\vsize
+- \doublecolumnpagegoal
+ }
+-
+- \def\enddoublecolumns{\eject \endgroup \pagegoal=\vsize \unvbox\partialpage}
+-
+- \def\doublecolumnsplit{\splittopskip=\topskip \splitmaxdepth=\maxdepth
+- \global\dimen@=\pageheight \global\advance\dimen@ by-\ht\partialpage
+- \global\setbox1=\vsplit255 to\dimen@ \global\setbox0=\vbox{\unvbox1}
+- \global\setbox3=\vsplit255 to\dimen@ \global\setbox2=\vbox{\unvbox3}
+- \ifdim\ht0>\dimen@ \setbox255=\vbox{\unvbox0\unvbox2} \global\setbox255=\copy5 \fi
+- \ifdim\ht2>\dimen@ \setbox255=\vbox{\unvbox0\unvbox2} \global\setbox255=\copy5 \fi
+- }
+- \def\doublecolumnpagegoal{%
+- \dimen@=\vsize \advance\dimen@ by-2\ht\partialpage \global\pagegoal=\dimen@
+- }
+- \def\pagesofar{\unvbox\partialpage %
+- \hsize=\doublecolumnhsize % have to restore this since output routine
+- \wd0=\hsize \wd2=\hsize \hbox to\pagewidth{\box0\hfil\box2}}
+ \def\doublecolumnout{%
+! \setbox5=\copy255
+! {\vbadness=10000 \doublecolumnsplit}
+! \ifvbox255
+! \setbox0=\vtop to\dimen@{\unvbox0}
+! \setbox2=\vtop to\dimen@{\unvbox2}
+! \onepageout\pagesofar \unvbox255 \penalty\outputpenalty
+! \else
+! \setbox0=\vbox{\unvbox5}
+! \ifvbox0
+! \dimen@=\ht0 \advance\dimen@ by\topskip \advance\dimen@ by-\baselineskip
+! \divide\dimen@ by2 \splittopskip=\topskip \splitmaxdepth=\maxdepth
+! {\vbadness=10000
+! \loop \global\setbox5=\copy0
+! \setbox1=\vsplit5 to\dimen@
+! \setbox3=\vsplit5 to\dimen@
+! \ifvbox5 \global\advance\dimen@ by1pt \repeat
+! \setbox0=\vbox to\dimen@{\unvbox1}
+! \setbox2=\vbox to\dimen@{\unvbox3}
+! \global\setbox\partialpage=\vbox{\pagesofar}
+! \doublecolumnpagegoal
+! }
+! \fi
+! \fi
+ }
+
+- \catcode `\@=\other
+ \message{sectioning,}
+ % Define chapters, sections, etc.
+
+! \newcount \chapno
+! \newcount \secno \secno=0
+! \newcount \subsecno \subsecno=0
+! \newcount \subsubsecno \subsubsecno=0
+
+ % This counter is funny since it counts through charcodes of letters A, B, ...
+! \newcount \appendixno \appendixno = `\@
+ \def\appendixletter{\char\the\appendixno}
+
+! \newwrite \contentsfile
+ % This is called from \setfilename.
+! \def\opencontents{\openout \contentsfile = \jobname.toc}
+
+ % Each @chapter defines this as the name of the chapter.
+ % page headings and footings can use it. @section does likewise
+
+ \def\thischapter{} \def\thissection{}
+! \def\seccheck#1{\if \pageno<0 %
+! \errmessage{@#1 not allowed after generating table of contents}\fi
+! %
+! }
+
+ \def\chapternofonts{%
+! \let\rawbackslash=\relax%
+! \let\frenchspacing=\relax%
+! \def\result{\realbackslash result}
+! \def\equiv{\realbackslash equiv}
+! \def\expansion{\realbackslash expansion}
+! \def\print{\realbackslash print}
+! \def\TeX{\realbackslash TeX}
+! \def\dots{\realbackslash dots}
+! \def\copyright{\realbackslash copyright}
+! \def\tt{\realbackslash tt}
+! \def\bf{\realbackslash bf }
+! \def\w{\realbackslash w}
+! \def\less{\realbackslash less}
+! \def\gtr{\realbackslash gtr}
+! \def\hat{\realbackslash hat}
+! \def\char{\realbackslash char}
+! \def\tclose##1{\realbackslash tclose {##1}}
+! \def\code##1{\realbackslash code {##1}}
+! \def\samp##1{\realbackslash samp {##1}}
+! \def\r##1{\realbackslash r {##1}}
+! \def\b##1{\realbackslash b {##1}}
+! \def\key##1{\realbackslash key {##1}}
+! \def\file##1{\realbackslash file {##1}}
+! \def\kbd##1{\realbackslash kbd {##1}}
+! % These are redefined because @smartitalic wouldn't work inside xdef.
+! \def\i##1{\realbackslash i {##1}}
+! \def\cite##1{\realbackslash cite {##1}}
+! \def\var##1{\realbackslash var {##1}}
+! \def\emph##1{\realbackslash emph {##1}}
+! \def\dfn##1{\realbackslash dfn {##1}}
+ }
+
+ \newcount\absseclevel % used to calculate proper heading level
+--- 2600,2709 ----
+ % Double the \vsize as well. (We don't need a separate register here,
+ % since nobody clobbers \vsize.)
+ \vsize = 2\vsize
+ }
+ \def\doublecolumnout{%
+! \splittopskip=\topskip \splitmaxdepth=\maxdepth
+! % Get the available space for the double columns -- the normal
+! % (undoubled) page height minus any material left over from the
+! % previous page.
+! \dimen@=\pageheight \advance\dimen@ by-\ht\partialpage
+! % box0 will be the left-hand column, box2 the right.
+! \setbox0=\vsplit255 to\dimen@ \setbox2=\vsplit255 to\dimen@
+! \onepageout\pagesofar
+! \unvbox255
+! \penalty\outputpenalty
+! }
+! \def\pagesofar{%
+! % Re-output the contents of the output page -- any previous material,
+! % followed by the two boxes we just split.
+! \unvbox\partialpage
+! \hsize = \doublecolumnhsize
+! \wd0=\hsize \wd2=\hsize \hbox to\pagewidth{\box0\hfil\box2}%
+ }
++ \def\enddoublecolumns{%
++ \output = {\balancecolumns}\eject % split what we have
++ \endgroup % started in \begindoublecolumns
++ %
++ % Back to normal single-column typesetting, but take account of the
++ % fact that we just accumulated some stuff on the output page.
++ \pagegoal = \vsize
++ }
++ \def\balancecolumns{%
++ % Called at the end of the double column material.
++ \setbox0 = \vbox{\unvbox255}%
++ \dimen@ = \ht0
++ \advance\dimen@ by \topskip
++ \advance\dimen@ by-\baselineskip
++ \divide\dimen@ by 2
++ \splittopskip = \topskip
++ % Loop until we get a decent breakpoint.
++ {\vbadness=10000 \loop
++ \global\setbox3=\copy0
++ \global\setbox1=\vsplit3 to\dimen@
++ \ifdim\ht3>\dimen@ \global\advance\dimen@ by1pt
++ \repeat}%
++ \setbox0=\vbox to\dimen@{\unvbox1}%
++ \setbox2=\vbox to\dimen@{\unvbox3}%
++ \pagesofar
++ }
++ \catcode`\@ = \other
++
+
+ \message{sectioning,}
+ % Define chapters, sections, etc.
+
+! \newcount\chapno
+! \newcount\secno \secno=0
+! \newcount\subsecno \subsecno=0
+! \newcount\subsubsecno \subsubsecno=0
+
+ % This counter is funny since it counts through charcodes of letters A, B, ...
+! \newcount\appendixno \appendixno = `\@
+ \def\appendixletter{\char\the\appendixno}
+
+! \newwrite\contentsfile
+ % This is called from \setfilename.
+! \def\opencontents{\openout\contentsfile = \jobname.toc }
+
+ % Each @chapter defines this as the name of the chapter.
+ % page headings and footings can use it. @section does likewise
+
+ \def\thischapter{} \def\thissection{}
+! \def\seccheck#1{\ifnum \pageno<0
+! \errmessage{@#1 not allowed after generating table of contents}%
+! \fi}
+
+ \def\chapternofonts{%
+! \let\rawbackslash=\relax
+! \let\frenchspacing=\relax
+! \def\result{\realbackslash result}%
+! \def\equiv{\realbackslash equiv}%
+! \def\expansion{\realbackslash expansion}%
+! \def\print{\realbackslash print}%
+! \def\TeX{\realbackslash TeX}%
+! \def\dots{\realbackslash dots}%
+! \def\copyright{\realbackslash copyright}%
+! \def\tt{\realbackslash tt}%
+! \def\bf{\realbackslash bf}%
+! \def\w{\realbackslash w}%
+! \def\less{\realbackslash less}%
+! \def\gtr{\realbackslash gtr}%
+! \def\hat{\realbackslash hat}%
+! \def\char{\realbackslash char}%
+! \def\tclose##1{\realbackslash tclose{##1}}%
+! \def\code##1{\realbackslash code{##1}}%
+! \def\samp##1{\realbackslash samp{##1}}%
+! \def\r##1{\realbackslash r{##1}}%
+! \def\b##1{\realbackslash b{##1}}%
+! \def\key##1{\realbackslash key{##1}}%
+! \def\file##1{\realbackslash file{##1}}%
+! \def\kbd##1{\realbackslash kbd{##1}}%
+! % These are redefined because @smartitalic wouldn't work inside xdef.
+! \def\i##1{\realbackslash i{##1}}%
+! \def\cite##1{\realbackslash cite{##1}}%
+! \def\var##1{\realbackslash var{##1}}%
+! \def\emph##1{\realbackslash emph{##1}}%
+! \def\dfn##1{\realbackslash dfn{##1}}%
+ }
+
+ \newcount\absseclevel % used to calculate proper heading level
+***************
+*** 2447,2453 ****
+ \def\chapteryyy #1{\numhead0{#1}} % normally numhead0 calls chapterzzz
+ \def\chapterzzz #1{\seccheck{chapter}%
+ \secno=0 \subsecno=0 \subsubsecno=0
+! \global\advance \chapno by 1 \message{Chapter \the\chapno}%
+ \chapmacro {#1}{\the\chapno}%
+ \gdef\thissection{#1}%
+ \gdef\thischaptername{#1}%
+--- 2782,2788 ----
+ \def\chapteryyy #1{\numhead0{#1}} % normally numhead0 calls chapterzzz
+ \def\chapterzzz #1{\seccheck{chapter}%
+ \secno=0 \subsecno=0 \subsubsecno=0
+! \global\advance \chapno by 1 \message{\putwordChapter \the\chapno}%
+ \chapmacro {#1}{\the\chapno}%
+ \gdef\thissection{#1}%
+ \gdef\thischaptername{#1}%
+***************
+*** 2455,2461 ****
+ % because we don't want its macros evaluated now.
+ \xdef\thischapter{\putwordChapter{} \the\chapno: \noexpand\thischaptername}%
+ {\chapternofonts%
+! \edef\temp{{\realbackslash chapentry {#1}{\the\chapno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \donoderef %
+--- 2790,2797 ----
+ % because we don't want its macros evaluated now.
+ \xdef\thischapter{\putwordChapter{} \the\chapno: \noexpand\thischaptername}%
+ {\chapternofonts%
+! \toks0 = {#1}%
+! \edef\temp{{\realbackslash chapentry{\the\toks0}{\the\chapno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \donoderef %
+***************
+*** 2474,2481 ****
+ \gdef\thischaptername{#1}%
+ \xdef\thischapter{\putwordAppendix{} \appendixletter: \noexpand\thischaptername}%
+ {\chapternofonts%
+! \edef\temp{{\realbackslash chapentry
+! {#1}{\putwordAppendix{} \appendixletter}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \appendixnoderef %
+--- 2810,2818 ----
+ \gdef\thischaptername{#1}%
+ \xdef\thischapter{\putwordAppendix{} \appendixletter: \noexpand\thischaptername}%
+ {\chapternofonts%
+! \toks0 = {#1}%
+! \edef\temp{{\realbackslash chapentry{\the\toks0}%
+! {\putwordAppendix{} \appendixletter}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \appendixnoderef %
+***************
+*** 2484,2489 ****
+--- 2821,2830 ----
+ \global\let\subsubsection = \appendixsubsubsec
+ }}
+
++ % @centerchap is like @unnumbered, but the heading is centered.
++ \outer\def\centerchap{\parsearg\centerchapyyy}
++ \def\centerchapyyy #1{{\let\unnumbchapmacro=\centerchapmacro \unnumberedyyy{#1}}}
++
+ \outer\def\top{\parsearg\unnumberedyyy}
+ \outer\def\unnumbered{\parsearg\unnumberedyyy}
+ \def\unnumberedyyy #1{\unnmhead0{#1}} % normally unnmhead0 calls unnumberedzzz
+***************
+*** 2505,2511 ****
+ \unnumbchapmacro {#1}%
+ \gdef\thischapter{#1}\gdef\thissection{#1}%
+ {\chapternofonts%
+! \edef\temp{{\realbackslash unnumbchapentry {#1}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \unnumbnoderef %
+--- 2846,2853 ----
+ \unnumbchapmacro {#1}%
+ \gdef\thischapter{#1}\gdef\thissection{#1}%
+ {\chapternofonts%
+! \toks0 = {#1}%
+! \edef\temp{{\realbackslash unnumbchapentry{\the\toks0}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \unnumbnoderef %
+***************
+*** 2520,2542 ****
+ \subsecno=0 \subsubsecno=0 \global\advance \secno by 1 %
+ \gdef\thissection{#1}\secheading {#1}{\the\chapno}{\the\secno}%
+ {\chapternofonts%
+ \edef\temp{{\realbackslash secentry %
+! {#1}{\the\chapno}{\the\secno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \donoderef %
+ \penalty 10000 %
+ }}
+
+! \outer\def\appenixsection{\parsearg\appendixsecyyy}
+ \outer\def\appendixsec{\parsearg\appendixsecyyy}
+ \def\appendixsecyyy #1{\apphead1{#1}} % normally calls appendixsectionzzz
+ \def\appendixsectionzzz #1{\seccheck{appendixsection}%
+ \subsecno=0 \subsubsecno=0 \global\advance \secno by 1 %
+ \gdef\thissection{#1}\secheading {#1}{\appendixletter}{\the\secno}%
+ {\chapternofonts%
+ \edef\temp{{\realbackslash secentry %
+! {#1}{\appendixletter}{\the\secno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \appendixnoderef %
+--- 2862,2886 ----
+ \subsecno=0 \subsubsecno=0 \global\advance \secno by 1 %
+ \gdef\thissection{#1}\secheading {#1}{\the\chapno}{\the\secno}%
+ {\chapternofonts%
++ \toks0 = {#1}%
+ \edef\temp{{\realbackslash secentry %
+! {\the\toks0}{\the\chapno}{\the\secno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \donoderef %
+ \penalty 10000 %
+ }}
+
+! \outer\def\appendixsection{\parsearg\appendixsecyyy}
+ \outer\def\appendixsec{\parsearg\appendixsecyyy}
+ \def\appendixsecyyy #1{\apphead1{#1}} % normally calls appendixsectionzzz
+ \def\appendixsectionzzz #1{\seccheck{appendixsection}%
+ \subsecno=0 \subsubsecno=0 \global\advance \secno by 1 %
+ \gdef\thissection{#1}\secheading {#1}{\appendixletter}{\the\secno}%
+ {\chapternofonts%
++ \toks0 = {#1}%
+ \edef\temp{{\realbackslash secentry %
+! {\the\toks0}{\appendixletter}{\the\secno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \appendixnoderef %
+***************
+*** 2548,2554 ****
+ \def\unnumberedseczzz #1{\seccheck{unnumberedsec}%
+ \plainsecheading {#1}\gdef\thissection{#1}%
+ {\chapternofonts%
+! \edef\temp{{\realbackslash unnumbsecentry{#1}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \unnumbnoderef %
+--- 2892,2899 ----
+ \def\unnumberedseczzz #1{\seccheck{unnumberedsec}%
+ \plainsecheading {#1}\gdef\thissection{#1}%
+ {\chapternofonts%
+! \toks0 = {#1}%
+! \edef\temp{{\realbackslash unnumbsecentry{\the\toks0}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \unnumbnoderef %
+***************
+*** 2561,2568 ****
+ \gdef\thissection{#1}\subsubsecno=0 \global\advance \subsecno by 1 %
+ \subsecheading {#1}{\the\chapno}{\the\secno}{\the\subsecno}%
+ {\chapternofonts%
+ \edef\temp{{\realbackslash subsecentry %
+! {#1}{\the\chapno}{\the\secno}{\the\subsecno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \donoderef %
+--- 2906,2914 ----
+ \gdef\thissection{#1}\subsubsecno=0 \global\advance \subsecno by 1 %
+ \subsecheading {#1}{\the\chapno}{\the\secno}{\the\subsecno}%
+ {\chapternofonts%
++ \toks0 = {#1}%
+ \edef\temp{{\realbackslash subsecentry %
+! {\the\toks0}{\the\chapno}{\the\secno}{\the\subsecno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \donoderef %
+***************
+*** 2575,2582 ****
+ \gdef\thissection{#1}\subsubsecno=0 \global\advance \subsecno by 1 %
+ \subsecheading {#1}{\appendixletter}{\the\secno}{\the\subsecno}%
+ {\chapternofonts%
+ \edef\temp{{\realbackslash subsecentry %
+! {#1}{\appendixletter}{\the\secno}{\the\subsecno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \appendixnoderef %
+--- 2921,2929 ----
+ \gdef\thissection{#1}\subsubsecno=0 \global\advance \subsecno by 1 %
+ \subsecheading {#1}{\appendixletter}{\the\secno}{\the\subsecno}%
+ {\chapternofonts%
++ \toks0 = {#1}%
+ \edef\temp{{\realbackslash subsecentry %
+! {\the\toks0}{\appendixletter}{\the\secno}{\the\subsecno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \appendixnoderef %
+***************
+*** 2586,2594 ****
+ \outer\def\unnumberedsubsec{\parsearg\unnumberedsubsecyyy}
+ \def\unnumberedsubsecyyy #1{\unnmhead2{#1}} %normally calls unnumberedsubseczzz
+ \def\unnumberedsubseczzz #1{\seccheck{unnumberedsubsec}%
+! \plainsecheading {#1}\gdef\thissection{#1}%
+ {\chapternofonts%
+! \edef\temp{{\realbackslash unnumbsubsecentry{#1}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \unnumbnoderef %
+--- 2933,2942 ----
+ \outer\def\unnumberedsubsec{\parsearg\unnumberedsubsecyyy}
+ \def\unnumberedsubsecyyy #1{\unnmhead2{#1}} %normally calls unnumberedsubseczzz
+ \def\unnumberedsubseczzz #1{\seccheck{unnumberedsubsec}%
+! \plainsubsecheading {#1}\gdef\thissection{#1}%
+ {\chapternofonts%
+! \toks0 = {#1}%
+! \edef\temp{{\realbackslash unnumbsubsecentry{\the\toks0}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \unnumbnoderef %
+***************
+*** 2602,2609 ****
+ \subsubsecheading {#1}
+ {\the\chapno}{\the\secno}{\the\subsecno}{\the\subsubsecno}%
+ {\chapternofonts%
+! \edef\temp{{\realbackslash subsubsecentry %
+! {#1}
+ {\the\chapno}{\the\secno}{\the\subsecno}{\the\subsubsecno}
+ {\noexpand\folio}}}%
+ \escapechar=`\\%
+--- 2950,2957 ----
+ \subsubsecheading {#1}
+ {\the\chapno}{\the\secno}{\the\subsecno}{\the\subsubsecno}%
+ {\chapternofonts%
+! \toks0 = {#1}%
+! \edef\temp{{\realbackslash subsubsecentry{\the\toks0}
+ {\the\chapno}{\the\secno}{\the\subsecno}{\the\subsubsecno}
+ {\noexpand\folio}}}%
+ \escapechar=`\\%
+***************
+*** 2619,2625 ****
+ \subsubsecheading {#1}
+ {\appendixletter}{\the\secno}{\the\subsecno}{\the\subsubsecno}%
+ {\chapternofonts%
+! \edef\temp{{\realbackslash subsubsecentry{#1}%
+ {\appendixletter}
+ {\the\secno}{\the\subsecno}{\the\subsubsecno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+--- 2967,2974 ----
+ \subsubsecheading {#1}
+ {\appendixletter}{\the\secno}{\the\subsecno}{\the\subsubsecno}%
+ {\chapternofonts%
+! \toks0 = {#1}%
+! \edef\temp{{\realbackslash subsubsecentry{\the\toks0}%
+ {\appendixletter}
+ {\the\secno}{\the\subsecno}{\the\subsubsecno}{\noexpand\folio}}}%
+ \escapechar=`\\%
+***************
+*** 2631,2639 ****
+ \outer\def\unnumberedsubsubsec{\parsearg\unnumberedsubsubsecyyy}
+ \def\unnumberedsubsubsecyyy #1{\unnmhead3{#1}} %normally unnumberedsubsubseczzz
+ \def\unnumberedsubsubseczzz #1{\seccheck{unnumberedsubsubsec}%
+! \plainsecheading {#1}\gdef\thissection{#1}%
+ {\chapternofonts%
+! \edef\temp{{\realbackslash unnumbsubsubsecentry{#1}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \unnumbnoderef %
+--- 2980,2989 ----
+ \outer\def\unnumberedsubsubsec{\parsearg\unnumberedsubsubsecyyy}
+ \def\unnumberedsubsubsecyyy #1{\unnmhead3{#1}} %normally unnumberedsubsubseczzz
+ \def\unnumberedsubsubseczzz #1{\seccheck{unnumberedsubsubsec}%
+! \plainsubsubsecheading {#1}\gdef\thissection{#1}%
+ {\chapternofonts%
+! \toks0 = {#1}%
+! \edef\temp{{\realbackslash unnumbsubsubsecentry{\the\toks0}{\noexpand\folio}}}%
+ \escapechar=`\\%
+ \write \contentsfile \temp %
+ \unnumbnoderef %
+***************
+*** 2669,2678 ****
+
+ % NOTE on use of \vbox for chapter headings, section headings, and
+ % such:
+! % 1) We use \vbox rather than the earlier \line to permit
+! % overlong headings to fold.
+! % 2) \hyphenpenalty is set to 10000 because hyphenation in a
+! % heading is obnoxious; this forbids it.
+ % 3) Likewise, headings look best if no \parindent is used, and
+ % if justification is not attempted. Hence \raggedright.
+
+--- 3019,3028 ----
+
+ % NOTE on use of \vbox for chapter headings, section headings, and
+ % such:
+! % 1) We use \vbox rather than the earlier \line to permit
+! % overlong headings to fold.
+! % 2) \hyphenpenalty is set to 10000 because hyphenation in a
+! % heading is obnoxious; this forbids it.
+ % 3) Likewise, headings look best if no \parindent is used, and
+ % if justification is not attempted. Hence \raggedright.
+
+***************
+*** 2690,2700 ****
+ \parindent=0pt\raggedright
+ \rm #1\hfill}}\bigskip \par\penalty 200}
+
+! \def\heading{\parsearg\secheadingi}
+!
+! \def\subheading{\parsearg\subsecheadingi}
+!
+! \def\subsubheading{\parsearg\subsubsecheadingi}
+
+ % These macros generate a chapter, section, etc. heading only
+ % (including whitespace, linebreaking, etc. around it),
+--- 3040,3049 ----
+ \parindent=0pt\raggedright
+ \rm #1\hfill}}\bigskip \par\penalty 200}
+
+! % @heading, @subheading, @subsubheading.
+! \def\heading{\parsearg\plainsecheading}
+! \def\subheading{\parsearg\plainsubsecheading}
+! \def\subsubheading{\parsearg\plainsubsubsecheading}
+
+ % These macros generate a chapter, section, etc. heading only
+ % (including whitespace, linebreaking, etc. around it),
+***************
+*** 2708,2714 ****
+ %%% Define plain chapter starts, and page on/off switching for it
+ % Parameter controlling skip before chapter headings (if needed)
+
+! \newskip \chapheadingskip \chapheadingskip = 30pt plus 8pt minus 4pt
+
+ \def\chapbreak{\dobreak \chapheadingskip {-4000}}
+ \def\chappager{\par\vfill\supereject}
+--- 3057,3063 ----
+ %%% Define plain chapter starts, and page on/off switching for it
+ % Parameter controlling skip before chapter headings (if needed)
+
+! \newskip\chapheadingskip
+
+ \def\chapbreak{\dobreak \chapheadingskip {-4000}}
+ \def\chappager{\par\vfill\supereject}
+***************
+*** 2717,2731 ****
+--- 3066,3083 ----
+ \def\setchapternewpage #1 {\csname CHAPPAG#1\endcsname}
+
+ \def\CHAPPAGoff{
++ \global\let\contentsalignmacro = \chappager
+ \global\let\pchapsepmacro=\chapbreak
+ \global\let\pagealignmacro=\chappager}
+
+ \def\CHAPPAGon{
++ \global\let\contentsalignmacro = \chappager
+ \global\let\pchapsepmacro=\chappager
+ \global\let\pagealignmacro=\chappager
+ \global\def\HEADINGSon{\HEADINGSsingle}}
+
+ \def\CHAPPAGodd{
++ \global\let\contentsalignmacro = \chapoddpage
+ \global\let\pchapsepmacro=\chapoddpage
+ \global\let\pagealignmacro=\chapoddpage
+ \global\def\HEADINGSon{\HEADINGSdouble}}
+***************
+*** 2734,2758 ****
+
+ \def\CHAPFplain{
+ \global\let\chapmacro=\chfplain
+! \global\let\unnumbchapmacro=\unnchfplain}
+
+! \def\chfplain #1#2{%
+ \pchapsepmacro
+ {%
+! \chapfonts \vbox{\hyphenpenalty=10000\tolerance=5000
+! \parindent=0pt\raggedright
+! \rm #2\enspace #1}%
+ }%
+! \bigskip
+! \penalty5000
+ }
+
+! \def\unnchfplain #1{%
+! \pchapsepmacro %
+! {\chapfonts \vbox{\hyphenpenalty=10000\tolerance=5000
+! \parindent=0pt\raggedright
+! \rm #1\hfill}}\bigskip \par\penalty 10000 %
+! }
+ \CHAPFplain % The default
+
+ \def\unnchfopen #1{%
+--- 3086,3124 ----
+
+ \def\CHAPFplain{
+ \global\let\chapmacro=\chfplain
+! \global\let\unnumbchapmacro=\unnchfplain
+! \global\let\centerchapmacro=\centerchfplain}
+
+! % Plain chapter opening.
+! % #1 is the text, #2 the chapter number or empty if unnumbered.
+! \def\chfplain#1#2{%
+ \pchapsepmacro
+ {%
+! \chapfonts \rm
+! \def\chapnum{#2}%
+! \setbox0 = \hbox{#2\ifx\chapnum\empty\else\enspace\fi}%
+! \vbox{\hyphenpenalty=10000 \tolerance=5000 \parindent=0pt \raggedright
+! \hangindent = \wd0 \centerparametersmaybe
+! \unhbox0 #1\par}%
+ }%
+! \nobreak\bigskip % no page break after a chapter title
+! \nobreak
+ }
+
+! % Plain opening for unnumbered.
+! \def\unnchfplain#1{\chfplain{#1}{}}
+!
+! % @centerchap -- centered and unnumbered.
+! \let\centerparametersmaybe = \relax
+! \def\centerchfplain#1{{%
+! \def\centerparametersmaybe{%
+! \advance\rightskip by 3\rightskip
+! \leftskip = \rightskip
+! \parfillskip = 0pt
+! }%
+! \chfplain{#1}{}%
+! }}
+!
+ \CHAPFplain % The default
+
+ \def\unnchfopen #1{%
+***************
+*** 2766,2839 ****
+ \par\penalty 5000 %
+ }
+
+ \def\CHAPFopen{
+ \global\let\chapmacro=\chfopen
+! \global\let\unnumbchapmacro=\unnchfopen}
+
+- % Parameter controlling skip before section headings.
+-
+- \newskip \subsecheadingskip \subsecheadingskip = 17pt plus 8pt minus 4pt
+- \def\subsecheadingbreak{\dobreak \subsecheadingskip {-500}}
+
+! \newskip \secheadingskip \secheadingskip = 21pt plus 8pt minus 4pt
+ \def\secheadingbreak{\dobreak \secheadingskip {-1000}}
+
+! % @paragraphindent is defined for the Info formatting commands only.
+! \let\paragraphindent=\comment
+
+! % Section fonts are the base font at magstep2, which produces
+! % a size a bit more than 14 points in the default situation.
+
+- \def\secheading #1#2#3{\secheadingi {#2.#3\enspace #1}}
+- \def\plainsecheading #1{\secheadingi {#1}}
+- \def\secheadingi #1{{\advance \secheadingskip by \parskip %
+- \secheadingbreak}%
+- {\secfonts \vbox{\hyphenpenalty=10000\tolerance=5000
+- \parindent=0pt\raggedright
+- \rm #1\hfill}}%
+- \ifdim \parskip<10pt \kern 10pt\kern -\parskip\fi \penalty 10000 }
+-
+-
+- % Subsection fonts are the base font at magstep1,
+- % which produces a size of 12 points.
+-
+- \def\subsecheading #1#2#3#4{\subsecheadingi {#2.#3.#4\enspace #1}}
+- \def\subsecheadingi #1{{\advance \subsecheadingskip by \parskip %
+- \subsecheadingbreak}%
+- {\subsecfonts \vbox{\hyphenpenalty=10000\tolerance=5000
+- \parindent=0pt\raggedright
+- \rm #1\hfill}}%
+- \ifdim \parskip<10pt \kern 10pt\kern -\parskip\fi \penalty 10000 }
+-
+- \def\subsubsecfonts{\subsecfonts} % Maybe this should change:
+- % Perhaps make sssec fonts scaled
+- % magstep half
+- \def\subsubsecheading #1#2#3#4#5{\subsubsecheadingi {#2.#3.#4.#5\enspace #1}}
+- \def\subsubsecheadingi #1{{\advance \subsecheadingskip by \parskip %
+- \subsecheadingbreak}%
+- {\subsubsecfonts \vbox{\hyphenpenalty=10000\tolerance=5000
+- \parindent=0pt\raggedright
+- \rm #1\hfill}}%
+- \ifdim \parskip<10pt \kern 10pt\kern -\parskip\fi \penalty 10000}
+
+
+- \message{toc printing,}
+
+ % Finish up the main text and prepare to read what we've written
+ % to \contentsfile.
+
+ \newskip\contentsrightmargin \contentsrightmargin=1in
+ \def\startcontents#1{%
+! \pagealignmacro
+ \immediate\closeout \contentsfile
+ \ifnum \pageno>0
+! \pageno = -1 % Request roman numbered pages.
+ \fi
+ % Don't need to put `Contents' or `Short Contents' in the headline.
+ % It is abundantly clear what they are.
+ \unnumbchapmacro{#1}\def\thischapter{}%
+! \begingroup % Set up to handle contents files properly.
+ \catcode`\\=0 \catcode`\{=1 \catcode`\}=2 \catcode`\@=11
+ \raggedbottom % Worry more about breakpoints than the bottom.
+ \advance\hsize by -\contentsrightmargin % Don't use the full line length.
+ }
+--- 3132,3214 ----
+ \par\penalty 5000 %
+ }
+
++ \def\centerchfopen #1{%
++ \chapoddpage {\chapfonts \vbox{\hyphenpenalty=10000\tolerance=5000
++ \parindent=0pt
++ \hfill {\rm #1}\hfill}}\bigskip \par\penalty 10000 %
++ }
++
+ \def\CHAPFopen{
+ \global\let\chapmacro=\chfopen
+! \global\let\unnumbchapmacro=\unnchfopen
+! \global\let\centerchapmacro=\centerchfopen}
+
+
+! % Section titles.
+! \newskip\secheadingskip
+ \def\secheadingbreak{\dobreak \secheadingskip {-1000}}
++ \def\secheading#1#2#3{\sectionheading{sec}{#2.#3}{#1}}
++ \def\plainsecheading#1{\sectionheading{sec}{}{#1}}
+
+! % Subsection titles.
+! \newskip \subsecheadingskip
+! \def\subsecheadingbreak{\dobreak \subsecheadingskip {-500}}
+! \def\subsecheading#1#2#3#4{\sectionheading{subsec}{#2.#3.#4}{#1}}
+! \def\plainsubsecheading#1{\sectionheading{subsec}{}{#1}}
+
+! % Subsubsection titles.
+! \let\subsubsecheadingskip = \subsecheadingskip
+! \let\subsubsecheadingbreak = \subsecheadingbreak
+! \def\subsubsecheading#1#2#3#4#5{\sectionheading{subsubsec}{#2.#3.#4.#5}{#1}}
+! \def\plainsubsubsecheading#1{\sectionheading{subsubsec}{}{#1}}
+
+
++ % Print any size section title.
++ %
++ % #1 is the section type (sec/subsec/subsubsec), #2 is the section
++ % number (maybe empty), #3 the text.
++ \def\sectionheading#1#2#3{%
++ {%
++ \expandafter\advance\csname #1headingskip\endcsname by \parskip
++ \csname #1headingbreak\endcsname
++ }%
++ {%
++ % Switch to the right set of fonts.
++ \csname #1fonts\endcsname \rm
++ %
++ % Only insert the separating space if we have a section number.
++ \def\secnum{#2}%
++ \setbox0 = \hbox{#2\ifx\secnum\empty\else\enspace\fi}%
++ %
++ \vbox{\hyphenpenalty=10000 \tolerance=5000 \parindent=0pt \raggedright
++ \hangindent = \wd0 % zero if no section number
++ \unhbox0 #3}%
++ }%
++ \ifdim\parskip<10pt \nobreak\kern10pt\nobreak\kern-\parskip\fi \nobreak
++ }
+
+
++ \message{toc printing,}
+ % Finish up the main text and prepare to read what we've written
+ % to \contentsfile.
+
+ \newskip\contentsrightmargin \contentsrightmargin=1in
+ \def\startcontents#1{%
+! % If @setchapternewpage on, and @headings double, the contents should
+! % start on an odd page, unlike chapters. Thus, we maintain
+! % \contentsalignmacro in parallel with \pagealignmacro.
+! % From: Torbjorn Granlund <tege@matematik.su.se>
+! \contentsalignmacro
+ \immediate\closeout \contentsfile
+ \ifnum \pageno>0
+! \pageno = -1 % Request roman numbered pages.
+ \fi
+ % Don't need to put `Contents' or `Short Contents' in the headline.
+ % It is abundantly clear what they are.
+ \unnumbchapmacro{#1}\def\thischapter{}%
+! \begingroup % Set up to handle contents files properly.
+ \catcode`\\=0 \catcode`\{=1 \catcode`\}=2 \catcode`\@=11
++ \catcode`\^=7 % to see ^^e4 as \"a etc. juha@piuha.ydi.vtt.fi
+ \raggedbottom % Worry more about breakpoints than the bottom.
+ \advance\hsize by -\contentsrightmargin % Don't use the full line length.
+ }
+***************
+*** 2857,2862 ****
+--- 3232,3238 ----
+ \secfonts
+ \let\rm=\shortcontrm \let\bf=\shortcontbf \let\sl=\shortcontsl
+ \rm
++ \hyphenpenalty = 10000
+ \advance\baselineskip by 1pt % Open it up a little.
+ \def\secentry ##1##2##3##4{}
+ \def\unnumbsecentry ##1##2{}
+***************
+*** 2900,2906 ****
+ % This space should be plenty, since a single number is .5em, and the
+ % widest letter (M) is 1em, at least in the Computer Modern fonts.
+ % (This space doesn't include the extra space that gets added after
+! % the label; that gets put in in \shortchapentry above.)
+ \advance\dimen0 by 1.1em
+ \hbox to \dimen0{#1\hfil}%
+ }
+--- 3276,3282 ----
+ % This space should be plenty, since a single number is .5em, and the
+ % widest letter (M) is 1em, at least in the Computer Modern fonts.
+ % (This space doesn't include the extra space that gets added after
+! % the label; that gets put in by \shortchapentry above.)
+ \advance\dimen0 by 1.1em
+ \hbox to \dimen0{#1\hfil}%
+ }
+***************
+*** 2921,2942 ****
+ \dosubsubsecentry{#2.#3.#4.#5\labelspace#1}{#6}}
+ \def\unnumbsubsubsecentry#1#2{\dosubsubsecentry{#1}{#2}}
+
+-
+ % This parameter controls the indentation of the various levels.
+ \newdimen\tocindent \tocindent = 3pc
+
+ % Now for the actual typesetting. In all these, #1 is the text and #2 is the
+ % page number.
+ %
+! % If the toc has to be broken over pages, we would want to be at chapters
+ % if at all possible; hence the \penalty.
+ \def\dochapentry#1#2{%
+! \penalty-300 \vskip\baselineskip
+ \begingroup
+ \chapentryfonts
+ \tocentry{#1}{\dopageno{#2}}%
+ \endgroup
+! \nobreak\vskip .25\baselineskip
+ }
+
+ \def\dosecentry#1#2{\begingroup
+--- 3297,3317 ----
+ \dosubsubsecentry{#2.#3.#4.#5\labelspace#1}{#6}}
+ \def\unnumbsubsubsecentry#1#2{\dosubsubsecentry{#1}{#2}}
+
+ % This parameter controls the indentation of the various levels.
+ \newdimen\tocindent \tocindent = 3pc
+
+ % Now for the actual typesetting. In all these, #1 is the text and #2 is the
+ % page number.
+ %
+! % If the toc has to be broken over pages, we want it to be at chapters
+ % if at all possible; hence the \penalty.
+ \def\dochapentry#1#2{%
+! \penalty-300 \vskip1\baselineskip plus.33\baselineskip minus.25\baselineskip
+ \begingroup
+ \chapentryfonts
+ \tocentry{#1}{\dopageno{#2}}%
+ \endgroup
+! \nobreak\vskip .25\baselineskip plus.1\baselineskip
+ }
+
+ \def\dosecentry#1#2{\begingroup
+***************
+*** 2959,2967 ****
+ % can't do that in the \entry macro, since index entries might consist
+ % of hyphenated-identifiers-that-do-not-fit-on-a-line-and-nothing-else.)
+ %
+ \def\tocentry#1#2{\begingroup
+! \hyphenpenalty = 10000
+! \entry{#1}{#2}%
+ \endgroup}
+
+ % Space between chapter (or whatever) number and the title.
+--- 3334,3343 ----
+ % can't do that in the \entry macro, since index entries might consist
+ % of hyphenated-identifiers-that-do-not-fit-on-a-line-and-nothing-else.)
+ %
++ % \turnoffactive is for the sake of @" used for umlauts.
+ \def\tocentry#1#2{\begingroup
+! \vskip 0pt plus1pt % allow a little stretch for the sake of nice page breaks
+! \entry{\turnoffactive #1}{\turnoffactive #2}%
+ \endgroup}
+
+ % Space between chapter (or whatever) number and the title.
+***************
+*** 2985,2992 ****
+ \newbox\pushcharbox \newbox\bullbox
+ \newbox\equivbox \newbox\errorbox
+
+- \let\ptexequiv = \equiv
+-
+ %{\tentt
+ %\global\setbox\dblarrowbox = \hbox to 1em{\hfil$\Rightarrow$\hfil}
+ %\global\setbox\longdblarrowbox = \hbox to 1em{\hfil$\mapsto$\hfil}
+--- 3361,3366 ----
+***************
+*** 2997,3008 ****
+ % depth .1ex\hfil}
+ %}
+
+ \def\point{$\star$}
+-
+ \def\result{\leavevmode\raise.15ex\hbox to 1em{\hfil$\Rightarrow$\hfil}}
+ \def\expansion{\leavevmode\raise.1ex\hbox to 1em{\hfil$\mapsto$\hfil}}
+ \def\print{\leavevmode\lower.1ex\hbox to 1em{\hfil$\dashv$\hfil}}
+-
+ \def\equiv{\leavevmode\lower.1ex\hbox to 1em{\hfil$\ptexequiv$\hfil}}
+
+ % Adapted from the TeXbook's \boxit.
+--- 3371,3381 ----
+ % depth .1ex\hfil}
+ %}
+
++ % @point{}, @result{}, @expansion{}, @print{}, @equiv{}.
+ \def\point{$\star$}
+ \def\result{\leavevmode\raise.15ex\hbox to 1em{\hfil$\Rightarrow$\hfil}}
+ \def\expansion{\leavevmode\raise.1ex\hbox to 1em{\hfil$\mapsto$\hfil}}
+ \def\print{\leavevmode\lower.1ex\hbox to 1em{\hfil$\dashv$\hfil}}
+ \def\equiv{\leavevmode\lower.1ex\hbox to 1em{\hfil$\ptexequiv$\hfil}}
+
+ % Adapted from the TeXbook's \boxit.
+***************
+*** 3034,3040 ****
+ \catcode `\$=3 \catcode `\&=4 \catcode `\#=6
+ \catcode `\^=7 \catcode `\_=8 \catcode `\~=13 \let~=\tie
+ \catcode `\%=14
+! \catcode 43=12
+ \catcode`\"=12
+ \catcode`\==12
+ \catcode`\|=12
+--- 3407,3413 ----
+ \catcode `\$=3 \catcode `\&=4 \catcode `\#=6
+ \catcode `\^=7 \catcode `\_=8 \catcode `\~=13 \let~=\tie
+ \catcode `\%=14
+! \catcode 43=12 % plus
+ \catcode`\"=12
+ \catcode`\==12
+ \catcode`\|=12
+***************
+*** 3042,3057 ****
+ \catcode`\>=12
+ \escapechar=`\\
+ %
+! \let\~=\ptextilde
+ \let\{=\ptexlbrace
+ \let\}=\ptexrbrace
+ \let\.=\ptexdot
+ \let\*=\ptexstar
+ \let\dots=\ptexdots
+ \def\@{@}%
+ \let\bullet=\ptexbullet
+! \let\b=\ptexb \let\c=\ptexc \let\i=\ptexi \let\t=\ptext \let\l=\ptexl
+! \let\L=\ptexL
+ %
+ \let\Etex=\endgroup}
+
+--- 3415,3431 ----
+ \catcode`\>=12
+ \escapechar=`\\
+ %
+! \let\,=\ptexcomma
+ \let\{=\ptexlbrace
+ \let\}=\ptexrbrace
+ \let\.=\ptexdot
+ \let\*=\ptexstar
+ \let\dots=\ptexdots
++ \def\endldots{\mathinner{\ldots\ldots\ldots\ldots}}%
++ \def\enddots{\relax\ifmmode\endldots\else$\mathsurround=0pt \endldots\,$\fi}%
+ \def\@{@}%
+ \let\bullet=\ptexbullet
+! \let\b=\ptexb \let\c=\ptexc \let\i=\ptexi \let\t=\ptext
+ %
+ \let\Etex=\endgroup}
+
+***************
+*** 3110,3159 ****
+ \def\cbl{{\circle\char'012\hskip -6pt}}
+ \def\cbr{{\hskip 6pt\circle\char'011}}
+ \def\carttop{\hbox to \cartouter{\hskip\lskip
+! \ctl\leaders\hrule height\circthick\hfil\ctr
+! \hskip\rskip}}
+ \def\cartbot{\hbox to \cartouter{\hskip\lskip
+! \cbl\leaders\hrule height\circthick\hfil\cbr
+! \hskip\rskip}}
+ %
+ \newskip\lskip\newskip\rskip
+
+ \long\def\cartouche{%
+ \begingroup
+! \lskip=\leftskip \rskip=\rightskip
+! \leftskip=0pt\rightskip=0pt %we want these *outside*.
+! \cartinner=\hsize \advance\cartinner by-\lskip
+! \advance\cartinner by-\rskip
+! \cartouter=\hsize
+! \advance\cartouter by 18pt % allow for 3pt kerns on either
+! % side, and for 6pt waste from
+! % each corner char
+! \normbskip=\baselineskip \normpskip=\parskip \normlskip=\lineskip
+! % Flag to tell @lisp, etc., not to narrow margin.
+! \let\nonarrowing=\comment
+! \vbox\bgroup
+! \baselineskip=0pt\parskip=0pt\lineskip=0pt
+! \carttop
+! \hbox\bgroup
+! \hskip\lskip
+! \vrule\kern3pt
+! \vbox\bgroup
+! \hsize=\cartinner
+! \kern3pt
+! \begingroup
+! \baselineskip=\normbskip
+! \lineskip=\normlskip
+! \parskip=\normpskip
+! \vskip -\parskip
+ \def\Ecartouche{%
+! \endgroup
+! \kern3pt
+! \egroup
+! \kern3pt\vrule
+! \hskip\rskip
+! \egroup
+! \cartbot
+! \egroup
+ \endgroup
+ }}
+
+--- 3484,3533 ----
+ \def\cbl{{\circle\char'012\hskip -6pt}}
+ \def\cbr{{\hskip 6pt\circle\char'011}}
+ \def\carttop{\hbox to \cartouter{\hskip\lskip
+! \ctl\leaders\hrule height\circthick\hfil\ctr
+! \hskip\rskip}}
+ \def\cartbot{\hbox to \cartouter{\hskip\lskip
+! \cbl\leaders\hrule height\circthick\hfil\cbr
+! \hskip\rskip}}
+ %
+ \newskip\lskip\newskip\rskip
+
+ \long\def\cartouche{%
+ \begingroup
+! \lskip=\leftskip \rskip=\rightskip
+! \leftskip=0pt\rightskip=0pt %we want these *outside*.
+! \cartinner=\hsize \advance\cartinner by-\lskip
+! \advance\cartinner by-\rskip
+! \cartouter=\hsize
+! \advance\cartouter by 18pt % allow for 3pt kerns on either
+! % side, and for 6pt waste from
+! % each corner char
+! \normbskip=\baselineskip \normpskip=\parskip \normlskip=\lineskip
+! % Flag to tell @lisp, etc., not to narrow margin.
+! \let\nonarrowing=\comment
+! \vbox\bgroup
+! \baselineskip=0pt\parskip=0pt\lineskip=0pt
+! \carttop
+! \hbox\bgroup
+! \hskip\lskip
+! \vrule\kern3pt
+! \vbox\bgroup
+! \hsize=\cartinner
+! \kern3pt
+! \begingroup
+! \baselineskip=\normbskip
+! \lineskip=\normlskip
+! \parskip=\normpskip
+! \vskip -\parskip
+ \def\Ecartouche{%
+! \endgroup
+! \kern3pt
+! \egroup
+! \kern3pt\vrule
+! \hskip\rskip
+! \egroup
+! \cartbot
+! \egroup
+ \endgroup
+ }}
+
+***************
+*** 3216,3223 ****
+ \let\Esmalllisp = \nonfillfinish
+ \let\Esmallexample = \nonfillfinish
+ %
+! % Smaller interline space and fonts for small examples.
+! \setleading{10pt}%
+ \indexfonts \tt
+ \rawbackslash % make \ output the \ character from the current font (tt)
+ \gobble
+--- 3590,3596 ----
+ \let\Esmalllisp = \nonfillfinish
+ \let\Esmallexample = \nonfillfinish
+ %
+! % Smaller fonts for small examples.
+ \indexfonts \tt
+ \rawbackslash % make \ output the \ character from the current font (tt)
+ \gobble
+***************
+*** 3306,3324 ****
+
+ \gdef\functionparens{\boldbrax\let&=\amprm\parencount=0 }
+ \gdef\boldbrax{\let(=\opnr\let)=\clnr\let[=\lbrb\let]=\rbrb}
+
+ % Definitions of (, ) and & used in args for functions.
+ % This is the definition of ( outside of all parentheses.
+! \gdef\oprm#1 {{\rm\char`\(}#1 \bf \let(=\opnested %
+! \global\advance\parencount by 1 }
+ %
+ % This is the definition of ( when already inside a level of parens.
+ \gdef\opnested{\char`\(\global\advance\parencount by 1 }
+ %
+ \gdef\clrm{% Print a paren in roman if it is taking us back to depth of 0.
+! % also in that case restore the outer-level definition of (.
+! \ifnum \parencount=1 {\rm \char `\)}\sl \let(=\oprm \else \char `\) \fi
+! \global\advance \parencount by -1 }
+ % If we encounter &foo, then turn on ()-hacking afterwards
+ \gdef\amprm#1 {{\rm\&#1}\let(=\oprm \let)=\clrm\ }
+ %
+--- 3679,3701 ----
+
+ \gdef\functionparens{\boldbrax\let&=\amprm\parencount=0 }
+ \gdef\boldbrax{\let(=\opnr\let)=\clnr\let[=\lbrb\let]=\rbrb}
++ % This is used to turn on special parens
++ % but make & act ordinary (given that it's active).
++ \gdef\boldbraxnoamp{\let(=\opnr\let)=\clnr\let[=\lbrb\let]=\rbrb\let&=\ampnr}
+
+ % Definitions of (, ) and & used in args for functions.
+ % This is the definition of ( outside of all parentheses.
+! \gdef\oprm#1 {{\rm\char`\(}#1 \bf \let(=\opnested
+! \global\advance\parencount by 1
+! }
+ %
+ % This is the definition of ( when already inside a level of parens.
+ \gdef\opnested{\char`\(\global\advance\parencount by 1 }
+ %
+ \gdef\clrm{% Print a paren in roman if it is taking us back to depth of 0.
+! % also in that case restore the outer-level definition of (.
+! \ifnum \parencount=1 {\rm \char `\)}\sl \let(=\oprm \else \char `\) \fi
+! \global\advance \parencount by -1 }
+ % If we encounter &foo, then turn on ()-hacking afterwards
+ \gdef\amprm#1 {{\rm\&#1}\let(=\oprm \let)=\clrm\ }
+ %
+***************
+*** 3326,3333 ****
+ } % End of definition inside \activeparens
+ %% These parens (in \boldbrax) actually are a little bolder than the
+ %% contained text. This is especially needed for [ and ]
+! \def\opnr{{\sf\char`\(}} \def\clnr{{\sf\char`\)}} \def\ampnr{\&}
+! \def\lbrb{{\bf\char`\[}} \def\rbrb{{\bf\char`\]}}
+
+ % First, defname, which formats the header line itself.
+ % #1 should be the function name.
+--- 3703,3713 ----
+ } % End of definition inside \activeparens
+ %% These parens (in \boldbrax) actually are a little bolder than the
+ %% contained text. This is especially needed for [ and ]
+! \def\opnr{{\sf\char`\(}\global\advance\parencount by 1 }
+! \def\clnr{{\sf\char`\)}\global\advance\parencount by -1 }
+! \def\ampnr{\&}
+! \def\lbrb{{\bf\char`\[}}
+! \def\rbrb{{\bf\char`\]}}
+
+ % First, defname, which formats the header line itself.
+ % #1 should be the function name.
+***************
+*** 3420,3426 ****
+
+ % This is used for \def{tp,vr}parsebody. It could probably be used for
+ % some of the others, too, with some judicious conditionals.
+! %
+ \def\parsebodycommon#1#2#3{%
+ \begingroup\inENV %
+ \medbreak %
+--- 3800,3806 ----
+
+ % This is used for \def{tp,vr}parsebody. It could probably be used for
+ % some of the others, too, with some judicious conditionals.
+! %
+ \def\parsebodycommon#1#2#3{%
+ \begingroup\inENV %
+ \medbreak %
+***************
+*** 3454,3470 ****
+ }
+
+ % Fine, but then we have to eventually remove the \empty *and* the
+! % braces (if any). That's what this does, putting the result in \tptemp.
+! %
+! \def\removeemptybraces\empty#1\relax{\def\tptemp{#1}}%
+
+ % After \spacesplit has done its work, this is called -- #1 is the final
+ % thing to call, #2 the type name (which starts with \empty), and #3
+ % (which might be empty) the arguments.
+! %
+ \def\parsetpheaderline#1#2#3{%
+! \removeemptybraces#2\relax
+! #1{\tptemp}{#3}%
+ }%
+
+ \def\defopvarparsebody #1#2#3#4#5 {\begingroup\inENV %
+--- 3834,3849 ----
+ }
+
+ % Fine, but then we have to eventually remove the \empty *and* the
+! % braces (if any). That's what this does.
+! %
+! \def\removeemptybraces\empty#1\relax{#1}
+
+ % After \spacesplit has done its work, this is called -- #1 is the final
+ % thing to call, #2 the type name (which starts with \empty), and #3
+ % (which might be empty) the arguments.
+! %
+ \def\parsetpheaderline#1#2#3{%
+! #1{\removeemptybraces#2\relax}{#3}%
+ }%
+
+ \def\defopvarparsebody #1#2#3#4#5 {\begingroup\inENV %
+***************
+*** 3505,3511 ****
+ \hyphenchar\tensl=0
+ #1%
+ \hyphenchar\tensl=45
+! \ifnum\parencount=0 \else \errmessage{unbalanced parens in @def arguments}\fi%
+ \interlinepenalty=10000
+ \advance\rightskip by 0pt plus 1fil
+ \endgraf\penalty 10000\vskip -\parskip\penalty 10000%
+--- 3884,3890 ----
+ \hyphenchar\tensl=0
+ #1%
+ \hyphenchar\tensl=45
+! \ifnum\parencount=0 \else \errmessage{Unbalanced parentheses in @def}\fi%
+ \interlinepenalty=10000
+ \advance\rightskip by 0pt plus 1fil
+ \endgraf\penalty 10000\vskip -\parskip\penalty 10000%
+***************
+*** 3514,3520 ****
+ \def\deftypefunargs #1{%
+ % Expand, preventing hyphenation at `-' chars.
+ % Note that groups don't affect changes in \hyphenchar.
+! \functionparens
+ \tclose{#1}% avoid \code because of side effects on active chars
+ \interlinepenalty=10000
+ \advance\rightskip by 0pt plus 1fil
+--- 3893,3900 ----
+ \def\deftypefunargs #1{%
+ % Expand, preventing hyphenation at `-' chars.
+ % Note that groups don't affect changes in \hyphenchar.
+! % Use \boldbraxnoamp, not \functionparens, so that & is not special.
+! \boldbraxnoamp
+ \tclose{#1}% avoid \code because of side effects on active chars
+ \interlinepenalty=10000
+ \advance\rightskip by 0pt plus 1fil
+***************
+*** 3551,3557 ****
+ % #1 is the data type, #2 the name, #3 the args.
+ \def\deftypefunheaderx #1#2 #3\relax{%
+ \doind {fn}{\code{#2}}% Make entry in function index
+! \begingroup\defname {\code{#1} #2}{Function}%
+ \deftypefunargs {#3}\endgroup %
+ \catcode 61=\other % Turn off change made in \defparsebody
+ }
+--- 3931,3937 ----
+ % #1 is the data type, #2 the name, #3 the args.
+ \def\deftypefunheaderx #1#2 #3\relax{%
+ \doind {fn}{\code{#2}}% Make entry in function index
+! \begingroup\defname {\defheaderxcond#1\relax$$$#2}{Function}%
+ \deftypefunargs {#3}\endgroup %
+ \catcode 61=\other % Turn off change made in \defparsebody
+ }
+***************
+*** 3560,3565 ****
+--- 3940,3949 ----
+
+ \def\deftypefn{\defmethparsebody\Edeftypefn\deftypefnx\deftypefnheader}
+
++ % \defheaderxcond#1\relax$$$
++ % puts #1 in @code, followed by a space, but does nothing if #1 is null.
++ \def\defheaderxcond#1#2$$${\ifx#1\relax\else\code{#1#2} \fi}
++
+ % #1 is the classification. #2 is the data type. #3 is the name and args.
+ \def\deftypefnheader #1#2#3{\deftypefnheaderx{#1}{#2}#3 \relax}
+ % #1 is the classification, #2 the data type, #3 the name, #4 the args.
+***************
+*** 3568,3574 ****
+ \begingroup
+ \normalparens % notably, turn off `&' magic, which prevents
+ % at least some C++ text from working
+! \defname {\code{#2} #3}{#1}%
+ \deftypefunargs {#4}\endgroup %
+ \catcode 61=\other % Turn off change made in \defparsebody
+ }
+--- 3952,3958 ----
+ \begingroup
+ \normalparens % notably, turn off `&' magic, which prevents
+ % at least some C++ text from working
+! \defname {\defheaderxcond#2\relax$$$#3}{#1}%
+ \deftypefunargs {#4}\endgroup %
+ \catcode 61=\other % Turn off change made in \defparsebody
+ }
+***************
+*** 3601,3606 ****
+--- 3985,3991 ----
+ \def\defmacx #1 {\errmessage{@defmacx in invalid context}}
+ \def\defspecx #1 {\errmessage{@defspecx in invalid context}}
+ \def\deftypefnx #1 {\errmessage{@deftypefnx in invalid context}}
++ \def\deftypemethodx #1 {\errmessage{@deftypemethodx in invalid context}}
+ \def\deftypeunx #1 {\errmessage{@deftypeunx in invalid context}}
+
+ % @defmethod, and so on
+***************
+*** 3616,3621 ****
+--- 4001,4016 ----
+ \defunargs {#3}\endgroup %
+ }
+
++ % @deftypemethod foo-class return-type foo-method args
++ %
++ \def\deftypemethod{%
++ \defmethparsebody\Edeftypemethod\deftypemethodx\deftypemethodheader}
++ %
++ % #1 is the class name, #2 the data type, #3 the method name, #4 the args.
++ \def\deftypemethodheader#1#2#3#4{%
++ \deftypefnheaderx{Method on #1}{#2}#3 #4\relax
++ }
++
+ % @defmethod == @defop Method
+
+ \def\defmethod{\defmethparsebody\Edefmethod\defmethodx\defmethodheader}
+***************
+*** 3693,3712 ****
+
+ \def\deftypevar{\defvarparsebody\Edeftypevar\deftypevarx\deftypevarheader}
+
+! % #1 is the data type. #2 is the name.
+ \def\deftypevarheader #1#2{%
+! \doind {vr}{\code{#2}}% Make entry in variables index
+! \begingroup\defname {\code{#1} #2}{Variable}%
+ \interlinepenalty=10000
+ \endgraf\penalty 10000\vskip -\parskip\penalty 10000
+ \endgroup}
+
+ % @deftypevr {Global Flag} int enable
+
+ \def\deftypevr{\defvrparsebody\Edeftypevr\deftypevrx\deftypevrheader}
+
+! \def\deftypevrheader #1#2#3{\doind {vr}{\code{#3}}%
+! \begingroup\defname {\code{#2} #3}{#1}
+ \interlinepenalty=10000
+ \endgraf\penalty 10000\vskip -\parskip\penalty 10000
+ \endgroup}
+--- 4088,4109 ----
+
+ \def\deftypevar{\defvarparsebody\Edeftypevar\deftypevarx\deftypevarheader}
+
+! % #1 is the data type. #2 is the name, perhaps followed by text that
+! % is actually part of the data type, which should not be put into the index.
+ \def\deftypevarheader #1#2{%
+! \dovarind#2 \relax% Make entry in variables index
+! \begingroup\defname {\defheaderxcond#1\relax$$$#2}{Variable}%
+ \interlinepenalty=10000
+ \endgraf\penalty 10000\vskip -\parskip\penalty 10000
+ \endgroup}
++ \def\dovarind#1 #2\relax{\doind{vr}{\code{#1}}}
+
+ % @deftypevr {Global Flag} int enable
+
+ \def\deftypevr{\defvrparsebody\Edeftypevr\deftypevrx\deftypevrheader}
+
+! \def\deftypevrheader #1#2#3{\dovarind#3 \relax%
+! \begingroup\defname {\defheaderxcond#2\relax$$$#3}{#1}
+ \interlinepenalty=10000
+ \endgraf\penalty 10000\vskip -\parskip\penalty 10000
+ \endgroup}
+***************
+*** 3737,3742 ****
+--- 4134,4140 ----
+
+ \def\deftpx #1 {\errmessage{@deftpx in invalid context}}
+
++
+ \message{cross reference,}
+ % Define cross-reference macros
+ \newwrite \auxfile
+***************
+*** 3744,3749 ****
+--- 4142,4152 ----
+ \newif\ifhavexrefs % True if xref values are known.
+ \newif\ifwarnedxrefs % True if we warned once that they aren't known.
+
++ % @inforef is simple.
++ \def\inforef #1{\inforefzzz #1,,,,**}
++ \def\inforefzzz #1,#2,#3,#4**{\putwordSee{} \putwordInfo{} \putwordfile{} \file{\ignorespaces #3{}},
++ node \samp{\ignorespaces#1{}}}
++
+ % \setref{foo} defines a cross-reference point named foo.
+
+ \def\setref#1{%
+***************
+*** 3777,3783 ****
+ \setbox0=\hbox{\printednodename}%
+ \ifdim \wd0 = 0pt
+ % No printed node name was explicitly given.
+! \ifx\SETxref-automatic-section-title\relax %
+ % Use the actual chapter/section title appear inside
+ % the square brackets. Use the real section title if we have it.
+ \ifdim \wd1>0pt%
+--- 4180,4189 ----
+ \setbox0=\hbox{\printednodename}%
+ \ifdim \wd0 = 0pt
+ % No printed node name was explicitly given.
+! \expandafter\ifx\csname SETxref-automatic-section-title\endcsname\relax
+! % Use the node name inside the square brackets.
+! \def\printednodename{\ignorespaces #1}%
+! \else
+ % Use the actual chapter/section title appear inside
+ % the square brackets. Use the real section title if we have it.
+ \ifdim \wd1>0pt%
+***************
+*** 3786,3801 ****
+ \else
+ \ifhavexrefs
+ % We know the real title if we have the xref values.
+! \def\printednodename{\refx{#1-title}}%
+ \else
+ % Otherwise just copy the Info node name.
+ \def\printednodename{\ignorespaces #1}%
+ \fi%
+ \fi
+- \def\printednodename{#1-title}%
+- \else
+- % Use the node name inside the square brackets.
+- \def\printednodename{\ignorespaces #1}%
+ \fi
+ \fi
+ %
+--- 4192,4203 ----
+ \else
+ \ifhavexrefs
+ % We know the real title if we have the xref values.
+! \def\printednodename{\refx{#1-title}{}}%
+ \else
+ % Otherwise just copy the Info node name.
+ \def\printednodename{\ignorespaces #1}%
+ \fi%
+ \fi
+ \fi
+ \fi
+ %
+***************
+*** 3823,3829 ****
+
+ % Use \turnoffactive so that punctuation chars such as underscore
+ % work in node names.
+! \def\dosetq #1#2{{\let\folio=0 \turnoffactive%
+ \edef\next{\write\auxfile{\internalsetq {#1}{#2}}}%
+ \next}}
+
+--- 4225,4231 ----
+
+ % Use \turnoffactive so that punctuation chars such as underscore
+ % work in node names.
+! \def\dosetq #1#2{{\let\folio=0 \turnoffactive
+ \edef\next{\write\auxfile{\internalsetq {#1}{#2}}}%
+ \next}}
+
+***************
+*** 3892,3974 ****
+ #2% Output the suffix in any case.
+ }
+
+- % Read the last existing aux file, if any. No error if none exists.
+-
+ % This is the macro invoked by entries in the aux file.
+! \def\xrdef #1#2{
+! {\catcode`\'=\other\expandafter \gdef \csname X#1\endcsname {#2}}}
+
+! \def\readauxfile{%
+! \begingroup
+! \catcode `\^^@=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\^^C=\other
+! \catcode `\^^D=\other
+! \catcode `\^^E=\other
+! \catcode `\^^F=\other
+! \catcode `\^^G=\other
+! \catcode `\^^H=\other
+! \catcode `\ =\other
+! \catcode `\^^L=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode `\=\other
+! \catcode 26=\other
+! \catcode `\^^[=\other
+! \catcode `\^^\=\other
+! \catcode `\^^]=\other
+! \catcode `\^^^=\other
+! \catcode `\^^_=\other
+! \catcode `\@=\other
+! \catcode `\^=\other
+! \catcode `\~=\other
+! \catcode `\[=\other
+! \catcode `\]=\other
+! \catcode`\"=\other
+! \catcode`\_=\other
+! \catcode`\|=\other
+! \catcode`\<=\other
+! \catcode`\>=\other
+! \catcode `\$=\other
+! \catcode `\#=\other
+! \catcode `\&=\other
+! % `\+ does not work, so use 43.
+! \catcode 43=\other
+! % Make the characters 128-255 be printing characters
+! {%
+! \count 1=128
+! \def\loop{%
+! \catcode\count 1=\other
+! \advance\count 1 by 1
+! \ifnum \count 1<256 \loop \fi
+ }%
+! }%
+! % the aux file uses ' as the escape.
+! % Turn off \ as an escape so we do not lose on
+! % entries which were dumped with control sequences in their names.
+! % For example, 'xrdef {$\leq $-fun}{page ...} made by @defun ^^
+! % Reference to such entries still does not work the way one would wish,
+! % but at least they do not bomb out when the aux file is read in.
+! \catcode `\{=1 \catcode `\}=2
+! \catcode `\%=\other
+! \catcode `\'=0
+! \catcode `\\=\other
+! \openin 1 \jobname.aux
+! \ifeof 1 \else \closein 1 \input \jobname.aux \global\havexrefstrue
+! \global\warnedobstrue
+! \fi
+! % Open the new aux file. Tex will close it automatically at exit.
+! \openout \auxfile=\jobname.aux
+ \endgroup}
+
+
+--- 4294,4394 ----
+ #2% Output the suffix in any case.
+ }
+
+ % This is the macro invoked by entries in the aux file.
+! \def\xrdef #1#2{{%
+! \catcode`\'=\other
+! \expandafter\gdef\csname X#1\endcsname{#2}%
+! }}
+
+! % Read the last existing aux file, if any. No error if none exists.
+! \def\readauxfile{\begingroup
+! \catcode`\^^@=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\^^C=\other
+! \catcode`\^^D=\other
+! \catcode`\^^E=\other
+! \catcode`\^^F=\other
+! \catcode`\^^G=\other
+! \catcode`\^^H=\other
+! \catcode`\ =\other
+! \catcode`\^^L=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode`\=\other
+! \catcode26=\other
+! \catcode`\^^[=\other
+! \catcode`\^^\=\other
+! \catcode`\^^]=\other
+! \catcode`\^^^=\other
+! \catcode`\^^_=\other
+! \catcode`\@=\other
+! \catcode`\^=\other
+! % It was suggested to define this as 7, which would allow ^^e4 etc.
+! % in xref tags, i.e., node names. But since ^^e4 notation isn't
+! % supported in the main text, it doesn't seem desirable. Furthermore,
+! % that is not enough: for node names that actually contain a ^
+! % character, we would end up writing a line like this: 'xrdef {'hat
+! % b-title}{'hat b} and \xrdef does a \csname...\endcsname on the first
+! % argument, and \hat is not an expandable control sequence. It could
+! % all be worked out, but why? Either we support ^^ or we don't.
+! %
+! % The other change necessary for this was to define \auxhat:
+! % \def\auxhat{\def^{'hat }}% extra space so ok if followed by letter
+! % and then to call \auxhat in \setq.
+! %
+! \catcode`\~=\other
+! \catcode`\[=\other
+! \catcode`\]=\other
+! \catcode`\"=\other
+! \catcode`\_=\other
+! \catcode`\|=\other
+! \catcode`\<=\other
+! \catcode`\>=\other
+! \catcode`\$=\other
+! \catcode`\#=\other
+! \catcode`\&=\other
+! % `\+ does not work, so use 43.
+! \catcode43=\other
+! % Make the characters 128-255 be printing characters
+! {%
+! \count 1=128
+! \def\loop{%
+! \catcode\count 1=\other
+! \advance\count 1 by 1
+! \ifnum \count 1<256 \loop \fi
+! }%
+ }%
+! % The aux file uses ' as the escape (for now).
+! % Turn off \ as an escape so we do not lose on
+! % entries which were dumped with control sequences in their names.
+! % For example, 'xrdef {$\leq $-fun}{page ...} made by @defun ^^
+! % Reference to such entries still does not work the way one would wish,
+! % but at least they do not bomb out when the aux file is read in.
+! \catcode`\{=1
+! \catcode`\}=2
+! \catcode`\%=\other
+! \catcode`\'=0
+! \catcode`\\=\other
+! %
+! \openin 1 \jobname.aux
+! \ifeof 1 \else
+! \closein 1
+! \input \jobname.aux
+! \global\havexrefstrue
+! \global\warnedobstrue
+! \fi
+! % Open the new aux file. TeX will close it automatically at exit.
+! \openout\auxfile=\jobname.aux
+ \endgroup}
+
+
+***************
+*** 3979,3985 ****
+ % The trailing space in the following definition for supereject is
+ % vital for proper filling; pages come out unaligned when you do a
+ % pagealignmacro call if that space before the closing brace is
+! % removed.
+ \def\supereject{\par\penalty -20000\footnoteno =0 }
+
+ % @footnotestyle is meaningful for info output only..
+--- 4399,4406 ----
+ % The trailing space in the following definition for supereject is
+ % vital for proper filling; pages come out unaligned when you do a
+ % pagealignmacro call if that space before the closing brace is
+! % removed. (Generally, numeric constants should always be followed by a
+! % space to prevent strange expansion errors.)
+ \def\supereject{\par\penalty -20000\footnoteno =0 }
+
+ % @footnotestyle is meaningful for info output only..
+***************
+*** 4008,4014 ****
+ % Don't bother with the trickery in plain.tex to not require the
+ % footnote text as a parameter. Our footnotes don't need to be so general.
+ %
+! \long\gdef\footnotezzz#1{\insert\footins{%
+ % We want to typeset this text as a normal paragraph, even if the
+ % footnote reference occurs in (for example) a display environment.
+ % So reset some parameters.
+--- 4429,4439 ----
+ % Don't bother with the trickery in plain.tex to not require the
+ % footnote text as a parameter. Our footnotes don't need to be so general.
+ %
+! % Oh yes, they do; otherwise, @ifset and anything else that uses
+! % \parseargline fail inside footnotes because the tokens are fixed when
+! % the footnote is read. --karl, 16nov96.
+! %
+! \long\gdef\footnotezzz{\insert\footins\bgroup
+ % We want to typeset this text as a normal paragraph, even if the
+ % footnote reference occurs in (for example) a display environment.
+ % So reset some parameters.
+***************
+*** 4030,4037 ****
+ % expands into a box, it must come within the paragraph, lest it
+ % provide a place where TeX can split the footnote.
+ \footstrut
+! #1\strut}%
+ }
+
+ }%end \catcode `\@=11
+
+--- 4455,4467 ----
+ % expands into a box, it must come within the paragraph, lest it
+ % provide a place where TeX can split the footnote.
+ \footstrut
+! \futurelet\next\fo@t
+ }
++ \def\fo@t{\ifcat\bgroup\noexpand\next \let\next\f@@t
++ \else\let\next\f@t\fi \next}
++ \def\f@@t{\bgroup\aftergroup\@foot\let\next}
++ \def\f@t#1{#1\@foot}
++ \def\@foot{\strut\egroup}
+
+ }%end \catcode `\@=11
+
+***************
+*** 4104,4116 ****
+
+ % Set some numeric style parameters, for 8.5 x 11 format.
+
+! %\hsize = 6.5in
+ \newdimen\defaultparindent \defaultparindent = 15pt
+ \parindent = \defaultparindent
+! \parskip 18pt plus 1pt
+! \setleading{15pt}
+ \advance\topskip by 1.2cm
+
+ % Prevent underfull vbox error messages.
+ \vbadness=10000
+
+--- 4534,4551 ----
+
+ % Set some numeric style parameters, for 8.5 x 11 format.
+
+! \hsize = 6in
+! \hoffset = .25in
+ \newdimen\defaultparindent \defaultparindent = 15pt
+ \parindent = \defaultparindent
+! \parskip 3pt plus 2pt minus 1pt
+! \setleading{13.2pt}
+ \advance\topskip by 1.2cm
+
++ \chapheadingskip = 15pt plus 4pt minus 2pt
++ \secheadingskip = 12pt plus 3pt minus 2pt
++ \subsecheadingskip = 9pt plus 2pt minus 2pt
++
+ % Prevent underfull vbox error messages.
+ \vbadness=10000
+
+***************
+*** 4133,4162 ****
+
+ % Use @smallbook to reset parameters for 7x9.5 format (or else 7x9.25)
+ \def\smallbook{
+!
+! % These values for secheadingskip and subsecheadingskip are
+! % experiments. RJC 7 Aug 1992
+! \global\secheadingskip = 17pt plus 6pt minus 3pt
+! \global\subsecheadingskip = 14pt plus 6pt minus 3pt
+!
+! \global\lispnarrowing = 0.3in
+! \setleading{12pt}
+! \advance\topskip by -1cm
+! \global\parskip 3pt plus 1pt
+! \global\hsize = 5in
+! \global\vsize=7.5in
+! \global\tolerance=700
+! \global\hfuzz=1pt
+! \global\contentsrightmargin=0pt
+! \global\deftypemargin=0pt
+! \global\defbodyindent=.5cm
+!
+! \global\pagewidth=\hsize
+! \global\pageheight=\vsize
+!
+! \global\let\smalllisp=\smalllispx
+! \global\let\smallexample=\smalllispx
+! \global\def\Esmallexample{\Esmalllisp}
+ }
+
+ % Use @afourpaper to print on European A4 paper.
+--- 4568,4595 ----
+
+ % Use @smallbook to reset parameters for 7x9.5 format (or else 7x9.25)
+ \def\smallbook{
+! \global\chapheadingskip = 15pt plus 4pt minus 2pt
+! \global\secheadingskip = 12pt plus 3pt minus 2pt
+! \global\subsecheadingskip = 9pt plus 2pt minus 2pt
+! %
+! \global\lispnarrowing = 0.3in
+! \setleading{12pt}
+! \advance\topskip by -1cm
+! \global\parskip 2pt plus 1pt
+! \global\hsize = 5in
+! \global\vsize=7.5in
+! \global\tolerance=700
+! \global\hfuzz=1pt
+! \global\contentsrightmargin=0pt
+! \global\deftypemargin=0pt
+! \global\defbodyindent=.5cm
+! %
+! \global\pagewidth=\hsize
+! \global\pageheight=\vsize
+! %
+! \global\let\smalllisp=\smalllispx
+! \global\let\smallexample=\smalllispx
+! \global\def\Esmallexample{\Esmalllisp}
+ }
+
+ % Use @afourpaper to print on European A4 paper.
+***************
+*** 4179,4190 ****
+ \global\pageheight=\vsize
+ }
+
+ % Allow control of the text dimensions. Parameters in order: textheight;
+! % textwidth; \voffset; \hoffset (!); binding offset. All require a dimension;
+ % header is additional; added length extends the bottom of the page.
+
+! \def\changepagesizes#1#2#3#4#5
+! {\global\vsize= #1
+ \advance\vsize by \topskip
+ \global\voffset= #3
+ \global\hsize= #2
+--- 4612,4630 ----
+ \global\pageheight=\vsize
+ }
+
++ \bindingoffset=0pt
++ \normaloffset=\hoffset
++ \pagewidth=\hsize
++ \pageheight=\vsize
++
+ % Allow control of the text dimensions. Parameters in order: textheight;
+! % textwidth; voffset; hoffset; binding offset; topskip.
+! % All require a dimension;
+ % header is additional; added length extends the bottom of the page.
+
+! \def\changepagesizes#1#2#3#4#5#6{
+! \global\vsize= #1
+! \global\topskip= #6
+ \advance\vsize by \topskip
+ \global\voffset= #3
+ \global\hsize= #2
+***************
+*** 4197,4205 ****
+ \global\normaloffset= #4
+ \global\bindingoffset= #5}
+
+! % This layout is compatible with Latex on A4 paper.
+!
+! \def\afourlatex{\changepagesizes{22cm}{15cm}{7mm}{4.6mm}{5mm}}
+
+ % Define macros to output various characters with catcode for normal text.
+ \catcode`\"=\other
+--- 4637,4656 ----
+ \global\normaloffset= #4
+ \global\bindingoffset= #5}
+
+! % A specific text layout, 24x15cm overall, intended for A4 paper. Top margin
+! % 29mm, hence bottom margin 28mm, nominal side margin 3cm.
+! \def\afourlatex
+! {\global\tolerance=700
+! \global\hfuzz=1pt
+! \setleading{12pt}
+! \global\parskip 15pt plus 1pt
+! \advance\baselineskip by 1.6pt
+! \changepagesizes{237mm}{150mm}{3.6mm}{3.6mm}{3mm}{7mm}
+! }
+!
+! % Use @afourwide to print on European A4 paper in wide format.
+! \def\afourwide{\afourpaper
+! \changepagesizes{9.5in}{6.5in}{\hoffset}{\normaloffset}{\bindingoffset}{7mm}}
+
+ % Define macros to output various characters with catcode for normal text.
+ \catcode`\"=\other
+***************
+*** 4247,4260 ****
+ \catcode`\_=\active
+ \def_{\ifusingtt\normalunderscore\_}
+ % Subroutine for the previous macro.
+! \def\_{\lvvmode \kern.06em \vbox{\hrule width.3em height.1ex}}
+!
+! % \lvvmode is equivalent in function to \leavevmode.
+! % Using \leavevmode runs into trouble when written out to
+! % an index file due to the expansion of \leavevmode into ``\unhbox
+! % \voidb@x'' ---which looks to TeX like ``\unhbox \voidb\x'' due to our
+! % magic tricks with @.
+! \def\lvvmode{\vbox to 0pt{}}
+
+ \catcode`\|=\active
+ \def|{{\tt \char '174}}
+--- 4698,4704 ----
+ \catcode`\_=\active
+ \def_{\ifusingtt\normalunderscore\_}
+ % Subroutine for the previous macro.
+! \def\_{\leavevmode \kern.06em \vbox{\hrule width.3em height.1ex}}
+
+ \catcode`\|=\active
+ \def|{{\tt \char '174}}
+***************
+*** 4273,4278 ****
+--- 4717,4731 ----
+ {\catcode`\==\active
+ \global\def={{\tt \char 61}}}
+
++ \catcode`+=\active
++ \catcode`\_=\active
++
++ % If a .fmt file is being used, characters that might appear in a file
++ % name cannot be active until we have parsed the command line.
++ % So turn them off again, and have \everyjob (or @setfilename) turn them on.
++ % \otherifyactive is called near the end of this file.
++ \def\otherifyactive{\catcode`+=\other \catcode`\_=\other}
++
+ \catcode`\@=0
+
+ % \rawbackslashxx output one backslash character in current font
+***************
+*** 4315,4320 ****
+--- 4768,4777 ----
+ @let>=@normalgreater
+ @let+=@normalplus}
+
++ % Make _ and + \other characters, temporarily.
++ % This is canceled by @fixbackslash.
++ @otherifyactive
++
+ % If a .fmt file is being used, we don't want the `\input texinfo' to show up.
+ % That is what \eatinput is for; after that, the `\' should revert to printing
+ % a backslash.
+***************
+*** 4325,4332 ****
+ % On the other hand, perhaps the file did not have a `\input texinfo'. Then
+ % the first `\{ in the file would cause an error. This macro tries to fix
+ % that, assuming it is called before the first `\' could plausibly occur.
+ %
+! @gdef@fixbackslash{@ifx\@eatinput @let\ = @normalbackslash @fi}
+
+ %% These look ok in all fonts, so just make them not special. The @rm below
+ %% makes sure that the current font starts out as the newly loaded cmr10
+--- 4782,4792 ----
+ % On the other hand, perhaps the file did not have a `\input texinfo'. Then
+ % the first `\{ in the file would cause an error. This macro tries to fix
+ % that, assuming it is called before the first `\' could plausibly occur.
++ % Also back turn on active characters that might appear in the input
++ % file name, in case not using a pre-dumped format.
+ %
+! @gdef@fixbackslash{@ifx\@eatinput @let\ = @normalbackslash @fi
+! @catcode`+=@active @catcode`@_=@active}
+
+ %% These look ok in all fonts, so just make them not special. The @rm below
+ %% makes sure that the current font starts out as the newly loaded cmr10