-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathChangeLog
1332 lines (957 loc) · 48.7 KB
/
ChangeLog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
Fri, Dec 10 2021
* zoem-21-341 released.
* Zoem is still as stable as it has been for the last ten years.
No development or features are planned, with changes limited to bug
fixes, documentation, and potentially code triage focussed on
clarification of corner cases and tightening of weird nesting patterns
involving file I/O.
* Zoem source is now hosted on github.com/micans/zoem .
Compiling zoem now requires installation of cimfomfa, a C utility library.
Cimfomfa is hosted on github.com/mican/cimfomfa .
Tar releases will for the foreseeable future still be hosted on
micans.org/zoem and micans.org/cimfomfa .
Previously cimfomfa was imported in the zoem source tree, but this
practice has stopped. The zoem source tree contains a script that
will download both cimfomfa and zoem tar archives and compile both.
* Fixed bug in let#1 (this is a cimfomfa bug); it would think that
'abs(2) == abs(1)' is true. The cause was a combination of two things:
failure to maintain float/integer correspondence by abs and other
functions, and a wrong ternary cascade that would check float
(in)equality even if the integer (in)equality test was already
conclusive.
Wed, Jun 15 2011
* zoem-11-166 released.
* The default search path was changed. The obsolete PREFIX/zoem/mac
component was dropped, and PREFIX/aephea was added. Now, if zoem and
aephea are both configured with the same prefix for installation (e.g.
--prefix=/usr/local or --prefix=$HOME/local), then aephea include files
will be found automatically by zoem.
* set#3 can now splice into a variable (that is, the string
refered to by a macro). This is achieved by pairing the respective
keys {start} and {width} with appropriate values in the first
argument to set#3. The start position is relative to an offst
of zero, so
\set{foo}{kaboom}
\set{{start}{2}{width}{3}}{foo}{za}
'\foo'
yields 'kazam'.
* The example zoem solution 8q2.azm to the N queens problem
has been updated. It now pretty-prints asciific chess boards using the
new splice mode to set#3.
* Small documentation fixes.
Wed, Sep 22 2010
* zoem-10-265 released.
* In interactive mode zoem now utilise readline editing and history
capababilities if available. This can be disabled completely at compile
time or optionally at run time.
* A new builtin macro seq#4 can be used as a simple type of
for loop.
\seq{i}{a}{b}{ ... }
is equivalent to the pseudo code
for (i=a;i<b;i++) {
...
}
Internally, its definition is
\set{\1}{\2}
\while{\let{\get{''}{\1}<\3}}{
\4
\setx{\1}{\let{\get{''}{\1}+1}}
}
* Environments that are not closed at end of processing are now reported in
a diagnostic message.
Fri, Jan 8 2010
* zoem-10-008 released.
* The HTML document framework has been wrapped up and split off under the
name Aephea, Adaptable Exo-skeleton for Practical HTML Extension and
Abstraction. PUD (Portable UNIX Documentation) is now shipped with
Aephea. PUD provides limited support for two mini languages (manuals and
FAQs) for two output devices, troff and HTML. Aephea provides more
elaborate support for a single output device, HTML.
The zoem package from now on provides only resources and documentation
for the macro/programming language zoem itself.
* This release mostly provides improved and streamlined support
for using zoem as a convenient and powerful layer on top of HTML,
providing full extension and abstraction capabilities.
* New device scope syntax was introduced specifically targeted
at HTML: \@e{ent} will expand to the character entity &ent; --
it is equivalent to and minimally shorter than \@{&ent;} .
* Trailing whitespace is removed from the output captured
by \system#3 invocations. This may be made optional in the future.
* Set macros can now be targeted at named dictionaries within the
dictionary stacks (of which there are two, the stack associated with
\begin{} - \end{} environments, and the default user stack). A new get#2
primitive allows getting from named dictionaries.
User stack
Getting: \get{foo}{tim} (looks only in foo dictionaries)
Setting: \set{{dict}{foo}}{tim}{zut} (sets in topmost foo dictionary)
Env stack
Getting: \get{foo}{$tim} (looks only in foo dictionaries)
Setting: \set{{dict}{foo}}{$tim}{zut} (sets in topmost foo dictionary)
The stack type to query is inferred from the key signature. No mechanism
is yet provided to get and use, in this manner, keys that take arguments,
although it can be achieved using apply#2.
* The f#2 (mathematical functions) primitive has new modes (first argument
to f#2) irand and drand for generating respectively integer and double
random numbers within the range specified in the second argument to f#2.
* An update mode for setting keys has been added to set#3, where a key is
required to be already present. The dictionary stack will be traversed
downwards until a key is found. This can be used to update keys in a
first environment from within a second environment. Aliases update#2 and
updatex#2 are provided.
* When the html device is set using the command line option -d html,
zoem automatically sets up mapping tables so that the HTML special
characters are converted where necessary.
* New syntax for HTML/XML tags that do not have an associated close tag,
such as <meta>, <link>, and <hr>. This is now specified in zoem
as for example \<*meta>. The previously accepted syntax \<meta!> is now
deprecated. The new syntax is more reasonable and makes it easier
to recognize such special tags.
* Zoem recognizes special classes of HTML/XML tags that do not have an associated
close tag. For now these are tags that start with '!' or '?'.
Previously accepted syntax such as \<!-- comment --!> is deprecated
and is now simply written \<!-- comment -->.
* The read routines now ignore nul bytes in files, improving zoem's
robustness. It no longer yields unpredictable results on files with
embedded nul bytes.
Fri, Sep 5 2008
* zoem-08-248 released.
* A bug manifested itself on powerpc + linux in the form of a crash,
resulting from using vsnprintf repeatedly without sufficient
corresponding va_start and va_end invocations. On some other platforms
this bug would manifest itself as a mysterious zoem syntax error due to
heap corruption. Fixed. Thanks to Philipp Benner, Tobias Quathamer, and
Joost van Baal for bug reports.
* Two modes for the defined#2 primitive have been renamed.
"prim" has become "primitive" and "alias" has become "builtin",
in line with zoem nomenclature and documentation. This change
is backwards incompatible, but unlikely to affect anyone.
* Option -ndollar was not working. fixed.
Thu, Nov 29 2007
* zoem-07-333 released.
* SYNOPSIS
A bug in set#3 was removed, and two directives were added, namely batch
definitions and a more legible way of appending to keys (see below).
Keys local to environments (aka dollar keys) can now be defined using
the same signature as when invoked, e.g. \begin{env}{{$k1}{v1}{$k2}{v2}}.
This release also continues the focus on retiring what little special
case syntax still exists. The format#2 specification syntax has been
reworked (in an incompatible way) into a standard and extensible
key-value syntax (see below). The format#2 implementation was redone and
several new format#2 directives were added.
xml/html syntactic sugar now stops introducing whitespace formatting
when so instructed with the at directive \@{\w}.
* Fixed bug in set#3 where usage of the {if} or {unless} directive
corrupts state when combined with the {modes}{x} directive.
* xml syntactic sugar cubes now obey the device scope \w directive.
This means that xml elements, in the scope of an at directive
\@{\w} no longer introduce white-space. This only affects the
formatting of the XML/HTML code itself.
This is for example useful when creating <pre> elements.
* The set#3 {modes} directive now accepts a v (for vararg mode)
where a batch of key-value pairs can be defined within a single set#3
invocation. This may improve the readability of resource files
containing many definitions. Example:
\set{{modes}{vw}}{}{
{is_last} {0}
{ctrprev} {0}
{ctrnow} {1}
}
* Introduced append mode in set#3:
\set{foo}{bar}
\set{{modes}{a}}{foo}{bar}
sets foo to barbar.
append#2 is an alias for \set{{modes}{a}}{\1}{\2}
appendx#2 is an alias for \set{{modes}{ax}}{\1}{\2}
Hence append#2 appends to keys without expanding and appendx#2 appends
to keys after expanding the to be appended text.
Keys that are not defined when appended to will first be instantiated
with an empty string.
* Keys local to environments (started by \begin#2) can now
be defined using the same signature as used when invoking them, i.e.
\begin{env}{{$foo}{bar}} as well as \begin{env}{{foo}{bar}}.
* Some bugs were found and removed in the format#2 implementation.
* format#2 has acquired a reuse mode where a format specification
can be be reused a number of times or exhaust all arguments (see below).
It has also acquired the 'border' directive for adding constant strings
to the left and right of the formatted units.
* The tr#2 specification language is now also described in zoem(1), the manual
page of the interpreter. The idea is that all - as few as possible -
special purpose sub-languages will be described in there for ease of
reference.
* The unwieldy format#2 specification language has been redefined to
follow standard zoem syntax using keys and vararg value lists. It is
more verbose, but also more robust, compatibly extensible, powerful, and
more easily understandable. As an example one now writes
\format{
%{{padding}{-=-_}
{delimit}{ }
{align}{left}
{length}{length}
{double}{{{arg}{foo}}}
{width}{40}
}%{
{align}{right}
{width}{40}
}
}{
{arg1}{arg2}
}
rather than
\format{%~{-=-_}{ }<40*{length}{foo}.%>40.}{
{arg1}{arg2}
}
Formerly a format specifier was enclosed inbetween '%' and '.' . It
interpreted special characters '<', '>', and '=', as well as the special
characters '@', '*', '~' each of which had to be followed by two blocks.
The same syntax is now obtained by a more customary key-value structure
encoded as a zoem vararg.
format#2 accepts new directives {border}{{left}{right}},
{delimit}{{left}{right}}, {double}{{[{key}{value}]*}}, and
{reuse}{<num>|*}.
{delimit} parameters decorate the formatted argument on the sides, and
participate in the computations involving width, alignment and padding.
There is no padding inbetween delimiters and the argument to be
formatted.
{border} parameters decorate the entire formatted product and do not
participate in aforementioned computations. Padding is computed and
produced before the borders are added.
{double} can be used have the length computations performed on
fake parameters. This can be useful when certain formatting
elements need to be present in the true parameters.
{reuse}{<num>} will reuse the current specification <num> times,
{reuse}{*} will reuse it until all arguments are exhausted. Thus
\format{%{{align}{right}{width}{10}{reuse}{*}{padding}{{'}{}}}}{
{beauty}{lies}{in}{the}{eye}{of}{the}{beholder}
}
\textmap{{repeat}{8}}{1234567890}
results in
''''beauty''''''lies''''''''in'''''''the'''''''eye''''''''of'''''''the''beholder
12345678901234567890123456789012345678901234567890123456789012345678901234567890
Fri, Nov 9 2007
* zoem-07-313 released.
* \set{''foo}{bar} now works. It sets a key in the bottom (global)
user dictionary. Same semantics as \set{{modes}{g}}{foo}{bar}.
* \undef#1 now checks whether its argument is a valid key signature.
* \undef{''foo} now works.
* Streamlined the error-processing part of the code.
* Added \textmap{{repeat}{<num>}}{<string>} mode. This results in <string>
<num> times repeated. <num> is evaluated before use.
* The special magic comment sequences
\:/ delete rest of line including newline
\:! replace by '\' (for quoting zoem comments)
are now deprecated (but still supported). Preferably use
\:{/}
\:{!}
instead. This syntax is both more robust and more extensible. This
change is similar to previous changes introducing \`{}, \={} and \*{}.
Wed, Jul 25 2007
* zoem-07-205 released.
* Zoem is now licensed under the GNU General Public License version 3
(or later).
* Added \set#3 that provides all the modalities of set#2, setx#2,
def#2, defx#2 (namely optional warning, expansion), as well as
additional modalities. It is possible to define a key conditionally (if
not set already), and a key can be explicitly set in the global (bottom)
user dictionary.
* \''foo will look up foo in the bottom user dictionary, allowing
this dictionary to function as a global namespace.
* Success status, as written in the session macro \__zoemstat__ by try#1
and catch#2 is now associated with the string "done" rather than "ok".
The status "done" can now be explicitly thrown with \throw{done}{}. In
this case the unprocessed part of the current interpretation stack is
discarded, but no error is generated.
When not captured by try#1 or catch#2, \throw{done}{} can be captured by
eval#1 and while#2. If neither of these four primitives catches the
throw, it is captured at the file processing level and results in
end-of-processing for the current file. This is fully equivalent
with what used to be the primitive \done. This primitive has now
been implemented as the alias \throw{done}{}.
* The primitive \done is now implemented as \throw{done}{}.
* Introduced \`{..} syntax, equivalent with \`..` syntax. These are only
available within the \formatted#1 primitive (where .. is a placeholder
for valid formatted#1 directives). This change is similar to previous
changes introducing \={} and \*{}. The old \`..` syntax is deprecated
and if it is used error messages are issued. The rationale for these
changes is that the new syntax is more pleasant on the eye and will be
extendible if needed.
* Added \ifdef#3 and \ifdef#4 aliases. This is the ifdef#3
definition:
\set{ifdef#3}{\if{\defined{\1}{\2}{\3}}}
* \defined{mode}{} now accepts modes 'zoem', 'prim', 'alias'.
mode zoem accepts the combined classes of prim(itives) and
alias.
* The command line option -s accepts 'key' as well as 'key=val'
syntax. In the former case the value of key will be set to '1'.
* Added two solutions to the N-queen problem in the examples directory.
Wed, Dec 13 2006
* zoem-06-347 released.
* Fixed display bug in PUD -- the { itemize, long-item, html, safari }
combination where long-item would be split over lines.
* Clean-ups and modifications in underlying util library (mostly
hash-related).
Wed, Aug 23 2006
* zoem-06-234 released.
* Added beta key \__env__#1 to retrieve environment variable settings.
\defined#2 tests for existence of a name in the environment with
the ENV type.
* Added caveat in zoem(1) and Zoem User Manual documentation;
\done will stop processing the current file only if it was read in its
entirety, i.e. if the chunk size is sufficiently large. The default
chunk size (1Mb) should be more than sufficient for authoring
environments.
* The session key \__fnup__ is set to the file that includes
the current file to aid in diagnostics.
* The underlying utility library was overhauled - it's integer
type system was redone and a more rigorous design was put in place,
following common practices (size_t and ssize_t wise).
Tue, Mar 22 2006
* zoem-06-080 released.
* A number of developments have settled with release. To sum up the most
noteworthy items (C, F and H stem from this release):
A) primitive namespace identification with \'
B) user keys can shadow primitives
+ C) user keys can inspect (vararg) argument structure with \nargs#1
ABC => D) improved facilities for backward compatability
E) PUD or portable UNIX documentation is now a separate entity
+ F) \__line__ now yields what it promises
G) many primitives recoded as user macros (counters and references)
+ H) \switch#2 can group branches
I) \register adds useful processing hook registration
J) \whilst#2 flushes output immediately
* A long standing minor bug has been fixed. Comments up to and including
the newline can be stripped with the sequence \:/.
This used to corrupt the file line counter as seen in the session macro
\__line__ and in error messages. No more.
* \switch#2 can collect several cases together using a vararg.
In the \nargs#1 example below one might use e.g.
\def{test#1}{
\switch{\nargs{\1}}{
{{-1}{-2}} { .. regular stuff .. }
{ .. apply stuff .. }
}
}
to do the same thing for both of the -1 and -2 cases.
Different devices can easily be lumped together using the idiom
\${ {{txt}{roff}} { .. stuff A .. }
{html} { .. stuff B .. }
}
In this case the txt and roff devices pass through the same
branch. \$#1 is a new alias introduced further below.
* Added \nargs#1 primitive which counts the number of scopes in its
argument - WHICH IS NOT EVALUATED. This allows construction of user
macros that can overload one or more particular arguments, i.e. behave
differently depending on the number of scopes in the argument.
A likely application is an argument that either specifies a simple
string (assuming default modes) or a vararg with strings and
modes specified using a key-value vararg.
One usage is to extend a macro's functionality while retaining
backward compatibility.
\nargs{{abc}def} : -2 \: neither fish nor fowl
\nargs{abc} : -1 \: regular argument
\nargs{abc{def}} : -1 \: regular argument too
\nargs{} : 0 \: empty vararg (not empty regular arg)
\nargs{ } : 0 \: empty vararg again
\nargs{{abc}} : 1 \: vararg with 1 argument
\nargs{{abc}{def}} : 2 \: vararg with 2 arguments
\nargs{ {abc}
{def}
} : 2 \: vararg with 2 arguments
etc.
User macros can now use a framework such as
\def{test#1}{
\switch{\nargs{\1}}{
{-2}{\inform{mixed feelings}\exit}
{-1}{ .. regular stuff .. }
{ \switch{\let{\nargs{\1}%2}}{
{0}{\apply{_#2\!{{ .. stuff with \1 and \2 .. }}}{\1}}
{\inform{vararg invocation requires paired arguments\exit}}
}
}
}
}
to branch on scope presence/absence. The purpose of the -2 return value
is to promote frameworks that spot errors early. Group -2 and -1
as {{-2}{-1}} within switch to make them pass through the same branch.
* Added $#1 and $#3 aliases.
$#1 maps to \switch{\__device__}{\1} \: switch
$#3 maps to \switch{\__device__}{{\1}{\2}{\3}} \: ifelse
* within write#3 invocations the key \__fnwrite__ is set to the
appropriate output file name. This allows easy branching on the file
being written to from macros accessed within the third argument. The key
is deleted after evaluation of the third argument has finished. Nested
invocations will currently overwrite this key.
* Spreading \foo over two lines as in
\fo\:/
o
(with the 'o' at the beginning of line) will be correctly parsed
regardless of chunk size.
Wed, 22 Feb 2006
* zoem-06-053 released.
* inspect#4 was broken since the previous release; the parse
code responsible for firing of the callback macro had not
been updated properly. Fixed.
* minor documentation improvements.
* The TODO was shrunk to a more reasonable size and PUD
now has its own DOPUD.
Wed, 15 Feb 2006
* zoem-06-046 released.
* Major clean-ups in both code and documentation. Facilitated
syntactic separation of primitives and user macros.
* (minor) Backward incompatible change in the PUD macro package.
As a further clean-up of the reference framework (in which refload#2
and friends moved to ref.zmm), publanch#2 and publref#1 have now
moved to ref.zmm and have been renamed to reference#2 and refer#1
for better consistency.
ref.zmm is now documented in pud-ref(7).
* pud-ref(7)
pud(7)
were added. The first describes the reference framework, which was
recently removed from the Zoem User Manual as it is no longer
implemented by primitives. The second is an introduction to and an
overview of Portable Unix Documentation.
* The counter primitives \ctradd#2, \ctrset#2, \ctrput#1 and the builtins
\ctrinc#2 and \ctrdec#2 were recoded as user macros in the new macro
package ctr.zmm .
* For primitives or builtins with standard alphabetic names
and the special primitive \$#2 and the special builtins
\"" and \""#1 the syntax
\'standard{arg1}..
\'${arg1}{arg2}
\'""
\'""{arg1}
is now accepted. Moreover, primitive definitions can be shadowed in
the user dictionary. Currently a warning is issued when this happens.
The prefered way of accessing primitives is now with the new syntax.
This makes existing zoem files compatible in case future zoem
primitives clash with user-defined keys.
It also makes works based on such files still extendible since the
new primitive can be unambiguously accessed by the new syntax.
Finally, with the new syntax zoem needs to do less hash table
lookups, making it again slightly faster. Said tiny speed increment
has been fully negated by the redefinition of counter primitives
as user macros however.
* The number of builtin aliases has been cut back.
* The idiosyncratic \> (close XML-type tag) syntax has been removed.
Use \<> or explicit \</foo> style syntax.
* Cleanups and deduplication in the parsing code. Examples:
\apply{<>#2}{{foo}{bar}}
\apply{$#2}{{html}{yes}}
now do something. You probably will not need it.
\def{<>}{foo}
now chokes.
* Documentation fixes and additions.
Tue, 10 Jan 2005
* zoem-06-010 released.
* Assembled the man and FAQ macros under the Portable Unix
Documentation label.
- the man_zmm(7) manual page was renamed to pud-man.
- the faq_zmm(7) manual page was renamed to pud-faq.
- the generic_zmm(7) manual page was renamed to pud-base.
* Redid a lot of documentation. Further separated package descriptions
from core zoem documentation.
Thu 5 Jan 2006
* zoem-06-005 released.
* Pruned the Zoem User Manual to only describe the core zoem language.
Diatribes and mini-language excursions were removed.
* A missing clearerr in util/io.c caused
./zoem --unsafe -E '\register{END}{\system{date}}'
to loop on EOF on at least one architecture (mac OSX). Fixed.
Thu, 24 Nov 2005
* zoem-05-328 released.
* This release contains substantial behind-the-scenes changes.
Oddbal zoem primitives were reimplemented as macros of exisisting
primitives or as special cases of a new more generic primitive. Users of
packages (man, faq, doc) should not be affected, with this exception:
____________________________________________________________________
{ }
{ The new zoem will choke on existing *.zmr and *.zmt auxiliary }
{ files. Remove these and you should be fine. }
{____________________________________________________________________}
The reason being that the primitive refload#6 is now replaced by
the macro refload#2 provided by the new ref.zmm package.
* Added \register#2, use e.g. as
\register{END}{
\if{\ctrput{zoem::ref::misses}}{
\write{stderr}{txt}{>>> [REF] \ctrput{zoem::ref::misses} missing references\|}
}{}
}
This example is from the file ref.zmm that now implements zoem
references. This particular registered macro outputs a warning after all
input has been processed if missing references were found during a run.
Currently only END is supported. registered macros are processed in
the order of registration.
* Reference handling was removed from the core zoem language.
\refload#6 and \ref#2 were reimplemented as simple macros (\refload#2 and
\ref#2) using the zoem data facilities and the new register#2 primitive.
They are found in the new macro file ref.zmm.
\refloadx#2 was added, it can be used to attach custom information to
a reference.
* \ucase#1 \roman#1 and \alpha#1 are reimplemented as simple
macros - and deprecated. They are now specific invocations
of the new \textmap#2 primitive.
* \textmap#2 implements a variety of text transformations. Among them:
{word}{ucase}
{word}{lcase}
{number}{roman}
{number}{alpha}
{caesar}{<num>}
{vigenere}{<key>}
{vigenerex}{<key>}
These transformations are applied sequentially, implying that
\textmap{{number}{roman}{word}{ucase}}{\your_nice_counter}
does what you expect it to do. Use caesar and vigerene[x] to
encrypt your sensitive data.
* Added \whilst2, which sends output to the current output file
without building up intermediate results.
* The tr#4 was sanitized. See further below.
* The zoem output implementation was thoroughly cleansed
and is in a maintainable state now. This bears on the handling of
multiple output sinks (altiplexing?).
Same for environment well-formedness checks. As part of the clean-up an
experimental (but backwards compatible) feature was put in place; see
immediately below.
* This item is important only for people that write their own
environment definitions. Dictionary stacks are now tied to (output)
sinks. This implies that
\begin{foo}
\write{zutfut}{device}{\begin{zut}}
\end{foo}
\write{zutfut}{device}{\end{zut}}
is now legal zoem, and any dollar key within a write scope is tied to the
output stream defined by the write invocation. Different instances of
the same environment spread over different output sinks will thus not
clobber one another.
If a dollar key is not found within some write scope, it is searched
in the default output scope.
* added \genoptref#1 to the generic package, for generic (html) linking to
an option only using the option identifier string.
* The first argument of inspect now takes a vararg rather than
a single string. The modifiers previously accepted as the first
argument are now accepted as argument to the 'mods' key.
So use e.g. \inspect{{mods}{count-matches}}{..}{..}{..}
if counting matches is what you are after.
* Incompatible change in what presumably is one of the
lesser-used primitives.
Removed \tr#4 because its interface was broken beyond repair.
Added \tr#2.
\tr{ {from}{from-spec}
{to}{to-spec}
{delete}{delete-spec}
{squash}{squash-spec}
}{
data
}
Data is unprotected, all specs are subject to tilde expansion.
Specs are largely POSIX compliant except that repeats are
denoted
[*c*20] \: repeat c 20 times
[*\012*20] \: repeat newline 20 times
[*X*] \: fill with X
[*X#] \: repeat X until class/range boundary
The magic repeat operator # stops on boundaries. A boundary happens at
start or end of a class or range. Complements are denoted by a leading
caret.
* \push#1 and \pop#1 semantics have changed. \push#1 now always pushes the
user dictionary stack. Its argument now denotes the name of dictionary
stack that is pushed. The matching \pop#1 should specify the same name.
* made -o work with -e and -E.
* rewrote parts of zmm_generic for the html device. It now makes
more use of style sheets and is reworked towards better
customizability.
* Included a description of the \inspect#4 and \format#2
(mini-mini) sublanguages in the zoem(1) manual. This covers
respectively tilde expansion for \inspect#4 and the format
specification strings for \format#2.
* itemize accepts {smallertext}{1}
* Added fase support for centering with \format#2. With centering,
the default now is that strings of length 1 and 2 will be layed-out
thusly: (even width)
[....8...]
[....9...]
[...10...]
[...11...]
or (odd width)
[....8....]
[....9....]
[...10....]
[...11....]
This can be changed by using '==' as the centering specification:
[...8....]
[...9....]
[...10...]
[...11...]
and
[....8....]
[....9....]
[....10...]
[....11...]
This pattern applies generally to strings of length (2*k+1, 2*k+2).
In case you need it, the fase will alternate with each equal sign
appended to it.
* Zoem's \alpha#1 macro (now implemented as
\textmap{{number}{roman}}{\1}) transforms numbers to strings by writing
them in base 27, using _ as zero. It's use is primarily to enable a) b)
c) style itemization. While experimenting with alpha#1, I found that
\alpha{1444} = azm
The most wonderful coincidence as azm is the zoem suffix
and 1444 is 38 squared - 38 is one of my lucky numbers no less.
This is a universal truth rather than a change. However, the simple act of
perceiving a universal truth instantly creates truth ripples through the
fabric of everything, and in doing so changes the course of the universe
in profound ways. I thought you might like to know this.
Fri, 3 Jun 2005
* zoem-05-154 released.
* Fixed segmentation fault occurring with -e option, introduced
in previous release.
* Added a regression test suite, stress2.azm.
stress.azm is now also called a regression test suite.
* Tested a large number of error paths, fixed a few
to yield truncated output as they should.
* Fixed doc.zmm to produce better W3C compliant output -
specifically compliant <a> anchors.
* Added a tilde escape mechanism to inspect#4 to prevent
cumbersome regexes when slashes are needed (either as a
literal or as a regex metacharacter).
* Sanitized the \inspect#4 implementation and interface.
supported options:
iter-args (was vararg)
iter-lines (was lines)
discard-nmp (was skip) [non-matching-part]
discard-nil-out (was snip)
count-matches (was count)
discard-miss
dotall
icase
Tue, 24 May 2005
* zoem-05-144 released
* Writeto obeys the --unsafe and --unsafe-silent options (or their
absence) when its filename contains a path separator, the forward
slash (entirely UNIX-centric). Such a path separator is considered
a risk in overwriting sensitive files. Zoem will prompt
the user according to the safety settings. It will never prompt the
user if the filename does not contain a path separator.
* The primitive env#3 has become env#4 and env#3 is now a macro
expanding to \env{\1}{}{\2}{\3}.
The second argument of env#4 is a list of key-value pairs
in a vararg that are set as default dollar keys. This simplifies
the definition of environments.
* keys set in the second (vararg) argument begin#2 can now
be keys taking arguments. e.g.
\begin{foo}{{bar#2}{\!2\!1}}
defines a key that is used as
\$bar{a}{b}
which would result in
ba
* Environments set \$__args__ and \$__xargs__ so that they can pass
the full argument list onwards if needed.
* Environments will now silently overwrite local keys previously defined.
This enables a convenient override system when one environment
encapsulates another environment - it can append user arguments
(using \$__args__) to default settings.
* Changed --allow=<name>[:<name>]* syntax to
-allow <name>[:<name>]* syntax.
* Moved option parsing to structured mcxOption framework.
Mon, 21 Jun 2004
* zoem-04-173 released.
* Repeated use of \special#1 would decrease available stack space.
Quite rare bug revealed by Tim Hughes as one of the first to use
clmformat/zoem on a larger scale.
This will not affect normal usage of zoem.
Fixed.
* Made the code better ISO-C compliant (split long constant strings).
Wed, 16 Jun 2004
* zoem-04-168 released.
* fixed embarassing special-related bug. It *did* affect exisiting macro
packages (see below).
Tue, 15 Jun 2004
* zoem-04-167 released.
* \special#1 now evaluates its argument. This does not affect existing
macro packages.
* Updated generic_zmm documentation.
* Treat spaces in manual name correctly (fixed bug in man.zmm results
spotted by Joost van Baal).
Sun, 13 Jun 2004
* zoem-04-165 released.
* fixed bug where inline files would cause zoem to crash.
* introduced enclosing variants for all paragraph incarnations.
\par -> \par#1 (content)
\cpar#1 -> \cpar#2 (caption, content)
\car -> \car#1 (content)
\ccar#1 -> \ccar#2 (caption, content)
Separation tags (such as \par) will be phased out from the
zoem macro packages. \item and \sec are to follow.
* \formatted#1 now skips \<> scope as well.
* Embedded newlines in *ml syntactic sugar \<..> would screw up the
line count. Now fixed.
* \<> stacks are now tied to files, so that alternating output
can never erroneously corrupt the well-formedness stack. (Do note that
funny user-side inverse processing could and still can do that).
* Environment stacks (\begin and \end stuff) are now also tied to files,
same as above.
* The hash module in the underlying library code was overhauled.
hashes now maintain private storage for links and key-value pointers.
Tue, 20 Apr 2004
* zoem-04-111 released.
* small documentation fixes.
Mon, 19 Apr 2004
* zoem-04-110 released.
* the builtin alias \error#1 is gone, replaced by \inform#1.
* Streamlined the examples, made them more suitable for web-publishing.
* Fixed a bug recently introduced into the util library;
file read from STDIN would only read a single line.
* (updated web index, otherwise irrelevant).
Sat, 17 Apr 2004
* zoem-04-108 released.
* Some activity at meta-zoem primitive level.
A new exception mechanism was fully integrated with the error
framework.
- Introduced \throw#2, which generalizes \quit (now removed).
- Removed \zoem#1. It is generalized by \catch{label}{expression}
and \try{expression}.
- Reimplemented \quit as \done, specialized for clean premature
file exit.
This enables
\catch{towel}{
\while{1}{
do stuff
\if{ifstuff}{\throw{towel}}{}
do stuff
}
}
and
\catch{error}{
do possibly erroneous *or* towel stuff
}
or