home *** CD-ROM | disk | FTP | other *** search
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was processed as: SHell self-extracting ARchive
(archive/shar).
You can browse this item here: 3572
Confidence | Program | Detection | Match Type | Support
|
---|
100%
| dexvert
| Newsgroup Content (archive/news)
| magic
| Supported |
100%
| dexvert
| SHell self-extracting ARchive (archive/shar)
| magic
| Supported |
100%
| dexvert
| Internet Message Format (text/imf)
| magic
| Supported |
1%
| dexvert
| Text File (text/txt)
| fallback
| Supported |
100%
| file
| news or mail, ASCII text
| default
| |
100%
| TrID
| E-Mail message (Var. 2)
| default
| |
100%
| checkBytes
| Printable ASCII
| default
| |
100%
| perlTextCheck
| Likely Text (Perl)
| default
| |
100%
| siegfried
| fmt/329 Shell Archive Format
| default
| |
100%
| detectItEasy
| Format: plain text[LF]
| default (weak)
| |
100%
| xdgMime
| message/rfc822
| default
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 46 72 6f 6d 3a 20 70 6d | 6d 40 6d 69 70 73 2e 63 |From: pm|m@mips.c|
|00000010| 6f 6d 20 28 50 61 75 6c | 20 4d 2e 20 4d 6f 72 69 |om (Paul| M. Mori|
|00000020| 61 72 74 79 29 0a 4e 65 | 77 73 67 72 6f 75 70 73 |arty).Ne|wsgroups|
|00000030| 3a 20 61 6c 74 2e 73 6f | 75 72 63 65 73 0a 53 75 |: alt.so|urces.Su|
|00000040| 62 6a 65 63 74 3a 20 4f | 70 3a 20 41 20 66 6c 65 |bject: O|p: A fle|
|00000050| 78 69 62 6c 65 20 54 6f | 6f 6c 20 66 6f 72 20 52 |xible To|ol for R|
|00000060| 65 73 74 72 69 63 74 65 | 64 20 53 75 70 65 72 75 |estricte|d Superu|
|00000070| 73 65 72 20 41 63 63 65 | 73 73 2c 20 50 61 72 74 |ser Acce|ss, Part|
|00000080| 30 32 2f 30 32 0a 4d 65 | 73 73 61 67 65 2d 49 44 |02/02.Me|ssage-ID|
|00000090| 3a 20 3c 35 32 39 30 40 | 73 70 69 6d 2e 6d 69 70 |: <5290@|spim.mip|
|000000a0| 73 2e 43 4f 4d 3e 0a 44 | 61 74 65 3a 20 31 20 4a |s.COM>.D|ate: 1 J|
|000000b0| 75 6c 20 39 31 20 32 31 | 3a 35 37 3a 33 33 20 47 |ul 91 21|:57:33 G|
|000000c0| 4d 54 0a 0a 2d 2d 2d 73 | 6e 69 70 2d 2d 2d 2d 2d |MT..---s|nip-----|
|000000d0| 2d 73 6e 69 70 2d 2d 2d | 2d 2d 2d 73 6e 69 70 2d |-snip---|---snip-|
|000000e0| 2d 2d 2d 2d 2d 73 6e 69 | 70 2d 2d 2d 2d 2d 2d 73 |-----sni|p------s|
|000000f0| 6e 69 70 2d 2d 2d 2d 2d | 2d 73 6e 69 70 2d 2d 2d |nip-----|-snip---|
|00000100| 2d 2d 2d 73 6e 69 70 2d | 2d 2d 2d 2d 2d 73 6e 69 |---snip-|-----sni|
|00000110| 70 2d 2d 2d 0a 23 21 20 | 2f 62 69 6e 2f 73 68 0a |p---.#! |/bin/sh.|
|00000120| 23 20 54 68 69 73 20 69 | 73 20 61 20 73 68 65 6c |# This i|s a shel|
|00000130| 6c 20 61 72 63 68 69 76 | 65 2e 20 20 52 65 6d 6f |l archiv|e. Remo|
|00000140| 76 65 20 61 6e 79 74 68 | 69 6e 67 20 62 65 66 6f |ve anyth|ing befo|
|00000150| 72 65 20 74 68 69 73 20 | 6c 69 6e 65 2c 20 74 68 |re this |line, th|
|00000160| 65 6e 20 75 6e 70 61 63 | 6b 0a 23 20 69 74 20 62 |en unpac|k.# it b|
|00000170| 79 20 73 61 76 69 6e 67 | 20 69 74 20 69 6e 74 6f |y saving| it into|
|00000180| 20 61 20 66 69 6c 65 20 | 61 6e 64 20 74 79 70 69 | a file |and typi|
|00000190| 6e 67 20 22 73 68 20 66 | 69 6c 65 22 2e 20 20 54 |ng "sh f|ile". T|
|000001a0| 6f 20 6f 76 65 72 77 72 | 69 74 65 20 65 78 69 73 |o overwr|ite exis|
|000001b0| 74 69 6e 67 0a 23 20 66 | 69 6c 65 73 2c 20 74 79 |ting.# f|iles, ty|
|000001c0| 70 65 20 22 73 68 20 66 | 69 6c 65 20 2d 63 22 2e |pe "sh f|ile -c".|
|000001d0| 20 20 59 6f 75 20 63 61 | 6e 20 61 6c 73 6f 20 66 | You ca|n also f|
|000001e0| 65 65 64 20 74 68 69 73 | 20 61 73 20 73 74 61 6e |eed this| as stan|
|000001f0| 64 61 72 64 20 69 6e 70 | 75 74 20 76 69 61 0a 23 |dard inp|ut via.#|
|00000200| 20 75 6e 73 68 61 72 2c | 20 6f 72 20 62 79 20 74 | unshar,| or by t|
|00000210| 79 70 69 6e 67 20 22 73 | 68 20 3c 66 69 6c 65 22 |yping "s|h <file"|
|00000220| 2c 20 65 2e 67 2e 2e 20 | 20 49 66 20 74 68 69 73 |, e.g.. | If this|
|00000230| 20 61 72 63 68 69 76 65 | 20 69 73 20 63 6f 6d 70 | archive| is comp|
|00000240| 6c 65 74 65 2c 20 79 6f | 75 0a 23 20 77 69 6c 6c |lete, yo|u.# will|
|00000250| 20 73 65 65 20 74 68 65 | 20 66 6f 6c 6c 6f 77 69 | see the| followi|
|00000260| 6e 67 20 6d 65 73 73 61 | 67 65 20 61 74 20 74 68 |ng messa|ge at th|
|00000270| 65 20 65 6e 64 3a 0a 23 | 09 09 22 45 6e 64 20 6f |e end:.#|.."End o|
|00000280| 66 20 61 72 63 68 69 76 | 65 20 32 20 28 6f 66 20 |f archiv|e 2 (of |
|00000290| 32 29 2e 22 0a 23 20 43 | 6f 6e 74 65 6e 74 73 3a |2).".# C|ontents:|
|000002a0| 20 20 72 65 67 65 78 70 | 2e 63 0a 23 20 57 72 61 | regexp|.c.# Wra|
|000002b0| 70 70 65 64 20 62 79 20 | 70 6d 6d 40 72 6f 63 6b |pped by |pmm@rock|
|000002c0| 79 20 6f 6e 20 4d 6f 6e | 20 4a 75 6c 20 20 31 20 |y on Mon| Jul 1 |
|000002d0| 31 34 3a 34 31 3a 31 37 | 20 31 39 39 31 0a 50 41 |14:41:17| 1991.PA|
|000002e0| 54 48 3d 2f 62 69 6e 3a | 2f 75 73 72 2f 62 69 6e |TH=/bin:|/usr/bin|
|000002f0| 3a 2f 75 73 72 2f 75 63 | 62 20 3b 20 65 78 70 6f |:/usr/uc|b ; expo|
|00000300| 72 74 20 50 41 54 48 0a | 69 66 20 74 65 73 74 20 |rt PATH.|if test |
|00000310| 2d 66 20 27 72 65 67 65 | 78 70 2e 63 27 20 2d 61 |-f 'rege|xp.c' -a|
|00000320| 20 22 24 7b 31 7d 22 20 | 21 3d 20 22 2d 63 22 20 | "${1}" |!= "-c" |
|00000330| 3b 20 74 68 65 6e 20 0a | 20 20 65 63 68 6f 20 73 |; then .| echo s|
|00000340| 68 61 72 3a 20 57 69 6c | 6c 20 6e 6f 74 20 63 6c |har: Wil|l not cl|
|00000350| 6f 62 62 65 72 20 65 78 | 69 73 74 69 6e 67 20 66 |obber ex|isting f|
|00000360| 69 6c 65 20 5c 22 27 72 | 65 67 65 78 70 2e 63 27 |ile \"'r|egexp.c'|
|00000370| 5c 22 0a 65 6c 73 65 0a | 65 63 68 6f 20 73 68 61 |\".else.|echo sha|
|00000380| 72 3a 20 45 78 74 72 61 | 63 74 69 6e 67 20 5c 22 |r: Extra|cting \"|
|00000390| 27 72 65 67 65 78 70 2e | 63 27 5c 22 20 5c 28 33 |'regexp.|c'\" \(3|
|000003a0| 31 31 34 39 20 63 68 61 | 72 61 63 74 65 72 73 5c |1149 cha|racters\|
|000003b0| 29 0a 73 65 64 20 22 73 | 2f 5e 58 2f 2f 22 20 3e |).sed "s|/^X//" >|
|000003c0| 27 72 65 67 65 78 70 2e | 63 27 20 3c 3c 27 45 4e |'regexp.|c' <<'EN|
|000003d0| 44 5f 4f 46 5f 46 49 4c | 45 27 0a 58 2f 2a 0a 58 |D_OF_FIL|E'.X/*.X|
|000003e0| 20 2a 20 72 65 67 63 6f | 6d 70 20 61 6e 64 20 72 | * regco|mp and r|
|000003f0| 65 67 65 78 65 63 20 2d | 2d 20 72 65 67 73 75 62 |egexec -|- regsub|
|00000400| 20 61 6e 64 20 72 65 67 | 65 72 72 6f 72 20 61 72 | and reg|error ar|
|00000410| 65 20 65 6c 73 65 77 68 | 65 72 65 0a 58 20 2a 0a |e elsewh|ere.X *.|
|00000420| 58 20 2a 09 43 6f 70 79 | 72 69 67 68 74 20 28 63 |X *.Copy|right (c|
|00000430| 29 20 31 39 38 36 20 62 | 79 20 55 6e 69 76 65 72 |) 1986 b|y Univer|
|00000440| 73 69 74 79 20 6f 66 20 | 54 6f 72 6f 6e 74 6f 2e |sity of |Toronto.|
|00000450| 0a 58 20 2a 09 57 72 69 | 74 74 65 6e 20 62 79 20 |.X *.Wri|tten by |
|00000460| 48 65 6e 72 79 20 53 70 | 65 6e 63 65 72 2e 20 20 |Henry Sp|encer. |
|00000470| 4e 6f 74 20 64 65 72 69 | 76 65 64 20 66 72 6f 6d |Not deri|ved from|
|00000480| 20 6c 69 63 65 6e 73 65 | 64 20 73 6f 66 74 77 61 | license|d softwa|
|00000490| 72 65 2e 0a 58 20 2a 0a | 58 20 2a 09 50 65 72 6d |re..X *.|X *.Perm|
|000004a0| 69 73 73 69 6f 6e 20 69 | 73 20 67 72 61 6e 74 65 |ission i|s grante|
|000004b0| 64 20 74 6f 20 61 6e 79 | 6f 6e 65 20 74 6f 20 75 |d to any|one to u|
|000004c0| 73 65 20 74 68 69 73 20 | 73 6f 66 74 77 61 72 65 |se this |software|
|000004d0| 20 66 6f 72 20 61 6e 79 | 0a 58 20 2a 09 70 75 72 | for any|.X *.pur|
|000004e0| 70 6f 73 65 20 6f 6e 20 | 61 6e 79 20 63 6f 6d 70 |pose on |any comp|
|000004f0| 75 74 65 72 20 73 79 73 | 74 65 6d 2c 20 61 6e 64 |uter sys|tem, and|
|00000500| 20 74 6f 20 72 65 64 69 | 73 74 72 69 62 75 74 65 | to redi|stribute|
|00000510| 20 69 74 20 66 72 65 65 | 6c 79 2c 0a 58 20 2a 09 | it free|ly,.X *.|
|00000520| 73 75 62 6a 65 63 74 20 | 74 6f 20 74 68 65 20 66 |subject |to the f|
|00000530| 6f 6c 6c 6f 77 69 6e 67 | 20 72 65 73 74 72 69 63 |ollowing| restric|
|00000540| 74 69 6f 6e 73 3a 0a 58 | 20 2a 0a 58 20 2a 09 31 |tions:.X| *.X *.1|
|00000550| 2e 20 54 68 65 20 61 75 | 74 68 6f 72 20 69 73 20 |. The au|thor is |
|00000560| 6e 6f 74 20 72 65 73 70 | 6f 6e 73 69 62 6c 65 20 |not resp|onsible |
|00000570| 66 6f 72 20 74 68 65 20 | 63 6f 6e 73 65 71 75 65 |for the |conseque|
|00000580| 6e 63 65 73 20 6f 66 20 | 75 73 65 20 6f 66 0a 58 |nces of |use of.X|
|00000590| 20 2a 09 09 74 68 69 73 | 20 73 6f 66 74 77 61 72 | *..this| softwar|
|000005a0| 65 2c 20 6e 6f 20 6d 61 | 74 74 65 72 20 68 6f 77 |e, no ma|tter how|
|000005b0| 20 61 77 66 75 6c 2c 20 | 65 76 65 6e 20 69 66 20 | awful, |even if |
|000005c0| 74 68 65 79 20 61 72 69 | 73 65 0a 58 20 2a 09 09 |they ari|se.X *..|
|000005d0| 66 72 6f 6d 20 64 65 66 | 65 63 74 73 20 69 6e 20 |from def|ects in |
|000005e0| 69 74 2e 0a 58 20 2a 0a | 58 20 2a 09 32 2e 20 54 |it..X *.|X *.2. T|
|000005f0| 68 65 20 6f 72 69 67 69 | 6e 20 6f 66 20 74 68 69 |he origi|n of thi|
|00000600| 73 20 73 6f 66 74 77 61 | 72 65 20 6d 75 73 74 20 |s softwa|re must |
|00000610| 6e 6f 74 20 62 65 20 6d | 69 73 72 65 70 72 65 73 |not be m|isrepres|
|00000620| 65 6e 74 65 64 2c 20 65 | 69 74 68 65 72 0a 58 20 |ented, e|ither.X |
|00000630| 2a 09 09 62 79 20 65 78 | 70 6c 69 63 69 74 20 63 |*..by ex|plicit c|
|00000640| 6c 61 69 6d 20 6f 72 20 | 62 79 20 6f 6d 69 73 73 |laim or |by omiss|
|00000650| 69 6f 6e 2e 0a 58 20 2a | 0a 58 20 2a 09 33 2e 20 |ion..X *|.X *.3. |
|00000660| 41 6c 74 65 72 65 64 20 | 76 65 72 73 69 6f 6e 73 |Altered |versions|
|00000670| 20 6d 75 73 74 20 62 65 | 20 70 6c 61 69 6e 6c 79 | must be| plainly|
|00000680| 20 6d 61 72 6b 65 64 20 | 61 73 20 73 75 63 68 2c | marked |as such,|
|00000690| 20 61 6e 64 20 6d 75 73 | 74 20 6e 6f 74 0a 58 20 | and mus|t not.X |
|000006a0| 2a 09 09 62 65 20 6d 69 | 73 72 65 70 72 65 73 65 |*..be mi|sreprese|
|000006b0| 6e 74 65 64 20 61 73 20 | 62 65 69 6e 67 20 74 68 |nted as |being th|
|000006c0| 65 20 6f 72 69 67 69 6e | 61 6c 20 73 6f 66 74 77 |e origin|al softw|
|000006d0| 61 72 65 2e 0a 58 20 2a | 2a 2a 20 54 48 49 53 20 |are..X *|** THIS |
|000006e0| 49 53 20 41 4e 20 41 4c | 54 45 52 45 44 20 56 45 |IS AN AL|TERED VE|
|000006f0| 52 53 49 4f 4e 2e 20 20 | 49 74 20 77 61 73 20 61 |RSION. |It was a|
|00000700| 6c 74 65 72 65 64 20 62 | 79 20 4a 6f 68 6e 20 47 |ltered b|y John G|
|00000710| 69 6c 6d 6f 72 65 2c 0a | 58 20 2a 2a 2a 20 68 6f |ilmore,.|X *** ho|
|00000720| 70 74 6f 61 64 21 67 6e | 75 2c 20 6f 6e 20 32 37 |ptoad!gn|u, on 27|
|00000730| 20 44 65 63 20 31 39 38 | 36 2c 20 74 6f 20 61 64 | Dec 198|6, to ad|
|00000740| 64 20 5c 6e 20 61 73 20 | 61 6e 20 61 6c 74 65 72 |d \n as |an alter|
|00000750| 6e 61 74 69 76 65 20 74 | 6f 20 7c 0a 58 20 2a 2a |native t|o |.X **|
|00000760| 2a 20 74 6f 20 61 73 73 | 69 73 74 20 69 6e 20 69 |* to ass|ist in i|
|00000770| 6d 70 6c 65 6d 65 6e 74 | 69 6e 67 20 65 67 72 65 |mplement|ing egre|
|00000780| 70 2e 0a 58 20 2a 2a 2a | 20 54 48 49 53 20 49 53 |p..X ***| THIS IS|
|00000790| 20 41 4e 20 41 4c 54 45 | 52 45 44 20 56 45 52 53 | AN ALTE|RED VERS|
|000007a0| 49 4f 4e 2e 20 20 49 74 | 20 77 61 73 20 61 6c 74 |ION. It| was alt|
|000007b0| 65 72 65 64 20 62 79 20 | 4a 6f 68 6e 20 47 69 6c |ered by |John Gil|
|000007c0| 6d 6f 72 65 2c 0a 58 20 | 2a 2a 2a 20 68 6f 70 74 |more,.X |*** hopt|
|000007d0| 6f 61 64 21 67 6e 75 2c | 20 6f 6e 20 32 37 20 44 |oad!gnu,| on 27 D|
|000007e0| 65 63 20 31 39 38 36 2c | 20 74 6f 20 61 64 64 20 |ec 1986,| to add |
|000007f0| 5c 3c 20 61 6e 64 20 5c | 3e 20 66 6f 72 20 77 6f |\< and \|> for wo|
|00000800| 72 64 2d 6d 61 74 63 68 | 69 6e 67 0a 58 20 2a 2a |rd-match|ing.X **|
|00000810| 2a 20 61 73 20 69 6e 20 | 42 53 44 20 67 72 65 70 |* as in |BSD grep|
|00000820| 20 61 6e 64 20 65 78 2e | 0a 58 20 2a 2a 2a 20 54 | and ex.|.X *** T|
|00000830| 48 49 53 20 49 53 20 41 | 4e 20 41 4c 54 45 52 45 |HIS IS A|N ALTERE|
|00000840| 44 20 56 45 52 53 49 4f | 4e 2e 20 20 49 74 20 77 |D VERSIO|N. It w|
|00000850| 61 73 20 61 6c 74 65 72 | 65 64 20 62 79 20 4a 6f |as alter|ed by Jo|
|00000860| 68 6e 20 47 69 6c 6d 6f | 72 65 2c 0a 58 20 2a 2a |hn Gilmo|re,.X **|
|00000870| 2a 20 68 6f 70 74 6f 61 | 64 21 67 6e 75 2c 20 6f |* hoptoa|d!gnu, o|
|00000880| 6e 20 32 38 20 44 65 63 | 20 31 39 38 36 2c 20 74 |n 28 Dec| 1986, t|
|00000890| 6f 20 6f 70 74 69 6d 69 | 7a 65 20 63 68 61 72 61 |o optimi|ze chara|
|000008a0| 63 74 65 72 73 20 71 75 | 6f 74 65 64 20 77 69 74 |cters qu|oted wit|
|000008b0| 68 20 5c 2e 0a 58 20 2a | 2a 2a 20 54 48 49 53 20 |h \..X *|** THIS |
|000008c0| 49 53 20 41 4e 20 41 4c | 54 45 52 45 44 20 56 45 |IS AN AL|TERED VE|
|000008d0| 52 53 49 4f 4e 2e 20 20 | 49 74 20 77 61 73 20 61 |RSION. |It was a|
|000008e0| 6c 74 65 72 65 64 20 62 | 79 20 4a 61 6d 65 73 20 |ltered b|y James |
|000008f0| 41 2e 20 57 6f 6f 64 73 | 2c 0a 58 20 2a 2a 2a 20 |A. Woods|,.X *** |
|00000900| 61 6d 65 73 21 6a 61 77 | 2c 20 6f 6e 20 31 39 20 |ames!jaw|, on 19 |
|00000910| 4a 75 6e 65 20 31 39 38 | 37 2c 20 74 6f 20 71 75 |June 198|7, to qu|
|00000920| 61 73 68 20 61 20 72 65 | 67 63 6f 6d 70 28 29 20 |ash a re|gcomp() |
|00000930| 72 65 64 75 6e 64 61 6e | 63 79 2e 0a 58 20 2a 0a |redundan|cy..X *.|
|00000940| 58 20 2a 20 42 65 77 61 | 72 65 20 74 68 61 74 20 |X * Bewa|re that |
|00000950| 73 6f 6d 65 20 6f 66 20 | 74 68 69 73 20 63 6f 64 |some of |this cod|
|00000960| 65 20 69 73 20 73 75 62 | 74 6c 79 20 61 77 61 72 |e is sub|tly awar|
|00000970| 65 20 6f 66 20 74 68 65 | 20 77 61 79 20 6f 70 65 |e of the| way ope|
|00000980| 72 61 74 6f 72 0a 58 20 | 2a 20 70 72 65 63 65 64 |rator.X |* preced|
|00000990| 65 6e 63 65 20 69 73 20 | 73 74 72 75 63 74 75 72 |ence is |structur|
|000009a0| 65 64 20 69 6e 20 72 65 | 67 75 6c 61 72 20 65 78 |ed in re|gular ex|
|000009b0| 70 72 65 73 73 69 6f 6e | 73 2e 20 20 53 65 72 69 |pression|s. Seri|
|000009c0| 6f 75 73 20 63 68 61 6e | 67 65 73 20 69 6e 0a 58 |ous chan|ges in.X|
|000009d0| 20 2a 20 72 65 67 75 6c | 61 72 2d 65 78 70 72 65 | * regul|ar-expre|
|000009e0| 73 73 69 6f 6e 20 73 79 | 6e 74 61 78 20 6d 69 67 |ssion sy|ntax mig|
|000009f0| 68 74 20 72 65 71 75 69 | 72 65 20 61 20 74 6f 74 |ht requi|re a tot|
|00000a00| 61 6c 20 72 65 74 68 69 | 6e 6b 2e 0a 58 20 2a 2f |al rethi|nk..X */|
|00000a10| 0a 58 23 69 6e 63 6c 75 | 64 65 20 3c 73 74 64 69 |.X#inclu|de <stdi|
|00000a20| 6f 2e 68 3e 0a 58 23 69 | 6e 63 6c 75 64 65 20 3c |o.h>.X#i|nclude <|
|00000a30| 63 74 79 70 65 2e 68 3e | 0a 58 23 69 6e 63 6c 75 |ctype.h>|.X#inclu|
|00000a40| 64 65 20 3c 72 65 67 65 | 78 70 2e 68 3e 0a 58 23 |de <rege|xp.h>.X#|
|00000a50| 69 6e 63 6c 75 64 65 20 | 22 72 65 67 6d 61 67 69 |include |"regmagi|
|00000a60| 63 2e 68 22 0a 58 0a 58 | 2f 2a 0a 58 20 2a 20 54 |c.h".X.X|/*.X * T|
|00000a70| 68 65 20 22 69 6e 74 65 | 72 6e 61 6c 20 75 73 65 |he "inte|rnal use|
|00000a80| 20 6f 6e 6c 79 22 20 66 | 69 65 6c 64 73 20 69 6e | only" f|ields in|
|00000a90| 20 72 65 67 65 78 70 2e | 68 20 61 72 65 20 70 72 | regexp.|h are pr|
|00000aa0| 65 73 65 6e 74 20 74 6f | 20 70 61 73 73 20 69 6e |esent to| pass in|
|00000ab0| 66 6f 20 66 72 6f 6d 0a | 58 20 2a 20 63 6f 6d 70 |fo from.|X * comp|
|00000ac0| 69 6c 65 20 74 6f 20 65 | 78 65 63 75 74 65 20 74 |ile to e|xecute t|
|00000ad0| 68 61 74 20 70 65 72 6d | 69 74 73 20 74 68 65 20 |hat perm|its the |
|00000ae0| 65 78 65 63 75 74 65 20 | 70 68 61 73 65 20 74 6f |execute |phase to|
|00000af0| 20 72 75 6e 20 6c 6f 74 | 73 20 66 61 73 74 65 72 | run lot|s faster|
|00000b00| 20 6f 6e 0a 58 20 2a 20 | 73 69 6d 70 6c 65 20 63 | on.X * |simple c|
|00000b10| 61 73 65 73 2e 20 20 54 | 68 65 79 20 61 72 65 3a |ases. T|hey are:|
|00000b20| 0a 58 20 2a 0a 58 20 2a | 20 72 65 67 73 74 61 72 |.X *.X *| regstar|
|00000b30| 74 09 63 68 61 72 20 74 | 68 61 74 20 6d 75 73 74 |t.char t|hat must|
|00000b40| 20 62 65 67 69 6e 20 61 | 20 6d 61 74 63 68 3b 20 | begin a| match; |
|00000b50| 27 5c 30 27 20 69 66 20 | 6e 6f 6e 65 20 6f 62 76 |'\0' if |none obv|
|00000b60| 69 6f 75 73 0a 58 20 2a | 20 72 65 67 61 6e 63 68 |ious.X *| reganch|
|00000b70| 09 69 73 20 74 68 65 20 | 6d 61 74 63 68 20 61 6e |.is the |match an|
|00000b80| 63 68 6f 72 65 64 20 28 | 61 74 20 62 65 67 69 6e |chored (|at begin|
|00000b90| 6e 69 6e 67 2d 6f 66 2d | 6c 69 6e 65 20 6f 6e 6c |ning-of-|line onl|
|00000ba0| 79 29 3f 0a 58 20 2a 20 | 72 65 67 6d 75 73 74 09 |y)?.X * |regmust.|
|00000bb0| 73 74 72 69 6e 67 20 28 | 70 6f 69 6e 74 65 72 20 |string (|pointer |
|00000bc0| 69 6e 74 6f 20 70 72 6f | 67 72 61 6d 29 20 74 68 |into pro|gram) th|
|00000bd0| 61 74 20 6d 61 74 63 68 | 20 6d 75 73 74 20 69 6e |at match| must in|
|00000be0| 63 6c 75 64 65 2c 20 6f | 72 20 4e 55 4c 4c 0a 58 |clude, o|r NULL.X|
|00000bf0| 20 2a 20 72 65 67 6d 6c | 65 6e 09 6c 65 6e 67 74 | * regml|en.lengt|
|00000c00| 68 20 6f 66 20 72 65 67 | 6d 75 73 74 20 73 74 72 |h of reg|must str|
|00000c10| 69 6e 67 0a 58 20 2a 0a | 58 20 2a 20 52 65 67 73 |ing.X *.|X * Regs|
|00000c20| 74 61 72 74 20 61 6e 64 | 20 72 65 67 61 6e 63 68 |tart and| reganch|
|00000c30| 20 70 65 72 6d 69 74 20 | 76 65 72 79 20 66 61 73 | permit |very fas|
|00000c40| 74 20 64 65 63 69 73 69 | 6f 6e 73 20 6f 6e 20 73 |t decisi|ons on s|
|00000c50| 75 69 74 61 62 6c 65 20 | 73 74 61 72 74 69 6e 67 |uitable |starting|
|00000c60| 20 70 6f 69 6e 74 73 0a | 58 20 2a 20 66 6f 72 20 | points.|X * for |
|00000c70| 61 20 6d 61 74 63 68 2c | 20 63 75 74 74 69 6e 67 |a match,| cutting|
|00000c80| 20 64 6f 77 6e 20 74 68 | 65 20 77 6f 72 6b 20 61 | down th|e work a|
|00000c90| 20 6c 6f 74 2e 20 20 52 | 65 67 6d 75 73 74 20 70 | lot. R|egmust p|
|00000ca0| 65 72 6d 69 74 73 20 66 | 61 73 74 20 72 65 6a 65 |ermits f|ast reje|
|00000cb0| 63 74 69 6f 6e 0a 58 20 | 2a 20 6f 66 20 6c 69 6e |ction.X |* of lin|
|00000cc0| 65 73 20 74 68 61 74 20 | 63 61 6e 6e 6f 74 20 70 |es that |cannot p|
|00000cd0| 6f 73 73 69 62 6c 79 20 | 6d 61 74 63 68 2e 20 20 |ossibly |match. |
|00000ce0| 54 68 65 20 72 65 67 6d | 75 73 74 20 74 65 73 74 |The regm|ust test|
|00000cf0| 73 20 61 72 65 20 63 6f | 73 74 6c 79 20 65 6e 6f |s are co|stly eno|
|00000d00| 75 67 68 0a 58 20 2a 20 | 74 68 61 74 20 72 65 67 |ugh.X * |that reg|
|00000d10| 63 6f 6d 70 28 29 20 73 | 75 70 70 6c 69 65 73 20 |comp() s|upplies |
|00000d20| 61 20 72 65 67 6d 75 73 | 74 20 6f 6e 6c 79 20 69 |a regmus|t only i|
|00000d30| 66 20 74 68 65 20 72 2e | 65 2e 20 63 6f 6e 74 61 |f the r.|e. conta|
|00000d40| 69 6e 73 20 73 6f 6d 65 | 74 68 69 6e 67 0a 58 20 |ins some|thing.X |
|00000d50| 2a 20 70 6f 74 65 6e 74 | 69 61 6c 6c 79 20 65 78 |* potent|ially ex|
|00000d60| 70 65 6e 73 69 76 65 20 | 28 61 74 20 70 72 65 73 |pensive |(at pres|
|00000d70| 65 6e 74 2c 20 74 68 65 | 20 6f 6e 6c 79 20 73 75 |ent, the| only su|
|00000d80| 63 68 20 74 68 69 6e 67 | 20 64 65 74 65 63 74 65 |ch thing| detecte|
|00000d90| 64 20 69 73 20 2a 20 6f | 72 20 2b 0a 58 20 2a 20 |d is * o|r +.X * |
|00000da0| 61 74 20 74 68 65 20 73 | 74 61 72 74 20 6f 66 20 |at the s|tart of |
|00000db0| 74 68 65 20 72 2e 65 2e | 2c 20 77 68 69 63 68 20 |the r.e.|, which |
|00000dc0| 63 61 6e 20 69 6e 76 6f | 6c 76 65 20 61 20 6c 6f |can invo|lve a lo|
|00000dd0| 74 20 6f 66 20 62 61 63 | 6b 75 70 29 2e 20 20 52 |t of bac|kup). R|
|00000de0| 65 67 6d 6c 65 6e 20 69 | 73 0a 58 20 2a 20 73 75 |egmlen i|s.X * su|
|00000df0| 70 70 6c 69 65 64 20 62 | 65 63 61 75 73 65 20 74 |pplied b|ecause t|
|00000e00| 68 65 20 74 65 73 74 20 | 69 6e 20 72 65 67 65 78 |he test |in regex|
|00000e10| 65 63 28 29 20 6e 65 65 | 64 73 20 69 74 20 61 6e |ec() nee|ds it an|
|00000e20| 64 20 72 65 67 63 6f 6d | 70 28 29 20 69 73 20 63 |d regcom|p() is c|
|00000e30| 6f 6d 70 75 74 69 6e 67 | 0a 58 20 2a 20 69 74 20 |omputing|.X * it |
|00000e40| 61 6e 79 77 61 79 2e 0a | 58 20 2a 2f 0a 58 0a 58 |anyway..|X */.X.X|
|00000e50| 2f 2a 0a 58 20 2a 20 53 | 74 72 75 63 74 75 72 65 |/*.X * S|tructure|
|00000e60| 20 66 6f 72 20 72 65 67 | 65 78 70 20 22 70 72 6f | for reg|exp "pro|
|00000e70| 67 72 61 6d 22 2e 20 20 | 54 68 69 73 20 69 73 20 |gram". |This is |
|00000e80| 65 73 73 65 6e 74 69 61 | 6c 6c 79 20 61 20 6c 69 |essentia|lly a li|
|00000e90| 6e 65 61 72 20 65 6e 63 | 6f 64 69 6e 67 0a 58 20 |near enc|oding.X |
|00000ea0| 2a 20 6f 66 20 61 20 6e | 6f 6e 64 65 74 65 72 6d |* of a n|ondeterm|
|00000eb0| 69 6e 69 73 74 69 63 20 | 66 69 6e 69 74 65 2d 73 |inistic |finite-s|
|00000ec0| 74 61 74 65 20 6d 61 63 | 68 69 6e 65 20 28 61 6b |tate mac|hine (ak|
|00000ed0| 61 20 73 79 6e 74 61 78 | 20 63 68 61 72 74 73 20 |a syntax| charts |
|00000ee0| 6f 72 0a 58 20 2a 20 22 | 72 61 69 6c 72 6f 61 64 |or.X * "|railroad|
|00000ef0| 20 6e 6f 72 6d 61 6c 20 | 66 6f 72 6d 22 20 69 6e | normal |form" in|
|00000f00| 20 70 61 72 73 69 6e 67 | 20 74 65 63 68 6e 6f 6c | parsing| technol|
|00000f10| 6f 67 79 29 2e 20 20 45 | 61 63 68 20 6e 6f 64 65 |ogy). E|ach node|
|00000f20| 20 69 73 20 61 6e 20 6f | 70 63 6f 64 65 0a 58 20 | is an o|pcode.X |
|00000f30| 2a 20 70 6c 75 73 20 61 | 20 22 6e 65 78 74 22 20 |* plus a| "next" |
|00000f40| 70 6f 69 6e 74 65 72 2c | 20 70 6f 73 73 69 62 6c |pointer,| possibl|
|00000f50| 79 20 70 6c 75 73 20 61 | 6e 20 6f 70 65 72 61 6e |y plus a|n operan|
|00000f60| 64 2e 20 20 22 4e 65 78 | 74 22 20 70 6f 69 6e 74 |d. "Nex|t" point|
|00000f70| 65 72 73 20 6f 66 0a 58 | 20 2a 20 61 6c 6c 20 6e |ers of.X| * all n|
|00000f80| 6f 64 65 73 20 65 78 63 | 65 70 74 20 42 52 41 4e |odes exc|ept BRAN|
|00000f90| 43 48 20 69 6d 70 6c 65 | 6d 65 6e 74 20 63 6f 6e |CH imple|ment con|
|00000fa0| 63 61 74 65 6e 61 74 69 | 6f 6e 3b 20 61 20 22 6e |catenati|on; a "n|
|00000fb0| 65 78 74 22 20 70 6f 69 | 6e 74 65 72 20 77 69 74 |ext" poi|nter wit|
|00000fc0| 68 0a 58 20 2a 20 61 20 | 42 52 41 4e 43 48 20 6f |h.X * a |BRANCH o|
|00000fd0| 6e 20 62 6f 74 68 20 65 | 6e 64 73 20 6f 66 20 69 |n both e|nds of i|
|00000fe0| 74 20 69 73 20 63 6f 6e | 6e 65 63 74 69 6e 67 20 |t is con|necting |
|00000ff0| 74 77 6f 20 61 6c 74 65 | 72 6e 61 74 69 76 65 73 |two alte|rnatives|
|00001000| 2e 20 20 28 48 65 72 65 | 20 77 65 0a 58 20 2a 20 |. (Here| we.X * |
|00001010| 68 61 76 65 20 6f 6e 65 | 20 6f 66 20 74 68 65 20 |have one| of the |
|00001020| 73 75 62 74 6c 65 20 73 | 79 6e 74 61 78 20 64 65 |subtle s|yntax de|
|00001030| 70 65 6e 64 65 6e 63 69 | 65 73 3a 20 20 61 6e 20 |pendenci|es: an |
|00001040| 69 6e 64 69 76 69 64 75 | 61 6c 20 42 52 41 4e 43 |individu|al BRANC|
|00001050| 48 20 28 61 73 0a 58 20 | 2a 20 6f 70 70 6f 73 65 |H (as.X |* oppose|
|00001060| 64 20 74 6f 20 61 20 63 | 6f 6c 6c 65 63 74 69 6f |d to a c|ollectio|
|00001070| 6e 20 6f 66 20 74 68 65 | 6d 29 20 69 73 20 6e 65 |n of the|m) is ne|
|00001080| 76 65 72 20 63 6f 6e 63 | 61 74 65 6e 61 74 65 64 |ver conc|atenated|
|00001090| 20 77 69 74 68 20 61 6e | 79 74 68 69 6e 67 0a 58 | with an|ything.X|
|000010a0| 20 2a 20 62 65 63 61 75 | 73 65 20 6f 66 20 6f 70 | * becau|se of op|
|000010b0| 65 72 61 74 6f 72 20 70 | 72 65 63 65 64 65 6e 63 |erator p|recedenc|
|000010c0| 65 2e 29 20 20 54 68 65 | 20 6f 70 65 72 61 6e 64 |e.) The| operand|
|000010d0| 20 6f 66 20 73 6f 6d 65 | 20 74 79 70 65 73 20 6f | of some| types o|
|000010e0| 66 20 6e 6f 64 65 20 69 | 73 0a 58 20 2a 20 61 20 |f node i|s.X * a |
|000010f0| 6c 69 74 65 72 61 6c 20 | 73 74 72 69 6e 67 3b 20 |literal |string; |
|00001100| 66 6f 72 20 6f 74 68 65 | 72 73 2c 20 69 74 20 69 |for othe|rs, it i|
|00001110| 73 20 61 20 6e 6f 64 65 | 20 6c 65 61 64 69 6e 67 |s a node| leading|
|00001120| 20 69 6e 74 6f 20 61 20 | 73 75 62 2d 46 53 4d 2e | into a |sub-FSM.|
|00001130| 20 20 49 6e 0a 58 20 2a | 20 70 61 72 74 69 63 75 | In.X *| particu|
|00001140| 6c 61 72 2c 20 74 68 65 | 20 6f 70 65 72 61 6e 64 |lar, the| operand|
|00001150| 20 6f 66 20 61 20 42 52 | 41 4e 43 48 20 6e 6f 64 | of a BR|ANCH nod|
|00001160| 65 20 69 73 20 74 68 65 | 20 66 69 72 73 74 20 6e |e is the| first n|
|00001170| 6f 64 65 20 6f 66 20 74 | 68 65 20 62 72 61 6e 63 |ode of t|he branc|
|00001180| 68 2e 0a 58 20 2a 20 28 | 4e 42 20 74 68 69 73 20 |h..X * (|NB this |
|00001190| 69 73 20 2a 6e 6f 74 2a | 20 61 20 74 72 65 65 20 |is *not*| a tree |
|000011a0| 73 74 72 75 63 74 75 72 | 65 3a 20 20 74 68 65 20 |structur|e: the |
|000011b0| 74 61 69 6c 20 6f 66 20 | 74 68 65 20 62 72 61 6e |tail of |the bran|
|000011c0| 63 68 20 63 6f 6e 6e 65 | 63 74 73 0a 58 20 2a 20 |ch conne|cts.X * |
|000011d0| 74 6f 20 74 68 65 20 74 | 68 69 6e 67 20 66 6f 6c |to the t|hing fol|
|000011e0| 6c 6f 77 69 6e 67 20 74 | 68 65 20 73 65 74 20 6f |lowing t|he set o|
|000011f0| 66 20 42 52 41 4e 43 48 | 65 73 2e 29 20 20 54 68 |f BRANCH|es.) Th|
|00001200| 65 20 6f 70 63 6f 64 65 | 73 20 61 72 65 3a 0a 58 |e opcode|s are:.X|
|00001210| 20 2a 2f 0a 58 0a 58 2f | 2a 20 64 65 66 69 6e 69 | */.X.X/|* defini|
|00001220| 74 69 6f 6e 09 6e 75 6d | 62 65 72 09 6f 70 6e 64 |tion.num|ber.opnd|
|00001230| 3f 09 6d 65 61 6e 69 6e | 67 20 2a 2f 0a 58 23 64 |?.meanin|g */.X#d|
|00001240| 65 66 69 6e 65 09 45 4e | 44 09 30 09 2f 2a 20 6e |efine.EN|D.0./* n|
|00001250| 6f 09 45 6e 64 20 6f 66 | 20 70 72 6f 67 72 61 6d |o.End of| program|
|00001260| 2e 20 2a 2f 0a 58 23 64 | 65 66 69 6e 65 09 42 4f |. */.X#d|efine.BO|
|00001270| 4c 09 31 09 2f 2a 20 6e | 6f 09 4d 61 74 63 68 20 |L.1./* n|o.Match |
|00001280| 22 22 20 61 74 20 62 65 | 67 69 6e 6e 69 6e 67 20 |"" at be|ginning |
|00001290| 6f 66 20 6c 69 6e 65 2e | 20 2a 2f 0a 58 23 64 65 |of line.| */.X#de|
|000012a0| 66 69 6e 65 09 45 4f 4c | 09 32 09 2f 2a 20 6e 6f |fine.EOL|.2./* no|
|000012b0| 09 4d 61 74 63 68 20 22 | 22 20 61 74 20 65 6e 64 |.Match "|" at end|
|000012c0| 20 6f 66 20 6c 69 6e 65 | 2e 20 2a 2f 0a 58 23 64 | of line|. */.X#d|
|000012d0| 65 66 69 6e 65 09 41 4e | 59 09 33 09 2f 2a 20 6e |efine.AN|Y.3./* n|
|000012e0| 6f 09 4d 61 74 63 68 20 | 61 6e 79 20 6f 6e 65 20 |o.Match |any one |
|000012f0| 63 68 61 72 61 63 74 65 | 72 2e 20 2a 2f 0a 58 23 |characte|r. */.X#|
|00001300| 64 65 66 69 6e 65 09 41 | 4e 59 4f 46 09 34 09 2f |define.A|NYOF.4./|
|00001310| 2a 20 73 74 72 09 4d 61 | 74 63 68 20 61 6e 79 20 |* str.Ma|tch any |
|00001320| 63 68 61 72 61 63 74 65 | 72 20 69 6e 20 74 68 69 |characte|r in thi|
|00001330| 73 20 73 74 72 69 6e 67 | 2e 20 2a 2f 0a 58 23 64 |s string|. */.X#d|
|00001340| 65 66 69 6e 65 09 41 4e | 59 42 55 54 09 35 09 2f |efine.AN|YBUT.5./|
|00001350| 2a 20 73 74 72 09 4d 61 | 74 63 68 20 61 6e 79 20 |* str.Ma|tch any |
|00001360| 63 68 61 72 61 63 74 65 | 72 20 6e 6f 74 20 69 6e |characte|r not in|
|00001370| 20 74 68 69 73 20 73 74 | 72 69 6e 67 2e 20 2a 2f | this st|ring. */|
|00001380| 0a 58 23 64 65 66 69 6e | 65 09 42 52 41 4e 43 48 |.X#defin|e.BRANCH|
|00001390| 09 36 09 2f 2a 20 6e 6f | 64 65 09 4d 61 74 63 68 |.6./* no|de.Match|
|000013a0| 20 74 68 69 73 20 61 6c | 74 65 72 6e 61 74 69 76 | this al|ternativ|
|000013b0| 65 2c 20 6f 72 20 74 68 | 65 20 6e 65 78 74 2e 2e |e, or th|e next..|
|000013c0| 2e 20 2a 2f 0a 58 23 64 | 65 66 69 6e 65 09 42 41 |. */.X#d|efine.BA|
|000013d0| 43 4b 09 37 09 2f 2a 20 | 6e 6f 09 4d 61 74 63 68 |CK.7./* |no.Match|
|000013e0| 20 22 22 2c 20 22 6e 65 | 78 74 22 20 70 74 72 20 | "", "ne|xt" ptr |
|000013f0| 70 6f 69 6e 74 73 20 62 | 61 63 6b 77 61 72 64 2e |points b|ackward.|
|00001400| 20 2a 2f 0a 58 23 64 65 | 66 69 6e 65 09 45 58 41 | */.X#de|fine.EXA|
|00001410| 43 54 4c 59 09 38 09 2f | 2a 20 73 74 72 09 4d 61 |CTLY.8./|* str.Ma|
|00001420| 74 63 68 20 74 68 69 73 | 20 73 74 72 69 6e 67 2e |tch this| string.|
|00001430| 20 2a 2f 0a 58 23 64 65 | 66 69 6e 65 09 4e 4f 54 | */.X#de|fine.NOT|
|00001440| 48 49 4e 47 09 39 09 2f | 2a 20 6e 6f 09 4d 61 74 |HING.9./|* no.Mat|
|00001450| 63 68 20 65 6d 70 74 79 | 20 73 74 72 69 6e 67 2e |ch empty| string.|
|00001460| 20 2a 2f 0a 58 23 64 65 | 66 69 6e 65 09 53 54 41 | */.X#de|fine.STA|
|00001470| 52 09 31 30 09 2f 2a 20 | 6e 6f 64 65 09 4d 61 74 |R.10./* |node.Mat|
|00001480| 63 68 20 74 68 69 73 20 | 28 73 69 6d 70 6c 65 29 |ch this |(simple)|
|00001490| 20 74 68 69 6e 67 20 30 | 20 6f 72 20 6d 6f 72 65 | thing 0| or more|
|000014a0| 20 74 69 6d 65 73 2e 20 | 2a 2f 0a 58 23 64 65 66 | times. |*/.X#def|
|000014b0| 69 6e 65 09 50 4c 55 53 | 09 31 31 09 2f 2a 20 6e |ine.PLUS|.11./* n|
|000014c0| 6f 64 65 09 4d 61 74 63 | 68 20 74 68 69 73 20 28 |ode.Matc|h this (|
|000014d0| 73 69 6d 70 6c 65 29 20 | 74 68 69 6e 67 20 31 20 |simple) |thing 1 |
|000014e0| 6f 72 20 6d 6f 72 65 20 | 74 69 6d 65 73 2e 20 2a |or more |times. *|
|000014f0| 2f 0a 58 23 64 65 66 69 | 6e 65 09 57 4f 52 44 41 |/.X#defi|ne.WORDA|
|00001500| 09 31 32 09 2f 2a 20 6e | 6f 09 4d 61 74 63 68 20 |.12./* n|o.Match |
|00001510| 22 22 20 61 74 20 77 6f | 72 64 63 68 61 72 2c 20 |"" at wo|rdchar, |
|00001520| 77 68 65 72 65 20 70 72 | 65 76 20 69 73 20 6e 6f |where pr|ev is no|
|00001530| 6e 77 6f 72 64 20 2a 2f | 0a 58 23 64 65 66 69 6e |nword */|.X#defin|
|00001540| 65 09 57 4f 52 44 5a 09 | 31 33 09 2f 2a 20 6e 6f |e.WORDZ.|13./* no|
|00001550| 09 4d 61 74 63 68 20 22 | 22 20 61 74 20 6e 6f 6e |.Match "|" at non|
|00001560| 77 6f 72 64 63 68 61 72 | 2c 20 77 68 65 72 65 20 |wordchar|, where |
|00001570| 70 72 65 76 20 69 73 20 | 77 6f 72 64 20 2a 2f 0a |prev is |word */.|
|00001580| 58 23 64 65 66 69 6e 65 | 09 4f 50 45 4e 09 32 30 |X#define|.OPEN.20|
|00001590| 09 2f 2a 20 6e 6f 09 4d | 61 72 6b 20 74 68 69 73 |./* no.M|ark this|
|000015a0| 20 70 6f 69 6e 74 20 69 | 6e 20 69 6e 70 75 74 20 | point i|n input |
|000015b0| 61 73 20 73 74 61 72 74 | 20 6f 66 20 23 6e 2e 20 |as start| of #n. |
|000015c0| 2a 2f 0a 58 09 09 09 2f | 2a 09 4f 50 45 4e 2b 31 |*/.X.../|*.OPEN+1|
|000015d0| 20 69 73 20 6e 75 6d 62 | 65 72 20 31 2c 20 65 74 | is numb|er 1, et|
|000015e0| 63 2e 20 2a 2f 0a 58 23 | 64 65 66 69 6e 65 09 43 |c. */.X#|define.C|
|000015f0| 4c 4f 53 45 09 33 30 09 | 2f 2a 20 6e 6f 09 41 6e |LOSE.30.|/* no.An|
|00001600| 61 6c 6f 67 6f 75 73 20 | 74 6f 20 4f 50 45 4e 2e |alogous |to OPEN.|
|00001610| 20 2a 2f 0a 58 0a 58 2f | 2a 0a 58 20 2a 20 4f 70 | */.X.X/|*.X * Op|
|00001620| 63 6f 64 65 20 6e 6f 74 | 65 73 3a 0a 58 20 2a 0a |code not|es:.X *.|
|00001630| 58 20 2a 20 42 52 41 4e | 43 48 09 54 68 65 20 73 |X * BRAN|CH.The s|
|00001640| 65 74 20 6f 66 20 62 72 | 61 6e 63 68 65 73 20 63 |et of br|anches c|
|00001650| 6f 6e 73 74 69 74 75 74 | 69 6e 67 20 61 20 73 69 |onstitut|ing a si|
|00001660| 6e 67 6c 65 20 63 68 6f | 69 63 65 20 61 72 65 20 |ngle cho|ice are |
|00001670| 68 6f 6f 6b 65 64 0a 58 | 20 2a 09 09 74 6f 67 65 |hooked.X| *..toge|
|00001680| 74 68 65 72 20 77 69 74 | 68 20 74 68 65 69 72 20 |ther wit|h their |
|00001690| 22 6e 65 78 74 22 20 70 | 6f 69 6e 74 65 72 73 2c |"next" p|ointers,|
|000016a0| 20 73 69 6e 63 65 20 70 | 72 65 63 65 64 65 6e 63 | since p|recedenc|
|000016b0| 65 20 70 72 65 76 65 6e | 74 73 0a 58 20 2a 09 09 |e preven|ts.X *..|
|000016c0| 61 6e 79 74 68 69 6e 67 | 20 62 65 69 6e 67 20 63 |anything| being c|
|000016d0| 6f 6e 63 61 74 65 6e 61 | 74 65 64 20 74 6f 20 61 |oncatena|ted to a|
|000016e0| 6e 79 20 69 6e 64 69 76 | 69 64 75 61 6c 20 62 72 |ny indiv|idual br|
|000016f0| 61 6e 63 68 2e 20 20 54 | 68 65 0a 58 20 2a 09 09 |anch. T|he.X *..|
|00001700| 22 6e 65 78 74 22 20 70 | 6f 69 6e 74 65 72 20 6f |"next" p|ointer o|
|00001710| 66 20 74 68 65 20 6c 61 | 73 74 20 42 52 41 4e 43 |f the la|st BRANC|
|00001720| 48 20 69 6e 20 61 20 63 | 68 6f 69 63 65 20 70 6f |H in a c|hoice po|
|00001730| 69 6e 74 73 20 74 6f 20 | 74 68 65 0a 58 20 2a 09 |ints to |the.X *.|
|00001740| 09 74 68 69 6e 67 20 66 | 6f 6c 6c 6f 77 69 6e 67 |.thing f|ollowing|
|00001750| 20 74 68 65 20 77 68 6f | 6c 65 20 63 68 6f 69 63 | the who|le choic|
|00001760| 65 2e 20 20 54 68 69 73 | 20 69 73 20 61 6c 73 6f |e. This| is also|
|00001770| 20 77 68 65 72 65 20 74 | 68 65 0a 58 20 2a 09 09 | where t|he.X *..|
|00001780| 66 69 6e 61 6c 20 22 6e | 65 78 74 22 20 70 6f 69 |final "n|ext" poi|
|00001790| 6e 74 65 72 20 6f 66 20 | 65 61 63 68 20 69 6e 64 |nter of |each ind|
|000017a0| 69 76 69 64 75 61 6c 20 | 62 72 61 6e 63 68 20 70 |ividual |branch p|
|000017b0| 6f 69 6e 74 73 3b 20 65 | 61 63 68 0a 58 20 2a 09 |oints; e|ach.X *.|
|000017c0| 09 62 72 61 6e 63 68 20 | 73 74 61 72 74 73 20 77 |.branch |starts w|
|000017d0| 69 74 68 20 74 68 65 20 | 6f 70 65 72 61 6e 64 20 |ith the |operand |
|000017e0| 6e 6f 64 65 20 6f 66 20 | 61 20 42 52 41 4e 43 48 |node of |a BRANCH|
|000017f0| 20 6e 6f 64 65 2e 0a 58 | 20 2a 0a 58 20 2a 20 42 | node..X| *.X * B|
|00001800| 41 43 4b 09 09 4e 6f 72 | 6d 61 6c 20 22 6e 65 78 |ACK..Nor|mal "nex|
|00001810| 74 22 20 70 6f 69 6e 74 | 65 72 73 20 61 6c 6c 20 |t" point|ers all |
|00001820| 69 6d 70 6c 69 63 69 74 | 6c 79 20 70 6f 69 6e 74 |implicit|ly point|
|00001830| 20 66 6f 72 77 61 72 64 | 3b 20 42 41 43 4b 0a 58 | forward|; BACK.X|
|00001840| 20 2a 09 09 65 78 69 73 | 74 73 20 74 6f 20 6d 61 | *..exis|ts to ma|
|00001850| 6b 65 20 6c 6f 6f 70 20 | 73 74 72 75 63 74 75 72 |ke loop |structur|
|00001860| 65 73 20 70 6f 73 73 69 | 62 6c 65 2e 0a 58 20 2a |es possi|ble..X *|
|00001870| 0a 58 20 2a 20 53 54 41 | 52 2c 50 4c 55 53 09 27 |.X * STA|R,PLUS.'|
|00001880| 3f 27 2c 20 61 6e 64 20 | 63 6f 6d 70 6c 65 78 20 |?', and |complex |
|00001890| 27 2a 27 20 61 6e 64 20 | 27 2b 27 2c 20 61 72 65 |'*' and |'+', are|
|000018a0| 20 69 6d 70 6c 65 6d 65 | 6e 74 65 64 20 61 73 20 | impleme|nted as |
|000018b0| 63 69 72 63 75 6c 61 72 | 0a 58 20 2a 09 09 42 52 |circular|.X *..BR|
|000018c0| 41 4e 43 48 20 73 74 72 | 75 63 74 75 72 65 73 20 |ANCH str|uctures |
|000018d0| 75 73 69 6e 67 20 42 41 | 43 4b 2e 20 20 53 69 6d |using BA|CK. Sim|
|000018e0| 70 6c 65 20 63 61 73 65 | 73 20 28 6f 6e 65 20 63 |ple case|s (one c|
|000018f0| 68 61 72 61 63 74 65 72 | 0a 58 20 2a 09 09 70 65 |haracter|.X *..pe|
|00001900| 72 20 6d 61 74 63 68 29 | 20 61 72 65 20 69 6d 70 |r match)| are imp|
|00001910| 6c 65 6d 65 6e 74 65 64 | 20 77 69 74 68 20 53 54 |lemented| with ST|
|00001920| 41 52 20 61 6e 64 20 50 | 4c 55 53 20 66 6f 72 20 |AR and P|LUS for |
|00001930| 73 70 65 65 64 0a 58 20 | 2a 09 09 61 6e 64 20 74 |speed.X |*..and t|
|00001940| 6f 20 6d 69 6e 69 6d 69 | 7a 65 20 72 65 63 75 72 |o minimi|ze recur|
|00001950| 73 69 76 65 20 70 6c 75 | 6e 67 65 73 2e 0a 58 20 |sive plu|nges..X |
|00001960| 2a 0a 58 20 2a 20 4f 50 | 45 4e 2c 43 4c 4f 53 45 |*.X * OP|EN,CLOSE|
|00001970| 09 2e 2e 2e 61 72 65 20 | 6e 75 6d 62 65 72 65 64 |....are |numbered|
|00001980| 20 61 74 20 63 6f 6d 70 | 69 6c 65 20 74 69 6d 65 | at comp|ile time|
|00001990| 2e 0a 58 20 2a 2f 0a 58 | 0a 58 2f 2a 0a 58 20 2a |..X */.X|.X/*.X *|
|000019a0| 20 41 20 6e 6f 64 65 20 | 69 73 20 6f 6e 65 20 63 | A node |is one c|
|000019b0| 68 61 72 20 6f 66 20 6f | 70 63 6f 64 65 20 66 6f |har of o|pcode fo|
|000019c0| 6c 6c 6f 77 65 64 20 62 | 79 20 74 77 6f 20 63 68 |llowed b|y two ch|
|000019d0| 61 72 73 20 6f 66 20 22 | 6e 65 78 74 22 20 70 6f |ars of "|next" po|
|000019e0| 69 6e 74 65 72 2e 0a 58 | 20 2a 20 22 4e 65 78 74 |inter..X| * "Next|
|000019f0| 22 20 70 6f 69 6e 74 65 | 72 73 20 61 72 65 20 73 |" pointe|rs are s|
|00001a00| 74 6f 72 65 64 20 61 73 | 20 74 77 6f 20 38 2d 62 |tored as| two 8-b|
|00001a10| 69 74 20 70 69 65 63 65 | 73 2c 20 68 69 67 68 20 |it piece|s, high |
|00001a20| 6f 72 64 65 72 20 66 69 | 72 73 74 2e 20 20 54 68 |order fi|rst. Th|
|00001a30| 65 0a 58 20 2a 20 76 61 | 6c 75 65 20 69 73 20 61 |e.X * va|lue is a|
|00001a40| 20 70 6f 73 69 74 69 76 | 65 20 6f 66 66 73 65 74 | positiv|e offset|
|00001a50| 20 66 72 6f 6d 20 74 68 | 65 20 6f 70 63 6f 64 65 | from th|e opcode|
|00001a60| 20 6f 66 20 74 68 65 20 | 6e 6f 64 65 20 63 6f 6e | of the |node con|
|00001a70| 74 61 69 6e 69 6e 67 20 | 69 74 2e 0a 58 20 2a 20 |taining |it..X * |
|00001a80| 41 6e 20 6f 70 65 72 61 | 6e 64 2c 20 69 66 20 61 |An opera|nd, if a|
|00001a90| 6e 79 2c 20 73 69 6d 70 | 6c 79 20 66 6f 6c 6c 6f |ny, simp|ly follo|
|00001aa0| 77 73 20 74 68 65 20 6e | 6f 64 65 2e 20 20 28 4e |ws the n|ode. (N|
|00001ab0| 6f 74 65 20 74 68 61 74 | 20 6d 75 63 68 20 6f 66 |ote that| much of|
|00001ac0| 20 74 68 65 0a 58 20 2a | 20 63 6f 64 65 20 67 65 | the.X *| code ge|
|00001ad0| 6e 65 72 61 74 69 6f 6e | 20 6b 6e 6f 77 73 20 61 |neration| knows a|
|00001ae0| 62 6f 75 74 20 74 68 69 | 73 20 69 6d 70 6c 69 63 |bout thi|s implic|
|00001af0| 69 74 20 72 65 6c 61 74 | 69 6f 6e 73 68 69 70 2e |it relat|ionship.|
|00001b00| 29 0a 58 20 2a 0a 58 20 | 2a 20 55 73 69 6e 67 20 |).X *.X |* Using |
|00001b10| 74 77 6f 20 62 79 74 65 | 73 20 66 6f 72 20 74 68 |two byte|s for th|
|00001b20| 65 20 22 6e 65 78 74 22 | 20 70 6f 69 6e 74 65 72 |e "next"| pointer|
|00001b30| 20 69 73 20 76 61 73 74 | 20 6f 76 65 72 6b 69 6c | is vast| overkil|
|00001b40| 6c 20 66 6f 72 20 6d 6f | 73 74 20 74 68 69 6e 67 |l for mo|st thing|
|00001b50| 73 2c 0a 58 20 2a 20 62 | 75 74 20 61 6c 6c 6f 77 |s,.X * b|ut allow|
|00001b60| 73 20 70 61 74 74 65 72 | 6e 73 20 74 6f 20 67 65 |s patter|ns to ge|
|00001b70| 74 20 62 69 67 20 77 69 | 74 68 6f 75 74 20 64 69 |t big wi|thout di|
|00001b80| 73 61 73 74 65 72 73 2e | 0a 58 20 2a 2f 0a 58 23 |sasters.|.X */.X#|
|00001b90| 64 65 66 69 6e 65 09 4f | 50 28 70 29 09 28 2a 28 |define.O|P(p).(*(|
|00001ba0| 70 29 29 0a 58 23 64 65 | 66 69 6e 65 09 4e 45 58 |p)).X#de|fine.NEX|
|00001bb0| 54 28 70 29 09 28 28 28 | 2a 28 28 70 29 2b 31 29 |T(p).(((|*((p)+1)|
|00001bc0| 26 30 33 37 37 29 3c 3c | 38 29 20 2b 20 28 2a 28 |&0377)<<|8) + (*(|
|00001bd0| 28 70 29 2b 32 29 26 30 | 33 37 37 29 29 0a 58 23 |(p)+2)&0|377)).X#|
|00001be0| 64 65 66 69 6e 65 09 4f | 50 45 52 41 4e 44 28 70 |define.O|PERAND(p|
|00001bf0| 29 09 28 28 70 29 20 2b | 20 33 29 0a 58 0a 58 2f |).((p) +| 3).X.X/|
|00001c00| 2a 0a 58 20 2a 20 53 65 | 65 20 72 65 67 6d 61 67 |*.X * Se|e regmag|
|00001c10| 69 63 2e 68 20 66 6f 72 | 20 6f 6e 65 20 66 75 72 |ic.h for| one fur|
|00001c20| 74 68 65 72 20 64 65 74 | 61 69 6c 20 6f 66 20 70 |ther det|ail of p|
|00001c30| 72 6f 67 72 61 6d 20 73 | 74 72 75 63 74 75 72 65 |rogram s|tructure|
|00001c40| 2e 0a 58 20 2a 2f 0a 58 | 0a 58 0a 58 2f 2a 0a 58 |..X */.X|.X.X/*.X|
|00001c50| 20 2a 20 55 74 69 6c 69 | 74 79 20 64 65 66 69 6e | * Utili|ty defin|
|00001c60| 69 74 69 6f 6e 73 2e 0a | 58 20 2a 2f 0a 58 23 69 |itions..|X */.X#i|
|00001c70| 66 6e 64 65 66 20 43 48 | 41 52 42 49 54 53 0a 58 |fndef CH|ARBITS.X|
|00001c80| 23 64 65 66 69 6e 65 09 | 55 43 48 41 52 41 54 28 |#define.|UCHARAT(|
|00001c90| 70 29 09 28 28 69 6e 74 | 29 2a 28 75 6e 73 69 67 |p).((int|)*(unsig|
|00001ca0| 6e 65 64 20 63 68 61 72 | 20 2a 29 28 70 29 29 0a |ned char| *)(p)).|
|00001cb0| 58 23 65 6c 73 65 0a 58 | 23 64 65 66 69 6e 65 09 |X#else.X|#define.|
|00001cc0| 55 43 48 41 52 41 54 28 | 70 29 09 28 28 69 6e 74 |UCHARAT(|p).((int|
|00001cd0| 29 2a 28 70 29 26 43 48 | 41 52 42 49 54 53 29 0a |)*(p)&CH|ARBITS).|
|00001ce0| 58 23 65 6e 64 69 66 0a | 58 0a 58 23 64 65 66 69 |X#endif.|X.X#defi|
|00001cf0| 6e 65 09 46 41 49 4c 28 | 6d 29 09 7b 20 72 65 67 |ne.FAIL(|m).{ reg|
|00001d00| 65 72 72 6f 72 28 6d 29 | 3b 20 72 65 74 75 72 6e |error(m)|; return|
|00001d10| 28 4e 55 4c 4c 29 3b 20 | 7d 0a 58 23 64 65 66 69 |(NULL); |}.X#defi|
|00001d20| 6e 65 09 49 53 4d 55 4c | 54 28 63 29 09 28 28 63 |ne.ISMUL|T(c).((c|
|00001d30| 29 20 3d 3d 20 27 2a 27 | 20 7c 7c 20 28 63 29 20 |) == '*'| || (c) |
|00001d40| 3d 3d 20 27 2b 27 20 7c | 7c 20 28 63 29 20 3d 3d |== '+' ||| (c) ==|
|00001d50| 20 27 3f 27 29 0a 58 0a | 58 2f 2a 0a 58 20 2a 20 | '?').X.|X/*.X * |
|00001d60| 46 6c 61 67 73 20 74 6f | 20 62 65 20 70 61 73 73 |Flags to| be pass|
|00001d70| 65 64 20 75 70 20 61 6e | 64 20 64 6f 77 6e 2e 0a |ed up an|d down..|
|00001d80| 58 20 2a 2f 0a 58 23 64 | 65 66 69 6e 65 09 48 41 |X */.X#d|efine.HA|
|00001d90| 53 57 49 44 54 48 09 30 | 31 09 2f 2a 20 4b 6e 6f |SWIDTH.0|1./* Kno|
|00001da0| 77 6e 20 6e 65 76 65 72 | 20 74 6f 20 6d 61 74 63 |wn never| to matc|
|00001db0| 68 20 6e 75 6c 6c 20 73 | 74 72 69 6e 67 2e 20 2a |h null s|tring. *|
|00001dc0| 2f 0a 58 23 64 65 66 69 | 6e 65 09 53 49 4d 50 4c |/.X#defi|ne.SIMPL|
|00001dd0| 45 09 09 30 32 09 2f 2a | 20 53 69 6d 70 6c 65 20 |E..02./*| Simple |
|00001de0| 65 6e 6f 75 67 68 20 74 | 6f 20 62 65 20 53 54 41 |enough t|o be STA|
|00001df0| 52 2f 50 4c 55 53 20 6f | 70 65 72 61 6e 64 2e 20 |R/PLUS o|perand. |
|00001e00| 2a 2f 0a 58 23 64 65 66 | 69 6e 65 09 53 50 53 54 |*/.X#def|ine.SPST|
|00001e10| 41 52 54 09 09 30 34 09 | 2f 2a 20 53 74 61 72 74 |ART..04.|/* Start|
|00001e20| 73 20 77 69 74 68 20 2a | 20 6f 72 20 2b 2e 20 2a |s with *| or +. *|
|00001e30| 2f 0a 58 23 64 65 66 69 | 6e 65 09 57 4f 52 53 54 |/.X#defi|ne.WORST|
|00001e40| 09 09 30 09 2f 2a 20 57 | 6f 72 73 74 20 63 61 73 |..0./* W|orst cas|
|00001e50| 65 2e 20 2a 2f 0a 58 0a | 58 2f 2a 0a 58 20 2a 20 |e. */.X.|X/*.X * |
|00001e60| 47 6c 6f 62 61 6c 20 77 | 6f 72 6b 20 76 61 72 69 |Global w|ork vari|
|00001e70| 61 62 6c 65 73 20 66 6f | 72 20 72 65 67 63 6f 6d |ables fo|r regcom|
|00001e80| 70 28 29 2e 0a 58 20 2a | 2f 0a 58 73 74 61 74 69 |p()..X *|/.Xstati|
|00001e90| 63 20 63 68 61 72 20 2a | 72 65 67 70 61 72 73 65 |c char *|regparse|
|00001ea0| 3b 09 09 2f 2a 20 49 6e | 70 75 74 2d 73 63 61 6e |;../* In|put-scan|
|00001eb0| 20 70 6f 69 6e 74 65 72 | 2e 20 2a 2f 0a 58 73 74 | pointer|. */.Xst|
|00001ec0| 61 74 69 63 20 69 6e 74 | 20 72 65 67 6e 70 61 72 |atic int| regnpar|
|00001ed0| 3b 09 09 2f 2a 20 28 29 | 20 63 6f 75 6e 74 2e 20 |;../* ()| count. |
|00001ee0| 2a 2f 0a 58 73 74 61 74 | 69 63 20 63 68 61 72 20 |*/.Xstat|ic char |
|00001ef0| 72 65 67 64 75 6d 6d 79 | 3b 0a 58 73 74 61 74 69 |regdummy|;.Xstati|
|00001f00| 63 20 63 68 61 72 20 2a | 72 65 67 63 6f 64 65 3b |c char *|regcode;|
|00001f10| 09 09 2f 2a 20 43 6f 64 | 65 2d 65 6d 69 74 20 70 |../* Cod|e-emit p|
|00001f20| 6f 69 6e 74 65 72 3b 20 | 26 72 65 67 64 75 6d 6d |ointer; |®dumm|
|00001f30| 79 20 3d 20 64 6f 6e 27 | 74 2e 20 2a 2f 0a 58 73 |y = don'|t. */.Xs|
|00001f40| 74 61 74 69 63 20 6c 6f | 6e 67 20 72 65 67 73 69 |tatic lo|ng regsi|
|00001f50| 7a 65 3b 09 09 2f 2a 20 | 43 6f 64 65 20 73 69 7a |ze;../* |Code siz|
|00001f60| 65 2e 20 2a 2f 0a 58 0a | 58 2f 2a 0a 58 20 2a 20 |e. */.X.|X/*.X * |
|00001f70| 46 6f 72 77 61 72 64 20 | 64 65 63 6c 61 72 61 74 |Forward |declarat|
|00001f80| 69 6f 6e 73 20 66 6f 72 | 20 72 65 67 63 6f 6d 70 |ions for| regcomp|
|00001f90| 28 29 27 73 20 66 72 69 | 65 6e 64 73 2e 0a 58 20 |()'s fri|ends..X |
|00001fa0| 2a 2f 0a 58 23 69 66 6e | 64 65 66 20 53 54 41 54 |*/.X#ifn|def STAT|
|00001fb0| 49 43 0a 58 23 64 65 66 | 69 6e 65 09 53 54 41 54 |IC.X#def|ine.STAT|
|00001fc0| 49 43 09 73 74 61 74 69 | 63 0a 58 23 65 6e 64 69 |IC.stati|c.X#endi|
|00001fd0| 66 0a 58 53 54 41 54 49 | 43 20 63 68 61 72 20 2a |f.XSTATI|C char *|
|00001fe0| 72 65 67 28 29 3b 0a 58 | 53 54 41 54 49 43 20 63 |reg();.X|STATIC c|
|00001ff0| 68 61 72 20 2a 72 65 67 | 62 72 61 6e 63 68 28 29 |har *reg|branch()|
|00002000| 3b 0a 58 53 54 41 54 49 | 43 20 63 68 61 72 20 2a |;.XSTATI|C char *|
|00002010| 72 65 67 70 69 65 63 65 | 28 29 3b 0a 58 53 54 41 |regpiece|();.XSTA|
|00002020| 54 49 43 20 63 68 61 72 | 20 2a 72 65 67 61 74 6f |TIC char| *regato|
|00002030| 6d 28 29 3b 0a 58 53 54 | 41 54 49 43 20 63 68 61 |m();.XST|ATIC cha|
|00002040| 72 20 2a 72 65 67 6e 6f | 64 65 28 29 3b 0a 58 53 |r *regno|de();.XS|
|00002050| 54 41 54 49 43 20 63 68 | 61 72 20 2a 72 65 67 6e |TATIC ch|ar *regn|
|00002060| 65 78 74 28 29 3b 0a 58 | 53 54 41 54 49 43 20 76 |ext();.X|STATIC v|
|00002070| 6f 69 64 20 72 65 67 63 | 28 29 3b 0a 58 53 54 41 |oid regc|();.XSTA|
|00002080| 54 49 43 20 76 6f 69 64 | 20 72 65 67 69 6e 73 65 |TIC void| reginse|
|00002090| 72 74 28 29 3b 0a 58 53 | 54 41 54 49 43 20 76 6f |rt();.XS|TATIC vo|
|000020a0| 69 64 20 72 65 67 74 61 | 69 6c 28 29 3b 0a 58 53 |id regta|il();.XS|
|000020b0| 54 41 54 49 43 20 76 6f | 69 64 20 72 65 67 6f 70 |TATIC vo|id regop|
|000020c0| 74 61 69 6c 28 29 3b 0a | 58 23 69 66 64 65 66 20 |tail();.|X#ifdef |
|000020d0| 53 54 52 43 53 50 4e 0a | 58 53 54 41 54 49 43 20 |STRCSPN.|XSTATIC |
|000020e0| 69 6e 74 20 73 74 72 63 | 73 70 6e 28 29 3b 0a 58 |int strc|spn();.X|
|000020f0| 23 65 6e 64 69 66 0a 58 | 0a 58 2f 2a 0a 58 20 2d |#endif.X|.X/*.X -|
|00002100| 20 72 65 67 63 6f 6d 70 | 20 2d 20 63 6f 6d 70 69 | regcomp| - compi|
|00002110| 6c 65 20 61 20 72 65 67 | 75 6c 61 72 20 65 78 70 |le a reg|ular exp|
|00002120| 72 65 73 73 69 6f 6e 20 | 69 6e 74 6f 20 69 6e 74 |ression |into int|
|00002130| 65 72 6e 61 6c 20 63 6f | 64 65 0a 58 20 2a 0a 58 |ernal co|de.X *.X|
|00002140| 20 2a 20 57 65 20 63 61 | 6e 27 74 20 61 6c 6c 6f | * We ca|n't allo|
|00002150| 63 61 74 65 20 73 70 61 | 63 65 20 75 6e 74 69 6c |cate spa|ce until|
|00002160| 20 77 65 20 6b 6e 6f 77 | 20 68 6f 77 20 62 69 67 | we know| how big|
|00002170| 20 74 68 65 20 63 6f 6d | 70 69 6c 65 64 20 66 6f | the com|piled fo|
|00002180| 72 6d 20 77 69 6c 6c 20 | 62 65 2c 0a 58 20 2a 20 |rm will |be,.X * |
|00002190| 62 75 74 20 77 65 20 63 | 61 6e 27 74 20 63 6f 6d |but we c|an't com|
|000021a0| 70 69 6c 65 20 69 74 20 | 28 61 6e 64 20 74 68 75 |pile it |(and thu|
|000021b0| 73 20 6b 6e 6f 77 20 68 | 6f 77 20 62 69 67 20 69 |s know h|ow big i|
|000021c0| 74 20 69 73 29 20 75 6e | 74 69 6c 20 77 65 27 76 |t is) un|til we'v|
|000021d0| 65 20 67 6f 74 20 61 0a | 58 20 2a 20 70 6c 61 63 |e got a.|X * plac|
|000021e0| 65 20 74 6f 20 70 75 74 | 20 74 68 65 20 63 6f 64 |e to put| the cod|
|000021f0| 65 2e 20 20 53 6f 20 77 | 65 20 63 68 65 61 74 3a |e. So w|e cheat:|
|00002200| 20 20 77 65 20 63 6f 6d | 70 69 6c 65 20 69 74 20 | we com|pile it |
|00002210| 74 77 69 63 65 2c 20 6f | 6e 63 65 20 77 69 74 68 |twice, o|nce with|
|00002220| 20 63 6f 64 65 0a 58 20 | 2a 20 67 65 6e 65 72 61 | code.X |* genera|
|00002230| 74 69 6f 6e 20 74 75 72 | 6e 65 64 20 6f 66 66 20 |tion tur|ned off |
|00002240| 61 6e 64 20 73 69 7a 65 | 20 63 6f 75 6e 74 69 6e |and size| countin|
|00002250| 67 20 74 75 72 6e 65 64 | 20 6f 6e 2c 20 61 6e 64 |g turned| on, and|
|00002260| 20 6f 6e 63 65 20 22 66 | 6f 72 20 72 65 61 6c 22 | once "f|or real"|
|00002270| 2e 0a 58 20 2a 20 54 68 | 69 73 20 61 6c 73 6f 20 |..X * Th|is also |
|00002280| 6d 65 61 6e 73 20 74 68 | 61 74 20 77 65 20 64 6f |means th|at we do|
|00002290| 6e 27 74 20 61 6c 6c 6f | 63 61 74 65 20 73 70 61 |n't allo|cate spa|
|000022a0| 63 65 20 75 6e 74 69 6c | 20 77 65 20 61 72 65 20 |ce until| we are |
|000022b0| 73 75 72 65 20 74 68 61 | 74 20 74 68 65 0a 58 20 |sure tha|t the.X |
|000022c0| 2a 20 74 68 69 6e 67 20 | 72 65 61 6c 6c 79 20 77 |* thing |really w|
|000022d0| 69 6c 6c 20 63 6f 6d 70 | 69 6c 65 20 73 75 63 63 |ill comp|ile succ|
|000022e0| 65 73 73 66 75 6c 6c 79 | 2c 20 61 6e 64 20 77 65 |essfully|, and we|
|000022f0| 20 6e 65 76 65 72 20 68 | 61 76 65 20 74 6f 20 6d | never h|ave to m|
|00002300| 6f 76 65 20 74 68 65 0a | 58 20 2a 20 63 6f 64 65 |ove the.|X * code|
|00002310| 20 61 6e 64 20 74 68 75 | 73 20 69 6e 76 61 6c 69 | and thu|s invali|
|00002320| 64 61 74 65 20 70 6f 69 | 6e 74 65 72 73 20 69 6e |date poi|nters in|
|00002330| 74 6f 20 69 74 2e 20 20 | 28 4e 6f 74 65 20 74 68 |to it. |(Note th|
|00002340| 61 74 20 69 74 20 68 61 | 73 20 74 6f 20 62 65 20 |at it ha|s to be |
|00002350| 69 6e 0a 58 20 2a 20 6f | 6e 65 20 70 69 65 63 65 |in.X * o|ne piece|
|00002360| 20 62 65 63 61 75 73 65 | 20 66 72 65 65 28 29 20 | because| free() |
|00002370| 6d 75 73 74 20 62 65 20 | 61 62 6c 65 20 74 6f 20 |must be |able to |
|00002380| 66 72 65 65 20 69 74 20 | 61 6c 6c 2e 29 0a 58 20 |free it |all.).X |
|00002390| 2a 0a 58 20 2a 20 42 65 | 77 61 72 65 20 74 68 61 |*.X * Be|ware tha|
|000023a0| 74 20 74 68 65 20 6f 70 | 74 69 6d 69 7a 61 74 69 |t the op|timizati|
|000023b0| 6f 6e 2d 70 72 65 70 61 | 72 61 74 69 6f 6e 20 63 |on-prepa|ration c|
|000023c0| 6f 64 65 20 69 6e 20 68 | 65 72 65 20 6b 6e 6f 77 |ode in h|ere know|
|000023d0| 73 20 61 62 6f 75 74 20 | 73 6f 6d 65 0a 58 20 2a |s about |some.X *|
|000023e0| 20 6f 66 20 74 68 65 20 | 73 74 72 75 63 74 75 72 | of the |structur|
|000023f0| 65 20 6f 66 20 74 68 65 | 20 63 6f 6d 70 69 6c 65 |e of the| compile|
|00002400| 64 20 72 65 67 65 78 70 | 2e 0a 58 20 2a 2f 0a 58 |d regexp|..X */.X|
|00002410| 72 65 67 65 78 70 20 2a | 0a 58 72 65 67 63 6f 6d |regexp *|.Xregcom|
|00002420| 70 28 65 78 70 29 0a 58 | 63 68 61 72 20 2a 65 78 |p(exp).X|char *ex|
|00002430| 70 3b 0a 58 7b 0a 58 09 | 72 65 67 69 73 74 65 72 |p;.X{.X.|register|
|00002440| 20 72 65 67 65 78 70 20 | 2a 72 3b 0a 58 09 72 65 | regexp |*r;.X.re|
|00002450| 67 69 73 74 65 72 20 63 | 68 61 72 20 2a 73 63 61 |gister c|har *sca|
|00002460| 6e 3b 0a 58 09 72 65 67 | 69 73 74 65 72 20 63 68 |n;.X.reg|ister ch|
|00002470| 61 72 20 2a 6c 6f 6e 67 | 65 73 74 3b 0a 58 09 72 |ar *long|est;.X.r|
|00002480| 65 67 69 73 74 65 72 20 | 69 6e 74 20 6c 65 6e 3b |egister |int len;|
|00002490| 0a 58 09 69 6e 74 20 66 | 6c 61 67 73 3b 0a 58 09 |.X.int f|lags;.X.|
|000024a0| 65 78 74 65 72 6e 20 63 | 68 61 72 20 2a 6d 61 6c |extern c|har *mal|
|000024b0| 6c 6f 63 28 29 3b 0a 58 | 0a 58 09 69 66 20 28 65 |loc();.X|.X.if (e|
|000024c0| 78 70 20 3d 3d 20 4e 55 | 4c 4c 29 0a 58 09 09 46 |xp == NU|LL).X..F|
|000024d0| 41 49 4c 28 22 4e 55 4c | 4c 20 61 72 67 75 6d 65 |AIL("NUL|L argume|
|000024e0| 6e 74 22 29 3b 0a 58 0a | 58 09 2f 2a 20 46 69 72 |nt");.X.|X./* Fir|
|000024f0| 73 74 20 70 61 73 73 3a | 20 64 65 74 65 72 6d 69 |st pass:| determi|
|00002500| 6e 65 20 73 69 7a 65 2c | 20 6c 65 67 61 6c 69 74 |ne size,| legalit|
|00002510| 79 2e 20 2a 2f 0a 58 09 | 69 66 20 28 65 78 70 5b |y. */.X.|if (exp[|
|00002520| 30 5d 20 3d 3d 20 27 2e | 27 20 26 26 20 65 78 70 |0] == '.|' && exp|
|00002530| 5b 31 5d 20 3d 3d 20 27 | 2a 27 29 20 65 78 70 20 |[1] == '|*') exp |
|00002540| 2b 3d 20 32 3b 20 20 2f | 2a 20 61 69 64 20 67 72 |+= 2; /|* aid gr|
|00002550| 65 70 20 2a 2f 0a 58 09 | 72 65 67 70 61 72 73 65 |ep */.X.|regparse|
|00002560| 20 3d 20 65 78 70 3b 0a | 58 09 72 65 67 6e 70 61 | = exp;.|X.regnpa|
|00002570| 72 20 3d 20 31 3b 0a 58 | 09 72 65 67 73 69 7a 65 |r = 1;.X|.regsize|
|00002580| 20 3d 20 30 4c 3b 0a 58 | 09 72 65 67 63 6f 64 65 | = 0L;.X|.regcode|
|00002590| 20 3d 20 26 72 65 67 64 | 75 6d 6d 79 3b 0a 58 09 | = ®d|ummy;.X.|
|000025a0| 72 65 67 63 28 4d 41 47 | 49 43 29 3b 0a 58 09 69 |regc(MAG|IC);.X.i|
|000025b0| 66 20 28 72 65 67 28 30 | 2c 20 26 66 6c 61 67 73 |f (reg(0|, &flags|
|000025c0| 29 20 3d 3d 20 4e 55 4c | 4c 29 0a 58 09 09 72 65 |) == NUL|L).X..re|
|000025d0| 74 75 72 6e 28 4e 55 4c | 4c 29 3b 0a 58 0a 58 09 |turn(NUL|L);.X.X.|
|000025e0| 2f 2a 20 53 6d 61 6c 6c | 20 65 6e 6f 75 67 68 20 |/* Small| enough |
|000025f0| 66 6f 72 20 70 6f 69 6e | 74 65 72 2d 73 74 6f 72 |for poin|ter-stor|
|00002600| 61 67 65 20 63 6f 6e 76 | 65 6e 74 69 6f 6e 3f 20 |age conv|ention? |
|00002610| 2a 2f 0a 58 09 69 66 20 | 28 72 65 67 73 69 7a 65 |*/.X.if |(regsize|
|00002620| 20 3e 3d 20 33 32 37 36 | 37 4c 29 09 09 2f 2a 20 | >= 3276|7L)../* |
|00002630| 50 72 6f 62 61 62 6c 79 | 20 63 6f 75 6c 64 20 62 |Probably| could b|
|00002640| 65 20 36 35 35 33 35 4c | 2e 20 2a 2f 0a 58 09 09 |e 65535L|. */.X..|
|00002650| 46 41 49 4c 28 22 72 65 | 67 65 78 70 20 74 6f 6f |FAIL("re|gexp too|
|00002660| 20 62 69 67 22 29 3b 0a | 58 0a 58 09 2f 2a 20 41 | big");.|X.X./* A|
|00002670| 6c 6c 6f 63 61 74 65 20 | 73 70 61 63 65 2e 20 2a |llocate |space. *|
|00002680| 2f 0a 58 09 72 20 3d 20 | 28 72 65 67 65 78 70 20 |/.X.r = |(regexp |
|00002690| 2a 29 6d 61 6c 6c 6f 63 | 28 73 69 7a 65 6f 66 28 |*)malloc|(sizeof(|
|000026a0| 72 65 67 65 78 70 29 20 | 2b 20 28 75 6e 73 69 67 |regexp) |+ (unsig|
|000026b0| 6e 65 64 29 72 65 67 73 | 69 7a 65 29 3b 0a 58 09 |ned)regs|ize);.X.|
|000026c0| 69 66 20 28 72 20 3d 3d | 20 4e 55 4c 4c 29 0a 58 |if (r ==| NULL).X|
|000026d0| 09 09 46 41 49 4c 28 22 | 6f 75 74 20 6f 66 20 73 |..FAIL("|out of s|
|000026e0| 70 61 63 65 22 29 3b 0a | 58 0a 58 09 2f 2a 20 53 |pace");.|X.X./* S|
|000026f0| 65 63 6f 6e 64 20 70 61 | 73 73 3a 20 65 6d 69 74 |econd pa|ss: emit|
|00002700| 20 63 6f 64 65 2e 20 2a | 2f 0a 58 09 72 65 67 70 | code. *|/.X.regp|
|00002710| 61 72 73 65 20 3d 20 65 | 78 70 3b 0a 58 09 72 65 |arse = e|xp;.X.re|
|00002720| 67 6e 70 61 72 20 3d 20 | 31 3b 0a 58 09 72 65 67 |gnpar = |1;.X.reg|
|00002730| 63 6f 64 65 20 3d 20 72 | 2d 3e 70 72 6f 67 72 61 |code = r|->progra|
|00002740| 6d 3b 0a 58 09 72 65 67 | 63 28 4d 41 47 49 43 29 |m;.X.reg|c(MAGIC)|
|00002750| 3b 0a 58 09 69 66 20 28 | 72 65 67 28 30 2c 20 26 |;.X.if (|reg(0, &|
|00002760| 66 6c 61 67 73 29 20 3d | 3d 20 4e 55 4c 4c 29 0a |flags) =|= NULL).|
|00002770| 58 09 09 72 65 74 75 72 | 6e 28 4e 55 4c 4c 29 3b |X..retur|n(NULL);|
|00002780| 0a 58 0a 58 09 2f 2a 20 | 44 69 67 20 6f 75 74 20 |.X.X./* |Dig out |
|00002790| 69 6e 66 6f 72 6d 61 74 | 69 6f 6e 20 66 6f 72 20 |informat|ion for |
|000027a0| 6f 70 74 69 6d 69 7a 61 | 74 69 6f 6e 73 2e 20 2a |optimiza|tions. *|
|000027b0| 2f 0a 58 09 72 2d 3e 72 | 65 67 73 74 61 72 74 20 |/.X.r->r|egstart |
|000027c0| 3d 20 27 5c 30 27 3b 09 | 2f 2a 20 57 6f 72 73 74 |= '\0';.|/* Worst|
|000027d0| 2d 63 61 73 65 20 64 65 | 66 61 75 6c 74 73 2e 20 |-case de|faults. |
|000027e0| 2a 2f 0a 58 09 72 2d 3e | 72 65 67 61 6e 63 68 20 |*/.X.r->|reganch |
|000027f0| 3d 20 30 3b 0a 58 09 72 | 2d 3e 72 65 67 6d 75 73 |= 0;.X.r|->regmus|
|00002800| 74 20 3d 20 4e 55 4c 4c | 3b 0a 58 09 72 2d 3e 72 |t = NULL|;.X.r->r|
|00002810| 65 67 6d 6c 65 6e 20 3d | 20 30 3b 0a 58 09 73 63 |egmlen =| 0;.X.sc|
|00002820| 61 6e 20 3d 20 72 2d 3e | 70 72 6f 67 72 61 6d 2b |an = r->|program+|
|00002830| 31 3b 09 09 09 2f 2a 20 | 46 69 72 73 74 20 42 52 |1;.../* |First BR|
|00002840| 41 4e 43 48 2e 20 2a 2f | 0a 58 09 69 66 20 28 4f |ANCH. */|.X.if (O|
|00002850| 50 28 72 65 67 6e 65 78 | 74 28 73 63 61 6e 29 29 |P(regnex|t(scan))|
|00002860| 20 3d 3d 20 45 4e 44 29 | 20 7b 09 09 2f 2a 20 4f | == END)| {../* O|
|00002870| 6e 6c 79 20 6f 6e 65 20 | 74 6f 70 2d 6c 65 76 65 |nly one |top-leve|
|00002880| 6c 20 63 68 6f 69 63 65 | 2e 20 2a 2f 0a 58 09 09 |l choice|. */.X..|
|00002890| 73 63 61 6e 20 3d 20 4f | 50 45 52 41 4e 44 28 73 |scan = O|PERAND(s|
|000028a0| 63 61 6e 29 3b 0a 58 0a | 58 09 09 2f 2a 20 53 74 |can);.X.|X../* St|
|000028b0| 61 72 74 69 6e 67 2d 70 | 6f 69 6e 74 20 69 6e 66 |arting-p|oint inf|
|000028c0| 6f 2e 20 2a 2f 0a 58 09 | 09 69 66 20 28 4f 50 28 |o. */.X.|.if (OP(|
|000028d0| 73 63 61 6e 29 20 3d 3d | 20 45 58 41 43 54 4c 59 |scan) ==| EXACTLY|
|000028e0| 29 0a 58 09 09 09 72 2d | 3e 72 65 67 73 74 61 72 |).X...r-|>regstar|
|000028f0| 74 20 3d 20 2a 4f 50 45 | 52 41 4e 44 28 73 63 61 |t = *OPE|RAND(sca|
|00002900| 6e 29 3b 0a 58 09 09 65 | 6c 73 65 20 69 66 20 28 |n);.X..e|lse if (|
|00002910| 4f 50 28 73 63 61 6e 29 | 20 3d 3d 20 42 4f 4c 29 |OP(scan)| == BOL)|
|00002920| 0a 58 09 09 09 72 2d 3e | 72 65 67 61 6e 63 68 2b |.X...r->|reganch+|
|00002930| 2b 3b 0a 58 0a 58 09 09 | 2f 2a 0a 58 09 09 20 2a |+;.X.X..|/*.X.. *|
|00002940| 20 49 66 20 74 68 65 72 | 65 27 73 20 73 6f 6d 65 | If ther|e's some|
|00002950| 74 68 69 6e 67 20 65 78 | 70 65 6e 73 69 76 65 20 |thing ex|pensive |
|00002960| 69 6e 20 74 68 65 20 72 | 2e 65 2e 2c 20 66 69 6e |in the r|.e., fin|
|00002970| 64 20 74 68 65 0a 58 09 | 09 20 2a 20 6c 6f 6e 67 |d the.X.|. * long|
|00002980| 65 73 74 20 6c 69 74 65 | 72 61 6c 20 73 74 72 69 |est lite|ral stri|
|00002990| 6e 67 20 74 68 61 74 20 | 6d 75 73 74 20 61 70 70 |ng that |must app|
|000029a0| 65 61 72 20 61 6e 64 20 | 6d 61 6b 65 20 69 74 20 |ear and |make it |
|000029b0| 74 68 65 0a 58 09 09 20 | 2a 20 72 65 67 6d 75 73 |the.X.. |* regmus|
|000029c0| 74 2e 20 20 52 65 73 6f | 6c 76 65 20 74 69 65 73 |t. Reso|lve ties|
|000029d0| 20 69 6e 20 66 61 76 6f | 72 20 6f 66 20 6c 61 74 | in favo|r of lat|
|000029e0| 65 72 20 73 74 72 69 6e | 67 73 2c 20 73 69 6e 63 |er strin|gs, sinc|
|000029f0| 65 0a 58 09 09 20 2a 20 | 74 68 65 20 72 65 67 73 |e.X.. * |the regs|
|00002a00| 74 61 72 74 20 63 68 65 | 63 6b 20 77 6f 72 6b 73 |tart che|ck works|
|00002a10| 20 77 69 74 68 20 74 68 | 65 20 62 65 67 69 6e 6e | with th|e beginn|
|00002a20| 69 6e 67 20 6f 66 20 74 | 68 65 20 72 2e 65 2e 0a |ing of t|he r.e..|
|00002a30| 58 09 09 20 2a 20 61 6e | 64 20 61 76 6f 69 64 69 |X.. * an|d avoidi|
|00002a40| 6e 67 20 64 75 70 6c 69 | 63 61 74 69 6f 6e 20 73 |ng dupli|cation s|
|00002a50| 74 72 65 6e 67 74 68 65 | 6e 73 20 63 68 65 63 6b |trengthe|ns check|
|00002a60| 69 6e 67 2e 20 20 4e 6f | 74 20 61 0a 58 09 09 20 |ing. No|t a.X.. |
|00002a70| 2a 20 73 74 72 6f 6e 67 | 20 72 65 61 73 6f 6e 2c |* strong| reason,|
|00002a80| 20 62 75 74 20 73 75 66 | 66 69 63 69 65 6e 74 20 | but suf|ficient |
|00002a90| 69 6e 20 74 68 65 20 61 | 62 73 65 6e 63 65 20 6f |in the a|bsence o|
|00002aa0| 66 20 6f 74 68 65 72 73 | 2e 0a 58 09 09 20 2a 2f |f others|..X.. */|
|00002ab0| 0a 58 09 09 69 66 20 28 | 66 6c 61 67 73 26 53 50 |.X..if (|flags&SP|
|00002ac0| 53 54 41 52 54 29 20 7b | 0a 58 09 09 09 6c 6f 6e |START) {|.X...lon|
|00002ad0| 67 65 73 74 20 3d 20 4e | 55 4c 4c 3b 0a 58 09 09 |gest = N|ULL;.X..|
|00002ae0| 09 6c 65 6e 20 3d 20 30 | 3b 0a 58 09 09 09 66 6f |.len = 0|;.X...fo|
|00002af0| 72 20 28 3b 20 73 63 61 | 6e 20 21 3d 20 4e 55 4c |r (; sca|n != NUL|
|00002b00| 4c 3b 20 73 63 61 6e 20 | 3d 20 72 65 67 6e 65 78 |L; scan |= regnex|
|00002b10| 74 28 73 63 61 6e 29 29 | 0a 58 09 09 09 09 69 66 |t(scan))|.X....if|
|00002b20| 20 28 4f 50 28 73 63 61 | 6e 29 20 3d 3d 20 45 58 | (OP(sca|n) == EX|
|00002b30| 41 43 54 4c 59 20 26 26 | 20 73 74 72 6c 65 6e 28 |ACTLY &&| strlen(|
|00002b40| 4f 50 45 52 41 4e 44 28 | 73 63 61 6e 29 29 20 3e |OPERAND(|scan)) >|
|00002b50| 3d 20 6c 65 6e 29 20 7b | 0a 58 09 09 09 09 09 6c |= len) {|.X.....l|
|00002b60| 6f 6e 67 65 73 74 20 3d | 20 4f 50 45 52 41 4e 44 |ongest =| OPERAND|
|00002b70| 28 73 63 61 6e 29 3b 0a | 58 09 09 09 09 09 6c 65 |(scan);.|X.....le|
|00002b80| 6e 20 3d 20 73 74 72 6c | 65 6e 28 4f 50 45 52 41 |n = strl|en(OPERA|
|00002b90| 4e 44 28 73 63 61 6e 29 | 29 3b 0a 58 09 09 09 09 |ND(scan)|);.X....|
|00002ba0| 7d 0a 58 09 09 09 72 2d | 3e 72 65 67 6d 75 73 74 |}.X...r-|>regmust|
|00002bb0| 20 3d 20 6c 6f 6e 67 65 | 73 74 3b 0a 58 09 09 09 | = longe|st;.X...|
|00002bc0| 72 2d 3e 72 65 67 6d 6c | 65 6e 20 3d 20 6c 65 6e |r->regml|en = len|
|00002bd0| 3b 0a 58 09 09 7d 0a 58 | 09 7d 0a 58 0a 58 09 72 |;.X..}.X|.}.X.X.r|
|00002be0| 65 74 75 72 6e 28 72 29 | 3b 0a 58 7d 0a 58 0a 58 |eturn(r)|;.X}.X.X|
|00002bf0| 2f 2a 0a 58 20 2d 20 72 | 65 67 20 2d 20 72 65 67 |/*.X - r|eg - reg|
|00002c00| 75 6c 61 72 20 65 78 70 | 72 65 73 73 69 6f 6e 2c |ular exp|ression,|
|00002c10| 20 69 2e 65 2e 20 6d 61 | 69 6e 20 62 6f 64 79 20 | i.e. ma|in body |
|00002c20| 6f 72 20 70 61 72 65 6e | 74 68 65 73 69 7a 65 64 |or paren|thesized|
|00002c30| 20 74 68 69 6e 67 0a 58 | 20 2a 0a 58 20 2a 20 43 | thing.X| *.X * C|
|00002c40| 61 6c 6c 65 72 20 6d 75 | 73 74 20 61 62 73 6f 72 |aller mu|st absor|
|00002c50| 62 20 6f 70 65 6e 69 6e | 67 20 70 61 72 65 6e 74 |b openin|g parent|
|00002c60| 68 65 73 69 73 2e 0a 58 | 20 2a 0a 58 20 2a 20 43 |hesis..X| *.X * C|
|00002c70| 6f 6d 62 69 6e 69 6e 67 | 20 70 61 72 65 6e 74 68 |ombining| parenth|
|00002c80| 65 73 69 73 20 68 61 6e | 64 6c 69 6e 67 20 77 69 |esis han|dling wi|
|00002c90| 74 68 20 74 68 65 20 62 | 61 73 65 20 6c 65 76 65 |th the b|ase leve|
|00002ca0| 6c 20 6f 66 20 72 65 67 | 75 6c 61 72 20 65 78 70 |l of reg|ular exp|
|00002cb0| 72 65 73 73 69 6f 6e 0a | 58 20 2a 20 69 73 20 61 |ression.|X * is a|
|00002cc0| 20 74 72 69 66 6c 65 20 | 66 6f 72 63 65 64 2c 20 | trifle |forced, |
|00002cd0| 62 75 74 20 74 68 65 20 | 6e 65 65 64 20 74 6f 20 |but the |need to |
|00002ce0| 74 69 65 20 74 68 65 20 | 74 61 69 6c 73 20 6f 66 |tie the |tails of|
|00002cf0| 20 74 68 65 20 62 72 61 | 6e 63 68 65 73 20 74 6f | the bra|nches to|
|00002d00| 20 77 68 61 74 0a 58 20 | 2a 20 66 6f 6c 6c 6f 77 | what.X |* follow|
|00002d10| 73 20 6d 61 6b 65 73 20 | 69 74 20 68 61 72 64 20 |s makes |it hard |
|00002d20| 74 6f 20 61 76 6f 69 64 | 2e 0a 58 20 2a 2f 0a 58 |to avoid|..X */.X|
|00002d30| 73 74 61 74 69 63 20 63 | 68 61 72 20 2a 0a 58 72 |static c|har *.Xr|
|00002d40| 65 67 28 70 61 72 65 6e | 2c 20 66 6c 61 67 70 29 |eg(paren|, flagp)|
|00002d50| 0a 58 69 6e 74 20 70 61 | 72 65 6e 3b 09 09 09 2f |.Xint pa|ren;.../|
|00002d60| 2a 20 50 61 72 65 6e 74 | 68 65 73 69 7a 65 64 3f |* Parent|hesized?|
|00002d70| 20 2a 2f 0a 58 69 6e 74 | 20 2a 66 6c 61 67 70 3b | */.Xint| *flagp;|
|00002d80| 0a 58 7b 0a 58 09 72 65 | 67 69 73 74 65 72 20 63 |.X{.X.re|gister c|
|00002d90| 68 61 72 20 2a 72 65 74 | 3b 0a 58 09 72 65 67 69 |har *ret|;.X.regi|
|00002da0| 73 74 65 72 20 63 68 61 | 72 20 2a 62 72 3b 0a 58 |ster cha|r *br;.X|
|00002db0| 09 72 65 67 69 73 74 65 | 72 20 63 68 61 72 20 2a |.registe|r char *|
|00002dc0| 65 6e 64 65 72 3b 0a 58 | 09 72 65 67 69 73 74 65 |ender;.X|.registe|
|00002dd0| 72 20 69 6e 74 20 70 61 | 72 6e 6f 3b 0a 58 09 69 |r int pa|rno;.X.i|
|00002de0| 6e 74 20 66 6c 61 67 73 | 3b 0a 58 0a 58 09 2a 66 |nt flags|;.X.X.*f|
|00002df0| 6c 61 67 70 20 3d 20 48 | 41 53 57 49 44 54 48 3b |lagp = H|ASWIDTH;|
|00002e00| 09 2f 2a 20 54 65 6e 74 | 61 74 69 76 65 6c 79 2e |./* Tent|atively.|
|00002e10| 20 2a 2f 0a 58 0a 58 09 | 2f 2a 20 4d 61 6b 65 20 | */.X.X.|/* Make |
|00002e20| 61 6e 20 4f 50 45 4e 20 | 6e 6f 64 65 2c 20 69 66 |an OPEN |node, if|
|00002e30| 20 70 61 72 65 6e 74 68 | 65 73 69 7a 65 64 2e 20 | parenth|esized. |
|00002e40| 2a 2f 0a 58 09 69 66 20 | 28 70 61 72 65 6e 29 20 |*/.X.if |(paren) |
|00002e50| 7b 0a 58 09 09 69 66 20 | 28 72 65 67 6e 70 61 72 |{.X..if |(regnpar|
|00002e60| 20 3e 3d 20 4e 53 55 42 | 45 58 50 29 0a 58 09 09 | >= NSUB|EXP).X..|
|00002e70| 09 46 41 49 4c 28 22 74 | 6f 6f 20 6d 61 6e 79 20 |.FAIL("t|oo many |
|00002e80| 28 29 22 29 3b 0a 58 09 | 09 70 61 72 6e 6f 20 3d |()");.X.|.parno =|
|00002e90| 20 72 65 67 6e 70 61 72 | 3b 0a 58 09 09 72 65 67 | regnpar|;.X..reg|
|00002ea0| 6e 70 61 72 2b 2b 3b 0a | 58 09 09 72 65 74 20 3d |npar++;.|X..ret =|
|00002eb0| 20 72 65 67 6e 6f 64 65 | 28 4f 50 45 4e 2b 70 61 | regnode|(OPEN+pa|
|00002ec0| 72 6e 6f 29 3b 0a 58 09 | 7d 20 65 6c 73 65 0a 58 |rno);.X.|} else.X|
|00002ed0| 09 09 72 65 74 20 3d 20 | 4e 55 4c 4c 3b 0a 58 0a |..ret = |NULL;.X.|
|00002ee0| 58 09 2f 2a 20 50 69 63 | 6b 20 75 70 20 74 68 65 |X./* Pic|k up the|
|00002ef0| 20 62 72 61 6e 63 68 65 | 73 2c 20 6c 69 6e 6b 69 | branche|s, linki|
|00002f00| 6e 67 20 74 68 65 6d 20 | 74 6f 67 65 74 68 65 72 |ng them |together|
|00002f10| 2e 20 2a 2f 0a 58 09 62 | 72 20 3d 20 72 65 67 62 |. */.X.b|r = regb|
|00002f20| 72 61 6e 63 68 28 26 66 | 6c 61 67 73 29 3b 0a 58 |ranch(&f|lags);.X|
|00002f30| 09 69 66 20 28 62 72 20 | 3d 3d 20 4e 55 4c 4c 29 |.if (br |== NULL)|
|00002f40| 0a 58 09 09 72 65 74 75 | 72 6e 28 4e 55 4c 4c 29 |.X..retu|rn(NULL)|
|00002f50| 3b 0a 58 09 69 66 20 28 | 72 65 74 20 21 3d 20 4e |;.X.if (|ret != N|
|00002f60| 55 4c 4c 29 0a 58 09 09 | 72 65 67 74 61 69 6c 28 |ULL).X..|regtail(|
|00002f70| 72 65 74 2c 20 62 72 29 | 3b 09 2f 2a 20 4f 50 45 |ret, br)|;./* OPE|
|00002f80| 4e 20 2d 3e 20 66 69 72 | 73 74 2e 20 2a 2f 0a 58 |N -> fir|st. */.X|
|00002f90| 09 65 6c 73 65 0a 58 09 | 09 72 65 74 20 3d 20 62 |.else.X.|.ret = b|
|00002fa0| 72 3b 0a 58 09 69 66 20 | 28 21 28 66 6c 61 67 73 |r;.X.if |(!(flags|
|00002fb0| 26 48 41 53 57 49 44 54 | 48 29 29 0a 58 09 09 2a |&HASWIDT|H)).X..*|
|00002fc0| 66 6c 61 67 70 20 26 3d | 20 7e 48 41 53 57 49 44 |flagp &=| ~HASWID|
|00002fd0| 54 48 3b 0a 58 09 2a 66 | 6c 61 67 70 20 7c 3d 20 |TH;.X.*f|lagp |= |
|00002fe0| 66 6c 61 67 73 26 53 50 | 53 54 41 52 54 3b 0a 58 |flags&SP|START;.X|
|00002ff0| 09 77 68 69 6c 65 20 28 | 2a 72 65 67 70 61 72 73 |.while (|*regpars|
|00003000| 65 20 3d 3d 20 27 7c 27 | 20 7c 7c 20 2a 72 65 67 |e == '|'| || *reg|
|00003010| 70 61 72 73 65 20 3d 3d | 20 27 5c 6e 27 29 20 7b |parse ==| '\n') {|
|00003020| 0a 58 09 09 72 65 67 70 | 61 72 73 65 2b 2b 3b 0a |.X..regp|arse++;.|
|00003030| 58 09 09 62 72 20 3d 20 | 72 65 67 62 72 61 6e 63 |X..br = |regbranc|
|00003040| 68 28 26 66 6c 61 67 73 | 29 3b 0a 58 09 09 69 66 |h(&flags|);.X..if|
|00003050| 20 28 62 72 20 3d 3d 20 | 4e 55 4c 4c 29 0a 58 09 | (br == |NULL).X.|
|00003060| 09 09 72 65 74 75 72 6e | 28 4e 55 4c 4c 29 3b 0a |..return|(NULL);.|
|00003070| 58 09 09 72 65 67 74 61 | 69 6c 28 72 65 74 2c 20 |X..regta|il(ret, |
|00003080| 62 72 29 3b 09 2f 2a 20 | 42 52 41 4e 43 48 20 2d |br);./* |BRANCH -|
|00003090| 3e 20 42 52 41 4e 43 48 | 2e 20 2a 2f 0a 58 09 09 |> BRANCH|. */.X..|
|000030a0| 69 66 20 28 21 28 66 6c | 61 67 73 26 48 41 53 57 |if (!(fl|ags&HASW|
|000030b0| 49 44 54 48 29 29 0a 58 | 09 09 09 2a 66 6c 61 67 |IDTH)).X|...*flag|
|000030c0| 70 20 26 3d 20 7e 48 41 | 53 57 49 44 54 48 3b 0a |p &= ~HA|SWIDTH;.|
|000030d0| 58 09 09 2a 66 6c 61 67 | 70 20 7c 3d 20 66 6c 61 |X..*flag|p |= fla|
|000030e0| 67 73 26 53 50 53 54 41 | 52 54 3b 0a 58 09 7d 0a |gs&SPSTA|RT;.X.}.|
|000030f0| 58 0a 58 09 2f 2a 20 4d | 61 6b 65 20 61 20 63 6c |X.X./* M|ake a cl|
|00003100| 6f 73 69 6e 67 20 6e 6f | 64 65 2c 20 61 6e 64 20 |osing no|de, and |
|00003110| 68 6f 6f 6b 20 69 74 20 | 6f 6e 20 74 68 65 20 65 |hook it |on the e|
|00003120| 6e 64 2e 20 2a 2f 0a 58 | 09 65 6e 64 65 72 20 3d |nd. */.X|.ender =|
|00003130| 20 72 65 67 6e 6f 64 65 | 28 28 70 61 72 65 6e 29 | regnode|((paren)|
|00003140| 20 3f 20 43 4c 4f 53 45 | 2b 70 61 72 6e 6f 20 3a | ? CLOSE|+parno :|
|00003150| 20 45 4e 44 29 3b 09 0a | 58 09 72 65 67 74 61 69 | END);..|X.regtai|
|00003160| 6c 28 72 65 74 2c 20 65 | 6e 64 65 72 29 3b 0a 58 |l(ret, e|nder);.X|
|00003170| 0a 58 09 2f 2a 20 48 6f | 6f 6b 20 74 68 65 20 74 |.X./* Ho|ok the t|
|00003180| 61 69 6c 73 20 6f 66 20 | 74 68 65 20 62 72 61 6e |ails of |the bran|
|00003190| 63 68 65 73 20 74 6f 20 | 74 68 65 20 63 6c 6f 73 |ches to |the clos|
|000031a0| 69 6e 67 20 6e 6f 64 65 | 2e 20 2a 2f 0a 58 09 66 |ing node|. */.X.f|
|000031b0| 6f 72 20 28 62 72 20 3d | 20 72 65 74 3b 20 62 72 |or (br =| ret; br|
|000031c0| 20 21 3d 20 4e 55 4c 4c | 3b 20 62 72 20 3d 20 72 | != NULL|; br = r|
|000031d0| 65 67 6e 65 78 74 28 62 | 72 29 29 0a 58 09 09 72 |egnext(b|r)).X..r|
|000031e0| 65 67 6f 70 74 61 69 6c | 28 62 72 2c 20 65 6e 64 |egoptail|(br, end|
|000031f0| 65 72 29 3b 0a 58 0a 58 | 09 2f 2a 20 43 68 65 63 |er);.X.X|./* Chec|
|00003200| 6b 20 66 6f 72 20 70 72 | 6f 70 65 72 20 74 65 72 |k for pr|oper ter|
|00003210| 6d 69 6e 61 74 69 6f 6e | 2e 20 2a 2f 0a 58 09 69 |mination|. */.X.i|
|00003220| 66 20 28 70 61 72 65 6e | 20 26 26 20 2a 72 65 67 |f (paren| && *reg|
|00003230| 70 61 72 73 65 2b 2b 20 | 21 3d 20 27 29 27 29 20 |parse++ |!= ')') |
|00003240| 7b 0a 58 09 09 46 41 49 | 4c 28 22 75 6e 6d 61 74 |{.X..FAI|L("unmat|
|00003250| 63 68 65 64 20 28 29 22 | 29 3b 0a 58 09 7d 20 65 |ched ()"|);.X.} e|
|00003260| 6c 73 65 20 69 66 20 28 | 21 70 61 72 65 6e 20 26 |lse if (|!paren &|
|00003270| 26 20 2a 72 65 67 70 61 | 72 73 65 20 21 3d 20 27 |& *regpa|rse != '|
|00003280| 5c 30 27 29 20 7b 0a 58 | 09 09 69 66 20 28 2a 72 |\0') {.X|..if (*r|
|00003290| 65 67 70 61 72 73 65 20 | 3d 3d 20 27 29 27 29 20 |egparse |== ')') |
|000032a0| 7b 0a 58 09 09 09 46 41 | 49 4c 28 22 75 6e 6d 61 |{.X...FA|IL("unma|
|000032b0| 74 63 68 65 64 20 28 29 | 22 29 3b 0a 58 09 09 7d |tched ()|");.X..}|
|000032c0| 20 65 6c 73 65 0a 58 09 | 09 09 46 41 49 4c 28 22 | else.X.|..FAIL("|
|000032d0| 6a 75 6e 6b 20 6f 6e 20 | 65 6e 64 22 29 3b 09 2f |junk on |end");./|
|000032e0| 2a 20 22 43 61 6e 27 74 | 20 68 61 70 70 65 6e 22 |* "Can't| happen"|
|000032f0| 2e 20 2a 2f 0a 58 09 09 | 2f 2a 20 4e 4f 54 52 45 |. */.X..|/* NOTRE|
|00003300| 41 43 48 45 44 20 2a 2f | 0a 58 09 7d 0a 58 0a 58 |ACHED */|.X.}.X.X|
|00003310| 09 72 65 74 75 72 6e 28 | 72 65 74 29 3b 0a 58 7d |.return(|ret);.X}|
|00003320| 0a 58 0a 58 2f 2a 0a 58 | 20 2d 20 72 65 67 62 72 |.X.X/*.X| - regbr|
|00003330| 61 6e 63 68 20 2d 20 6f | 6e 65 20 61 6c 74 65 72 |anch - o|ne alter|
|00003340| 6e 61 74 69 76 65 20 6f | 66 20 61 6e 20 7c 20 6f |native o|f an | o|
|00003350| 70 65 72 61 74 6f 72 0a | 58 20 2a 0a 58 20 2a 20 |perator.|X *.X * |
|00003360| 49 6d 70 6c 65 6d 65 6e | 74 73 20 74 68 65 20 63 |Implemen|ts the c|
|00003370| 6f 6e 63 61 74 65 6e 61 | 74 69 6f 6e 20 6f 70 65 |oncatena|tion ope|
|00003380| 72 61 74 6f 72 2e 0a 58 | 20 2a 2f 0a 58 73 74 61 |rator..X| */.Xsta|
|00003390| 74 69 63 20 63 68 61 72 | 20 2a 0a 58 72 65 67 62 |tic char| *.Xregb|
|000033a0| 72 61 6e 63 68 28 66 6c | 61 67 70 29 0a 58 69 6e |ranch(fl|agp).Xin|
|000033b0| 74 20 2a 66 6c 61 67 70 | 3b 0a 58 7b 0a 58 09 72 |t *flagp|;.X{.X.r|
|000033c0| 65 67 69 73 74 65 72 20 | 63 68 61 72 20 2a 72 65 |egister |char *re|
|000033d0| 74 3b 0a 58 09 72 65 67 | 69 73 74 65 72 20 63 68 |t;.X.reg|ister ch|
|000033e0| 61 72 20 2a 63 68 61 69 | 6e 3b 0a 58 09 72 65 67 |ar *chai|n;.X.reg|
|000033f0| 69 73 74 65 72 20 63 68 | 61 72 20 2a 6c 61 74 65 |ister ch|ar *late|
|00003400| 73 74 3b 0a 58 09 69 6e | 74 20 66 6c 61 67 73 3b |st;.X.in|t flags;|
|00003410| 0a 58 0a 58 09 2a 66 6c | 61 67 70 20 3d 20 57 4f |.X.X.*fl|agp = WO|
|00003420| 52 53 54 3b 09 09 2f 2a | 20 54 65 6e 74 61 74 69 |RST;../*| Tentati|
|00003430| 76 65 6c 79 2e 20 2a 2f | 0a 58 0a 58 09 72 65 74 |vely. */|.X.X.ret|
|00003440| 20 3d 20 72 65 67 6e 6f | 64 65 28 42 52 41 4e 43 | = regno|de(BRANC|
|00003450| 48 29 3b 0a 58 09 63 68 | 61 69 6e 20 3d 20 4e 55 |H);.X.ch|ain = NU|
|00003460| 4c 4c 3b 0a 58 09 77 68 | 69 6c 65 20 28 2a 72 65 |LL;.X.wh|ile (*re|
|00003470| 67 70 61 72 73 65 20 21 | 3d 20 27 5c 30 27 20 26 |gparse !|= '\0' &|
|00003480| 26 20 2a 72 65 67 70 61 | 72 73 65 20 21 3d 20 27 |& *regpa|rse != '|
|00003490| 29 27 20 26 26 0a 58 09 | 20 20 20 20 20 20 20 2a |)' &&.X.| *|
|000034a0| 72 65 67 70 61 72 73 65 | 20 21 3d 20 27 5c 6e 27 |regparse| != '\n'|
|000034b0| 20 26 26 20 2a 72 65 67 | 70 61 72 73 65 20 21 3d | && *reg|parse !=|
|000034c0| 20 27 7c 27 29 20 7b 0a | 58 09 09 6c 61 74 65 73 | '|') {.|X..lates|
|000034d0| 74 20 3d 20 72 65 67 70 | 69 65 63 65 28 26 66 6c |t = regp|iece(&fl|
|000034e0| 61 67 73 29 3b 0a 58 09 | 09 69 66 20 28 6c 61 74 |ags);.X.|.if (lat|
|000034f0| 65 73 74 20 3d 3d 20 4e | 55 4c 4c 29 0a 58 09 09 |est == N|ULL).X..|
|00003500| 09 72 65 74 75 72 6e 28 | 4e 55 4c 4c 29 3b 0a 58 |.return(|NULL);.X|
|00003510| 09 09 2a 66 6c 61 67 70 | 20 7c 3d 20 66 6c 61 67 |..*flagp| |= flag|
|00003520| 73 26 48 41 53 57 49 44 | 54 48 3b 0a 58 09 09 69 |s&HASWID|TH;.X..i|
|00003530| 66 20 28 63 68 61 69 6e | 20 3d 3d 20 4e 55 4c 4c |f (chain| == NULL|
|00003540| 29 09 2f 2a 20 46 69 72 | 73 74 20 70 69 65 63 65 |)./* Fir|st piece|
|00003550| 2e 20 2a 2f 0a 58 09 09 | 09 2a 66 6c 61 67 70 20 |. */.X..|.*flagp |
|00003560| 7c 3d 20 66 6c 61 67 73 | 26 53 50 53 54 41 52 54 ||= flags|&SPSTART|
|00003570| 3b 0a 58 09 09 65 6c 73 | 65 0a 58 09 09 09 72 65 |;.X..els|e.X...re|
|00003580| 67 74 61 69 6c 28 63 68 | 61 69 6e 2c 20 6c 61 74 |gtail(ch|ain, lat|
|00003590| 65 73 74 29 3b 0a 58 09 | 09 63 68 61 69 6e 20 3d |est);.X.|.chain =|
|000035a0| 20 6c 61 74 65 73 74 3b | 0a 58 09 7d 0a 58 09 69 | latest;|.X.}.X.i|
|000035b0| 66 20 28 63 68 61 69 6e | 20 3d 3d 20 4e 55 4c 4c |f (chain| == NULL|
|000035c0| 29 09 2f 2a 20 4c 6f 6f | 70 20 72 61 6e 20 7a 65 |)./* Loo|p ran ze|
|000035d0| 72 6f 20 74 69 6d 65 73 | 2e 20 2a 2f 0a 58 09 09 |ro times|. */.X..|
|000035e0| 28 76 6f 69 64 29 20 72 | 65 67 6e 6f 64 65 28 4e |(void) r|egnode(N|
|000035f0| 4f 54 48 49 4e 47 29 3b | 0a 58 0a 58 09 72 65 74 |OTHING);|.X.X.ret|
|00003600| 75 72 6e 28 72 65 74 29 | 3b 0a 58 7d 0a 58 0a 58 |urn(ret)|;.X}.X.X|
|00003610| 2f 2a 0a 58 20 2d 20 72 | 65 67 70 69 65 63 65 20 |/*.X - r|egpiece |
|00003620| 2d 20 73 6f 6d 65 74 68 | 69 6e 67 20 66 6f 6c 6c |- someth|ing foll|
|00003630| 6f 77 65 64 20 62 79 20 | 70 6f 73 73 69 62 6c 65 |owed by |possible|
|00003640| 20 5b 2a 2b 3f 5d 0a 58 | 20 2a 0a 58 20 2a 20 4e | [*+?].X| *.X * N|
|00003650| 6f 74 65 20 74 68 61 74 | 20 74 68 65 20 62 72 61 |ote that| the bra|
|00003660| 6e 63 68 69 6e 67 20 63 | 6f 64 65 20 73 65 71 75 |nching c|ode sequ|
|00003670| 65 6e 63 65 73 20 75 73 | 65 64 20 66 6f 72 20 3f |ences us|ed for ?|
|00003680| 20 61 6e 64 20 74 68 65 | 20 67 65 6e 65 72 61 6c | and the| general|
|00003690| 20 63 61 73 65 73 0a 58 | 20 2a 20 6f 66 20 2a 20 | cases.X| * of * |
|000036a0| 61 6e 64 20 2b 20 61 72 | 65 20 73 6f 6d 65 77 68 |and + ar|e somewh|
|000036b0| 61 74 20 6f 70 74 69 6d | 69 7a 65 64 3a 20 20 74 |at optim|ized: t|
|000036c0| 68 65 79 20 75 73 65 20 | 74 68 65 20 73 61 6d 65 |hey use |the same|
|000036d0| 20 4e 4f 54 48 49 4e 47 | 20 6e 6f 64 65 20 61 73 | NOTHING| node as|
|000036e0| 0a 58 20 2a 20 62 6f 74 | 68 20 74 68 65 20 65 6e |.X * bot|h the en|
|000036f0| 64 6d 61 72 6b 65 72 20 | 66 6f 72 20 74 68 65 69 |dmarker |for thei|
|00003700| 72 20 62 72 61 6e 63 68 | 20 6c 69 73 74 20 61 6e |r branch| list an|
|00003710| 64 20 74 68 65 20 62 6f | 64 79 20 6f 66 20 74 68 |d the bo|dy of th|
|00003720| 65 20 6c 61 73 74 20 62 | 72 61 6e 63 68 2e 0a 58 |e last b|ranch..X|
|00003730| 20 2a 20 49 74 20 6d 69 | 67 68 74 20 73 65 65 6d | * It mi|ght seem|
|00003740| 20 74 68 61 74 20 74 68 | 69 73 20 6e 6f 64 65 20 | that th|is node |
|00003750| 63 6f 75 6c 64 20 62 65 | 20 64 69 73 70 65 6e 73 |could be| dispens|
|00003760| 65 64 20 77 69 74 68 20 | 65 6e 74 69 72 65 6c 79 |ed with |entirely|
|00003770| 2c 20 62 75 74 20 74 68 | 65 0a 58 20 2a 20 65 6e |, but th|e.X * en|
|00003780| 64 6d 61 72 6b 65 72 20 | 72 6f 6c 65 20 69 73 20 |dmarker |role is |
|00003790| 6e 6f 74 20 72 65 64 75 | 6e 64 61 6e 74 2e 0a 58 |not redu|ndant..X|
|000037a0| 20 2a 2f 0a 58 73 74 61 | 74 69 63 20 63 68 61 72 | */.Xsta|tic char|
|000037b0| 20 2a 0a 58 72 65 67 70 | 69 65 63 65 28 66 6c 61 | *.Xregp|iece(fla|
|000037c0| 67 70 29 0a 58 69 6e 74 | 20 2a 66 6c 61 67 70 3b |gp).Xint| *flagp;|
|000037d0| 0a 58 7b 0a 58 09 72 65 | 67 69 73 74 65 72 20 63 |.X{.X.re|gister c|
|000037e0| 68 61 72 20 2a 72 65 74 | 3b 0a 58 09 72 65 67 69 |har *ret|;.X.regi|
|000037f0| 73 74 65 72 20 63 68 61 | 72 20 6f 70 3b 0a 58 09 |ster cha|r op;.X.|
|00003800| 72 65 67 69 73 74 65 72 | 20 63 68 61 72 20 2a 6e |register| char *n|
|00003810| 65 78 74 3b 0a 58 09 69 | 6e 74 20 66 6c 61 67 73 |ext;.X.i|nt flags|
|00003820| 3b 0a 58 0a 58 09 72 65 | 74 20 3d 20 72 65 67 61 |;.X.X.re|t = rega|
|00003830| 74 6f 6d 28 26 66 6c 61 | 67 73 29 3b 0a 58 09 69 |tom(&fla|gs);.X.i|
|00003840| 66 20 28 72 65 74 20 3d | 3d 20 4e 55 4c 4c 29 0a |f (ret =|= NULL).|
|00003850| 58 09 09 72 65 74 75 72 | 6e 28 4e 55 4c 4c 29 3b |X..retur|n(NULL);|
|00003860| 0a 58 0a 58 09 6f 70 20 | 3d 20 2a 72 65 67 70 61 |.X.X.op |= *regpa|
|00003870| 72 73 65 3b 0a 58 09 69 | 66 20 28 21 49 53 4d 55 |rse;.X.i|f (!ISMU|
|00003880| 4c 54 28 6f 70 29 29 20 | 7b 0a 58 09 09 2a 66 6c |LT(op)) |{.X..*fl|
|00003890| 61 67 70 20 3d 20 66 6c | 61 67 73 3b 0a 58 09 09 |agp = fl|ags;.X..|
|000038a0| 72 65 74 75 72 6e 28 72 | 65 74 29 3b 0a 58 09 7d |return(r|et);.X.}|
|000038b0| 0a 58 0a 58 09 69 66 20 | 28 21 28 66 6c 61 67 73 |.X.X.if |(!(flags|
|000038c0| 26 48 41 53 57 49 44 54 | 48 29 20 26 26 20 6f 70 |&HASWIDT|H) && op|
|000038d0| 20 21 3d 20 27 3f 27 29 | 0a 58 09 09 46 41 49 4c | != '?')|.X..FAIL|
|000038e0| 28 22 2a 2b 20 6f 70 65 | 72 61 6e 64 20 63 6f 75 |("*+ ope|rand cou|
|000038f0| 6c 64 20 62 65 20 65 6d | 70 74 79 22 29 3b 0a 58 |ld be em|pty");.X|
|00003900| 09 2a 66 6c 61 67 70 20 | 3d 20 28 6f 70 20 21 3d |.*flagp |= (op !=|
|00003910| 20 27 2b 27 29 20 3f 20 | 28 57 4f 52 53 54 7c 53 | '+') ? |(WORST|S|
|00003920| 50 53 54 41 52 54 29 20 | 3a 20 28 57 4f 52 53 54 |PSTART) |: (WORST|
|00003930| 7c 48 41 53 57 49 44 54 | 48 29 3b 0a 58 0a 58 09 ||HASWIDT|H);.X.X.|
|00003940| 69 66 20 28 6f 70 20 3d | 3d 20 27 2a 27 20 26 26 |if (op =|= '*' &&|
|00003950| 20 28 66 6c 61 67 73 26 | 53 49 4d 50 4c 45 29 29 | (flags&|SIMPLE))|
|00003960| 0a 58 09 09 72 65 67 69 | 6e 73 65 72 74 28 53 54 |.X..regi|nsert(ST|
|00003970| 41 52 2c 20 72 65 74 29 | 3b 0a 58 09 65 6c 73 65 |AR, ret)|;.X.else|
|00003980| 20 69 66 20 28 6f 70 20 | 3d 3d 20 27 2a 27 29 20 | if (op |== '*') |
|00003990| 7b 0a 58 09 09 2f 2a 20 | 45 6d 69 74 20 78 2a 20 |{.X../* |Emit x* |
|000039a0| 61 73 20 28 78 26 7c 29 | 2c 20 77 68 65 72 65 20 |as (x&|)|, where |
|000039b0| 26 20 6d 65 61 6e 73 20 | 22 73 65 6c 66 22 2e 20 |& means |"self". |
|000039c0| 2a 2f 0a 58 09 09 72 65 | 67 69 6e 73 65 72 74 28 |*/.X..re|ginsert(|
|000039d0| 42 52 41 4e 43 48 2c 20 | 72 65 74 29 3b 09 09 09 |BRANCH, |ret);...|
|000039e0| 2f 2a 20 45 69 74 68 65 | 72 20 78 20 2a 2f 0a 58 |/* Eithe|r x */.X|
|000039f0| 09 09 72 65 67 6f 70 74 | 61 69 6c 28 72 65 74 2c |..regopt|ail(ret,|
|00003a00| 20 72 65 67 6e 6f 64 65 | 28 42 41 43 4b 29 29 3b | regnode|(BACK));|
|00003a10| 09 09 2f 2a 20 61 6e 64 | 20 6c 6f 6f 70 20 2a 2f |../* and| loop */|
|00003a20| 0a 58 09 09 72 65 67 6f | 70 74 61 69 6c 28 72 65 |.X..rego|ptail(re|
|00003a30| 74 2c 20 72 65 74 29 3b | 09 09 09 2f 2a 20 62 61 |t, ret);|.../* ba|
|00003a40| 63 6b 20 2a 2f 0a 58 09 | 09 72 65 67 74 61 69 6c |ck */.X.|.regtail|
|00003a50| 28 72 65 74 2c 20 72 65 | 67 6e 6f 64 65 28 42 52 |(ret, re|gnode(BR|
|00003a60| 41 4e 43 48 29 29 3b 09 | 09 2f 2a 20 6f 72 20 2a |ANCH));.|./* or *|
|00003a70| 2f 0a 58 09 09 72 65 67 | 74 61 69 6c 28 72 65 74 |/.X..reg|tail(ret|
|00003a80| 2c 20 72 65 67 6e 6f 64 | 65 28 4e 4f 54 48 49 4e |, regnod|e(NOTHIN|
|00003a90| 47 29 29 3b 09 09 2f 2a | 20 6e 75 6c 6c 2e 20 2a |G));../*| null. *|
|00003aa0| 2f 0a 58 09 7d 20 65 6c | 73 65 20 69 66 20 28 6f |/.X.} el|se if (o|
|00003ab0| 70 20 3d 3d 20 27 2b 27 | 20 26 26 20 28 66 6c 61 |p == '+'| && (fla|
|00003ac0| 67 73 26 53 49 4d 50 4c | 45 29 29 0a 58 09 09 72 |gs&SIMPL|E)).X..r|
|00003ad0| 65 67 69 6e 73 65 72 74 | 28 50 4c 55 53 2c 20 72 |eginsert|(PLUS, r|
|00003ae0| 65 74 29 3b 0a 58 09 65 | 6c 73 65 20 69 66 20 28 |et);.X.e|lse if (|
|00003af0| 6f 70 20 3d 3d 20 27 2b | 27 29 20 7b 0a 58 09 09 |op == '+|') {.X..|
|00003b00| 2f 2a 20 45 6d 69 74 20 | 78 2b 20 61 73 20 78 28 |/* Emit |x+ as x(|
|00003b10| 26 7c 29 2c 20 77 68 65 | 72 65 20 26 20 6d 65 61 |&|), whe|re & mea|
|00003b20| 6e 73 20 22 73 65 6c 66 | 22 2e 20 2a 2f 0a 58 09 |ns "self|". */.X.|
|00003b30| 09 6e 65 78 74 20 3d 20 | 72 65 67 6e 6f 64 65 28 |.next = |regnode(|
|00003b40| 42 52 41 4e 43 48 29 3b | 09 09 09 2f 2a 20 45 69 |BRANCH);|.../* Ei|
|00003b50| 74 68 65 72 20 2a 2f 0a | 58 09 09 72 65 67 74 61 |ther */.|X..regta|
|00003b60| 69 6c 28 72 65 74 2c 20 | 6e 65 78 74 29 3b 0a 58 |il(ret, |next);.X|
|00003b70| 09 09 72 65 67 74 61 69 | 6c 28 72 65 67 6e 6f 64 |..regtai|l(regnod|
|00003b80| 65 28 42 41 43 4b 29 2c | 20 72 65 74 29 3b 09 09 |e(BACK),| ret);..|
|00003b90| 2f 2a 20 6c 6f 6f 70 20 | 62 61 63 6b 20 2a 2f 0a |/* loop |back */.|
|00003ba0| 58 09 09 72 65 67 74 61 | 69 6c 28 6e 65 78 74 2c |X..regta|il(next,|
|00003bb0| 20 72 65 67 6e 6f 64 65 | 28 42 52 41 4e 43 48 29 | regnode|(BRANCH)|
|00003bc0| 29 3b 09 09 2f 2a 20 6f | 72 20 2a 2f 0a 58 09 09 |);../* o|r */.X..|
|00003bd0| 72 65 67 74 61 69 6c 28 | 72 65 74 2c 20 72 65 67 |regtail(|ret, reg|
|00003be0| 6e 6f 64 65 28 4e 4f 54 | 48 49 4e 47 29 29 3b 09 |node(NOT|HING));.|
|00003bf0| 09 2f 2a 20 6e 75 6c 6c | 2e 20 2a 2f 0a 58 09 7d |./* null|. */.X.}|
|00003c00| 20 65 6c 73 65 20 69 66 | 20 28 6f 70 20 3d 3d 20 | else if| (op == |
|00003c10| 27 3f 27 29 20 7b 0a 58 | 09 09 2f 2a 20 45 6d 69 |'?') {.X|../* Emi|
|00003c20| 74 20 78 3f 20 61 73 20 | 28 78 7c 29 20 2a 2f 0a |t x? as |(x|) */.|
|00003c30| 58 09 09 72 65 67 69 6e | 73 65 72 74 28 42 52 41 |X..regin|sert(BRA|
|00003c40| 4e 43 48 2c 20 72 65 74 | 29 3b 09 09 09 2f 2a 20 |NCH, ret|);.../* |
|00003c50| 45 69 74 68 65 72 20 78 | 20 2a 2f 0a 58 09 09 72 |Either x| */.X..r|
|00003c60| 65 67 74 61 69 6c 28 72 | 65 74 2c 20 72 65 67 6e |egtail(r|et, regn|
|00003c70| 6f 64 65 28 42 52 41 4e | 43 48 29 29 3b 09 09 2f |ode(BRAN|CH));../|
|00003c80| 2a 20 6f 72 20 2a 2f 0a | 58 09 09 6e 65 78 74 20 |* or */.|X..next |
|00003c90| 3d 20 72 65 67 6e 6f 64 | 65 28 4e 4f 54 48 49 4e |= regnod|e(NOTHIN|
|00003ca0| 47 29 3b 09 09 2f 2a 20 | 6e 75 6c 6c 2e 20 2a 2f |G);../* |null. */|
|00003cb0| 0a 58 09 09 72 65 67 74 | 61 69 6c 28 72 65 74 2c |.X..regt|ail(ret,|
|00003cc0| 20 6e 65 78 74 29 3b 0a | 58 09 09 72 65 67 6f 70 | next);.|X..regop|
|00003cd0| 74 61 69 6c 28 72 65 74 | 2c 20 6e 65 78 74 29 3b |tail(ret|, next);|
|00003ce0| 0a 58 09 7d 0a 58 09 72 | 65 67 70 61 72 73 65 2b |.X.}.X.r|egparse+|
|00003cf0| 2b 3b 0a 58 09 69 66 20 | 28 49 53 4d 55 4c 54 28 |+;.X.if |(ISMULT(|
|00003d00| 2a 72 65 67 70 61 72 73 | 65 29 29 0a 58 09 09 46 |*regpars|e)).X..F|
|00003d10| 41 49 4c 28 22 6e 65 73 | 74 65 64 20 2a 3f 2b 22 |AIL("nes|ted *?+"|
|00003d20| 29 3b 0a 58 0a 58 09 72 | 65 74 75 72 6e 28 72 65 |);.X.X.r|eturn(re|
|00003d30| 74 29 3b 0a 58 7d 0a 58 | 0a 58 2f 2a 0a 58 20 2d |t);.X}.X|.X/*.X -|
|00003d40| 20 72 65 67 61 74 6f 6d | 20 2d 20 74 68 65 20 6c | regatom| - the l|
|00003d50| 6f 77 65 73 74 20 6c 65 | 76 65 6c 0a 58 20 2a 0a |owest le|vel.X *.|
|00003d60| 58 20 2a 20 4f 70 74 69 | 6d 69 7a 61 74 69 6f 6e |X * Opti|mization|
|00003d70| 3a 20 20 67 6f 62 62 6c | 65 73 20 61 6e 20 65 6e |: gobbl|es an en|
|00003d80| 74 69 72 65 20 73 65 71 | 75 65 6e 63 65 20 6f 66 |tire seq|uence of|
|00003d90| 20 6f 72 64 69 6e 61 72 | 79 20 63 68 61 72 61 63 | ordinar|y charac|
|00003da0| 74 65 72 73 20 73 6f 20 | 74 68 61 74 0a 58 20 2a |ters so |that.X *|
|00003db0| 20 69 74 20 63 61 6e 20 | 74 75 72 6e 20 74 68 65 | it can |turn the|
|00003dc0| 6d 20 69 6e 74 6f 20 61 | 20 73 69 6e 67 6c 65 20 |m into a| single |
|00003dd0| 6e 6f 64 65 2c 20 77 68 | 69 63 68 20 69 73 20 73 |node, wh|ich is s|
|00003de0| 6d 61 6c 6c 65 72 20 74 | 6f 20 73 74 6f 72 65 20 |maller t|o store |
|00003df0| 61 6e 64 0a 58 20 2a 20 | 66 61 73 74 65 72 20 74 |and.X * |faster t|
|00003e00| 6f 20 72 75 6e 2e 20 20 | 42 61 63 6b 73 6c 61 73 |o run. |Backslas|
|00003e10| 68 65 64 20 63 68 61 72 | 61 63 74 65 72 73 20 61 |hed char|acters a|
|00003e20| 72 65 20 65 78 63 65 70 | 74 69 6f 6e 73 2c 20 65 |re excep|tions, e|
|00003e30| 61 63 68 20 62 65 63 6f | 6d 69 6e 67 20 61 0a 58 |ach beco|ming a.X|
|00003e40| 20 2a 20 73 65 70 61 72 | 61 74 65 20 6e 6f 64 65 | * separ|ate node|
|00003e50| 3b 20 74 68 65 20 63 6f | 64 65 20 69 73 20 73 69 |; the co|de is si|
|00003e60| 6d 70 6c 65 72 20 74 68 | 61 74 20 77 61 79 20 61 |mpler th|at way a|
|00003e70| 6e 64 20 69 74 27 73 20 | 6e 6f 74 20 77 6f 72 74 |nd it's |not wort|
|00003e80| 68 20 66 69 78 69 6e 67 | 2e 0a 58 20 2a 2f 0a 58 |h fixing|..X */.X|
|00003e90| 73 74 61 74 69 63 20 63 | 68 61 72 20 2a 0a 58 72 |static c|har *.Xr|
|00003ea0| 65 67 61 74 6f 6d 28 66 | 6c 61 67 70 29 0a 58 69 |egatom(f|lagp).Xi|
|00003eb0| 6e 74 20 2a 66 6c 61 67 | 70 3b 0a 58 7b 0a 58 09 |nt *flag|p;.X{.X.|
|00003ec0| 72 65 67 69 73 74 65 72 | 20 63 68 61 72 20 2a 72 |register| char *r|
|00003ed0| 65 74 3b 0a 58 09 69 6e | 74 20 66 6c 61 67 73 3b |et;.X.in|t flags;|
|00003ee0| 0a 58 0a 58 09 2a 66 6c | 61 67 70 20 3d 20 57 4f |.X.X.*fl|agp = WO|
|00003ef0| 52 53 54 3b 09 09 2f 2a | 20 54 65 6e 74 61 74 69 |RST;../*| Tentati|
|00003f00| 76 65 6c 79 2e 20 2a 2f | 0a 58 0a 58 09 73 77 69 |vely. */|.X.X.swi|
|00003f10| 74 63 68 20 28 2a 72 65 | 67 70 61 72 73 65 2b 2b |tch (*re|gparse++|
|00003f20| 29 20 7b 0a 58 09 2f 2a | 20 46 49 58 4d 45 3a 20 |) {.X./*| FIXME: |
|00003f30| 74 68 65 73 65 20 63 68 | 61 72 73 20 6f 6e 6c 79 |these ch|ars only|
|00003f40| 20 68 61 76 65 20 6d 65 | 61 6e 69 6e 67 20 61 74 | have me|aning at|
|00003f50| 20 62 65 67 2f 65 6e 64 | 20 6f 66 20 70 61 74 3f | beg/end| of pat?|
|00003f60| 20 2a 2f 0a 58 09 63 61 | 73 65 20 27 5e 27 3a 0a | */.X.ca|se '^':.|
|00003f70| 58 09 09 72 65 74 20 3d | 20 72 65 67 6e 6f 64 65 |X..ret =| regnode|
|00003f80| 28 42 4f 4c 29 3b 0a 58 | 09 09 62 72 65 61 6b 3b |(BOL);.X|..break;|
|00003f90| 0a 58 09 63 61 73 65 20 | 27 24 27 3a 0a 58 09 09 |.X.case |'$':.X..|
|00003fa0| 72 65 74 20 3d 20 72 65 | 67 6e 6f 64 65 28 45 4f |ret = re|gnode(EO|
|00003fb0| 4c 29 3b 0a 58 09 09 62 | 72 65 61 6b 3b 0a 58 09 |L);.X..b|reak;.X.|
|00003fc0| 63 61 73 65 20 27 2e 27 | 3a 0a 58 09 09 72 65 74 |case '.'|:.X..ret|
|00003fd0| 20 3d 20 72 65 67 6e 6f | 64 65 28 41 4e 59 29 3b | = regno|de(ANY);|
|00003fe0| 0a 58 09 09 2a 66 6c 61 | 67 70 20 7c 3d 20 48 41 |.X..*fla|gp |= HA|
|00003ff0| 53 57 49 44 54 48 7c 53 | 49 4d 50 4c 45 3b 0a 58 |SWIDTH|S|IMPLE;.X|
|00004000| 09 09 62 72 65 61 6b 3b | 0a 58 09 63 61 73 65 20 |..break;|.X.case |
|00004010| 27 5b 27 3a 20 7b 0a 58 | 09 09 09 72 65 67 69 73 |'[': {.X|...regis|
|00004020| 74 65 72 20 69 6e 74 20 | 63 6c 61 73 73 3b 0a 58 |ter int |class;.X|
|00004030| 09 09 09 72 65 67 69 73 | 74 65 72 20 69 6e 74 20 |...regis|ter int |
|00004040| 63 6c 61 73 73 65 6e 64 | 3b 0a 58 0a 58 09 09 09 |classend|;.X.X...|
|00004050| 69 66 20 28 2a 72 65 67 | 70 61 72 73 65 20 3d 3d |if (*reg|parse ==|
|00004060| 20 27 5e 27 29 20 7b 09 | 2f 2a 20 43 6f 6d 70 6c | '^') {.|/* Compl|
|00004070| 65 6d 65 6e 74 20 6f 66 | 20 72 61 6e 67 65 2e 20 |ement of| range. |
|00004080| 2a 2f 0a 58 09 09 09 09 | 72 65 74 20 3d 20 72 65 |*/.X....|ret = re|
|00004090| 67 6e 6f 64 65 28 41 4e | 59 42 55 54 29 3b 0a 58 |gnode(AN|YBUT);.X|
|000040a0| 09 09 09 09 72 65 67 70 | 61 72 73 65 2b 2b 3b 0a |....regp|arse++;.|
|000040b0| 58 09 09 09 7d 20 65 6c | 73 65 0a 58 09 09 09 09 |X...} el|se.X....|
|000040c0| 72 65 74 20 3d 20 72 65 | 67 6e 6f 64 65 28 41 4e |ret = re|gnode(AN|
|000040d0| 59 4f 46 29 3b 0a 58 09 | 09 09 69 66 20 28 2a 72 |YOF);.X.|..if (*r|
|000040e0| 65 67 70 61 72 73 65 20 | 3d 3d 20 27 5d 27 20 7c |egparse |== ']' ||
|000040f0| 7c 20 2a 72 65 67 70 61 | 72 73 65 20 3d 3d 20 27 || *regpa|rse == '|
|00004100| 2d 27 29 0a 58 09 09 09 | 09 72 65 67 63 28 2a 72 |-').X...|.regc(*r|
|00004110| 65 67 70 61 72 73 65 2b | 2b 29 3b 0a 58 09 09 09 |egparse+|+);.X...|
|00004120| 77 68 69 6c 65 20 28 2a | 72 65 67 70 61 72 73 65 |while (*|regparse|
|00004130| 20 21 3d 20 27 5c 30 27 | 20 26 26 20 2a 72 65 67 | != '\0'| && *reg|
|00004140| 70 61 72 73 65 20 21 3d | 20 27 5d 27 29 20 7b 0a |parse !=| ']') {.|
|00004150| 58 09 09 09 09 69 66 20 | 28 2a 72 65 67 70 61 72 |X....if |(*regpar|
|00004160| 73 65 20 3d 3d 20 27 2d | 27 29 20 7b 0a 58 09 09 |se == '-|') {.X..|
|00004170| 09 09 09 72 65 67 70 61 | 72 73 65 2b 2b 3b 0a 58 |...regpa|rse++;.X|
|00004180| 09 09 09 09 09 69 66 20 | 28 2a 72 65 67 70 61 72 |.....if |(*regpar|
|00004190| 73 65 20 3d 3d 20 27 5d | 27 20 7c 7c 20 2a 72 65 |se == ']|' || *re|
|000041a0| 67 70 61 72 73 65 20 3d | 3d 20 27 5c 30 27 29 0a |gparse =|= '\0').|
|000041b0| 58 09 09 09 09 09 09 72 | 65 67 63 28 27 2d 27 29 |X......r|egc('-')|
|000041c0| 3b 0a 58 09 09 09 09 09 | 65 6c 73 65 20 7b 0a 58 |;.X.....|else {.X|
|000041d0| 09 09 09 09 09 09 63 6c | 61 73 73 20 3d 20 55 43 |......cl|ass = UC|
|000041e0| 48 41 52 41 54 28 72 65 | 67 70 61 72 73 65 2d 32 |HARAT(re|gparse-2|
|000041f0| 29 2b 31 3b 0a 58 09 09 | 09 09 09 09 63 6c 61 73 |)+1;.X..|....clas|
|00004200| 73 65 6e 64 20 3d 20 55 | 43 48 41 52 41 54 28 72 |send = U|CHARAT(r|
|00004210| 65 67 70 61 72 73 65 29 | 3b 0a 58 09 09 09 09 09 |egparse)|;.X.....|
|00004220| 09 69 66 20 28 63 6c 61 | 73 73 20 3e 20 63 6c 61 |.if (cla|ss > cla|
|00004230| 73 73 65 6e 64 2b 31 29 | 0a 58 09 09 09 09 09 09 |ssend+1)|.X......|
|00004240| 09 46 41 49 4c 28 22 69 | 6e 76 61 6c 69 64 20 5b |.FAIL("i|nvalid [|
|00004250| 5d 20 72 61 6e 67 65 22 | 29 3b 0a 58 09 09 09 09 |] range"|);.X....|
|00004260| 09 09 66 6f 72 20 28 3b | 20 63 6c 61 73 73 20 3c |..for (;| class <|
|00004270| 3d 20 63 6c 61 73 73 65 | 6e 64 3b 20 63 6c 61 73 |= classe|nd; clas|
|00004280| 73 2b 2b 29 0a 58 09 09 | 09 09 09 09 09 72 65 67 |s++).X..|.....reg|
|00004290| 63 28 63 6c 61 73 73 29 | 3b 0a 58 09 09 09 09 09 |c(class)|;.X.....|
|000042a0| 09 72 65 67 70 61 72 73 | 65 2b 2b 3b 0a 58 09 09 |.regpars|e++;.X..|
|000042b0| 09 09 09 7d 0a 58 09 09 | 09 09 7d 20 65 6c 73 65 |...}.X..|..} else|
|000042c0| 0a 58 09 09 09 09 09 72 | 65 67 63 28 2a 72 65 67 |.X.....r|egc(*reg|
|000042d0| 70 61 72 73 65 2b 2b 29 | 3b 0a 58 09 09 09 7d 0a |parse++)|;.X...}.|
|000042e0| 58 09 09 09 72 65 67 63 | 28 27 5c 30 27 29 3b 0a |X...regc|('\0');.|
|000042f0| 58 09 09 09 69 66 20 28 | 2a 72 65 67 70 61 72 73 |X...if (|*regpars|
|00004300| 65 20 21 3d 20 27 5d 27 | 29 0a 58 09 09 09 09 46 |e != ']'|).X....F|
|00004310| 41 49 4c 28 22 75 6e 6d | 61 74 63 68 65 64 20 5b |AIL("unm|atched [|
|00004320| 5d 22 29 3b 0a 58 09 09 | 09 72 65 67 70 61 72 73 |]");.X..|.regpars|
|00004330| 65 2b 2b 3b 0a 58 09 09 | 09 2a 66 6c 61 67 70 20 |e++;.X..|.*flagp |
|00004340| 7c 3d 20 48 41 53 57 49 | 44 54 48 7c 53 49 4d 50 ||= HASWI|DTH|SIMP|
|00004350| 4c 45 3b 0a 58 09 09 7d | 0a 58 09 09 62 72 65 61 |LE;.X..}|.X..brea|
|00004360| 6b 3b 0a 58 09 63 61 73 | 65 20 27 28 27 3a 0a 58 |k;.X.cas|e '(':.X|
|00004370| 09 09 72 65 74 20 3d 20 | 72 65 67 28 31 2c 20 26 |..ret = |reg(1, &|
|00004380| 66 6c 61 67 73 29 3b 0a | 58 09 09 69 66 20 28 72 |flags);.|X..if (r|
|00004390| 65 74 20 3d 3d 20 4e 55 | 4c 4c 29 0a 58 09 09 09 |et == NU|LL).X...|
|000043a0| 72 65 74 75 72 6e 28 4e | 55 4c 4c 29 3b 0a 58 09 |return(N|ULL);.X.|
|000043b0| 09 2a 66 6c 61 67 70 20 | 7c 3d 20 66 6c 61 67 73 |.*flagp ||= flags|
|000043c0| 26 28 48 41 53 57 49 44 | 54 48 7c 53 50 53 54 41 |&(HASWID|TH|SPSTA|
|000043d0| 52 54 29 3b 0a 58 09 09 | 62 72 65 61 6b 3b 0a 58 |RT);.X..|break;.X|
|000043e0| 09 63 61 73 65 20 27 5c | 30 27 3a 0a 58 09 63 61 |.case '\|0':.X.ca|
|000043f0| 73 65 20 27 7c 27 3a 0a | 58 09 63 61 73 65 20 27 |se '|':.|X.case '|
|00004400| 5c 6e 27 3a 0a 58 09 63 | 61 73 65 20 27 29 27 3a |\n':.X.c|ase ')':|
|00004410| 0a 58 09 09 46 41 49 4c | 28 22 69 6e 74 65 72 6e |.X..FAIL|("intern|
|00004420| 61 6c 20 75 72 70 22 29 | 3b 09 2f 2a 20 53 75 70 |al urp")|;./* Sup|
|00004430| 70 6f 73 65 64 20 74 6f | 20 62 65 20 63 61 75 67 |posed to| be caug|
|00004440| 68 74 20 65 61 72 6c 69 | 65 72 2e 20 2a 2f 0a 58 |ht earli|er. */.X|
|00004450| 09 09 62 72 65 61 6b 3b | 0a 58 09 63 61 73 65 20 |..break;|.X.case |
|00004460| 27 3f 27 3a 0a 58 09 63 | 61 73 65 20 27 2b 27 3a |'?':.X.c|ase '+':|
|00004470| 0a 58 09 63 61 73 65 20 | 27 2a 27 3a 0a 58 09 09 |.X.case |'*':.X..|
|00004480| 46 41 49 4c 28 22 3f 2b | 2a 20 66 6f 6c 6c 6f 77 |FAIL("?+|* follow|
|00004490| 73 20 6e 6f 74 68 69 6e | 67 22 29 3b 0a 58 09 09 |s nothin|g");.X..|
|000044a0| 62 72 65 61 6b 3b 0a 58 | 09 63 61 73 65 20 27 5c |break;.X|.case '\|
|000044b0| 5c 27 3a 0a 58 09 09 73 | 77 69 74 63 68 20 28 2a |\':.X..s|witch (*|
|000044c0| 72 65 67 70 61 72 73 65 | 2b 2b 29 20 7b 0a 58 09 |regparse|++) {.X.|
|000044d0| 09 63 61 73 65 20 27 5c | 30 27 3a 0a 58 09 09 09 |.case '\|0':.X...|
|000044e0| 46 41 49 4c 28 22 74 72 | 61 69 6c 69 6e 67 20 5c |FAIL("tr|ailing \|
|000044f0| 5c 22 29 3b 0a 58 09 09 | 09 62 72 65 61 6b 3b 0a |\");.X..|.break;.|
|00004500| 58 09 09 63 61 73 65 20 | 27 3c 27 3a 0a 58 09 09 |X..case |'<':.X..|
|00004510| 09 72 65 74 20 3d 20 72 | 65 67 6e 6f 64 65 28 57 |.ret = r|egnode(W|
|00004520| 4f 52 44 41 29 3b 0a 58 | 09 09 09 62 72 65 61 6b |ORDA);.X|...break|
|00004530| 3b 0a 58 09 09 63 61 73 | 65 20 27 3e 27 3a 0a 58 |;.X..cas|e '>':.X|
|00004540| 09 09 09 72 65 74 20 3d | 20 72 65 67 6e 6f 64 65 |...ret =| regnode|
|00004550| 28 57 4f 52 44 5a 29 3b | 0a 58 09 09 09 62 72 65 |(WORDZ);|.X...bre|
|00004560| 61 6b 3b 0a 58 09 09 2f | 2a 20 46 49 58 4d 45 3a |ak;.X../|* FIXME:|
|00004570| 20 53 6f 6d 65 64 61 79 | 20 68 61 6e 64 6c 65 20 | Someday| handle |
|00004580| 5c 31 2c 20 5c 32 2c 20 | 2e 2e 2e 20 2a 2f 0a 58 |\1, \2, |... */.X|
|00004590| 09 09 64 65 66 61 75 6c | 74 3a 0a 58 09 09 09 2f |..defaul|t:.X.../|
|000045a0| 2a 20 48 61 6e 64 6c 65 | 20 67 65 6e 65 72 61 6c |* Handle| general|
|000045b0| 20 71 75 6f 74 65 64 20 | 63 68 61 72 73 20 69 6e | quoted |chars in|
|000045c0| 20 65 78 61 63 74 2d 6d | 61 74 63 68 20 72 6f 75 | exact-m|atch rou|
|000045d0| 74 69 6e 65 20 2a 2f 0a | 58 09 09 09 67 6f 74 6f |tine */.|X...goto|
|000045e0| 20 64 65 5f 66 61 75 6c | 74 3b 0a 58 09 09 7d 0a | de_faul|t;.X..}.|
|000045f0| 58 09 09 62 72 65 61 6b | 3b 0a 58 09 64 65 5f 66 |X..break|;.X.de_f|
|00004600| 61 75 6c 74 3a 0a 58 09 | 64 65 66 61 75 6c 74 3a |ault:.X.|default:|
|00004610| 0a 58 09 09 2f 2a 0a 58 | 09 09 20 2a 20 45 6e 63 |.X../*.X|.. * Enc|
|00004620| 6f 64 65 20 61 20 73 74 | 72 69 6e 67 20 6f 66 20 |ode a st|ring of |
|00004630| 63 68 61 72 61 63 74 65 | 72 73 20 74 6f 20 62 65 |characte|rs to be|
|00004640| 20 6d 61 74 63 68 65 64 | 20 65 78 61 63 74 6c 79 | matched| exactly|
|00004650| 2e 0a 58 09 09 20 2a 0a | 58 09 09 20 2a 20 54 68 |..X.. *.|X.. * Th|
|00004660| 69 73 20 69 73 20 61 20 | 62 69 74 20 74 72 69 63 |is is a |bit tric|
|00004670| 6b 79 20 64 75 65 20 74 | 6f 20 71 75 6f 74 65 64 |ky due t|o quoted|
|00004680| 20 63 68 61 72 73 20 61 | 6e 64 20 64 75 65 20 74 | chars a|nd due t|
|00004690| 6f 0a 58 09 09 20 2a 20 | 27 2a 27 2c 20 27 2b 27 |o.X.. * |'*', '+'|
|000046a0| 2c 20 61 6e 64 20 27 3f | 27 20 74 61 6b 69 6e 67 |, and '?|' taking|
|000046b0| 20 74 68 65 20 53 49 4e | 47 4c 45 20 63 68 61 72 | the SIN|GLE char|
|000046c0| 20 70 72 65 76 69 6f 75 | 73 0a 58 09 09 20 2a 20 | previou|s.X.. * |
|000046d0| 61 73 20 74 68 65 69 72 | 20 6f 70 65 72 61 6e 64 |as their| operand|
|000046e0| 2e 0a 58 09 09 20 2a 0a | 58 09 09 20 2a 20 4f 6e |..X.. *.|X.. * On|
|000046f0| 20 65 6e 74 72 79 2c 20 | 74 68 65 20 63 68 61 72 | entry, |the char|
|00004700| 20 61 74 20 72 65 67 70 | 61 72 73 65 5b 2d 31 5d | at regp|arse[-1]|
|00004710| 20 69 73 20 67 6f 69 6e | 67 20 74 6f 20 67 6f 0a | is goin|g to go.|
|00004720| 58 09 09 20 2a 20 69 6e | 74 6f 20 74 68 65 20 73 |X.. * in|to the s|
|00004730| 74 72 69 6e 67 2c 20 6e | 6f 20 6d 61 74 74 65 72 |tring, n|o matter|
|00004740| 20 77 68 61 74 20 69 74 | 20 69 73 2e 20 20 28 49 | what it| is. (I|
|00004750| 74 20 63 6f 75 6c 64 20 | 62 65 0a 58 09 09 20 2a |t could |be.X.. *|
|00004760| 20 66 6f 6c 6c 6f 77 69 | 6e 67 20 61 20 5c 20 69 | followi|ng a \ i|
|00004770| 66 20 77 65 20 61 72 65 | 20 65 6e 74 65 72 65 64 |f we are| entered|
|00004780| 20 66 72 6f 6d 20 74 68 | 65 20 27 5c 27 20 63 61 | from th|e '\' ca|
|00004790| 73 65 2e 29 0a 58 09 09 | 20 2a 20 0a 58 09 09 20 |se.).X..| * .X.. |
|000047a0| 2a 20 42 61 73 69 63 20 | 69 64 65 61 20 69 73 20 |* Basic |idea is |
|000047b0| 74 6f 20 70 69 63 6b 20 | 75 70 20 61 20 67 6f 6f |to pick |up a goo|
|000047c0| 64 20 63 68 61 72 20 69 | 6e 20 20 63 68 20 20 61 |d char i|n ch a|
|000047d0| 6e 64 0a 58 09 09 20 2a | 20 65 78 61 6d 69 6e 65 |nd.X.. *| examine|
|000047e0| 20 74 68 65 20 6e 65 78 | 74 20 63 68 61 72 2e 20 | the nex|t char. |
|000047f0| 20 49 66 20 69 74 27 73 | 20 2a 2b 3f 20 74 68 65 | If it's| *+? the|
|00004800| 6e 20 77 65 20 74 77 69 | 64 64 6c 65 2e 0a 58 09 |n we twi|ddle..X.|
|00004810| 09 20 2a 20 49 66 20 69 | 74 27 73 20 5c 20 74 68 |. * If i|t's \ th|
|00004820| 65 6e 20 77 65 20 66 72 | 6f 7a 7a 6c 65 2e 20 20 |en we fr|ozzle. |
|00004830| 49 66 20 69 74 27 73 20 | 6f 74 68 65 72 20 6d 61 |If it's |other ma|
|00004840| 67 69 63 20 63 68 61 72 | 0a 58 09 09 20 2a 20 77 |gic char|.X.. * w|
|00004850| 65 20 70 75 73 68 20 20 | 63 68 20 20 61 6e 64 20 |e push |ch and |
|00004860| 74 65 72 6d 69 6e 61 74 | 65 20 74 68 65 20 73 74 |terminat|e the st|
|00004870| 72 69 6e 67 2e 20 20 49 | 66 20 6e 6f 6e 65 20 6f |ring. I|f none o|
|00004880| 66 20 74 68 65 0a 58 09 | 09 20 2a 20 61 62 6f 76 |f the.X.|. * abov|
|00004890| 65 2c 20 77 65 20 70 75 | 73 68 20 20 63 68 20 20 |e, we pu|sh ch |
|000048a0| 6f 6e 20 74 68 65 20 73 | 74 72 69 6e 67 20 61 6e |on the s|tring an|
|000048b0| 64 20 67 6f 20 61 72 6f | 75 6e 64 20 61 67 61 69 |d go aro|und agai|
|000048c0| 6e 2e 0a 58 09 09 20 2a | 0a 58 09 09 20 2a 20 20 |n..X.. *|.X.. * |
|000048d0| 72 65 67 70 72 65 76 20 | 20 69 73 20 75 73 65 64 |regprev | is used|
|000048e0| 20 74 6f 20 72 65 6d 65 | 6d 62 65 72 20 77 68 65 | to reme|mber whe|
|000048f0| 72 65 20 22 74 68 65 20 | 63 75 72 72 65 6e 74 20 |re "the |current |
|00004900| 63 68 61 72 22 0a 58 09 | 09 20 2a 20 73 74 61 72 |char".X.|. * star|
|00004910| 74 73 20 69 6e 20 74 68 | 65 20 73 74 72 69 6e 67 |ts in th|e string|
|00004920| 2c 20 69 66 20 64 75 65 | 20 74 6f 20 61 20 2a 2b |, if due| to a *+|
|00004930| 3f 20 77 65 20 6e 65 65 | 64 20 74 6f 20 62 61 63 |? we nee|d to bac|
|00004940| 6b 0a 58 09 09 20 2a 20 | 75 70 20 61 6e 64 20 70 |k.X.. * |up and p|
|00004950| 75 74 20 74 68 65 20 63 | 75 72 72 65 6e 74 20 63 |ut the c|urrent c|
|00004960| 68 61 72 20 69 6e 20 61 | 20 73 65 70 61 72 61 74 |har in a| separat|
|00004970| 65 2c 20 31 2d 63 68 61 | 72 2c 20 73 74 72 69 6e |e, 1-cha|r, strin|
|00004980| 67 2e 0a 58 09 09 20 2a | 20 57 68 65 6e 20 20 72 |g..X.. *| When r|
|00004990| 65 67 70 72 65 76 20 20 | 69 73 20 4e 55 4c 4c 2c |egprev |is NULL,|
|000049a0| 20 20 63 68 20 20 69 73 | 20 74 68 65 20 6f 6e 6c | ch is| the onl|
|000049b0| 79 20 63 68 61 72 20 69 | 6e 20 74 68 65 0a 58 09 |y char i|n the.X.|
|000049c0| 09 20 2a 20 73 74 72 69 | 6e 67 3b 20 74 68 69 73 |. * stri|ng; this|
|000049d0| 20 69 73 20 75 73 65 64 | 20 69 6e 20 2a 2b 3f 20 | is used| in *+? |
|000049e0| 68 61 6e 64 6c 69 6e 67 | 2c 20 61 6e 64 20 69 6e |handling|, and in|
|000049f0| 20 73 65 74 74 69 6e 67 | 0a 58 09 09 20 2a 20 66 | setting|.X.. * f|
|00004a00| 6c 61 67 73 20 7c 3d 20 | 53 49 4d 50 4c 45 20 61 |lags |= |SIMPLE a|
|00004a10| 74 20 74 68 65 20 65 6e | 64 2e 0a 58 09 09 20 2a |t the en|d..X.. *|
|00004a20| 2f 0a 58 09 09 7b 0a 58 | 09 09 09 63 68 61 72 20 |/.X..{.X|...char |
|00004a30| 2a 72 65 67 70 72 65 76 | 3b 0a 58 09 09 09 72 65 |*regprev|;.X...re|
|00004a40| 67 69 73 74 65 72 20 63 | 68 61 72 20 63 68 3b 0a |gister c|har ch;.|
|00004a50| 58 0a 58 09 09 09 72 65 | 67 70 61 72 73 65 2d 2d |X.X...re|gparse--|
|00004a60| 3b 09 09 09 2f 2a 20 4c | 6f 6f 6b 20 61 74 20 63 |;.../* L|ook at c|
|00004a70| 75 72 20 63 68 61 72 20 | 2a 2f 0a 58 09 09 09 72 |ur char |*/.X...r|
|00004a80| 65 74 20 3d 20 72 65 67 | 6e 6f 64 65 28 45 58 41 |et = reg|node(EXA|
|00004a90| 43 54 4c 59 29 3b 0a 58 | 09 09 09 66 6f 72 20 28 |CTLY);.X|...for (|
|00004aa0| 20 72 65 67 70 72 65 76 | 20 3d 20 30 20 3b 20 3b | regprev| = 0 ; ;|
|00004ab0| 20 29 20 7b 0a 58 09 09 | 09 09 63 68 20 3d 20 2a | ) {.X..|..ch = *|
|00004ac0| 72 65 67 70 61 72 73 65 | 2b 2b 3b 09 2f 2a 20 47 |regparse|++;./* G|
|00004ad0| 65 74 20 63 75 72 72 65 | 6e 74 20 63 68 61 72 20 |et curre|nt char |
|00004ae0| 2a 2f 0a 58 09 09 09 09 | 73 77 69 74 63 68 20 28 |*/.X....|switch (|
|00004af0| 2a 72 65 67 70 61 72 73 | 65 29 20 7b 09 2f 2a 20 |*regpars|e) {./* |
|00004b00| 6c 6f 6f 6b 20 61 74 20 | 6e 65 78 74 20 6f 6e 65 |look at |next one|
|00004b10| 20 2a 2f 0a 58 0a 58 09 | 09 09 09 64 65 66 61 75 | */.X.X.|...defau|
|00004b20| 6c 74 3a 0a 58 09 09 09 | 09 09 72 65 67 63 28 63 |lt:.X...|..regc(c|
|00004b30| 68 29 3b 09 2f 2a 20 41 | 64 64 20 63 75 72 20 74 |h);./* A|dd cur t|
|00004b40| 6f 20 73 74 72 69 6e 67 | 20 2a 2f 0a 58 09 09 09 |o string| */.X...|
|00004b50| 09 09 62 72 65 61 6b 3b | 0a 58 0a 58 09 09 09 09 |..break;|.X.X....|
|00004b60| 63 61 73 65 20 27 2e 27 | 3a 20 63 61 73 65 20 27 |case '.'|: case '|
|00004b70| 5b 27 3a 20 63 61 73 65 | 20 27 28 27 3a 0a 58 09 |[': case| '(':.X.|
|00004b80| 09 09 09 63 61 73 65 20 | 27 29 27 3a 20 63 61 73 |...case |')': cas|
|00004b90| 65 20 27 7c 27 3a 20 63 | 61 73 65 20 27 5c 6e 27 |e '|': c|ase '\n'|
|00004ba0| 3a 0a 58 09 09 09 09 63 | 61 73 65 20 27 24 27 3a |:.X....c|ase '$':|
|00004bb0| 20 63 61 73 65 20 27 5e | 27 3a 0a 58 09 09 09 09 | case '^|':.X....|
|00004bc0| 63 61 73 65 20 27 5c 30 | 27 3a 0a 58 09 09 09 09 |case '\0|':.X....|
|00004bd0| 2f 2a 20 46 49 58 4d 45 | 2c 20 24 20 61 6e 64 20 |/* FIXME|, $ and |
|00004be0| 5e 20 73 68 6f 75 6c 64 | 20 6e 6f 74 20 61 6c 77 |^ should| not alw|
|00004bf0| 61 79 73 20 62 65 20 6d | 61 67 69 63 20 2a 2f 0a |ays be m|agic */.|
|00004c00| 58 09 09 09 09 6d 61 67 | 69 63 3a 0a 58 09 09 09 |X....mag|ic:.X...|
|00004c10| 09 09 72 65 67 63 28 63 | 68 29 3b 09 2f 2a 20 64 |..regc(c|h);./* d|
|00004c20| 75 6d 70 20 63 75 72 20 | 63 68 61 72 20 2a 2f 0a |ump cur |char */.|
|00004c30| 58 09 09 09 09 09 67 6f | 74 6f 20 64 6f 6e 65 3b |X.....go|to done;|
|00004c40| 09 2f 2a 20 61 6e 64 20 | 77 65 20 61 72 65 20 64 |./* and |we are d|
|00004c50| 6f 6e 65 20 2a 2f 0a 58 | 0a 58 09 09 09 09 63 61 |one */.X|.X....ca|
|00004c60| 73 65 20 27 3f 27 3a 20 | 63 61 73 65 20 27 2b 27 |se '?': |case '+'|
|00004c70| 3a 20 63 61 73 65 20 27 | 2a 27 3a 0a 58 09 09 09 |: case '|*':.X...|
|00004c80| 09 09 69 66 20 28 21 72 | 65 67 70 72 65 76 29 20 |..if (!r|egprev) |
|00004c90| 09 2f 2a 20 49 66 20 6a | 75 73 74 20 63 68 20 69 |./* If j|ust ch i|
|00004ca0| 6e 20 73 74 72 2c 20 2a | 2f 0a 58 09 09 09 09 09 |n str, *|/.X.....|
|00004cb0| 09 67 6f 74 6f 20 6d 61 | 67 69 63 3b 09 2f 2a 20 |.goto ma|gic;./* |
|00004cc0| 75 73 65 20 69 74 20 2a | 2f 0a 58 09 09 09 09 09 |use it *|/.X.....|
|00004cd0| 2f 2a 20 45 6e 64 20 6d | 75 6c 74 2d 63 68 61 72 |/* End m|ult-char|
|00004ce0| 20 73 74 72 69 6e 67 20 | 6f 6e 65 20 65 61 72 6c | string |one earl|
|00004cf0| 79 20 2a 2f 0a 58 09 09 | 09 09 09 72 65 67 70 61 |y */.X..|...regpa|
|00004d00| 72 73 65 20 3d 20 72 65 | 67 70 72 65 76 3b 20 2f |rse = re|gprev; /|
|00004d10| 2a 20 42 61 63 6b 20 75 | 70 20 70 61 72 73 65 20 |* Back u|p parse |
|00004d20| 2a 2f 0a 58 09 09 09 09 | 09 67 6f 74 6f 20 64 6f |*/.X....|.goto do|
|00004d30| 6e 65 3b 0a 58 0a 58 09 | 09 09 09 63 61 73 65 20 |ne;.X.X.|...case |
|00004d40| 27 5c 5c 27 3a 0a 58 09 | 09 09 09 09 72 65 67 63 |'\\':.X.|....regc|
|00004d50| 28 63 68 29 3b 09 2f 2a | 20 43 75 72 20 63 68 61 |(ch);./*| Cur cha|
|00004d60| 72 20 4f 4b 20 2a 2f 0a | 58 09 09 09 09 09 73 77 |r OK */.|X.....sw|
|00004d70| 69 74 63 68 20 28 72 65 | 67 70 61 72 73 65 5b 31 |itch (re|gparse[1|
|00004d80| 5d 29 7b 20 2f 2a 20 4c | 6f 6f 6b 20 61 66 74 65 |]){ /* L|ook afte|
|00004d90| 72 20 5c 20 2a 2f 0a 58 | 09 09 09 09 09 63 61 73 |r \ */.X|.....cas|
|00004da0| 65 20 27 5c 30 27 3a 0a | 58 09 09 09 09 09 63 61 |e '\0':.|X.....ca|
|00004db0| 73 65 20 27 3c 27 3a 0a | 58 09 09 09 09 09 63 61 |se '<':.|X.....ca|
|00004dc0| 73 65 20 27 3e 27 3a 0a | 58 09 09 09 09 09 2f 2a |se '>':.|X...../*|
|00004dd0| 20 46 49 58 4d 45 3a 20 | 53 6f 6d 65 64 61 79 20 | FIXME: |Someday |
|00004de0| 68 61 6e 64 6c 65 20 5c | 31 2c 20 5c 32 2c 20 2e |handle \|1, \2, .|
|00004df0| 2e 2e 20 2a 2f 0a 58 09 | 09 09 09 09 09 67 6f 74 |.. */.X.|.....got|
|00004e00| 6f 20 64 6f 6e 65 3b 20 | 2f 2a 20 4e 6f 74 20 71 |o done; |/* Not q|
|00004e10| 75 6f 74 65 64 20 2a 2f | 0a 58 09 09 09 09 09 64 |uoted */|.X.....d|
|00004e20| 65 66 61 75 6c 74 3a 0a | 58 09 09 09 09 09 09 2f |efault:.|X....../|
|00004e30| 2a 20 42 61 63 6b 75 70 | 20 70 6f 69 6e 74 20 69 |* Backup| point i|
|00004e40| 73 20 5c 2c 20 73 63 61 | 6e 09 09 09 09 09 09 09 |s \, sca|n.......|
|00004e50| 20 2a 20 70 6f 69 6e 74 | 20 69 73 20 61 66 74 65 | * point| is afte|
|00004e60| 72 20 69 74 2e 20 2a 2f | 0a 58 09 09 09 09 09 09 |r it. */|.X......|
|00004e70| 72 65 67 70 72 65 76 20 | 3d 20 72 65 67 70 61 72 |regprev |= regpar|
|00004e80| 73 65 3b 0a 58 09 09 09 | 09 09 09 72 65 67 70 61 |se;.X...|...regpa|
|00004e90| 72 73 65 2b 2b 3b 20 0a | 58 09 09 09 09 09 09 63 |rse++; .|X......c|
|00004ea0| 6f 6e 74 69 6e 75 65 3b | 09 2f 2a 20 4e 4f 54 20 |ontinue;|./* NOT |
|00004eb0| 62 72 65 61 6b 3b 20 2a | 2f 0a 58 09 09 09 09 09 |break; *|/.X.....|
|00004ec0| 7d 0a 58 09 09 09 09 7d | 0a 58 09 09 09 09 72 65 |}.X....}|.X....re|
|00004ed0| 67 70 72 65 76 20 3d 20 | 72 65 67 70 61 72 73 65 |gprev = |regparse|
|00004ee0| 3b 09 2f 2a 20 53 65 74 | 20 62 61 63 6b 75 70 20 |;./* Set| backup |
|00004ef0| 70 6f 69 6e 74 20 2a 2f | 0a 58 09 09 09 7d 0a 58 |point */|.X...}.X|
|00004f00| 09 09 64 6f 6e 65 3a 0a | 58 09 09 09 72 65 67 63 |..done:.|X...regc|
|00004f10| 28 27 5c 30 27 29 3b 0a | 58 09 09 09 2a 66 6c 61 |('\0');.|X...*fla|
|00004f20| 67 70 20 7c 3d 20 48 41 | 53 57 49 44 54 48 3b 0a |gp |= HA|SWIDTH;.|
|00004f30| 58 09 09 09 69 66 20 28 | 21 72 65 67 70 72 65 76 |X...if (|!regprev|
|00004f40| 29 09 09 2f 2a 20 4f 6e | 65 20 63 68 61 72 3f 20 |)../* On|e char? |
|00004f50| 2a 2f 0a 58 09 09 09 09 | 2a 66 6c 61 67 70 20 7c |*/.X....|*flagp ||
|00004f60| 3d 20 53 49 4d 50 4c 45 | 3b 0a 58 09 09 7d 0a 58 |= SIMPLE|;.X..}.X|
|00004f70| 09 09 62 72 65 61 6b 3b | 0a 58 09 7d 0a 58 0a 58 |..break;|.X.}.X.X|
|00004f80| 09 72 65 74 75 72 6e 28 | 72 65 74 29 3b 0a 58 7d |.return(|ret);.X}|
|00004f90| 0a 58 0a 58 2f 2a 0a 58 | 20 2d 20 72 65 67 6e 6f |.X.X/*.X| - regno|
|00004fa0| 64 65 20 2d 20 65 6d 69 | 74 20 61 20 6e 6f 64 65 |de - emi|t a node|
|00004fb0| 0a 58 20 2a 2f 0a 58 73 | 74 61 74 69 63 20 63 68 |.X */.Xs|tatic ch|
|00004fc0| 61 72 20 2a 09 09 09 2f | 2a 20 4c 6f 63 61 74 69 |ar *.../|* Locati|
|00004fd0| 6f 6e 2e 20 2a 2f 0a 58 | 72 65 67 6e 6f 64 65 28 |on. */.X|regnode(|
|00004fe0| 6f 70 29 0a 58 63 68 61 | 72 20 6f 70 3b 0a 58 7b |op).Xcha|r op;.X{|
|00004ff0| 0a 58 09 72 65 67 69 73 | 74 65 72 20 63 68 61 72 |.X.regis|ter char|
|00005000| 20 2a 72 65 74 3b 0a 58 | 09 72 65 67 69 73 74 65 | *ret;.X|.registe|
|00005010| 72 20 63 68 61 72 20 2a | 70 74 72 3b 0a 58 0a 58 |r char *|ptr;.X.X|
|00005020| 09 72 65 74 20 3d 20 72 | 65 67 63 6f 64 65 3b 0a |.ret = r|egcode;.|
|00005030| 58 09 69 66 20 28 72 65 | 74 20 3d 3d 20 26 72 65 |X.if (re|t == &re|
|00005040| 67 64 75 6d 6d 79 29 20 | 7b 0a 58 09 09 72 65 67 |gdummy) |{.X..reg|
|00005050| 73 69 7a 65 20 2b 3d 20 | 33 3b 0a 58 09 09 72 65 |size += |3;.X..re|
|00005060| 74 75 72 6e 28 72 65 74 | 29 3b 0a 58 09 7d 0a 58 |turn(ret|);.X.}.X|
|00005070| 0a 58 09 70 74 72 20 3d | 20 72 65 74 3b 0a 58 09 |.X.ptr =| ret;.X.|
|00005080| 2a 70 74 72 2b 2b 20 3d | 20 6f 70 3b 0a 58 09 2a |*ptr++ =| op;.X.*|
|00005090| 70 74 72 2b 2b 20 3d 20 | 27 5c 30 27 3b 09 09 2f |ptr++ = |'\0';../|
|000050a0| 2a 20 4e 75 6c 6c 20 22 | 6e 65 78 74 22 20 70 6f |* Null "|next" po|
|000050b0| 69 6e 74 65 72 2e 20 2a | 2f 0a 58 09 2a 70 74 72 |inter. *|/.X.*ptr|
|000050c0| 2b 2b 20 3d 20 27 5c 30 | 27 3b 0a 58 09 72 65 67 |++ = '\0|';.X.reg|
|000050d0| 63 6f 64 65 20 3d 20 70 | 74 72 3b 0a 58 0a 58 09 |code = p|tr;.X.X.|
|000050e0| 72 65 74 75 72 6e 28 72 | 65 74 29 3b 0a 58 7d 0a |return(r|et);.X}.|
|000050f0| 58 0a 58 2f 2a 0a 58 20 | 2d 20 72 65 67 63 20 2d |X.X/*.X |- regc -|
|00005100| 20 65 6d 69 74 20 28 69 | 66 20 61 70 70 72 6f 70 | emit (i|f approp|
|00005110| 72 69 61 74 65 29 20 61 | 20 62 79 74 65 20 6f 66 |riate) a| byte of|
|00005120| 20 63 6f 64 65 0a 58 20 | 2a 2f 0a 58 73 74 61 74 | code.X |*/.Xstat|
|00005130| 69 63 20 76 6f 69 64 0a | 58 72 65 67 63 28 62 29 |ic void.|Xregc(b)|
|00005140| 0a 58 63 68 61 72 20 62 | 3b 0a 58 7b 0a 58 09 69 |.Xchar b|;.X{.X.i|
|00005150| 66 20 28 72 65 67 63 6f | 64 65 20 21 3d 20 26 72 |f (regco|de != &r|
|00005160| 65 67 64 75 6d 6d 79 29 | 0a 58 09 09 2a 72 65 67 |egdummy)|.X..*reg|
|00005170| 63 6f 64 65 2b 2b 20 3d | 20 62 3b 0a 58 09 65 6c |code++ =| b;.X.el|
|00005180| 73 65 0a 58 09 09 72 65 | 67 73 69 7a 65 2b 2b 3b |se.X..re|gsize++;|
|00005190| 0a 58 7d 0a 58 0a 58 2f | 2a 0a 58 20 2d 20 72 65 |.X}.X.X/|*.X - re|
|000051a0| 67 69 6e 73 65 72 74 20 | 2d 20 69 6e 73 65 72 74 |ginsert |- insert|
|000051b0| 20 61 6e 20 6f 70 65 72 | 61 74 6f 72 20 69 6e 20 | an oper|ator in |
|000051c0| 66 72 6f 6e 74 20 6f 66 | 20 61 6c 72 65 61 64 79 |front of| already|
|000051d0| 2d 65 6d 69 74 74 65 64 | 20 6f 70 65 72 61 6e 64 |-emitted| operand|
|000051e0| 0a 58 20 2a 0a 58 20 2a | 20 4d 65 61 6e 73 20 72 |.X *.X *| Means r|
|000051f0| 65 6c 6f 63 61 74 69 6e | 67 20 74 68 65 20 6f 70 |elocatin|g the op|
|00005200| 65 72 61 6e 64 2e 0a 58 | 20 2a 2f 0a 58 73 74 61 |erand..X| */.Xsta|
|00005210| 74 69 63 20 76 6f 69 64 | 0a 58 72 65 67 69 6e 73 |tic void|.Xregins|
|00005220| 65 72 74 28 6f 70 2c 20 | 6f 70 6e 64 29 0a 58 63 |ert(op, |opnd).Xc|
|00005230| 68 61 72 20 6f 70 3b 0a | 58 63 68 61 72 20 2a 6f |har op;.|Xchar *o|
|00005240| 70 6e 64 3b 0a 58 7b 0a | 58 09 72 65 67 69 73 74 |pnd;.X{.|X.regist|
|00005250| 65 72 20 63 68 61 72 20 | 2a 73 72 63 3b 0a 58 09 |er char |*src;.X.|
|00005260| 72 65 67 69 73 74 65 72 | 20 63 68 61 72 20 2a 64 |register| char *d|
|00005270| 73 74 3b 0a 58 09 72 65 | 67 69 73 74 65 72 20 63 |st;.X.re|gister c|
|00005280| 68 61 72 20 2a 70 6c 61 | 63 65 3b 0a 58 0a 58 09 |har *pla|ce;.X.X.|
|00005290| 69 66 20 28 72 65 67 63 | 6f 64 65 20 3d 3d 20 26 |if (regc|ode == &|
|000052a0| 72 65 67 64 75 6d 6d 79 | 29 20 7b 0a 58 09 09 72 |regdummy|) {.X..r|
|000052b0| 65 67 73 69 7a 65 20 2b | 3d 20 33 3b 0a 58 09 09 |egsize +|= 3;.X..|
|000052c0| 72 65 74 75 72 6e 3b 0a | 58 09 7d 0a 58 0a 58 09 |return;.|X.}.X.X.|
|000052d0| 73 72 63 20 3d 20 72 65 | 67 63 6f 64 65 3b 0a 58 |src = re|gcode;.X|
|000052e0| 09 72 65 67 63 6f 64 65 | 20 2b 3d 20 33 3b 0a 58 |.regcode| += 3;.X|
|000052f0| 09 64 73 74 20 3d 20 72 | 65 67 63 6f 64 65 3b 0a |.dst = r|egcode;.|
|00005300| 58 09 77 68 69 6c 65 20 | 28 73 72 63 20 3e 20 6f |X.while |(src > o|
|00005310| 70 6e 64 29 0a 58 09 09 | 2a 2d 2d 64 73 74 20 3d |pnd).X..|*--dst =|
|00005320| 20 2a 2d 2d 73 72 63 3b | 0a 58 0a 58 09 70 6c 61 | *--src;|.X.X.pla|
|00005330| 63 65 20 3d 20 6f 70 6e | 64 3b 09 09 2f 2a 20 4f |ce = opn|d;../* O|
|00005340| 70 20 6e 6f 64 65 2c 20 | 77 68 65 72 65 20 6f 70 |p node, |where op|
|00005350| 65 72 61 6e 64 20 75 73 | 65 64 20 74 6f 20 62 65 |erand us|ed to be|
|00005360| 2e 20 2a 2f 0a 58 09 2a | 70 6c 61 63 65 2b 2b 20 |. */.X.*|place++ |
|00005370| 3d 20 6f 70 3b 0a 58 09 | 2a 70 6c 61 63 65 2b 2b |= op;.X.|*place++|
|00005380| 20 3d 20 27 5c 30 27 3b | 0a 58 09 2a 70 6c 61 63 | = '\0';|.X.*plac|
|00005390| 65 2b 2b 20 3d 20 27 5c | 30 27 3b 0a 58 7d 0a 58 |e++ = '\|0';.X}.X|
|000053a0| 0a 58 2f 2a 0a 58 20 2d | 20 72 65 67 74 61 69 6c |.X/*.X -| regtail|
|000053b0| 20 2d 20 73 65 74 20 74 | 68 65 20 6e 65 78 74 2d | - set t|he next-|
|000053c0| 70 6f 69 6e 74 65 72 20 | 61 74 20 74 68 65 20 65 |pointer |at the e|
|000053d0| 6e 64 20 6f 66 20 61 20 | 6e 6f 64 65 20 63 68 61 |nd of a |node cha|
|000053e0| 69 6e 0a 58 20 2a 2f 0a | 58 73 74 61 74 69 63 20 |in.X */.|Xstatic |
|000053f0| 76 6f 69 64 0a 58 72 65 | 67 74 61 69 6c 28 70 2c |void.Xre|gtail(p,|
|00005400| 20 76 61 6c 29 0a 58 63 | 68 61 72 20 2a 70 3b 0a | val).Xc|har *p;.|
|00005410| 58 63 68 61 72 20 2a 76 | 61 6c 3b 0a 58 7b 0a 58 |Xchar *v|al;.X{.X|
|00005420| 09 72 65 67 69 73 74 65 | 72 20 63 68 61 72 20 2a |.registe|r char *|
|00005430| 73 63 61 6e 3b 0a 58 09 | 72 65 67 69 73 74 65 72 |scan;.X.|register|
|00005440| 20 63 68 61 72 20 2a 74 | 65 6d 70 3b 0a 58 09 72 | char *t|emp;.X.r|
|00005450| 65 67 69 73 74 65 72 20 | 69 6e 74 20 6f 66 66 73 |egister |int offs|
|00005460| 65 74 3b 0a 58 0a 58 09 | 69 66 20 28 70 20 3d 3d |et;.X.X.|if (p ==|
|00005470| 20 26 72 65 67 64 75 6d | 6d 79 29 0a 58 09 09 72 | ®dum|my).X..r|
|00005480| 65 74 75 72 6e 3b 0a 58 | 0a 58 09 2f 2a 20 46 69 |eturn;.X|.X./* Fi|
|00005490| 6e 64 20 6c 61 73 74 20 | 6e 6f 64 65 2e 20 2a 2f |nd last |node. */|
|000054a0| 0a 58 09 73 63 61 6e 20 | 3d 20 70 3b 0a 58 09 66 |.X.scan |= p;.X.f|
|000054b0| 6f 72 20 28 3b 3b 29 20 | 7b 0a 58 09 09 74 65 6d |or (;;) |{.X..tem|
|000054c0| 70 20 3d 20 72 65 67 6e | 65 78 74 28 73 63 61 6e |p = regn|ext(scan|
|000054d0| 29 3b 0a 58 09 09 69 66 | 20 28 74 65 6d 70 20 3d |);.X..if| (temp =|
|000054e0| 3d 20 4e 55 4c 4c 29 0a | 58 09 09 09 62 72 65 61 |= NULL).|X...brea|
|000054f0| 6b 3b 0a 58 09 09 73 63 | 61 6e 20 3d 20 74 65 6d |k;.X..sc|an = tem|
|00005500| 70 3b 0a 58 09 7d 0a 58 | 0a 58 09 69 66 20 28 4f |p;.X.}.X|.X.if (O|
|00005510| 50 28 73 63 61 6e 29 20 | 3d 3d 20 42 41 43 4b 29 |P(scan) |== BACK)|
|00005520| 0a 58 09 09 6f 66 66 73 | 65 74 20 3d 20 73 63 61 |.X..offs|et = sca|
|00005530| 6e 20 2d 20 76 61 6c 3b | 0a 58 09 65 6c 73 65 0a |n - val;|.X.else.|
|00005540| 58 09 09 6f 66 66 73 65 | 74 20 3d 20 76 61 6c 20 |X..offse|t = val |
|00005550| 2d 20 73 63 61 6e 3b 0a | 58 09 2a 28 73 63 61 6e |- scan;.|X.*(scan|
|00005560| 2b 31 29 20 3d 20 28 6f | 66 66 73 65 74 3e 3e 38 |+1) = (o|ffset>>8|
|00005570| 29 26 30 33 37 37 3b 0a | 58 09 2a 28 73 63 61 6e |)&0377;.|X.*(scan|
|00005580| 2b 32 29 20 3d 20 6f 66 | 66 73 65 74 26 30 33 37 |+2) = of|fset&037|
|00005590| 37 3b 0a 58 7d 0a 58 0a | 58 2f 2a 0a 58 20 2d 20 |7;.X}.X.|X/*.X - |
|000055a0| 72 65 67 6f 70 74 61 69 | 6c 20 2d 20 72 65 67 74 |regoptai|l - regt|
|000055b0| 61 69 6c 20 6f 6e 20 6f | 70 65 72 61 6e 64 20 6f |ail on o|perand o|
|000055c0| 66 20 66 69 72 73 74 20 | 61 72 67 75 6d 65 6e 74 |f first |argument|
|000055d0| 3b 20 6e 6f 70 20 69 66 | 20 6f 70 65 72 61 6e 64 |; nop if| operand|
|000055e0| 6c 65 73 73 0a 58 20 2a | 2f 0a 58 73 74 61 74 69 |less.X *|/.Xstati|
|000055f0| 63 20 76 6f 69 64 0a 58 | 72 65 67 6f 70 74 61 69 |c void.X|regoptai|
|00005600| 6c 28 70 2c 20 76 61 6c | 29 0a 58 63 68 61 72 20 |l(p, val|).Xchar |
|00005610| 2a 70 3b 0a 58 63 68 61 | 72 20 2a 76 61 6c 3b 0a |*p;.Xcha|r *val;.|
|00005620| 58 7b 0a 58 09 2f 2a 20 | 22 4f 70 65 72 61 6e 64 |X{.X./* |"Operand|
|00005630| 6c 65 73 73 22 20 61 6e | 64 20 22 6f 70 20 21 3d |less" an|d "op !=|
|00005640| 20 42 52 41 4e 43 48 22 | 20 61 72 65 20 73 79 6e | BRANCH"| are syn|
|00005650| 6f 6e 79 6d 6f 75 73 20 | 69 6e 20 70 72 61 63 74 |onymous |in pract|
|00005660| 69 63 65 2e 20 2a 2f 0a | 58 09 69 66 20 28 70 20 |ice. */.|X.if (p |
|00005670| 3d 3d 20 4e 55 4c 4c 20 | 7c 7c 20 70 20 3d 3d 20 |== NULL ||| p == |
|00005680| 26 72 65 67 64 75 6d 6d | 79 20 7c 7c 20 4f 50 28 |®dumm|y || OP(|
|00005690| 70 29 20 21 3d 20 42 52 | 41 4e 43 48 29 0a 58 09 |p) != BR|ANCH).X.|
|000056a0| 09 72 65 74 75 72 6e 3b | 0a 58 09 72 65 67 74 61 |.return;|.X.regta|
|000056b0| 69 6c 28 4f 50 45 52 41 | 4e 44 28 70 29 2c 20 76 |il(OPERA|ND(p), v|
|000056c0| 61 6c 29 3b 0a 58 7d 0a | 58 0a 58 2f 2a 0a 58 20 |al);.X}.|X.X/*.X |
|000056d0| 2a 20 72 65 67 65 78 65 | 63 20 61 6e 64 20 66 72 |* regexe|c and fr|
|000056e0| 69 65 6e 64 73 0a 58 20 | 2a 2f 0a 58 0a 58 2f 2a |iends.X |*/.X.X/*|
|000056f0| 0a 58 20 2a 20 47 6c 6f | 62 61 6c 20 77 6f 72 6b |.X * Glo|bal work|
|00005700| 20 76 61 72 69 61 62 6c | 65 73 20 66 6f 72 20 72 | variabl|es for r|
|00005710| 65 67 65 78 65 63 28 29 | 2e 0a 58 20 2a 2f 0a 58 |egexec()|..X */.X|
|00005720| 73 74 61 74 69 63 20 63 | 68 61 72 20 2a 72 65 67 |static c|har *reg|
|00005730| 69 6e 70 75 74 3b 09 09 | 2f 2a 20 53 74 72 69 6e |input;..|/* Strin|
|00005740| 67 2d 69 6e 70 75 74 20 | 70 6f 69 6e 74 65 72 2e |g-input |pointer.|
|00005750| 20 2a 2f 0a 58 73 74 61 | 74 69 63 20 63 68 61 72 | */.Xsta|tic char|
|00005760| 20 2a 72 65 67 62 6f 6c | 3b 09 09 2f 2a 20 42 65 | *regbol|;../* Be|
|00005770| 67 69 6e 6e 69 6e 67 20 | 6f 66 20 69 6e 70 75 74 |ginning |of input|
|00005780| 2c 20 66 6f 72 20 5e 20 | 63 68 65 63 6b 2e 20 2a |, for ^ |check. *|
|00005790| 2f 0a 58 73 74 61 74 69 | 63 20 63 68 61 72 20 2a |/.Xstati|c char *|
|000057a0| 2a 72 65 67 73 74 61 72 | 74 70 3b 09 2f 2a 20 50 |*regstar|tp;./* P|
|000057b0| 6f 69 6e 74 65 72 20 74 | 6f 20 73 74 61 72 74 70 |ointer t|o startp|
|000057c0| 20 61 72 72 61 79 2e 20 | 2a 2f 0a 58 73 74 61 74 | array. |*/.Xstat|
|000057d0| 69 63 20 63 68 61 72 20 | 2a 2a 72 65 67 65 6e 64 |ic char |**regend|
|000057e0| 70 3b 09 09 2f 2a 20 44 | 69 74 74 6f 20 66 6f 72 |p;../* D|itto for|
|000057f0| 20 65 6e 64 70 2e 20 2a | 2f 0a 58 0a 58 2f 2a 0a | endp. *|/.X.X/*.|
|00005800| 58 20 2a 20 46 6f 72 77 | 61 72 64 73 2e 0a 58 20 |X * Forw|ards..X |
|00005810| 2a 2f 0a 58 53 54 41 54 | 49 43 20 69 6e 74 20 72 |*/.XSTAT|IC int r|
|00005820| 65 67 74 72 79 28 29 3b | 0a 58 53 54 41 54 49 43 |egtry();|.XSTATIC|
|00005830| 20 69 6e 74 20 72 65 67 | 6d 61 74 63 68 28 29 3b | int reg|match();|
|00005840| 0a 58 53 54 41 54 49 43 | 20 69 6e 74 20 72 65 67 |.XSTATIC| int reg|
|00005850| 72 65 70 65 61 74 28 29 | 3b 0a 58 0a 58 23 69 66 |repeat()|;.X.X#if|
|00005860| 64 65 66 20 44 45 42 55 | 47 0a 58 69 6e 74 20 72 |def DEBU|G.Xint r|
|00005870| 65 67 6e 61 72 72 61 74 | 65 20 3d 20 30 3b 0a 58 |egnarrat|e = 0;.X|
|00005880| 76 6f 69 64 20 72 65 67 | 64 75 6d 70 28 29 3b 0a |void reg|dump();.|
|00005890| 58 53 54 41 54 49 43 20 | 63 68 61 72 20 2a 72 65 |XSTATIC |char *re|
|000058a0| 67 70 72 6f 70 28 29 3b | 0a 58 23 65 6e 64 69 66 |gprop();|.X#endif|
|000058b0| 0a 58 0a 58 2f 2a 0a 58 | 20 2d 20 72 65 67 65 78 |.X.X/*.X| - regex|
|000058c0| 65 63 20 2d 20 6d 61 74 | 63 68 20 61 20 72 65 67 |ec - mat|ch a reg|
|000058d0| 65 78 70 20 61 67 61 69 | 6e 73 74 20 61 20 73 74 |exp agai|nst a st|
|000058e0| 72 69 6e 67 0a 58 20 2a | 2f 0a 58 69 6e 74 0a 58 |ring.X *|/.Xint.X|
|000058f0| 72 65 67 65 78 65 63 28 | 70 72 6f 67 2c 20 73 74 |regexec(|prog, st|
|00005900| 72 69 6e 67 29 0a 58 72 | 65 67 69 73 74 65 72 20 |ring).Xr|egister |
|00005910| 72 65 67 65 78 70 20 2a | 70 72 6f 67 3b 0a 58 72 |regexp *|prog;.Xr|
|00005920| 65 67 69 73 74 65 72 20 | 63 68 61 72 20 2a 73 74 |egister |char *st|
|00005930| 72 69 6e 67 3b 0a 58 7b | 0a 58 09 72 65 67 69 73 |ring;.X{|.X.regis|
|00005940| 74 65 72 20 63 68 61 72 | 20 2a 73 3b 0a 58 09 65 |ter char| *s;.X.e|
|00005950| 78 74 65 72 6e 20 63 68 | 61 72 20 2a 73 74 72 63 |xtern ch|ar *strc|
|00005960| 68 72 28 29 3b 0a 58 0a | 58 09 2f 2a 20 42 65 20 |hr();.X.|X./* Be |
|00005970| 70 61 72 61 6e 6f 69 64 | 2e 2e 2e 20 2a 2f 0a 58 |paranoid|... */.X|
|00005980| 09 69 66 20 28 70 72 6f | 67 20 3d 3d 20 4e 55 4c |.if (pro|g == NUL|
|00005990| 4c 20 7c 7c 20 73 74 72 | 69 6e 67 20 3d 3d 20 4e |L || str|ing == N|
|000059a0| 55 4c 4c 29 20 7b 0a 58 | 09 09 72 65 67 65 72 72 |ULL) {.X|..regerr|
|000059b0| 6f 72 28 22 4e 55 4c 4c | 20 70 61 72 61 6d 65 74 |or("NULL| paramet|
|000059c0| 65 72 22 29 3b 0a 58 09 | 09 72 65 74 75 72 6e 28 |er");.X.|.return(|
|000059d0| 30 29 3b 0a 58 09 7d 0a | 58 0a 58 09 2f 2a 20 43 |0);.X.}.|X.X./* C|
|000059e0| 68 65 63 6b 20 76 61 6c | 69 64 69 74 79 20 6f 66 |heck val|idity of|
|000059f0| 20 70 72 6f 67 72 61 6d | 2e 20 2a 2f 0a 58 09 69 | program|. */.X.i|
|00005a00| 66 20 28 55 43 48 41 52 | 41 54 28 70 72 6f 67 2d |f (UCHAR|AT(prog-|
|00005a10| 3e 70 72 6f 67 72 61 6d | 29 20 21 3d 20 4d 41 47 |>program|) != MAG|
|00005a20| 49 43 29 20 7b 0a 58 09 | 09 72 65 67 65 72 72 6f |IC) {.X.|.regerro|
|00005a30| 72 28 22 63 6f 72 72 75 | 70 74 65 64 20 70 72 6f |r("corru|pted pro|
|00005a40| 67 72 61 6d 22 29 3b 0a | 58 09 09 72 65 74 75 72 |gram");.|X..retur|
|00005a50| 6e 28 30 29 3b 0a 58 09 | 7d 0a 58 0a 58 09 2f 2a |n(0);.X.|}.X.X./*|
|00005a60| 20 49 66 20 74 68 65 72 | 65 20 69 73 20 61 20 22 | If ther|e is a "|
|00005a70| 6d 75 73 74 20 61 70 70 | 65 61 72 22 20 73 74 72 |must app|ear" str|
|00005a80| 69 6e 67 2c 20 6c 6f 6f | 6b 20 66 6f 72 20 69 74 |ing, loo|k for it|
|00005a90| 2e 20 2a 2f 0a 58 09 69 | 66 20 28 70 72 6f 67 2d |. */.X.i|f (prog-|
|00005aa0| 3e 72 65 67 6d 75 73 74 | 20 21 3d 20 4e 55 4c 4c |>regmust| != NULL|
|00005ab0| 29 20 7b 0a 58 09 09 73 | 20 3d 20 73 74 72 69 6e |) {.X..s| = strin|
|00005ac0| 67 3b 0a 58 09 09 77 68 | 69 6c 65 20 28 28 73 20 |g;.X..wh|ile ((s |
|00005ad0| 3d 20 73 74 72 63 68 72 | 28 73 2c 20 70 72 6f 67 |= strchr|(s, prog|
|00005ae0| 2d 3e 72 65 67 6d 75 73 | 74 5b 30 5d 29 29 20 21 |->regmus|t[0])) !|
|00005af0| 3d 20 4e 55 4c 4c 29 20 | 7b 0a 58 09 09 09 69 66 |= NULL) |{.X...if|
|00005b00| 20 28 73 74 72 6e 63 6d | 70 28 73 2c 20 70 72 6f | (strncm|p(s, pro|
|00005b10| 67 2d 3e 72 65 67 6d 75 | 73 74 2c 20 70 72 6f 67 |g->regmu|st, prog|
|00005b20| 2d 3e 72 65 67 6d 6c 65 | 6e 29 20 3d 3d 20 30 29 |->regmle|n) == 0)|
|00005b30| 0a 58 09 09 09 09 62 72 | 65 61 6b 3b 09 2f 2a 20 |.X....br|eak;./* |
|00005b40| 46 6f 75 6e 64 20 69 74 | 2e 20 2a 2f 0a 58 09 09 |Found it|. */.X..|
|00005b50| 09 73 2b 2b 3b 0a 58 09 | 09 7d 0a 58 09 09 69 66 |.s++;.X.|.}.X..if|
|00005b60| 20 28 73 20 3d 3d 20 4e | 55 4c 4c 29 09 2f 2a 20 | (s == N|ULL)./* |
|00005b70| 4e 6f 74 20 70 72 65 73 | 65 6e 74 2e 20 2a 2f 0a |Not pres|ent. */.|
|00005b80| 58 09 09 09 72 65 74 75 | 72 6e 28 30 29 3b 0a 58 |X...retu|rn(0);.X|
|00005b90| 09 7d 0a 58 0a 58 09 2f | 2a 20 4d 61 72 6b 20 62 |.}.X.X./|* Mark b|
|00005ba0| 65 67 69 6e 6e 69 6e 67 | 20 6f 66 20 6c 69 6e 65 |eginning| of line|
|00005bb0| 20 66 6f 72 20 5e 20 2e | 20 2a 2f 0a 58 09 72 65 | for ^ .| */.X.re|
|00005bc0| 67 62 6f 6c 20 3d 20 73 | 74 72 69 6e 67 3b 0a 58 |gbol = s|tring;.X|
|00005bd0| 0a 58 09 2f 2a 20 53 69 | 6d 70 6c 65 73 74 20 63 |.X./* Si|mplest c|
|00005be0| 61 73 65 3a 20 20 61 6e | 63 68 6f 72 65 64 20 6d |ase: an|chored m|
|00005bf0| 61 74 63 68 20 6e 65 65 | 64 20 62 65 20 74 72 69 |atch nee|d be tri|
|00005c00| 65 64 20 6f 6e 6c 79 20 | 6f 6e 63 65 2e 20 2a 2f |ed only |once. */|
|00005c10| 0a 58 09 69 66 20 28 70 | 72 6f 67 2d 3e 72 65 67 |.X.if (p|rog->reg|
|00005c20| 61 6e 63 68 29 0a 58 09 | 09 72 65 74 75 72 6e 28 |anch).X.|.return(|
|00005c30| 72 65 67 74 72 79 28 70 | 72 6f 67 2c 20 73 74 72 |regtry(p|rog, str|
|00005c40| 69 6e 67 29 29 3b 0a 58 | 0a 58 09 2f 2a 20 4d 65 |ing));.X|.X./* Me|
|00005c50| 73 73 79 20 63 61 73 65 | 73 3a 20 20 75 6e 61 6e |ssy case|s: unan|
|00005c60| 63 68 6f 72 65 64 20 6d | 61 74 63 68 2e 20 2a 2f |chored m|atch. */|
|00005c70| 0a 58 09 73 20 3d 20 73 | 74 72 69 6e 67 3b 0a 58 |.X.s = s|tring;.X|
|00005c80| 09 69 66 20 28 70 72 6f | 67 2d 3e 72 65 67 73 74 |.if (pro|g->regst|
|00005c90| 61 72 74 20 21 3d 20 27 | 5c 30 27 29 0a 58 09 09 |art != '|\0').X..|
|00005ca0| 2f 2a 20 57 65 20 6b 6e | 6f 77 20 77 68 61 74 20 |/* We kn|ow what |
|00005cb0| 63 68 61 72 20 69 74 20 | 6d 75 73 74 20 73 74 61 |char it |must sta|
|00005cc0| 72 74 20 77 69 74 68 2e | 20 2a 2f 0a 58 09 09 77 |rt with.| */.X..w|
|00005cd0| 68 69 6c 65 20 28 28 73 | 20 3d 20 73 74 72 63 68 |hile ((s| = strch|
|00005ce0| 72 28 73 2c 20 70 72 6f | 67 2d 3e 72 65 67 73 74 |r(s, pro|g->regst|
|00005cf0| 61 72 74 29 29 20 21 3d | 20 4e 55 4c 4c 29 20 7b |art)) !=| NULL) {|
|00005d00| 0a 58 09 09 09 69 66 20 | 28 72 65 67 74 72 79 28 |.X...if |(regtry(|
|00005d10| 70 72 6f 67 2c 20 73 29 | 29 0a 58 09 09 09 09 72 |prog, s)|).X....r|
|00005d20| 65 74 75 72 6e 28 31 29 | 3b 0a 58 09 09 09 73 2b |eturn(1)|;.X...s+|
|00005d30| 2b 3b 0a 58 09 09 7d 0a | 58 09 65 6c 73 65 0a 58 |+;.X..}.|X.else.X|
|00005d40| 09 09 2f 2a 20 57 65 20 | 64 6f 6e 27 74 20 2d 2d |../* We |don't --|
|00005d50| 20 67 65 6e 65 72 61 6c | 20 63 61 73 65 2e 20 2a | general| case. *|
|00005d60| 2f 0a 58 09 09 64 6f 20 | 7b 0a 58 09 09 09 69 66 |/.X..do |{.X...if|
|00005d70| 20 28 72 65 67 74 72 79 | 28 70 72 6f 67 2c 20 73 | (regtry|(prog, s|
|00005d80| 29 29 0a 58 09 09 09 09 | 72 65 74 75 72 6e 28 31 |)).X....|return(1|
|00005d90| 29 3b 0a 58 09 09 7d 20 | 77 68 69 6c 65 20 28 2a |);.X..} |while (*|
|00005da0| 73 2b 2b 20 21 3d 20 27 | 5c 30 27 29 3b 0a 58 0a |s++ != '|\0');.X.|
|00005db0| 58 09 2f 2a 20 46 61 69 | 6c 75 72 65 2e 20 2a 2f |X./* Fai|lure. */|
|00005dc0| 0a 58 09 72 65 74 75 72 | 6e 28 30 29 3b 0a 58 7d |.X.retur|n(0);.X}|
|00005dd0| 0a 58 0a 58 2f 2a 0a 58 | 20 2d 20 72 65 67 74 72 |.X.X/*.X| - regtr|
|00005de0| 79 20 2d 20 74 72 79 20 | 6d 61 74 63 68 20 61 74 |y - try |match at|
|00005df0| 20 73 70 65 63 69 66 69 | 63 20 70 6f 69 6e 74 0a | specifi|c point.|
|00005e00| 58 20 2a 2f 0a 58 73 74 | 61 74 69 63 20 69 6e 74 |X */.Xst|atic int|
|00005e10| 09 09 09 2f 2a 20 30 20 | 66 61 69 6c 75 72 65 2c |.../* 0 |failure,|
|00005e20| 20 31 20 73 75 63 63 65 | 73 73 20 2a 2f 0a 58 72 | 1 succe|ss */.Xr|
|00005e30| 65 67 74 72 79 28 70 72 | 6f 67 2c 20 73 74 72 69 |egtry(pr|og, stri|
|00005e40| 6e 67 29 0a 58 72 65 67 | 65 78 70 20 2a 70 72 6f |ng).Xreg|exp *pro|
|00005e50| 67 3b 0a 58 63 68 61 72 | 20 2a 73 74 72 69 6e 67 |g;.Xchar| *string|
|00005e60| 3b 0a 58 7b 0a 58 09 72 | 65 67 69 73 74 65 72 20 |;.X{.X.r|egister |
|00005e70| 69 6e 74 20 69 3b 0a 58 | 09 72 65 67 69 73 74 65 |int i;.X|.registe|
|00005e80| 72 20 63 68 61 72 20 2a | 2a 73 70 3b 0a 58 09 72 |r char *|*sp;.X.r|
|00005e90| 65 67 69 73 74 65 72 20 | 63 68 61 72 20 2a 2a 65 |egister |char **e|
|00005ea0| 70 3b 0a 58 0a 58 09 72 | 65 67 69 6e 70 75 74 20 |p;.X.X.r|eginput |
|00005eb0| 3d 20 73 74 72 69 6e 67 | 3b 0a 58 09 72 65 67 73 |= string|;.X.regs|
|00005ec0| 74 61 72 74 70 20 3d 20 | 70 72 6f 67 2d 3e 73 74 |tartp = |prog->st|
|00005ed0| 61 72 74 70 3b 0a 58 09 | 72 65 67 65 6e 64 70 20 |artp;.X.|regendp |
|00005ee0| 3d 20 70 72 6f 67 2d 3e | 65 6e 64 70 3b 0a 58 0a |= prog->|endp;.X.|
|00005ef0| 58 09 73 70 20 3d 20 70 | 72 6f 67 2d 3e 73 74 61 |X.sp = p|rog->sta|
|00005f00| 72 74 70 3b 0a 58 09 65 | 70 20 3d 20 70 72 6f 67 |rtp;.X.e|p = prog|
|00005f10| 2d 3e 65 6e 64 70 3b 0a | 58 09 66 6f 72 20 28 69 |->endp;.|X.for (i|
|00005f20| 20 3d 20 4e 53 55 42 45 | 58 50 3b 20 69 20 3e 20 | = NSUBE|XP; i > |
|00005f30| 30 3b 20 69 2d 2d 29 20 | 7b 0a 58 09 09 2a 73 70 |0; i--) |{.X..*sp|
|00005f40| 2b 2b 20 3d 20 4e 55 4c | 4c 3b 0a 58 09 09 2a 65 |++ = NUL|L;.X..*e|
|00005f50| 70 2b 2b 20 3d 20 4e 55 | 4c 4c 3b 0a 58 09 7d 0a |p++ = NU|LL;.X.}.|
|00005f60| 58 09 69 66 20 28 72 65 | 67 6d 61 74 63 68 28 70 |X.if (re|gmatch(p|
|00005f70| 72 6f 67 2d 3e 70 72 6f | 67 72 61 6d 20 2b 20 31 |rog->pro|gram + 1|
|00005f80| 29 29 20 7b 0a 58 09 09 | 70 72 6f 67 2d 3e 73 74 |)) {.X..|prog->st|
|00005f90| 61 72 74 70 5b 30 5d 20 | 3d 20 73 74 72 69 6e 67 |artp[0] |= string|
|00005fa0| 3b 0a 58 09 09 70 72 6f | 67 2d 3e 65 6e 64 70 5b |;.X..pro|g->endp[|
|00005fb0| 30 5d 20 3d 20 72 65 67 | 69 6e 70 75 74 3b 0a 58 |0] = reg|input;.X|
|00005fc0| 09 09 72 65 74 75 72 6e | 28 31 29 3b 0a 58 09 7d |..return|(1);.X.}|
|00005fd0| 20 65 6c 73 65 0a 58 09 | 09 72 65 74 75 72 6e 28 | else.X.|.return(|
|00005fe0| 30 29 3b 0a 58 7d 0a 58 | 0a 58 2f 2a 0a 58 20 2d |0);.X}.X|.X/*.X -|
|00005ff0| 20 72 65 67 6d 61 74 63 | 68 20 2d 20 6d 61 69 6e | regmatc|h - main|
|00006000| 20 6d 61 74 63 68 69 6e | 67 20 72 6f 75 74 69 6e | matchin|g routin|
|00006010| 65 0a 58 20 2a 0a 58 20 | 2a 20 43 6f 6e 63 65 70 |e.X *.X |* Concep|
|00006020| 74 75 61 6c 6c 79 20 74 | 68 65 20 73 74 72 61 74 |tually t|he strat|
|00006030| 65 67 79 20 69 73 20 73 | 69 6d 70 6c 65 3a 20 20 |egy is s|imple: |
|00006040| 63 68 65 63 6b 20 74 6f | 20 73 65 65 20 77 68 65 |check to| see whe|
|00006050| 74 68 65 72 20 74 68 65 | 20 63 75 72 72 65 6e 74 |ther the| current|
|00006060| 0a 58 20 2a 20 6e 6f 64 | 65 20 6d 61 74 63 68 65 |.X * nod|e matche|
|00006070| 73 2c 20 63 61 6c 6c 20 | 73 65 6c 66 20 72 65 63 |s, call |self rec|
|00006080| 75 72 73 69 76 65 6c 79 | 20 74 6f 20 73 65 65 20 |ursively| to see |
|00006090| 77 68 65 74 68 65 72 20 | 74 68 65 20 72 65 73 74 |whether |the rest|
|000060a0| 20 6d 61 74 63 68 65 73 | 2c 0a 58 20 2a 20 61 6e | matches|,.X * an|
|000060b0| 64 20 74 68 65 6e 20 61 | 63 74 20 61 63 63 6f 72 |d then a|ct accor|
|000060c0| 64 69 6e 67 6c 79 2e 20 | 20 49 6e 20 70 72 61 63 |dingly. | In prac|
|000060d0| 74 69 63 65 20 77 65 20 | 6d 61 6b 65 20 73 6f 6d |tice we |make som|
|000060e0| 65 20 65 66 66 6f 72 74 | 20 74 6f 20 61 76 6f 69 |e effort| to avoi|
|000060f0| 64 0a 58 20 2a 20 72 65 | 63 75 72 73 69 6f 6e 2c |d.X * re|cursion,|
|00006100| 20 69 6e 20 70 61 72 74 | 69 63 75 6c 61 72 20 62 | in part|icular b|
|00006110| 79 20 67 6f 69 6e 67 20 | 74 68 72 6f 75 67 68 20 |y going |through |
|00006120| 22 6f 72 64 69 6e 61 72 | 79 22 20 6e 6f 64 65 73 |"ordinar|y" nodes|
|00006130| 20 28 74 68 61 74 20 64 | 6f 6e 27 74 0a 58 20 2a | (that d|on't.X *|
|00006140| 20 6e 65 65 64 20 74 6f | 20 6b 6e 6f 77 20 77 68 | need to| know wh|
|00006150| 65 74 68 65 72 20 74 68 | 65 20 72 65 73 74 20 6f |ether th|e rest o|
|00006160| 66 20 74 68 65 20 6d 61 | 74 63 68 20 66 61 69 6c |f the ma|tch fail|
|00006170| 65 64 29 20 62 79 20 61 | 20 6c 6f 6f 70 20 69 6e |ed) by a| loop in|
|00006180| 73 74 65 61 64 20 6f 66 | 0a 58 20 2a 20 62 79 20 |stead of|.X * by |
|00006190| 72 65 63 75 72 73 69 6f | 6e 2e 0a 58 20 2a 2f 0a |recursio|n..X */.|
|000061a0| 58 73 74 61 74 69 63 20 | 69 6e 74 09 09 09 2f 2a |Xstatic |int.../*|
|000061b0| 20 30 20 66 61 69 6c 75 | 72 65 2c 20 31 20 73 75 | 0 failu|re, 1 su|
|000061c0| 63 63 65 73 73 20 2a 2f | 0a 58 72 65 67 6d 61 74 |ccess */|.Xregmat|
|000061d0| 63 68 28 70 72 6f 67 29 | 0a 58 63 68 61 72 20 2a |ch(prog)|.Xchar *|
|000061e0| 70 72 6f 67 3b 0a 58 7b | 0a 58 09 72 65 67 69 73 |prog;.X{|.X.regis|
|000061f0| 74 65 72 20 63 68 61 72 | 20 2a 73 63 61 6e 3b 09 |ter char| *scan;.|
|00006200| 2f 2a 20 43 75 72 72 65 | 6e 74 20 6e 6f 64 65 2e |/* Curre|nt node.|
|00006210| 20 2a 2f 0a 58 09 63 68 | 61 72 20 2a 6e 65 78 74 | */.X.ch|ar *next|
|00006220| 3b 09 09 2f 2a 20 4e 65 | 78 74 20 6e 6f 64 65 2e |;../* Ne|xt node.|
|00006230| 20 2a 2f 0a 58 09 65 78 | 74 65 72 6e 20 63 68 61 | */.X.ex|tern cha|
|00006240| 72 20 2a 73 74 72 63 68 | 72 28 29 3b 0a 58 0a 58 |r *strch|r();.X.X|
|00006250| 09 73 63 61 6e 20 3d 20 | 70 72 6f 67 3b 0a 58 23 |.scan = |prog;.X#|
|00006260| 69 66 64 65 66 20 44 45 | 42 55 47 0a 58 09 69 66 |ifdef DE|BUG.X.if|
|00006270| 20 28 73 63 61 6e 20 21 | 3d 20 4e 55 4c 4c 20 26 | (scan !|= NULL &|
|00006280| 26 20 72 65 67 6e 61 72 | 72 61 74 65 29 0a 58 09 |& regnar|rate).X.|
|00006290| 09 66 70 72 69 6e 74 66 | 28 73 74 64 65 72 72 2c |.fprintf|(stderr,|
|000062a0| 20 22 25 73 28 5c 6e 22 | 2c 20 72 65 67 70 72 6f | "%s(\n"|, regpro|
|000062b0| 70 28 73 63 61 6e 29 29 | 3b 0a 58 23 65 6e 64 69 |p(scan))|;.X#endi|
|000062c0| 66 0a 58 09 77 68 69 6c | 65 20 28 73 63 61 6e 20 |f.X.whil|e (scan |
|000062d0| 21 3d 20 4e 55 4c 4c 29 | 20 7b 0a 58 23 69 66 64 |!= NULL)| {.X#ifd|
|000062e0| 65 66 20 44 45 42 55 47 | 0a 58 09 09 69 66 20 28 |ef DEBUG|.X..if (|
|000062f0| 72 65 67 6e 61 72 72 61 | 74 65 29 0a 58 09 09 09 |regnarra|te).X...|
|00006300| 66 70 72 69 6e 74 66 28 | 73 74 64 65 72 72 2c 20 |fprintf(|stderr, |
|00006310| 22 25 73 2e 2e 2e 5c 6e | 22 2c 20 72 65 67 70 72 |"%s...\n|", regpr|
|00006320| 6f 70 28 73 63 61 6e 29 | 29 3b 0a 58 23 65 6e 64 |op(scan)|);.X#end|
|00006330| 69 66 0a 58 09 09 6e 65 | 78 74 20 3d 20 72 65 67 |if.X..ne|xt = reg|
|00006340| 6e 65 78 74 28 73 63 61 | 6e 29 3b 0a 58 0a 58 09 |next(sca|n);.X.X.|
|00006350| 09 73 77 69 74 63 68 20 | 28 4f 50 28 73 63 61 6e |.switch |(OP(scan|
|00006360| 29 29 20 7b 0a 58 09 09 | 63 61 73 65 20 42 4f 4c |)) {.X..|case BOL|
|00006370| 3a 0a 58 09 09 09 69 66 | 20 28 72 65 67 69 6e 70 |:.X...if| (reginp|
|00006380| 75 74 20 21 3d 20 72 65 | 67 62 6f 6c 29 0a 58 09 |ut != re|gbol).X.|
|00006390| 09 09 09 72 65 74 75 72 | 6e 28 30 29 3b 0a 58 09 |...retur|n(0);.X.|
|000063a0| 09 09 62 72 65 61 6b 3b | 0a 58 09 09 63 61 73 65 |..break;|.X..case|
|000063b0| 20 45 4f 4c 3a 0a 58 09 | 09 09 69 66 20 28 2a 72 | EOL:.X.|..if (*r|
|000063c0| 65 67 69 6e 70 75 74 20 | 21 3d 20 27 5c 30 27 29 |eginput |!= '\0')|
|000063d0| 0a 58 09 09 09 09 72 65 | 74 75 72 6e 28 30 29 3b |.X....re|turn(0);|
|000063e0| 0a 58 09 09 09 62 72 65 | 61 6b 3b 0a 58 09 09 63 |.X...bre|ak;.X..c|
|000063f0| 61 73 65 20 57 4f 52 44 | 41 3a 0a 58 09 09 09 2f |ase WORD|A:.X.../|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.