]>
Commit | Line | Data |
---|---|---|
9385eb3d A |
1 | # @(#)WHATSNEW 8.3 (Berkeley) 3/18/94 |
2 | ||
3 | New in alpha3.4: The complex bug alluded to below has been fixed (in a | |
4 | slightly kludgey temporary way that may hurt efficiency a bit; this is | |
5 | another "get it out the door for 4.4" release). The tests at the end of | |
6 | the tests file have accordingly been uncommented. The primary sign of | |
7 | the bug was that something like a?b matching ab matched b rather than ab. | |
8 | (The bug was essentially specific to this exact situation, else it would | |
9 | have shown up earlier.) | |
10 | ||
11 | New in alpha3.3: The definition of word boundaries has been altered | |
12 | slightly, to more closely match the usual programming notion that "_" | |
13 | is an alphabetic. Stuff used for pre-ANSI systems is now in a subdir, | |
14 | and the makefile no longer alludes to it in mysterious ways. The | |
15 | makefile has generally been cleaned up some. Fixes have been made | |
16 | (again!) so that the regression test will run without -DREDEBUG, at | |
17 | the cost of weaker checking. A workaround for a bug in some folks' | |
18 | <assert.h> has been added. And some more things have been added to | |
19 | tests, including a couple right at the end which are commented out | |
20 | because the code currently flunks them (complex bug; fix coming). | |
21 | Plus the usual minor cleanup. | |
22 | ||
23 | New in alpha3.2: Assorted bits of cleanup and portability improvement | |
24 | (the development base is now a BSDI system using GCC instead of an ancient | |
25 | Sun system, and the newer compiler exposed some glitches). Fix for a | |
26 | serious bug that affected REs using many [] (including REG_ICASE REs | |
27 | because of the way they are implemented), *sometimes*, depending on | |
28 | memory-allocation patterns. The header-file prototypes no longer name | |
29 | the parameters, avoiding possible name conflicts. The possibility that | |
30 | some clot has defined CHAR_MIN as (say) `-128' instead of `(-128)' is | |
31 | now handled gracefully. "uchar" is no longer used as an internal type | |
32 | name (too many people have the same idea). Still the same old lousy | |
33 | performance, alas. | |
34 | ||
35 | New in alpha3.1: Basically nothing, this release is just a bookkeeping | |
36 | convenience. Stay tuned. | |
37 | ||
38 | New in alpha3.0: Performance is no better, alas, but some fixes have been | |
39 | made and some functionality has been added. (This is basically the "get | |
40 | it out the door in time for 4.4" release.) One bug fix: regfree() didn't | |
41 | free the main internal structure (how embarrassing). It is now possible | |
42 | to put NULs in either the RE or the target string, using (resp.) a new | |
43 | REG_PEND flag and the old REG_STARTEND flag. The REG_NOSPEC flag to | |
44 | regcomp() makes all characters ordinary, so you can match a literal | |
45 | string easily (this will become more useful when performance improves!). | |
46 | There are now primitives to match beginnings and ends of words, although | |
47 | the syntax is disgusting and so is the implementation. The REG_ATOI | |
48 | debugging interface has changed a bit. And there has been considerable | |
49 | internal cleanup of various kinds. | |
50 | ||
51 | New in alpha2.3: Split change list out of README, and moved flags notes | |
52 | into Makefile. Macro-ized the name of regex(7) in regex(3), since it has | |
53 | to change for 4.4BSD. Cleanup work in engine.c, and some new regression | |
54 | tests to catch tricky cases thereof. | |
55 | ||
56 | New in alpha2.2: Out-of-date manpages updated. Regerror() acquires two | |
57 | small extensions -- REG_ITOA and REG_ATOI -- which avoid debugging kludges | |
58 | in my own test program and might be useful to others for similar purposes. | |
59 | The regression test will now compile (and run) without REDEBUG. The | |
60 | BRE \$ bug is fixed. Most uses of "uchar" are gone; it's all chars now. | |
61 | Char/uchar parameters are now written int/unsigned, to avoid possible | |
62 | portability problems with unpromoted parameters. Some unsigned casts have | |
63 | been introduced to minimize portability problems with shifting into sign | |
64 | bits. | |
65 | ||
66 | New in alpha2.1: Lots of little stuff, cleanup and fixes. The one big | |
67 | thing is that regex.h is now generated, using mkh, rather than being | |
68 | supplied in the distribution; due to circularities in dependencies, | |
69 | you have to build regex.h explicitly by "make h". The two known bugs | |
70 | have been fixed (and the regression test now checks for them), as has a | |
71 | problem with assertions not being suppressed in the absence of REDEBUG. | |
72 | No performance work yet. | |
73 | ||
74 | New in alpha2: Backslash-anything is an ordinary character, not an | |
75 | error (except, of course, for the handful of backslashed metacharacters | |
76 | in BREs), which should reduce script breakage. The regression test | |
77 | checks *where* null strings are supposed to match, and has generally | |
78 | been tightened up somewhat. Small bug fixes in parameter passing (not | |
79 | harmful, but technically errors) and some other areas. Debugging | |
80 | invoked by defining REDEBUG rather than not defining NDEBUG. | |
81 | ||
82 | New in alpha+3: full prototyping for internal routines, using a little | |
83 | helper program, mkh, which extracts prototypes given in stylized comments. | |
84 | More minor cleanup. Buglet fix: it's CHAR_BIT, not CHAR_BITS. Simple | |
85 | pre-screening of input when a literal string is known to be part of the | |
86 | RE; this does wonders for performance. | |
87 | ||
88 | New in alpha+2: minor bits of cleanup. Notably, the number "32" for the | |
89 | word width isn't hardwired into regexec.c any more, the public header | |
90 | file prototypes the functions if __STDC__ is defined, and some small typos | |
91 | in the manpages have been fixed. | |
92 | ||
93 | New in alpha+1: improvements to the manual pages, and an important | |
94 | extension, the REG_STARTEND option to regexec(). |