texlive[61509] Build/source/texk/web2c: [WEB] Add Pascal TWILL 4.5.
commits+ascherer at tug.org
commits+ascherer at tug.org
Thu Jan 6 12:08:43 CET 2022
Revision: 61509
http://tug.org/svn/texlive?view=revision&revision=61509
Author: ascherer
Date: 2022-01-06 12:08:43 +0100 (Thu, 06 Jan 2022)
Log Message:
-----------
[WEB] Add Pascal TWILL 4.5.
See 'git log' in https://github.com/ascherer/twill (now 'archived') and
in https://github.com/ascherer/web (both branches 'master' and
'adapt-twill-for-texlive') for details of this impromptu project.
Modified Paths:
--------------
trunk/Build/source/texk/web2c/ChangeLog
trunk/Build/source/texk/web2c/Makefile.in
trunk/Build/source/texk/web2c/am/web.am
trunk/Build/source/texk/web2c/help.h
trunk/Build/source/texk/web2c/web2c/ChangeLog
trunk/Build/source/texk/web2c/web2c/common.defines
Added Paths:
-----------
trunk/Build/source/texk/web2c/twill.test
trunk/Build/source/texk/web2c/weav-twill.ch
Modified: trunk/Build/source/texk/web2c/ChangeLog
===================================================================
--- trunk/Build/source/texk/web2c/ChangeLog 2022-01-06 00:48:34 UTC (rev 61508)
+++ trunk/Build/source/texk/web2c/ChangeLog 2022-01-06 11:08:43 UTC (rev 61509)
@@ -1,3 +1,11 @@
+2022-01-06 Andreas Scherer <https://ascherer.github.io>
+
+ * Makefile.in,
+ * am/web.am,
+ * help.h,
+ * twill.test,
+ * weav-twill.ch: Add TWILL 4.5.
+
2021-12-26 Andreas Scherer <https://ascherer.github.io>
* ctangleboot.cin,
Modified: trunk/Build/source/texk/web2c/Makefile.in
===================================================================
--- trunk/Build/source/texk/web2c/Makefile.in 2022-01-06 00:48:34 UTC (rev 61508)
+++ trunk/Build/source/texk/web2c/Makefile.in 2022-01-06 11:08:43 UTC (rev 61509)
@@ -438,7 +438,7 @@
gftodvi$(EXEEXT) gftopk$(EXEEXT) gftype$(EXEEXT) mft$(EXEEXT) \
patgen$(EXEEXT) pktogf$(EXEEXT) pktype$(EXEEXT) \
pltotf$(EXEEXT) pooltype$(EXEEXT) tftopl$(EXEEXT) \
- vftovp$(EXEEXT) vptovf$(EXEEXT) weave$(EXEEXT)
+ vftovp$(EXEEXT) vptovf$(EXEEXT) weave$(EXEEXT) twill$(EXEEXT)
am__EXEEXT_2 = pbibtex$(EXEEXT) pdvitype$(EXEEXT) ppltotf$(EXEEXT) \
ptftopl$(EXEEXT)
am__EXEEXT_3 = upbibtex$(EXEEXT) updvitype$(EXEEXT) uppltotf$(EXEEXT) \
@@ -1695,6 +1695,10 @@
weave_OBJECTS = $(nodist_weave_OBJECTS)
weave_LDADD = $(LDADD)
weave_DEPENDENCIES = $(proglib) $(am__DEPENDENCIES_1)
+nodist_twill_OBJECTS = twill.$(OBJEXT)
+twill_OBJECTS = $(nodist_twill_OBJECTS)
+twill_LDADD = $(LDADD)
+twill_DEPENDENCIES = $(proglib) $(am__DEPENDENCIES_1)
nodist_wofm2opl_OBJECTS = ofm2opl.$(OBJEXT)
wofm2opl_OBJECTS = $(nodist_wofm2opl_OBJECTS)
wofm2opl_LDADD = $(LDADD)
@@ -1846,9 +1850,9 @@
./$(DEPDIR)/uptex-uptex-pool.Po ./$(DEPDIR)/uptex-uptex0.Po \
./$(DEPDIR)/uptex-uptexini.Po ./$(DEPDIR)/uptftopl-uptftopl.Po \
./$(DEPDIR)/vftovp.Po ./$(DEPDIR)/vptovf.Po \
- ./$(DEPDIR)/weave.Po ./$(DEPDIR)/xetex-dummy.Po \
- ./$(DEPDIR)/xetex-xetex-pool.Po ./$(DEPDIR)/xetex-xetex0.Po \
- ./$(DEPDIR)/xetex-xetexini.Po \
+ ./$(DEPDIR)/weave.Po ./$(DEPDIR)/twill.Po \
+ ./$(DEPDIR)/xetex-dummy.Po ./$(DEPDIR)/xetex-xetex-pool.Po \
+ ./$(DEPDIR)/xetex-xetex0.Po ./$(DEPDIR)/xetex-xetexini.Po \
alephdir/$(DEPDIR)/aleph-aleph.Po \
alephdir/$(DEPDIR)/aleph-alephbis.Po \
alephdir/$(DEPDIR)/aleph-alephextra.Po \
@@ -2557,6 +2561,7 @@
$(nodist_uptex_SOURCES) $(uptftopl_SOURCES) \
$(nodist_uptftopl_SOURCES) $(nodist_vftovp_SOURCES) \
$(nodist_vptovf_SOURCES) $(nodist_weave_SOURCES) \
+ $(nodist_twill_SOURCES) \
$(nodist_wofm2opl_SOURCES) $(nodist_wopl2ofm_SOURCES) \
$(nodist_wovf2ovp_SOURCES) $(nodist_wovp2ovf_SOURCES) \
$(dist_xetex_SOURCES) $(nodist_xetex_SOURCES) \
@@ -2791,7 +2796,7 @@
am__EXEEXT_44 = bibtex.test dvicopy.test dvitype.test gftodvi.test \
gftopk.test gftype.test mft.test patgen.test pktogf.test \
pktype.test pltotf.test pooltype.test tftopl.test vftovp.test \
- vptovf.test weave.test
+ vptovf.test weave.test twill.test
am__EXEEXT_45 = $(am__EXEEXT_44) tests/bibtex-openout-test.pl \
tests/bibtex-longline-test.pl tests/bibtex-mem.test \
tests/bibtex-bigauth.test tests/bibtex-auxinclude.test
@@ -3798,7 +3803,8 @@
nodist_ctangleboot_SOURCES = ctangleboot.c cwebboot.c
ctangleboot_DEPENDENCIES = $(default_dependencies)
web_programs = bibtex dvicopy dvitype gftodvi gftopk gftype mft \
- patgen pktogf pktype pltotf pooltype tftopl vftovp vptovf weave
+ patgen pktogf pktype pltotf pooltype tftopl vftovp vptovf \
+ weave twill
web_tests = $(web_programs:=.test) tests/bibtex-openout-test.pl \
tests/bibtex-longline-test.pl tests/bibtex-mem.test \
@@ -3820,6 +3826,7 @@
nodist_vftovp_SOURCES = vftovp.c vftovp.h
nodist_vptovf_SOURCES = vptovf.c vptovf.h
nodist_weave_SOURCES = weave.c weave.h
+nodist_twill_SOURCES = twill.c twill.h
nodist_ctie_SOURCES = ctie.c
nodist_cweave_SOURCES = cweave.c cweb.c
nodist_ctwill_SOURCES = ctwill.c cweb.c
@@ -8327,6 +8334,10 @@
@rm -f weave$(EXEEXT)
$(AM_V_CCLD)$(LINK) $(weave_OBJECTS) $(weave_LDADD) $(LIBS)
+twill$(EXEEXT): $(twill_OBJECTS) $(twill_DEPENDENCIES) $(EXTRA_twill_DEPENDENCIES)
+ @rm -f twill$(EXEEXT)
+ $(AM_V_CCLD)$(LINK) $(twill_OBJECTS) $(twill_LDADD) $(LIBS)
+
wofm2opl$(EXEEXT): $(wofm2opl_OBJECTS) $(wofm2opl_DEPENDENCIES) $(EXTRA_wofm2opl_DEPENDENCIES)
@rm -f wofm2opl$(EXEEXT)
$(AM_V_CCLD)$(LINK) $(wofm2opl_OBJECTS) $(wofm2opl_LDADD) $(LIBS)
@@ -8571,6 +8582,7 @@
@AMDEP_TRUE@@am__include@ @am__quote at ./$(DEPDIR)/vftovp.Po at am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote at ./$(DEPDIR)/vptovf.Po at am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote at ./$(DEPDIR)/weave.Po at am__quote@ # am--include-marker
+ at AMDEP_TRUE@@am__include@ @am__quote at ./$(DEPDIR)/twill.Po at am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote at ./$(DEPDIR)/xetex-dummy.Po at am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote at ./$(DEPDIR)/xetex-xetex-pool.Po at am__quote@ # am--include-marker
@AMDEP_TRUE@@am__include@ @am__quote at ./$(DEPDIR)/xetex-xetex0.Po at am__quote@ # am--include-marker
@@ -19922,6 +19934,7 @@
-rm -f ./$(DEPDIR)/vftovp.Po
-rm -f ./$(DEPDIR)/vptovf.Po
-rm -f ./$(DEPDIR)/weave.Po
+ -rm -f ./$(DEPDIR)/twill.Po
-rm -f ./$(DEPDIR)/xetex-dummy.Po
-rm -f ./$(DEPDIR)/xetex-xetex-pool.Po
-rm -f ./$(DEPDIR)/xetex-xetex0.Po
@@ -20702,6 +20715,7 @@
-rm -f ./$(DEPDIR)/vftovp.Po
-rm -f ./$(DEPDIR)/vptovf.Po
-rm -f ./$(DEPDIR)/weave.Po
+ -rm -f ./$(DEPDIR)/twill.Po
-rm -f ./$(DEPDIR)/xetex-dummy.Po
-rm -f ./$(DEPDIR)/xetex-xetex-pool.Po
-rm -f ./$(DEPDIR)/xetex-xetex0.Po
@@ -21548,6 +21562,15 @@
weave.p: tangle$(EXEEXT) weave.web weave.ch
$(tangle) weave weave
weave.log: weave$(EXEEXT)
+twill.c twill.h: twill-web2c
+ @$(web2c) twill
+twill-web2c: twill.p $(web2c_depend)
+ @$(web2c) twill
+twill.p: tangle$(EXEEXT) twill.web
+ $(tangle) twill
+twill.log: twill$(EXEEXT)
+twill.web: tie$(EXEEXT) weave.web weave.ch weav-twill.ch
+ $(tie_m) weave.web weave.ch weav-twill.ch
ctie.c: ctangle$(EXEEXT) ctiedir/ctie.w ctiedir/ctie-k.ch
$(ctangle_silent)CWEBINPUTS=$(srcdir)/ctiedir $(ctangle) ctie.w ctie-k.ch
cweave.c: ctangle$(EXEEXT) cwebdir/comm-w2c.h cwebdir/cweave.w cwebdir/prod-cweave.w cwebdir/cweav-w2c.ch
Modified: trunk/Build/source/texk/web2c/am/web.am
===================================================================
--- trunk/Build/source/texk/web2c/am/web.am 2022-01-06 00:48:34 UTC (rev 61508)
+++ trunk/Build/source/texk/web2c/am/web.am 2022-01-06 11:08:43 UTC (rev 61509)
@@ -7,7 +7,8 @@
## You may freely use, modify and/or distribute this file.
web_programs = bibtex dvicopy dvitype gftodvi gftopk gftype mft \
- patgen pktogf pktype pltotf pooltype tftopl vftovp vptovf weave
+ patgen pktogf pktype pltotf pooltype tftopl vftovp vptovf \
+ weave twill
## Basic tests, one for each program.
##
@@ -174,6 +175,17 @@
$(tangle) weave weave
weave.log: weave$(EXEEXT)
+nodist_twill_SOURCES = twill.c twill.h
+twill.c twill.h: twill-web2c
+ @$(web2c) twill
+twill-web2c: twill.p $(web2c_depend)
+ @$(web2c) twill
+twill.p: tangle$(EXEEXT) twill.web
+ $(tangle) twill
+twill.web: tie$(EXEEXT) weave.web weave.ch weav-twill.ch
+ $(tie_m) weave.web weave.ch weav-twill.ch
+twill.log: twill$(EXEEXT)
+
## Tests.
##
if WEB
Modified: trunk/Build/source/texk/web2c/help.h
===================================================================
--- trunk/Build/source/texk/web2c/help.h 2022-01-06 00:48:34 UTC (rev 61508)
+++ trunk/Build/source/texk/web2c/help.h 2022-01-06 11:08:43 UTC (rev 61509)
@@ -639,4 +639,18 @@
};
#endif /* WEAVE */
+#ifdef TWILL
+const_string TWILLHELP[] = {
+ "Usage: twill [OPTION]... WEBFILE[.web] [CHANGEFILE[.ch]]",
+ " Weave WEBFILE with CHANGEFILE into a TeX document.",
+ " Default CHANGEFILE is " DEV_NULL ";",
+ " TeX output goes to the basename of WEBFILE extended with `.tex'.",
+ "",
+ "-x omit cross-reference information",
+ "-help display this help and exit",
+ "-version output version information and exit",
+ NULL
+};
+#endif /* TWILL */
+
#endif /* not HELP_H */
Added: trunk/Build/source/texk/web2c/twill.test
===================================================================
--- trunk/Build/source/texk/web2c/twill.test (rev 0)
+++ trunk/Build/source/texk/web2c/twill.test 2022-01-06 11:08:43 UTC (rev 61509)
@@ -0,0 +1,12 @@
+#! /bin/sh -vx
+# $Id$
+# Copyright 2022 Andreas Scherer <https://ascherer.github.io>
+# Copyright 2017 Karl Berry <tex-live at tug.org>
+# Copyright 2009 Peter Breitenlohner <tex-live at tug.org>
+# You may freely use, modify and/or distribute this file.
+
+test -d tests || mkdir -p tests
+
+TEXMFCNF=$srcdir/../kpathsea WEBINPUTS=$srcdir \
+ ./twill pooltype || exit 1
+
Property changes on: trunk/Build/source/texk/web2c/twill.test
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Added: trunk/Build/source/texk/web2c/weav-twill.ch
===================================================================
--- trunk/Build/source/texk/web2c/weav-twill.ch (rev 0)
+++ trunk/Build/source/texk/web2c/weav-twill.ch 2022-01-06 11:08:43 UTC (rev 61509)
@@ -0,0 +1,987 @@
+Changes for WEAVE.WEB to mogrify WEAVE into TWILL.
+
+See the 'git log' in https://github.com/ascherer/twill and
+https://github.com/ascherer/web for details.
+
+Public domain. Originally written by Andreas Scherer, 2022.
+
+Limbo.
+
+ at x 2,29c2,5
+% Version 0 was released in December, 1981.
+% Version 1 was released in September, 1982, with version 0 of TeX.
+% Slight changes were made in October, 1982, for version 0.6 of TeX.
+% Version 1.1 changed "_" to "\_" if not within an identifier (November, 1982).
+% Version 1.2 added @@= and @@\ and marked changed modules (December, 1982).
+% Version 1.3 marked and indexed changed modules better (January, 1983).
+% Version 1.4 added "history" (February, 1983).
+% Version 1.5 conformed to TeX version 0.96 (March, 1983).
+% Version 1.6 conformed to TeX version 0.98 (May, 1983).
+% Version 1.7 introduced the new change file format (June, 1983).
+% Version 2 was released in July, 1983, with version 0.999 of TeX.
+% Version 2.1 corrected a bug in changed_module reckoning (August, 1983).
+% Version 2.2 corrected it better (August, 1983).
+% Version 2.3 starts the output with \input webmac (August, 1983).
+% Version 2.4 fixed a bug in compress(#) (September, 1983).
+% Version 2.5 cleared xrefswitch after module names (November, 1983).
+% Version 2.6 fixed a bug in declaration of trans array (January, 1984).
+% Version 2.7 fixed a bug in real constants (August, 1984).
+% Version 2.8 fixed a bug in change_buffer movement (August, 1985).
+% Version 2.9 increased max_refs and max_toks to 30000 each (January, 1987).
+% Version 3, for Sewell's book, fixed long-line bug in input_ln (March, 1989).
+% Version 3.1 fixed a bug for programs with only one module (April, 1989).
+% Version 4 was major change to allow 8-bit input (September, 1989).
+% Version 4.1, for Breitenlohner, avoids English-only output (March, 1990).
+% Version 4.2 conforms to ANSI standard for-loop rules (September, 1990).
+% Version 4.3 catches extra } in input (Breitenlohner, September, 1991).
+% Version 4.4 corrects changed_module logic, %-overflow (January, 1992).
+% Version 4.5 corrects archaic @@z logic and empty change file (January, 2021).
+ at y
+% But it is not polished either, so you probably shouldn't try....
+% Version 2.8 (based on WEAVE 2.8) was hacked together on 28 Sep 1985.
+% Version 2.9 fixed output for dtype_string (14 Jun 1987).
+% Version 4.5 (based on WEAVE 4.5) was hacked together on 04 Jan 2022.
+ at z
+
+ at x 48c24
+ \centerline{\titlefont The {\ttitlefont WEAVE} processor}
+ at y
+ \centerline{\titlefont The {\ttitlefont TWILL} processor}
+ at z
+
+ at x 43c19
+\let\maybe=\iffalse
+\def\title{WEAVE changes for C}
+ at y
+\let\maybe=\iftrue
+\def\title{TWILL for \TeX~Live}
+ at z
+
+Section 1.
+
+ at x 54a31,35
+@* Introduction.
+ at y
+@* Introduction.
+[Apology: This modification of \.{WEAVE} was put together hastily at the
+end of September, 1985, in order to prepare the listing of \TeX,
+on the WAITS system. No attempt has been made to polish anything
+or to make this code usable by anyone else but its author.]
+
+ at z
+
+ at x 77c58
+ at d banner=='This is WEAVE, Version 4.5'
+ at y
+ at d banner=='This is TWILL, Version 4.5'
+ at z
+
+Section 8.
+
+ at x 203a185
+@!stack_size=2000; {number of simultaneous output levels}
+ at y
+@!stack_size=2000; {number of simultaneous output levels}
+@!max_new_refs=200; {number of different references to other modules}
+ at z
+
+Section 37.
+
+ at x 742a725
+@!xref: array [0..max_names] of sixteen_bits; {heads of cross-reference lists}
+ at y
+@!xref: array [0..max_names] of sixteen_bits; {heads of cross-reference lists}
+@!def_val: array [0..max_names] of integer; {values of numeric macros}
+ at z
+
+Section 46.
+
+ at x 889a873,876
+ at d xlink(#)==xmem[#].xlink_field
+ at y
+ at d xlink(#)==xmem[#].xlink_field
+ at d dtype(#)==xmem[#].dtype_field
+ at d dname(#)==xmem[#].dname_field
+ at d dback(#)==xmem[#].dback_field
+ at d dlink(#)==xmem[#].dlink_field
+ at z
+
+Section 48.
+
+ at x 895c882,899
+@ @<Globals...@>=
+ at y
+@ Definitions are classified into 15 types.
+ at d dtype_none=0
+ at d dtype_macro=1
+ at d dtype_const=2
+ at d dtype_string=3
+ at d dtype_colon_bold=4
+ at d dtype_equal_bold=5
+ at d dtype_colon_packed=6
+ at d dtype_equal_packed=7
+ at d dtype_colon_ital=8
+ at d dtype_equal_ital=9
+ at d dtype_comma=10
+ at d dtype_colon_const_dots=11
+ at d dtype_equal_const_dots=12
+ at d dtype_colon_ital_dots=13
+ at d dtype_equal_ital_dots=14
+
+@<Globals...@>=
+ at z
+
+ at x 898a903,906
+ @!xlink_field: sixteen_bits; {pointer to the previous cross reference}
+ at y
+ @!xlink_field: sixteen_bits; {pointer to the previous cross reference}
+ @!dtype_field: sixteen_bits; {type of definition}
+ @!dname_field: sixteen_bits; {identifier or constant}
+ @!dback_field: sixteen_bits; {if nonzero, this is a reference to name}
+ @!dlink_field: sixteen_bits; {link to definitions only}
+ at z
+
+ at x 901a910,912
+@!xref_switch,@!mod_xref_switch:0..def_flag; {either zero or |def_flag|}
+ at y
+@!xref_switch,@!mod_xref_switch:0..def_flag; {either zero or |def_flag|}
+@!def_type,@!def_name,@!def_subtype,@!def_subname,
+ @!const_name,@!packed_name:integer;
+@!danger_zone:boolean;
+ at z
+
+Section 49.
+
+ at x 903a915
+@ @<Set init...@>=xref_ptr:=0; xref_switch:=0; mod_xref_switch:=0; num(0):=0;
+ at y
+@ @<Set init...@>=xref_ptr:=0; xref_switch:=0; mod_xref_switch:=0; num(0):=0;
+danger_zone:=false;
+ at z
+
+Section 50.
+
+ at x 908a...
+to one-letter identifiers or \PASCAL's reserved words.
+ at y
+to one-letter identifiers or \PASCAL's reserved words.
+
+The |new_blank_xref| is similar but it ignores the |xref_switch|.
+ at z
+
+ at x 911a924
+ else begin incr(xref_ptr); num(xref_ptr):=#;
+ at y
+ else begin incr(xref_ptr); num(xref_ptr):=#;
+ dback(xref_ptr):=0;
+ at z
+
+ at x 925,926c938,942
+ begin num(q):=m; return;
+ end;
+ at y
+ if (def_type>=dtype_comma) or danger_zone then
+ q:=xlink(q) {delete entry}
+ else begin num(q):=m; dtype(q):=def_type;
+ dname(q):=def_name; dback(q):=p; return;
+ end;
+ at z
+
+ at x 928,929c945,952
+append_xref(m); xlink(xref_ptr):=q; xref[p]:=xref_ptr;
+exit: end;
+ at y
+append_xref(m); xlink(xref_ptr):=q; xref[p]:=xref_ptr;
+if m>def_flag then
+ begin dtype(xref_ptr):=def_type; dname(xref_ptr):=def_name;
+ dback(xref_ptr):=p;
+ if def_type>dtype_comma then
+ begin append_xref(0); dtype(xref_ptr):=def_subtype;
+ dname(xref_ptr):=def_subname;
+ end;
+ end;
+exit: end;
+@#
+procedure new_blank_xref(@!p:integer);
+var xs:integer;
+begin xs:=xref_switch; xref_switch:=0; new_xref(p); xref_switch:=xs;
+end;
+ at z
+
+Section 62.
+
+ at x 1064a1096,1097
+@ When we begin the following segment of the program, |p=name_ptr|.
+ at y
+@ When we begin the following segment of the program, |p=name_ptr|.
+
+ at d undef_val==10000000
+
+ at z
+
+ at x 1074c1107
+ilk[p]:=t; xref[p]:=0;
+ at y
+ilk[p]:=t; xref[p]:=0; def_val[p]:=undef_val;
+ at z
+
+Section 64.
+
+ at x 1112c1145
+id5("c")("o")("n")("s")("t")(const_like);@/
+ at y
+id5("c")("o")("n")("s")("t")(const_like); const_name:=cur_name;@/
+ at z
+
+ at x 1130c1163
+id6("p")("a")("c")("k")("e")("d")(goto_like);@/
+ at y
+id6("p")("a")("c")("k")("e")("d")(goto_like); packed_name:=cur_name;@/
+ at z
+
+Section 71.
+
+ at x 1278,1279d1310
+@!change_pending: boolean; {if |true|, the current change is not yet
+ recorded in |changed_module[module_count]|}
+ at y
+ at z
+
+Section 79.
+
+ at x 1371,1383d1401
+When a match is found, the current module is marked as changed unless
+the first line after the \.{@@x} and after the \.{@@y} both start with
+either |'@@*'| or |'@@ '| (possibly preceded by whitespace).
+
+ at d if_module_start_then_make_change_pending(#)==
+ loc:=0; buffer[limit]:="!";
+ while (buffer[loc]=" ")or(buffer[loc]=tab_mark) do incr(loc);
+ buffer[limit]:=" ";
+ if buffer[loc]="@@" then
+ if (buffer[loc+1]="*") or
+ (buffer[loc+1]=" ") or (buffer[loc+1]=tab_mark) then
+ change_pending:=#
+
+ at y
+ at z
+
+ at x 1389,1393d1406
+change_pending:=false;
+if not changed_module[module_count] then
+ begin if_module_start_then_make_change_pending(true);
+ if not change_pending then changed_module[module_count]:=true;
+ end;
+ at y
+ at z
+
+Section 82.
+
+ at x 1450,1454c1463,1469
+begin restart:if changing then
+ @<Read from |change_file| and maybe turn off |changing|@>;
+if not changing then
+ begin @<Read from |web_file| and maybe turn on |changing|@>;
+ if changing then goto restart;
+ at y
+begin restart: if changing then changed_module[module_count]:=true
+else @<Read from |web_file| and maybe turn on |changing|@>;
+if changing then
+ begin @<Read from |change_file| and maybe turn off |changing|@>;
+ if not changing then
+ begin changed_module[module_count]:=true; goto restart;
+ end;
+ at z
+
+Section 83.
+
+ at x 1462c1477,1479
+else if change_limit>0 then check_change;
+ at y
+else if limit=change_limit then
+ if buffer[0]=change_buffer[0] then
+ if change_limit>0 then check_change;
+ at z
+
+Section 84.
+
+ at x 1472,1479c1489
+if limit>0 then {check if the change has ended}
+ begin if change_pending then
+ begin if_module_start_then_make_change_pending(false);
+ if change_pending then
+ begin changed_module[module_count]:=true; change_pending:=false;
+ end;
+ end;
+ buffer[limit]:=" ";
+ at y
+if limit>1 then {check if the change has ended}
+ at z
+
+ at x 1491d1500
+ end;
+ at y
+ at z
+
+Section 88.
+
+ at x 1594a1604,1606
+"0","1","2": begin tracing:=c-"0"; control_code:=ignore;
+ at y
+"0","1","2": begin tracing:=c-"0"; control_code:=ignore;
+"3": begin @{'*****************************************************'@}
+ control_code:=ignore; {to set a breakpoint}
+ end;
+ at z
+
+Section 110.
+
+ at x 1965c2032
+changed_module[module_count]:=changing;
+ at y
+changed_module[module_count]:=false;
+ at z
+
+Section 111.
+
+ at x 1991c...
+ at p procedure Pascal_xref; {makes cross references for \PASCAL\ identifiers}
+ at y
+ at p @<Functions |scan_const| and |scan_exp|@>
+@#
+procedure Pascal_xref; {makes cross references for \PASCAL\ identifiers}
+ at z
+
+ at x 1992c2059
+label exit;
+ at y
+label exit,done,found,not_found;
+ at z
+
+ at x 1993a2061
+var p:name_pointer; {a referenced name}
+ at y
+var p:name_pointer; {a referenced name}
+@!eq:0..3; {addition to |dtype| code}
+ at z
+
+ at x 1997c2065,2069
+ begin p:=id_lookup(next_control-identifier); new_xref(p);
+ at y
+ begin p:=id_lookup(next_control-identifier);
+ if next_control=identifier then if xref_switch<>0 then if ilk[p]=normal then
+ @<Figure out the |def_type| and |def_name|, etc.@>;
+ new_xref(p);
+ danger_zone:=(def_type=dtype_comma);
+ at z
+
+ at x 1999a2072,2078
+ xref_switch:=def_flag; {implied `\.{@@!}'}
+ at y
+ xref_switch:=def_flag; {implied `\.{@@!}'}
+ if ilk[p]=proc_like then
+ begin def_name:=p; next_control:=get_next;
+ if next_control<>identifier then goto done;
+ if xref_switch=0 then goto done;
+ p:=id_lookup(normal); def_type:=dtype_colon_bold;
+ new_xref(p);
+ end;
+ at z
+
+ at x 2002c2081
+ if (next_control="|")or(next_control="{") then return;
+ at y
+done: if (next_control="|")or(next_control="{") then return;
+ at z
+
+Section 115.
+
+ at x 2061c2208,2226
+ if next_control=definition then next_control:=get_next
+ at y
+ if next_control=definition then
+ begin next_control:=get_next;
+ if next_control=identifier then
+ begin lhs:=id_lookup(normal);
+ next_control:=get_next;
+ if (next_control=equivalence_sign)or(next_control="(") then
+ begin def_type:=dtype_macro; new_xref(lhs);
+ end
+ else if next_control="=" then
+ begin xref_switch:=0; next_control:=get_next;
+ def_val[lhs]:=scan_exp;
+ def_name:=def_val[lhs]; def_type:=dtype_const;
+ xref_switch:=def_flag;
+ if abs(def_name)>=32768 then def_type:=dtype_macro
+ else if def_name<0 then def_name:=def_name+65536;
+ new_xref(lhs);
+ end;
+ end;
+ end
+ at z
+
+Section 124.
+
+ at x 2199,2201c2364
+`\.{\\input webmac}'.
+ at .\\input webmac@>
+ at .webmac@>
+ at y
+`\.{\\input twimac}'.
+ at .\\input twimac@>
+ at .twimac@>
+ at z
+
+ at x 2204c2367
+out_ptr:=1; out_line:=1; out_buf[1]:="c"; write(tex_file,'\input webma');
+ at y
+out_ptr:=1; out_line:=1; out_buf[1]:="c"; write(tex_file,'\input twima');
+ at z
+
+Section 125.
+
+ at x 2219a2383,2389
+ at d oot5(#)==oot(#)@,oot4
+ at y
+ at d oot5(#)==oot(#)@,oot4
+ at d oot6(#)==oot(#)@,oot5
+ at d oot7(#)==oot(#)@,oot6
+ at d oot8(#)==oot(#)@,oot7
+ at d oot9(#)==oot(#)@,oot8
+ at d oot10(#)==oot(#)@,oot9
+ at d oot11(#)==oot(#)@,oot10
+ at d oot12(#)==oot(#)@,oot11
+ at z
+
+ at x 2224a2395,2401
+ at d out5==@+begin oot5
+ at y
+ at d out5==@+begin oot5
+ at d out6==@+begin oot6
+ at d out7==@+begin oot7
+ at d out8==@+begin oot8
+ at d out9==@+begin oot9
+ at d out10==@+begin oot10
+ at d out11==@+begin oot11
+ at d out12==@+begin oot12
+ at z
+
+Section 130.
+
+ at x 2273c...
+@ The number to be converted by |out_mod| is known to be less than
+|def_flag|, so it cannot have more than five decimal digits. If
+the module is changed, we output `\.{\\*}' just after the number.
+ at y
+@ The number to be converted by |out_mod| is known to be less than
+|def_flag|, so it cannot have more than five decimal digits.
+ at z
+
+ at x 2285d
+if changed_module[m] then out2("\")("*");
+ at .\\*@>
+ at y
+ at z
+
+Section 133.
+
+ at x 2333,2334c2510,2512
+ out("@@");
+ if c<>"@@" then err_print('! Double @@ required outside of sections');
+ at .Double \AT! required...@>
+ at y
+ if (c<>"z")and(c<>"Z") then
+ begin out("@@");
+ if c<>"@@" then err_print('! Double @@ required outside of sections');
+ at .Double \AT! required...@>
+ end;
+ at z
+
+Section 183.
+
+ at x 3522a3702
+@!p:name_pointer; {identifier designator}
+ at y
+@!p:name_pointer; {identifier designator}
+@!q,@!qq,@!r:integer; {registers for new reference insertion loop}
+ at z
+
+Section 191.
+
+ at x 3698a3879
+begin p:=id_lookup(normal);
+ at y
+begin p:=id_lookup(normal);
+if ilk[p]=normal then @<Insert a new reference, if this is new@>;
+ at z
+
+Section 197.
+
+ at x 3816c...
+ at p function Pascal_translate: text_pointer;
+ at y
+ at d flaky=1
+ at d guaranteed=0
+
+ at p function Pascal_translate: text_pointer;
+ at z
+ at x 3819c4033
+begin save_base:=scrap_base; scrap_base:=scrap_ptr+1;
+ at y
+begin save_base:=scrap_base; scrap_base:=scrap_ptr+1; safety:=flaky;
+ at z
+
+ at x 3827c4041
+Pascal_translate:=p;
+ at y
+safety:=guaranteed; Pascal_translate:=p;
+ at z
+
+Section 218.
+
+ at x 4226c4440
+module_count:=0;
+ at y
+module_count:=0; xx:=0;
+ at z
+
+ at x 4228a4443
+finish_line; flush_buffer(0,false,false); {insert a blank line, it looks nice}
+ at y
+finish_line; flush_buffer(0,false,false); {insert a blank line, it looks nice}
+@<Prepare high-speed access to definitions via |dlink| and |def_val|@>;
+ at z
+
+Section 220.
+
+ at x 4249a4492,4493
+begin incr(module_count);@/
+ at y
+begin incr(module_count);@/
+mm:=module_count+def_flag; ref_link[0]:=0; ref_loc[0]:=0; new_ref_ptr:=0;
+safety:=guaranteed;
+ at z
+
+Section 236.
+
+ at x 4503a4749
+if flag=0 then out("U")@+else out("A");
+ at y
+if flag=0 then out("U")@+else out("A");
+out8(" ")("s")("e")("c")("t")("i")("o")("n");
+ at z
+
+ at x 4514,4515c4760
+ at .\\As@>
+ at .\\Us@>
+ at y
+out("~");
+ at z
+
+Section 237.
+
+ at x 4519,4524c4764,4767
+ if num(xlink(cur_xref))>flag then out2(",")(" ") {not the last}
+ else begin out3("\")("E")("T"); {the last}
+ at .\\ET@>
+ if cur_xref<>xlink(q) then out("s"); {the last of more than two}
+ at .\\ETs@>
+ end;
+ at y
+ if (num(xlink(cur_xref))>flag)or(cur_xref<>xlink(q)) then out(",");
+ {not the last of two}
+ out(" ");
+ if num(xlink(cur_xref))<=flag then out4("a")("n")("d")("~"); {the last}
+ at z
+
+Section 238.
+
+ at x 4529c4772,4776
+out3("\")("f")("i"); finish_line;
+ at y
+out6("\")("m")("i")("n")("i")("%");
+ at .\\mini@>
+beta_out;
+flush_buffer(out_ptr,false,false);
+out4("}")("\")("F")("I"); finish_line;
+ at z
+
+ at x 4531c4778,4893
+ at .\\fi@>
+ at y
+ at .\\FI@>
+ at z
+
+Section 241.
+
+ at x 4561a4924
+k_module:=1;
+ at y
+k_module:=1;
+while not changed_module[k_module] do incr(k_module);
+ at z
+
+ at x 4563,4568d4925
+while k_module<module_count do
+ begin if changed_module[k_module] then
+ begin out_mod(k_module); out2(",")(" ");
+ end;
+ incr(k_module);
+ end;
+ at y
+ at z
+
+ at x 4569a4927,4929
+out_mod(k_module);
+ at y
+out_mod(k_module);
+repeat repeat incr(k_module)@+ until changed_module[k_module];
+ out2(",")(" "); out_mod(k_module);
+until k_module=module_count;
+ at z
+
+Section 254.
+
+ at x 4726c5086,5093
+if cur_val<def_flag then out_mod(cur_val)
+ at y
+if cur_val<def_flag then
+ begin out_mod(cur_val);
+ if cur_val+1=num(xlink(cur_xref)) then
+ begin out2("-")("-");
+ repeat cur_xref:=xlink(cur_xref); incr(cur_val);
+ until cur_val+1<>num(xlink(cur_xref)); out_mod(cur_val);
+ end;
+ end
+ at z
+
+Section 261.
+
+ at x 4842c...
+ at p procedure Phase_I;
+ at y
+ at p @<Functions |alpha_out|, |beta_out|, and helpers@>
+@#
+procedure Phase_I;
+ at z
+
+ at x 4846a5214
+procedure Phase_II;
+ at y
+procedure Phase_II;
+var lhs:integer;
+ at z
+
+Section 264.
+
+ at x WEAVE.CH
+ usage_help (WEAVE_HELP, nil);
+ at y
+ usage_help (TWILL_HELP, nil);
+ at z
+
+ at x
+@!web_name,@!chg_name,@!tex_name:const_c_string;
+ at y
+@!web_name,@!chg_name,@!tex_name:const_c_string;
+
+@* New material for \.{TWILL}.
+Here's a new subroutine needed for \.{TWILL}. Assuming that |next_control|
+is the beginning of a numeric constant, and that string constants have
+length~1, the |scan_const| function returns the value of the constant
+and sets |next_control| to the following token.
+
+@<Functions |scan_const| and |scan_exp|@>=
+function scan_const:integer;
+label done;
+var radix,accum,p:integer;
+begin if next_control=string then
+ begin accum:=buffer[id_first+1]; next_control:=get_next; goto done;
+ end
+else if next_control=identifier then
+ begin p:=id_lookup(normal); new_blank_xref(p);
+ accum:=def_val[p]; next_control:=get_next; goto done;
+ end
+else begin accum:=0;
+ if next_control=hex then radix:=16
+ else if next_control=octal then radix:=8
+ else begin radix:=10; accum:=next_control-"0";
+ end;
+ loop begin next_control :=get_next;
+ if next_control<"0" then goto done;
+ if radix=16 then
+ begin if (next_control>="A")and(next_control<="F") then
+ next_control:=next_control-"A"+"0"+10
+ else if next_control>"9" then goto done;
+ end
+ else if next_control>="0"+radix then goto done;
+ accum:=accum*radix+next_control-"0";
+ end;
+ end;
+done: scan_const:=accum;
+end;
+
+@ Simple linear arithmetic is handled by the following
+subroutine, which doesn't complain about certain syntactic errors.
+
+ at d start_of_const(#)==(((#>="0")and(#<="9"))or(#=hex)or(#=octal)or(#=string)
+ or(#=identifier))
+ at d sign(#)==(abs(#-",")=1)
+ at d start_of_num(#)==(start_of_const(#)or sign(#))
+
+@<Functions |scan_const| and |scan_exp|@>=
+function scan_exp:integer;
+label done;
+var accum,s:integer;
+begin if sign(next_control) then accum:=0
+else accum:=scan_const;
+loop begin if not sign(next_control) then goto done;
+ s:=","-next_control; next_control:=get_next;
+ if not start_of_const(next_control) then goto done;
+ accum:=accum+s*scan_const;
+ end;
+done:scan_exp:=accum;
+end;
+
+@ @d found_it(#)==begin def_type:=#; goto found; end
+
+@<Figure out the |def_type| and |def_name|, etc.@>=
+begin next_control:=get_next;
+if next_control="," then found_it(dtype_comma);
+if(next_control=":")or(next_control="=") then
+ @<Figure out a type and |goto| either |found| or |not_found|@>;
+not_found:def_type:=dtype_none; new_xref(p); goto done;
+found: end
+
+@ @<Figure out a type and...@>=
+begin eq:=(next_control-":") div ("="-":");
+next_control:=get_next;
+if next_control=identifier then
+ @<Figure out a type starting with an identifier;
+ |goto| |found| or |not_found| unless it's a subrange@>
+else if (next_control=string)and(id_loc-id_first>2) then found_it(dtype_string)
+else if start_of_num(next_control) then
+ @<Figure out a type starting with a constant;
+ |goto| |found| or |not_found| unless it's a subrange@>
+else goto not_found;
+next_control:=get_next;
+if next_control=identifier then
+ begin def_subname:=id_lookup(normal);
+ if ilk[def_subname]<>normal then goto not_found;
+ if def_val[def_subname]=undef_val then
+ begin new_blank_xref(def_subname);
+ def_subtype:=dtype_colon_ital_dots; goto found;
+ end;
+ end;
+if start_of_num(next_control) then
+ begin def_subname:=scan_exp; def_subtype:=dtype_colon_const_dots;
+ if abs(def_subname)>=32768 then goto not_found;
+ if def_subname<0 then def_subname:=def_subname+65536;
+ goto found;
+ end;
+goto not_found;
+end
+
+@ @<Figure out a type starting with an identifier...@>=
+begin def_name:=id_lookup(normal);
+if ilk[def_name]=goto_like then {\&{packed}}
+ begin next_control:=get_next; eq:=eq+2;
+ if next_control<>identifier then goto not_found;
+ def_name:=id_lookup(normal);
+ end;
+if (ilk[def_name]=array_like)or(ilk[def_name]=record_like) then
+ found_it(dtype_colon_bold+eq);
+if ilk[def_name]<>normal then goto found;
+new_blank_xref(def_name);
+if def_val[def_name]=undef_val then
+ begin next_control:=get_next;
+ if next_control=double_dot then def_type:=dtype_colon_ital_dots+eq
+ else found_it(dtype_colon_ital+eq);
+ end
+else @<Figure out a type starting with a constant...@>;
+end
+
+@ @<Figure out a type starting with a constant...@>=
+begin def_name:=scan_exp;
+if next_control<>double_dot then
+ if eq=1 then found_it(dtype_equal_bold; def_name:=const_name)
+ else goto not_found;
+if abs(def_name)>=32768 then goto not_found;
+if def_name<0 then def_name:=def_name+65536;
+def_type:=dtype_colon_const_dots+eq;
+end
+
+@ Some identifiers can be inserted during Phase II that weren't
+seen in Phase I (namely, if they appear only in module names);
+so we have to watch out that |def_val| might be |undef_val|.
+
+@<Insert a new reference, if this is new@>=
+begin q:=def_val[p];
+if q<>0 then if q<>undef_val then if not phase_three then
+ begin repeat r:=q; q:=dlink(q);
+ until (q=0) or (num(q)>mm);
+ if num(r)<>mm then
+ begin qq:=0; q:=ref_link[0];
+ while ref_loc[q]>r do
+ begin qq:=q; q:=ref_link[qq];
+ end;
+ if ref_loc[q]=r then
+ begin if safety=guaranteed then
+ if ref_safety[q]=flaky then ref_safety[q]:=guaranteed;
+ end
+ else begin if new_ref_ptr=max_new_refs then overflow('new references');
+ incr(new_ref_ptr);
+ ref_link[new_ref_ptr]:=q; ref_link[qq]:=new_ref_ptr;
+ ref_loc[new_ref_ptr]:=r;
+ if dlink(def_val[p])=0 then ref_safety[new_ref_ptr]:=guaranteed
+ else ref_safety[new_ref_ptr]:=safety;
+ end;
+ end;
+ end;
+end
+
+@ @<Prepare high-speed access to definitions via |dlink| and |def_val|@>=
+for lhs:=1 to name_ptr do if ilk[lhs]=normal then
+ begin def_val[lhs]:=0; rhs:=xref[lhs];
+ while rhs<>0 do
+ begin if num(rhs)>def_flag then
+ begin dlink(rhs):=def_val[lhs];
+ def_val[lhs]:=rhs;
+ end;
+ rhs:=xlink(rhs);
+ end;
+ end
+
+@ We keep a separate list of all references made in the current module,
+sorted by |xref| number. A reference is considered to need manual checking
+if it appears only in a comment within the section and if the corresponding
+identifier is multiply defined.
+
+@<Glob...@>=
+@!mm:integer; {current module number plus |def_flag|}
+@!ref_loc:array[0..max_new_refs] of sixteen_bits;
+@!ref_link:array[0..max_new_refs] of sixteen_bits;
+@!ref_safety:array[0..max_new_refs] of guaranteed..flaky;
+@!new_ref_ptr:0..max_new_refs;
+@!safety:guaranteed..flaky;
+@!xx:xref_number;
+
+@ The |alpha_out| procedure makes entries for all identifiers defined
+in the current module. (However, I no longer need these!)
+
+@<Functions |alpha_out|, |beta_out|, and helpers@>=
+procedure alpha_out;
+label exit;
+var p,w,k:integer;
+begin loop begin
+ if xx=xref_ptr then return;
+ if num(xx+1)>mm then return;
+ incr(xx);
+ if num(xx)>def_flag then if dback(xx)>0 then
+ if ilk[dback(xx)]=normal then
+ begin flush_buffer(out_ptr,false,false);
+ out5("\")("m")("i")("n")("i");
+ at .\\mini@>
+ p:=dback(xx);
+ w:=p mod ww;
+ for k:=byte_start[p] to byte_start[p+ww]-1 do out(byte_mem[w,k]);
+ if dtype(xx)>dtype_comma then incr(xx);
+ end;
+ end;
+exit:end;
+
+@ Here's a procedure that's very much like |out_mod|.
+
+@<Functions |alpha_out|, |beta_out|, and helpers@>=
+procedure out_const(@!n:sixteen_bits);
+var a,k:integer;
+begin a:=n; k:=0;
+if a>=32768 then
+ begin out("-"); a:=65536-a;
+ end;
+repeat dig[k]:=a mod 10; a:=a div 10; incr(k);
+until a=0;
+repeat decr(k); out(dig[k]+"0");
+until k=0;
+end;
+
+@ And here's something that could have been made a subroutine earlier.
+
+@<Functions |alpha_out|, |beta_out|, and helpers@>=
+procedure out_id(@!p:integer);
+begin out("\");
+if ilk[p]=normal then
+ if length(p)=1 then out("|")
+ at .\\|@>
+ else out("\")
+ at .\\\\@>
+else out("&");
+ at .\\\&@>
+if length(p)=1 then out(byte_mem[p mod ww,byte_start[p]])
+else out_name(p);
+end;
+
+@ The |beta_out| procedure makes entries for all identifiers used
+but not defined in the current module.
+
+@<Functions |alpha_out|, |beta_out|, and helpers@>=
+procedure beta_out;
+label done,888,found;
+var k,p,q,w,xx,mmm:integer;
+begin p:=ref_link[0];
+while p<>0 do
+ begin flush_buffer(out_ptr,false,false);
+ out2("\")("[");
+ xx:=ref_loc[p]; q:=dback(xx); w:=q mod ww;
+ for k:=byte_start[q] to byte_start[q+ww]-1 do out(byte_mem[w,k]);
+ out(" "); out_const(num(xx)-def_flag);
+ out(" ");
+ @<Move past commas@>;
+ @<Output the reference, based on its |dtype|@>;
+ if ref_safety[p]=flaky then out3(" ")("%")("?");
+ p:=ref_link[p];
+ end;
+end;
+
+@ @<Output the reference, based on its |dtype|@>=
+case dtype(xx) of
+dtype_none: out5("\")("n")("o")("n")("e");
+dtype_macro: out6("=")("m")("a")("c")("r")("o");
+dtype_const: begin out2("=")("$"); out_const(dname(xx)); out("$");
+ end;
+dtype_string:
+ out12("\")(".")("{")("""")("s")("t")("r")("i")("n")("g")("""")("}");
+dtype_colon_bold,dtype_colon_ital: begin out(":"); out_id(dname(xx)); end;
+dtype_equal_bold,dtype_equal_ital: begin out("="); out_id(dname(xx)); end;
+dtype_colon_packed: begin out(":"); out_id(packed_name); out2("\")(" ");
+ out_id(dname(xx)); end;
+dtype_equal_packed: begin out("="); out_id(packed_name); out2("\")(" ");
+ out_id(dname(xx)); end;
+dtype_colon_const_dots: begin out2(":")("$"); out_const(dname(xx));
+ goto 888; end;
+dtype_equal_const_dots: begin out2("=")("$"); out_const(dname(xx));
+ goto 888; end;
+dtype_colon_ital_dots: begin out2(":")("$"); out_id(dname(xx)); goto 888; end;
+dtype_equal_ital_dots: begin out2("=")("$"); out_id(dname(xx)); goto 888; end;
+end; {there are no other cases}
+goto found;
+888: out3("\")("t")("o");
+ if dtype(xx+1)=dtype_colon_ital_dots then
+ out_id(dname(xx+1))
+ else out_const(dname(xx+1));
+ out("$");
+found:
+
+@ @<Move past commas@>=
+mmm:=num(xx);
+loop begin if dtype(xx)<>dtype_comma then if num(xx)=mmm then goto done;
+ if xx=xref_ptr then
+ begin dtype(xx):=dtype_none; goto done;
+ end;
+ if num(xx+1)>mmm then
+ begin dtype(xx):=dtype_none; goto done;
+ end;
+ incr(xx);
+ end;
+done:
+ at z
Property changes on: trunk/Build/source/texk/web2c/weav-twill.ch
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Modified: trunk/Build/source/texk/web2c/web2c/ChangeLog
===================================================================
--- trunk/Build/source/texk/web2c/web2c/ChangeLog 2022-01-06 00:48:34 UTC (rev 61508)
+++ trunk/Build/source/texk/web2c/web2c/ChangeLog 2022-01-06 11:08:43 UTC (rev 61509)
@@ -1,3 +1,7 @@
+2022-01-06 Andreas Scherer <https://ascherer.github.io>
+
+ * common.defines: New TWILLHELP.
+
2021-03-23 Karl Berry <karl at tug.org>
* TL'21.
Modified: trunk/Build/source/texk/web2c/web2c/common.defines
===================================================================
--- trunk/Build/source/texk/web2c/web2c/common.defines 2022-01-06 00:48:34 UTC (rev 61508)
+++ trunk/Build/source/texk/web2c/web2c/common.defines 2022-01-06 11:08:43 UTC (rev 61509)
@@ -94,6 +94,7 @@
@define const VFTOVPHELP;
@define const VPTOVFHELP;
@define const WEAVEHELP;
+ at define const TWILLHELP;
@define function abs ();
@define function addressof ();
More information about the tex-live-commits
mailing list.