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: 1709
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 text
| default
| |
99%
| file
| C source text
| default
| |
98%
| file
| C source, 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 6b 69 | 72 6b 65 6e 64 61 40 65 |From: ki|rkenda@e|
|00000010| 65 63 73 2e 63 73 2e 70 | 64 78 2e 65 64 75 20 28 |ecs.cs.p|dx.edu (|
|00000020| 53 74 65 76 65 20 4b 69 | 72 6b 65 6e 64 61 6c 6c |Steve Ki|rkendall|
|00000030| 29 0a 4e 65 77 73 67 72 | 6f 75 70 73 3a 20 61 6c |).Newsgr|oups: al|
|00000040| 74 2e 73 6f 75 72 63 65 | 73 0a 53 75 62 6a 65 63 |t.source|s.Subjec|
|00000050| 74 3a 20 65 6c 76 69 73 | 20 31 2e 33 20 2d 20 61 |t: elvis| 1.3 - a|
|00000060| 20 63 6c 6f 6e 65 20 6f | 66 20 76 69 2f 65 78 2c | clone o|f vi/ex,|
|00000070| 20 70 61 72 74 20 35 20 | 6f 66 20 36 0a 4d 65 73 | part 5 |of 6.Mes|
|00000080| 73 61 67 65 2d 49 44 3a | 20 3c 33 32 38 30 40 70 |sage-ID:| <3280@p|
|00000090| 73 75 65 65 61 2e 55 55 | 43 50 3e 0a 44 61 74 65 |sueea.UU|CP>.Date|
|000000a0| 3a 20 32 34 20 41 75 67 | 20 39 30 20 31 37 3a 35 |: 24 Aug| 90 17:5|
|000000b0| 39 3a 30 39 20 47 4d 54 | 0a 0a 41 72 63 68 69 76 |9:09 GMT|..Archiv|
|000000c0| 65 2d 6e 61 6d 65 3a 20 | 65 6c 76 69 73 31 2e 33 |e-name: |elvis1.3|
|000000d0| 2f 70 61 72 74 35 0a 23 | 21 20 2f 62 69 6e 2f 73 |/part5.#|! /bin/s|
|000000e0| 68 0a 23 20 54 68 69 73 | 20 69 73 20 61 20 73 68 |h.# This| is a sh|
|000000f0| 65 6c 6c 20 61 72 63 68 | 69 76 65 2c 20 6d 65 61 |ell arch|ive, mea|
|00000100| 6e 69 6e 67 3a 0a 23 20 | 31 2e 20 52 65 6d 6f 76 |ning:.# |1. Remov|
|00000110| 65 20 65 76 65 72 79 74 | 68 69 6e 67 20 61 62 6f |e everyt|hing abo|
|00000120| 76 65 20 74 68 65 20 23 | 21 20 2f 62 69 6e 2f 73 |ve the #|! /bin/s|
|00000130| 68 20 6c 69 6e 65 2e 0a | 23 20 32 2e 20 53 61 76 |h line..|# 2. Sav|
|00000140| 65 20 74 68 65 20 72 65 | 73 75 6c 74 69 6e 67 20 |e the re|sulting |
|00000150| 74 65 78 74 20 69 6e 20 | 61 20 66 69 6c 65 2e 0a |text in |a file..|
|00000160| 23 20 33 2e 20 45 78 65 | 63 75 74 65 20 74 68 65 |# 3. Exe|cute the|
|00000170| 20 66 69 6c 65 20 77 69 | 74 68 20 2f 62 69 6e 2f | file wi|th /bin/|
|00000180| 73 68 20 28 6e 6f 74 20 | 63 73 68 29 20 74 6f 20 |sh (not |csh) to |
|00000190| 63 72 65 61 74 65 3a 0a | 23 09 72 65 67 65 78 70 |create:.|#.regexp|
|000001a0| 2e 63 0a 23 09 72 65 67 | 65 78 70 2e 68 0a 23 09 |.c.#.reg|exp.h.#.|
|000001b0| 72 65 67 73 75 62 2e 63 | 0a 23 09 73 79 73 64 6f |regsub.c|.#.sysdo|
|000001c0| 73 2e 63 0a 23 09 73 79 | 73 74 65 6d 2e 63 0a 23 |s.c.#.sy|stem.c.#|
|000001d0| 09 74 69 6e 79 74 63 61 | 70 2e 63 0a 23 09 74 69 |.tinytca|p.c.#.ti|
|000001e0| 6f 2e 63 0a 23 09 74 6d | 70 2e 63 0a 23 20 54 68 |o.c.#.tm|p.c.# Th|
|000001f0| 69 73 20 61 72 63 68 69 | 76 65 20 63 72 65 61 74 |is archi|ve creat|
|00000200| 65 64 3a 20 46 72 69 20 | 41 75 67 20 32 34 20 31 |ed: Fri |Aug 24 1|
|00000210| 30 3a 32 39 3a 35 39 20 | 31 39 39 30 0a 65 78 70 |0:29:59 |1990.exp|
|00000220| 6f 72 74 20 50 41 54 48 | 3b 20 50 41 54 48 3d 2f |ort PATH|; PATH=/|
|00000230| 62 69 6e 3a 2f 75 73 72 | 2f 62 69 6e 3a 24 50 41 |bin:/usr|/bin:$PA|
|00000240| 54 48 0a 69 66 20 74 65 | 73 74 20 2d 66 20 27 72 |TH.if te|st -f 'r|
|00000250| 65 67 65 78 70 2e 63 27 | 0a 74 68 65 6e 0a 09 65 |egexp.c'|.then..e|
|00000260| 63 68 6f 20 73 68 61 72 | 3a 20 22 77 69 6c 6c 20 |cho shar|: "will |
|00000270| 6e 6f 74 20 6f 76 65 72 | 2d 77 72 69 74 65 20 65 |not over|-write e|
|00000280| 78 69 73 74 69 6e 67 20 | 66 69 6c 65 20 27 72 65 |xisting |file 're|
|00000290| 67 65 78 70 2e 63 27 22 | 0a 65 6c 73 65 0a 63 61 |gexp.c'"|.else.ca|
|000002a0| 74 20 3c 3c 20 5c 53 48 | 41 52 5f 45 4f 46 20 3e |t << \SH|AR_EOF >|
|000002b0| 20 27 72 65 67 65 78 70 | 2e 63 27 0a 2f 2a 20 41 | 'regexp|.c'./* A|
|000002c0| 4c 54 45 52 45 44 20 56 | 45 52 53 49 4f 4e 20 2a |LTERED V|ERSION *|
|000002d0| 2f 0a 0a 2f 2a 0a 20 2a | 20 72 65 67 63 6f 6d 70 |/../*. *| regcomp|
|000002e0| 20 61 6e 64 20 72 65 67 | 65 78 65 63 20 2d 2d 20 | and reg|exec -- |
|000002f0| 72 65 67 73 75 62 20 61 | 6e 64 20 72 65 67 65 72 |regsub a|nd reger|
|00000300| 72 6f 72 20 61 72 65 20 | 65 6c 73 65 77 68 65 72 |ror are |elsewher|
|00000310| 65 0a 20 2a 0a 20 2a 09 | 43 6f 70 79 72 69 67 68 |e. *. *.|Copyrigh|
|00000320| 74 20 28 63 29 20 31 39 | 38 36 20 62 79 20 55 6e |t (c) 19|86 by Un|
|00000330| 69 76 65 72 73 69 74 79 | 20 6f 66 20 54 6f 72 6f |iversity| of Toro|
|00000340| 6e 74 6f 2e 0a 20 2a 09 | 57 72 69 74 74 65 6e 20 |nto.. *.|Written |
|00000350| 62 79 20 48 65 6e 72 79 | 20 53 70 65 6e 63 65 72 |by Henry| Spencer|
|00000360| 2e 20 20 4e 6f 74 20 64 | 65 72 69 76 65 64 20 66 |. Not d|erived f|
|00000370| 72 6f 6d 20 6c 69 63 65 | 6e 73 65 64 20 73 6f 66 |rom lice|nsed sof|
|00000380| 74 77 61 72 65 2e 0a 20 | 2a 0a 20 2a 09 50 65 72 |tware.. |*. *.Per|
|00000390| 6d 69 73 73 69 6f 6e 20 | 69 73 20 67 72 61 6e 74 |mission |is grant|
|000003a0| 65 64 20 74 6f 20 61 6e | 79 6f 6e 65 20 74 6f 20 |ed to an|yone to |
|000003b0| 75 73 65 20 74 68 69 73 | 20 73 6f 66 74 77 61 72 |use this| softwar|
|000003c0| 65 20 66 6f 72 20 61 6e | 79 0a 20 2a 09 70 75 72 |e for an|y. *.pur|
|000003d0| 70 6f 73 65 20 6f 6e 20 | 61 6e 79 20 63 6f 6d 70 |pose on |any comp|
|000003e0| 75 74 65 72 20 73 79 73 | 74 65 6d 2c 20 61 6e 64 |uter sys|tem, and|
|000003f0| 20 74 6f 20 72 65 64 69 | 73 74 72 69 62 75 74 65 | to redi|stribute|
|00000400| 20 69 74 20 66 72 65 65 | 6c 79 2c 0a 20 2a 09 73 | it free|ly,. *.s|
|00000410| 75 62 6a 65 63 74 20 74 | 6f 20 74 68 65 20 66 6f |ubject t|o the fo|
|00000420| 6c 6c 6f 77 69 6e 67 20 | 72 65 73 74 72 69 63 74 |llowing |restrict|
|00000430| 69 6f 6e 73 3a 0a 20 2a | 0a 20 2a 09 31 2e 20 54 |ions:. *|. *.1. T|
|00000440| 68 65 20 61 75 74 68 6f | 72 20 69 73 20 6e 6f 74 |he autho|r is not|
|00000450| 20 72 65 73 70 6f 6e 73 | 69 62 6c 65 20 66 6f 72 | respons|ible for|
|00000460| 20 74 68 65 20 63 6f 6e | 73 65 71 75 65 6e 63 65 | the con|sequence|
|00000470| 73 20 6f 66 20 75 73 65 | 20 6f 66 0a 20 2a 09 09 |s of use| of. *..|
|00000480| 74 68 69 73 20 73 6f 66 | 74 77 61 72 65 2c 20 6e |this sof|tware, n|
|00000490| 6f 20 6d 61 74 74 65 72 | 20 68 6f 77 20 61 77 66 |o matter| how awf|
|000004a0| 75 6c 2c 20 65 76 65 6e | 20 69 66 20 74 68 65 79 |ul, even| if they|
|000004b0| 20 61 72 69 73 65 0a 20 | 2a 09 09 66 72 6f 6d 20 | arise. |*..from |
|000004c0| 64 65 66 65 63 74 73 20 | 69 6e 20 69 74 2e 0a 20 |defects |in it.. |
|000004d0| 2a 0a 20 2a 09 32 2e 20 | 54 68 65 20 6f 72 69 67 |*. *.2. |The orig|
|000004e0| 69 6e 20 6f 66 20 74 68 | 69 73 20 73 6f 66 74 77 |in of th|is softw|
|000004f0| 61 72 65 20 6d 75 73 74 | 20 6e 6f 74 20 62 65 20 |are must| not be |
|00000500| 6d 69 73 72 65 70 72 65 | 73 65 6e 74 65 64 2c 20 |misrepre|sented, |
|00000510| 65 69 74 68 65 72 0a 20 | 2a 09 09 62 79 20 65 78 |either. |*..by ex|
|00000520| 70 6c 69 63 69 74 20 63 | 6c 61 69 6d 20 6f 72 20 |plicit c|laim or |
|00000530| 62 79 20 6f 6d 69 73 73 | 69 6f 6e 2e 0a 20 2a 0a |by omiss|ion.. *.|
|00000540| 20 2a 09 33 2e 20 41 6c | 74 65 72 65 64 20 76 65 | *.3. Al|tered ve|
|00000550| 72 73 69 6f 6e 73 20 6d | 75 73 74 20 62 65 20 70 |rsions m|ust be p|
|00000560| 6c 61 69 6e 6c 79 20 6d | 61 72 6b 65 64 20 61 73 |lainly m|arked as|
|00000570| 20 73 75 63 68 2c 20 61 | 6e 64 20 6d 75 73 74 20 | such, a|nd must |
|00000580| 6e 6f 74 0a 20 2a 09 09 | 62 65 20 6d 69 73 72 65 |not. *..|be misre|
|00000590| 70 72 65 73 65 6e 74 65 | 64 20 61 73 20 62 65 69 |presente|d as bei|
|000005a0| 6e 67 20 74 68 65 20 6f | 72 69 67 69 6e 61 6c 20 |ng the o|riginal |
|000005b0| 73 6f 66 74 77 61 72 65 | 2e 0a 20 2a 0a 20 2a 20 |software|.. *. * |
|000005c0| 42 65 77 61 72 65 20 74 | 68 61 74 20 73 6f 6d 65 |Beware t|hat some|
|000005d0| 20 6f 66 20 74 68 69 73 | 20 63 6f 64 65 20 69 73 | of this| code is|
|000005e0| 20 73 75 62 74 6c 79 20 | 61 77 61 72 65 20 6f 66 | subtly |aware of|
|000005f0| 20 74 68 65 20 77 61 79 | 20 6f 70 65 72 61 74 6f | the way| operato|
|00000600| 72 0a 20 2a 20 70 72 65 | 63 65 64 65 6e 63 65 20 |r. * pre|cedence |
|00000610| 69 73 20 73 74 72 75 63 | 74 75 72 65 64 20 69 6e |is struc|tured in|
|00000620| 20 72 65 67 75 6c 61 72 | 20 65 78 70 72 65 73 73 | regular| express|
|00000630| 69 6f 6e 73 2e 20 20 53 | 65 72 69 6f 75 73 20 63 |ions. S|erious c|
|00000640| 68 61 6e 67 65 73 20 69 | 6e 0a 20 2a 20 72 65 67 |hanges i|n. * reg|
|00000650| 75 6c 61 72 2d 65 78 70 | 72 65 73 73 69 6f 6e 20 |ular-exp|ression |
|00000660| 73 79 6e 74 61 78 20 6d | 69 67 68 74 20 72 65 71 |syntax m|ight req|
|00000670| 75 69 72 65 20 61 20 74 | 6f 74 61 6c 20 72 65 74 |uire a t|otal ret|
|00000680| 68 69 6e 6b 2e 0a 20 2a | 0a 20 2a 09 54 68 65 20 |hink.. *|. *.The |
|00000690| 74 68 69 72 64 20 70 61 | 72 61 6d 65 74 65 72 20 |third pa|rameter |
|000006a0| 74 6f 20 72 65 67 65 78 | 65 63 20 77 61 73 20 61 |to regex|ec was a|
|000006b0| 64 64 65 64 20 62 79 20 | 4d 61 72 74 69 6e 20 43 |dded by |Martin C|
|000006c0| 2e 20 41 74 6b 69 6e 73 | 2e 0a 20 2a 09 41 6e 64 |. Atkins|.. *.And|
|000006d0| 79 20 54 61 6e 65 6e 62 | 61 75 6d 20 61 6c 73 6f |y Tanenb|aum also|
|000006e0| 20 6d 61 64 65 20 73 6f | 6d 65 20 63 68 61 6e 67 | made so|me chang|
|000006f0| 65 73 2e 0a 20 2a 09 53 | 74 65 76 65 20 4b 69 72 |es.. *.S|teve Kir|
|00000700| 6b 65 6e 64 61 6c 6c 20 | 63 68 61 6e 67 65 64 20 |kendall |changed |
|00000710| 74 68 65 20 73 79 6e 74 | 61 78 20 61 6e 64 20 61 |the synt|ax and a|
|00000720| 64 64 65 64 20 6f 5f 6d | 61 67 69 63 2c 20 6f 5f |dded o_m|agic, o_|
|00000730| 69 67 6e 6f 72 65 63 61 | 73 65 0a 20 2a 2f 0a 0a |ignoreca|se. */..|
|00000740| 23 69 6e 63 6c 75 64 65 | 20 3c 63 74 79 70 65 2e |#include| <ctype.|
|00000750| 68 3e 0a 23 69 6e 63 6c | 75 64 65 20 22 63 6f 6e |h>.#incl|ude "con|
|00000760| 66 69 67 2e 68 22 0a 23 | 69 6e 63 6c 75 64 65 20 |fig.h".#|include |
|00000770| 22 76 69 2e 68 22 0a 23 | 69 6e 63 6c 75 64 65 20 |"vi.h".#|include |
|00000780| 22 72 65 67 65 78 70 2e | 68 22 0a 23 64 65 66 69 |"regexp.|h".#defi|
|00000790| 6e 65 20 4e 55 4c 4c 20 | 28 63 68 61 72 20 2a 29 |ne NULL |(char *)|
|000007a0| 30 0a 0a 65 78 74 65 72 | 6e 20 63 68 61 72 09 2a |0..exter|n char.*|
|000007b0| 75 73 74 72 63 68 72 28 | 29 3b 09 2f 2a 20 76 65 |ustrchr(|);./* ve|
|000007c0| 72 73 69 6f 6e 20 6f 66 | 20 73 74 72 63 68 72 20 |rsion of| strchr |
|000007d0| 77 68 69 63 68 20 75 73 | 65 73 20 6f 5f 69 67 6e |which us|es o_ign|
|000007e0| 6f 72 65 63 61 73 65 20 | 2a 2f 0a 65 78 74 65 72 |orecase |*/.exter|
|000007f0| 6e 20 69 6e 74 09 75 73 | 74 72 6e 63 6d 70 28 29 |n int.us|trncmp()|
|00000800| 3b 09 2f 2a 20 76 65 72 | 73 69 6f 6e 20 6f 66 20 |;./* ver|sion of |
|00000810| 73 74 72 63 6d 70 20 77 | 68 69 63 68 20 75 73 65 |strcmp w|hich use|
|00000820| 73 20 6f 5f 69 67 6e 6f | 72 65 63 61 73 65 20 2a |s o_igno|recase *|
|00000830| 2f 0a 0a 2f 2a 0a 20 2a | 20 54 68 65 20 66 69 72 |/../*. *| The fir|
|00000840| 73 74 20 62 79 74 65 20 | 6f 66 20 74 68 65 20 72 |st byte |of the r|
|00000850| 65 67 65 78 70 20 69 6e | 74 65 72 6e 61 6c 20 22 |egexp in|ternal "|
|00000860| 70 72 6f 67 72 61 6d 22 | 20 69 73 20 61 63 74 75 |program"| is actu|
|00000870| 61 6c 6c 79 20 74 68 69 | 73 20 6d 61 67 69 63 0a |ally thi|s magic.|
|00000880| 20 2a 20 6e 75 6d 62 65 | 72 3b 20 74 68 65 20 73 | * numbe|r; the s|
|00000890| 74 61 72 74 20 6e 6f 64 | 65 20 62 65 67 69 6e 73 |tart nod|e begins|
|000008a0| 20 69 6e 20 74 68 65 20 | 73 65 63 6f 6e 64 20 62 | in the |second b|
|000008b0| 79 74 65 2e 0a 20 2a 2f | 0a 23 64 65 66 69 6e 65 |yte.. */|.#define|
|000008c0| 09 4d 41 47 49 43 09 30 | 32 33 34 0a 0a 23 69 66 |.MAGIC.0|234..#if|
|000008d0| 64 65 66 20 4e 4f 5f 4d | 41 47 49 43 0a 23 20 69 |def NO_M|AGIC.# i|
|000008e0| 6e 63 6c 75 64 65 20 22 | 6e 6f 6d 61 67 69 63 2e |nclude "|nomagic.|
|000008f0| 63 22 0a 23 65 6c 73 65 | 0a 0a 2f 2a 0a 20 2a 20 |c".#else|../*. * |
|00000900| 54 68 65 20 22 69 6e 74 | 65 72 6e 61 6c 20 75 73 |The "int|ernal us|
|00000910| 65 20 6f 6e 6c 79 22 20 | 66 69 65 6c 64 73 20 69 |e only" |fields i|
|00000920| 6e 20 72 65 67 65 78 70 | 2e 68 20 61 72 65 20 70 |n regexp|.h are p|
|00000930| 72 65 73 65 6e 74 20 74 | 6f 20 70 61 73 73 20 69 |resent t|o pass i|
|00000940| 6e 66 6f 20 66 72 6f 6d | 0a 20 2a 20 63 6f 6d 70 |nfo from|. * comp|
|00000950| 69 6c 65 20 74 6f 20 65 | 78 65 63 75 74 65 20 74 |ile to e|xecute t|
|00000960| 68 61 74 20 70 65 72 6d | 69 74 73 20 74 68 65 20 |hat perm|its the |
|00000970| 65 78 65 63 75 74 65 20 | 70 68 61 73 65 20 74 6f |execute |phase to|
|00000980| 20 72 75 6e 20 6c 6f 74 | 73 20 66 61 73 74 65 72 | run lot|s faster|
|00000990| 20 6f 6e 0a 20 2a 20 73 | 69 6d 70 6c 65 20 63 61 | on. * s|imple ca|
|000009a0| 73 65 73 2e 20 20 54 68 | 65 79 20 61 72 65 3a 0a |ses. Th|ey are:.|
|000009b0| 20 2a 0a 20 2a 20 72 65 | 67 73 74 61 72 74 09 63 | *. * re|gstart.c|
|000009c0| 68 61 72 20 74 68 61 74 | 20 6d 75 73 74 20 62 65 |har that| must be|
|000009d0| 67 69 6e 20 61 20 6d 61 | 74 63 68 3b 20 27 5c 30 |gin a ma|tch; '\0|
|000009e0| 27 20 69 66 20 6e 6f 6e | 65 20 6f 62 76 69 6f 75 |' if non|e obviou|
|000009f0| 73 0a 20 2a 20 72 65 67 | 61 6e 63 68 09 69 73 20 |s. * reg|anch.is |
|00000a00| 74 68 65 20 6d 61 74 63 | 68 20 61 6e 63 68 6f 72 |the matc|h anchor|
|00000a10| 65 64 20 28 61 74 20 62 | 65 67 69 6e 6e 69 6e 67 |ed (at b|eginning|
|00000a20| 2d 6f 66 2d 6c 69 6e 65 | 20 6f 6e 6c 79 29 3f 0a |-of-line| only)?.|
|00000a30| 20 2a 20 72 65 67 6d 75 | 73 74 09 73 74 72 69 6e | * regmu|st.strin|
|00000a40| 67 20 28 70 6f 69 6e 74 | 65 72 20 69 6e 74 6f 20 |g (point|er into |
|00000a50| 70 72 6f 67 72 61 6d 29 | 20 74 68 61 74 20 6d 61 |program)| that ma|
|00000a60| 74 63 68 20 6d 75 73 74 | 20 69 6e 63 6c 75 64 65 |tch must| include|
|00000a70| 2c 20 6f 72 20 4e 55 4c | 4c 0a 20 2a 20 72 65 67 |, or NUL|L. * reg|
|00000a80| 6d 6c 65 6e 09 6c 65 6e | 67 74 68 20 6f 66 20 72 |mlen.len|gth of r|
|00000a90| 65 67 6d 75 73 74 20 73 | 74 72 69 6e 67 0a 20 2a |egmust s|tring. *|
|00000aa0| 0a 20 2a 20 52 65 67 73 | 74 61 72 74 20 61 6e 64 |. * Regs|tart and|
|00000ab0| 20 72 65 67 61 6e 63 68 | 20 70 65 72 6d 69 74 20 | reganch| permit |
|00000ac0| 76 65 72 79 20 66 61 73 | 74 20 64 65 63 69 73 69 |very fas|t decisi|
|00000ad0| 6f 6e 73 20 6f 6e 20 73 | 75 69 74 61 62 6c 65 20 |ons on s|uitable |
|00000ae0| 73 74 61 72 74 69 6e 67 | 20 70 6f 69 6e 74 73 0a |starting| points.|
|00000af0| 20 2a 20 66 6f 72 20 61 | 20 6d 61 74 63 68 2c 20 | * for a| match, |
|00000b00| 63 75 74 74 69 6e 67 20 | 64 6f 77 6e 20 74 68 65 |cutting |down the|
|00000b10| 20 77 6f 72 6b 20 61 20 | 6c 6f 74 2e 20 20 52 65 | work a |lot. Re|
|00000b20| 67 6d 75 73 74 20 70 65 | 72 6d 69 74 73 20 66 61 |gmust pe|rmits fa|
|00000b30| 73 74 20 72 65 6a 65 63 | 74 69 6f 6e 0a 20 2a 20 |st rejec|tion. * |
|00000b40| 6f 66 20 6c 69 6e 65 73 | 20 74 68 61 74 20 63 61 |of lines| that ca|
|00000b50| 6e 6e 6f 74 20 70 6f 73 | 73 69 62 6c 79 20 6d 61 |nnot pos|sibly ma|
|00000b60| 74 63 68 2e 20 20 54 68 | 65 20 72 65 67 6d 75 73 |tch. Th|e regmus|
|00000b70| 74 20 74 65 73 74 73 20 | 61 72 65 20 63 6f 73 74 |t tests |are cost|
|00000b80| 6c 79 20 65 6e 6f 75 67 | 68 0a 20 2a 20 74 68 61 |ly enoug|h. * tha|
|00000b90| 74 20 72 65 67 63 6f 6d | 70 28 29 20 73 75 70 70 |t regcom|p() supp|
|00000ba0| 6c 69 65 73 20 61 20 72 | 65 67 6d 75 73 74 20 6f |lies a r|egmust o|
|00000bb0| 6e 6c 79 20 69 66 20 74 | 68 65 20 72 2e 65 2e 20 |nly if t|he r.e. |
|00000bc0| 63 6f 6e 74 61 69 6e 73 | 20 73 6f 6d 65 74 68 69 |contains| somethi|
|00000bd0| 6e 67 0a 20 2a 20 70 6f | 74 65 6e 74 69 61 6c 6c |ng. * po|tentiall|
|00000be0| 79 20 65 78 70 65 6e 73 | 69 76 65 20 28 61 74 20 |y expens|ive (at |
|00000bf0| 70 72 65 73 65 6e 74 2c | 20 74 68 65 20 6f 6e 6c |present,| the onl|
|00000c00| 79 20 73 75 63 68 20 74 | 68 69 6e 67 20 64 65 74 |y such t|hing det|
|00000c10| 65 63 74 65 64 20 69 73 | 20 2a 20 6f 72 20 2b 0a |ected is| * or +.|
|00000c20| 20 2a 20 61 74 20 74 68 | 65 20 73 74 61 72 74 20 | * at th|e start |
|00000c30| 6f 66 20 74 68 65 20 72 | 2e 65 2e 2c 20 77 68 69 |of the r|.e., whi|
|00000c40| 63 68 20 63 61 6e 20 69 | 6e 76 6f 6c 76 65 20 61 |ch can i|nvolve a|
|00000c50| 20 6c 6f 74 20 6f 66 20 | 62 61 63 6b 75 70 29 2e | lot of |backup).|
|00000c60| 20 20 52 65 67 6d 6c 65 | 6e 20 69 73 0a 20 2a 20 | Regmle|n is. * |
|00000c70| 73 75 70 70 6c 69 65 64 | 20 62 65 63 61 75 73 65 |supplied| because|
|00000c80| 20 74 68 65 20 74 65 73 | 74 20 69 6e 20 72 65 67 | the tes|t in reg|
|00000c90| 65 78 65 63 28 29 20 6e | 65 65 64 73 20 69 74 20 |exec() n|eeds it |
|00000ca0| 61 6e 64 20 72 65 67 63 | 6f 6d 70 28 29 20 69 73 |and regc|omp() is|
|00000cb0| 20 63 6f 6d 70 75 74 69 | 6e 67 0a 20 2a 20 69 74 | computi|ng. * it|
|00000cc0| 20 61 6e 79 77 61 79 2e | 0a 20 2a 2f 0a 0a 2f 2a | anyway.|. */../*|
|00000cd0| 0a 20 2a 20 53 74 72 75 | 63 74 75 72 65 20 66 6f |. * Stru|cture fo|
|00000ce0| 72 20 72 65 67 65 78 70 | 20 22 70 72 6f 67 72 61 |r regexp| "progra|
|00000cf0| 6d 22 2e 20 20 54 68 69 | 73 20 69 73 20 65 73 73 |m". Thi|s is ess|
|00000d00| 65 6e 74 69 61 6c 6c 79 | 20 61 20 6c 69 6e 65 61 |entially| a linea|
|00000d10| 72 20 65 6e 63 6f 64 69 | 6e 67 0a 20 2a 20 6f 66 |r encodi|ng. * of|
|00000d20| 20 61 20 6e 6f 6e 64 65 | 74 65 72 6d 69 6e 69 73 | a nonde|terminis|
|00000d30| 74 69 63 20 66 69 6e 69 | 74 65 2d 73 74 61 74 65 |tic fini|te-state|
|00000d40| 20 6d 61 63 68 69 6e 65 | 20 28 61 6b 61 20 73 79 | machine| (aka sy|
|00000d50| 6e 74 61 78 20 63 68 61 | 72 74 73 20 6f 72 0a 20 |ntax cha|rts or. |
|00000d60| 2a 20 22 72 61 69 6c 72 | 6f 61 64 20 6e 6f 72 6d |* "railr|oad norm|
|00000d70| 61 6c 20 66 6f 72 6d 22 | 20 69 6e 20 70 61 72 73 |al form"| in pars|
|00000d80| 69 6e 67 20 74 65 63 68 | 6e 6f 6c 6f 67 79 29 2e |ing tech|nology).|
|00000d90| 20 20 45 61 63 68 20 6e | 6f 64 65 20 69 73 20 61 | Each n|ode is a|
|00000da0| 6e 20 6f 70 63 6f 64 65 | 0a 20 2a 20 70 6c 75 73 |n opcode|. * plus|
|00000db0| 20 61 20 22 6e 65 78 74 | 22 20 70 6f 69 6e 74 65 | a "next|" pointe|
|00000dc0| 72 2c 20 70 6f 73 73 69 | 62 6c 79 20 70 6c 75 73 |r, possi|bly plus|
|00000dd0| 20 61 6e 20 6f 70 65 72 | 61 6e 64 2e 20 20 22 4e | an oper|and. "N|
|00000de0| 65 78 74 22 20 70 6f 69 | 6e 74 65 72 73 20 6f 66 |ext" poi|nters of|
|00000df0| 0a 20 2a 20 61 6c 6c 20 | 6e 6f 64 65 73 20 65 78 |. * all |nodes ex|
|00000e00| 63 65 70 74 20 42 52 41 | 4e 43 48 20 69 6d 70 6c |cept BRA|NCH impl|
|00000e10| 65 6d 65 6e 74 20 63 6f | 6e 63 61 74 65 6e 61 74 |ement co|ncatenat|
|00000e20| 69 6f 6e 3b 20 61 20 22 | 6e 65 78 74 22 20 70 6f |ion; a "|next" po|
|00000e30| 69 6e 74 65 72 20 77 69 | 74 68 0a 20 2a 20 61 20 |inter wi|th. * a |
|00000e40| 42 52 41 4e 43 48 20 6f | 6e 20 62 6f 74 68 20 65 |BRANCH o|n both e|
|00000e50| 6e 64 73 20 6f 66 20 69 | 74 20 69 73 20 63 6f 6e |nds of i|t is con|
|00000e60| 6e 65 63 74 69 6e 67 20 | 74 77 6f 20 61 6c 74 65 |necting |two alte|
|00000e70| 72 6e 61 74 69 76 65 73 | 2e 20 20 28 48 65 72 65 |rnatives|. (Here|
|00000e80| 20 77 65 0a 20 2a 20 68 | 61 76 65 20 6f 6e 65 20 | we. * h|ave one |
|00000e90| 6f 66 20 74 68 65 20 73 | 75 62 74 6c 65 20 73 79 |of the s|ubtle sy|
|00000ea0| 6e 74 61 78 20 64 65 70 | 65 6e 64 65 6e 63 69 65 |ntax dep|endencie|
|00000eb0| 73 3a 20 20 61 6e 20 69 | 6e 64 69 76 69 64 75 61 |s: an i|ndividua|
|00000ec0| 6c 20 42 52 41 4e 43 48 | 20 28 61 73 0a 20 2a 20 |l BRANCH| (as. * |
|00000ed0| 6f 70 70 6f 73 65 64 20 | 74 6f 20 61 20 63 6f 6c |opposed |to a col|
|00000ee0| 6c 65 63 74 69 6f 6e 20 | 6f 66 20 74 68 65 6d 29 |lection |of them)|
|00000ef0| 20 69 73 20 6e 65 76 65 | 72 20 63 6f 6e 63 61 74 | is neve|r concat|
|00000f00| 65 6e 61 74 65 64 20 77 | 69 74 68 20 61 6e 79 74 |enated w|ith anyt|
|00000f10| 68 69 6e 67 0a 20 2a 20 | 62 65 63 61 75 73 65 20 |hing. * |because |
|00000f20| 6f 66 20 6f 70 65 72 61 | 74 6f 72 20 70 72 65 63 |of opera|tor prec|
|00000f30| 65 64 65 6e 63 65 2e 29 | 20 20 54 68 65 20 6f 70 |edence.)| The op|
|00000f40| 65 72 61 6e 64 20 6f 66 | 20 73 6f 6d 65 20 74 79 |erand of| some ty|
|00000f50| 70 65 73 20 6f 66 20 6e | 6f 64 65 20 69 73 0a 20 |pes of n|ode is. |
|00000f60| 2a 20 61 20 6c 69 74 65 | 72 61 6c 20 73 74 72 69 |* a lite|ral stri|
|00000f70| 6e 67 3b 20 66 6f 72 20 | 6f 74 68 65 72 73 2c 20 |ng; for |others, |
|00000f80| 69 74 20 69 73 20 61 20 | 6e 6f 64 65 20 6c 65 61 |it is a |node lea|
|00000f90| 64 69 6e 67 20 69 6e 74 | 6f 20 61 20 73 75 62 2d |ding int|o a sub-|
|00000fa0| 46 53 4d 2e 20 20 49 6e | 0a 20 2a 20 70 61 72 74 |FSM. In|. * part|
|00000fb0| 69 63 75 6c 61 72 2c 20 | 74 68 65 20 6f 70 65 72 |icular, |the oper|
|00000fc0| 61 6e 64 20 6f 66 20 61 | 20 42 52 41 4e 43 48 20 |and of a| BRANCH |
|00000fd0| 6e 6f 64 65 20 69 73 20 | 74 68 65 20 66 69 72 73 |node is |the firs|
|00000fe0| 74 20 6e 6f 64 65 20 6f | 66 20 74 68 65 20 62 72 |t node o|f the br|
|00000ff0| 61 6e 63 68 2e 0a 20 2a | 20 28 4e 42 20 74 68 69 |anch.. *| (NB thi|
|00001000| 73 20 69 73 20 2a 6e 6f | 74 2a 20 61 20 74 72 65 |s is *no|t* a tre|
|00001010| 65 20 73 74 72 75 63 74 | 75 72 65 3a 20 20 74 68 |e struct|ure: th|
|00001020| 65 20 74 61 69 6c 20 6f | 66 20 74 68 65 20 62 72 |e tail o|f the br|
|00001030| 61 6e 63 68 20 63 6f 6e | 6e 65 63 74 73 0a 20 2a |anch con|nects. *|
|00001040| 20 74 6f 20 74 68 65 20 | 74 68 69 6e 67 20 66 6f | to the |thing fo|
|00001050| 6c 6c 6f 77 69 6e 67 20 | 74 68 65 20 73 65 74 20 |llowing |the set |
|00001060| 6f 66 20 42 52 41 4e 43 | 48 65 73 2e 29 20 20 54 |of BRANC|Hes.) T|
|00001070| 68 65 20 6f 70 63 6f 64 | 65 73 20 61 72 65 3a 0a |he opcod|es are:.|
|00001080| 20 2a 2f 0a 0a 2f 2a 20 | 64 65 66 69 6e 69 74 69 | */../* |definiti|
|00001090| 6f 6e 09 6e 75 6d 62 65 | 72 09 6f 70 6e 64 3f 09 |on.numbe|r.opnd?.|
|000010a0| 6d 65 61 6e 69 6e 67 20 | 2a 2f 0a 23 64 65 66 69 |meaning |*/.#defi|
|000010b0| 6e 65 09 45 4e 44 09 30 | 09 2f 2a 20 6e 6f 09 45 |ne.END.0|./* no.E|
|000010c0| 6e 64 20 6f 66 20 70 72 | 6f 67 72 61 6d 2e 20 2a |nd of pr|ogram. *|
|000010d0| 2f 0a 23 64 65 66 69 6e | 65 09 42 4f 4c 09 31 09 |/.#defin|e.BOL.1.|
|000010e0| 2f 2a 20 6e 6f 09 4d 61 | 74 63 68 20 22 22 20 61 |/* no.Ma|tch "" a|
|000010f0| 74 20 62 65 67 69 6e 6e | 69 6e 67 20 6f 66 20 6c |t beginn|ing of l|
|00001100| 69 6e 65 2e 20 2a 2f 0a | 23 64 65 66 69 6e 65 09 |ine. */.|#define.|
|00001110| 45 4f 4c 09 32 09 2f 2a | 20 6e 6f 09 4d 61 74 63 |EOL.2./*| no.Matc|
|00001120| 68 20 22 22 20 61 74 20 | 65 6e 64 20 6f 66 20 6c |h "" at |end of l|
|00001130| 69 6e 65 2e 20 2a 2f 0a | 23 64 65 66 69 6e 65 09 |ine. */.|#define.|
|00001140| 41 4e 59 09 33 09 2f 2a | 20 6e 6f 09 4d 61 74 63 |ANY.3./*| no.Matc|
|00001150| 68 20 61 6e 79 20 6f 6e | 65 20 63 68 61 72 61 63 |h any on|e charac|
|00001160| 74 65 72 2e 20 2a 2f 0a | 23 64 65 66 69 6e 65 09 |ter. */.|#define.|
|00001170| 41 4e 59 4f 46 09 34 09 | 2f 2a 20 73 74 72 09 4d |ANYOF.4.|/* str.M|
|00001180| 61 74 63 68 20 61 6e 79 | 20 63 68 61 72 61 63 74 |atch any| charact|
|00001190| 65 72 20 69 6e 20 74 68 | 69 73 20 73 74 72 69 6e |er in th|is strin|
|000011a0| 67 2e 20 2a 2f 0a 23 64 | 65 66 69 6e 65 09 41 4e |g. */.#d|efine.AN|
|000011b0| 59 42 55 54 09 35 09 2f | 2a 20 73 74 72 09 4d 61 |YBUT.5./|* str.Ma|
|000011c0| 74 63 68 20 61 6e 79 20 | 63 68 61 72 61 63 74 65 |tch any |characte|
|000011d0| 72 20 6e 6f 74 20 69 6e | 20 74 68 69 73 20 73 74 |r not in| this st|
|000011e0| 72 69 6e 67 2e 20 2a 2f | 0a 23 64 65 66 69 6e 65 |ring. */|.#define|
|000011f0| 09 42 52 41 4e 43 48 09 | 36 09 2f 2a 20 6e 6f 64 |.BRANCH.|6./* nod|
|00001200| 65 09 4d 61 74 63 68 20 | 74 68 69 73 20 61 6c 74 |e.Match |this alt|
|00001210| 65 72 6e 61 74 69 76 65 | 2c 20 6f 72 20 74 68 65 |ernative|, or the|
|00001220| 20 6e 65 78 74 2e 2e 2e | 20 2a 2f 0a 23 64 65 66 | next...| */.#def|
|00001230| 69 6e 65 09 42 41 43 4b | 09 37 09 2f 2a 20 6e 6f |ine.BACK|.7./* no|
|00001240| 09 4d 61 74 63 68 20 22 | 22 2c 20 22 6e 65 78 74 |.Match "|", "next|
|00001250| 22 20 70 74 72 20 70 6f | 69 6e 74 73 20 62 61 63 |" ptr po|ints bac|
|00001260| 6b 77 61 72 64 2e 20 2a | 2f 0a 23 64 65 66 69 6e |kward. *|/.#defin|
|00001270| 65 09 45 58 41 43 54 4c | 59 09 38 09 2f 2a 20 73 |e.EXACTL|Y.8./* s|
|00001280| 74 72 09 4d 61 74 63 68 | 20 74 68 69 73 20 73 74 |tr.Match| this st|
|00001290| 72 69 6e 67 2e 20 2a 2f | 0a 23 64 65 66 69 6e 65 |ring. */|.#define|
|000012a0| 09 4e 4f 54 48 49 4e 47 | 09 39 09 2f 2a 20 6e 6f |.NOTHING|.9./* no|
|000012b0| 09 4d 61 74 63 68 20 65 | 6d 70 74 79 20 73 74 72 |.Match e|mpty str|
|000012c0| 69 6e 67 2e 20 2a 2f 0a | 23 64 65 66 69 6e 65 09 |ing. */.|#define.|
|000012d0| 53 54 41 52 09 31 30 09 | 2f 2a 20 6e 6f 64 65 09 |STAR.10.|/* node.|
|000012e0| 4d 61 74 63 68 20 74 68 | 69 73 20 28 73 69 6d 70 |Match th|is (simp|
|000012f0| 6c 65 29 20 74 68 69 6e | 67 20 30 20 6f 72 20 6d |le) thin|g 0 or m|
|00001300| 6f 72 65 20 74 69 6d 65 | 73 2e 20 2a 2f 0a 23 64 |ore time|s. */.#d|
|00001310| 65 66 69 6e 65 09 50 4c | 55 53 09 31 31 09 2f 2a |efine.PL|US.11./*|
|00001320| 20 6e 6f 64 65 09 4d 61 | 74 63 68 20 74 68 69 73 | node.Ma|tch this|
|00001330| 20 28 73 69 6d 70 6c 65 | 29 20 74 68 69 6e 67 20 | (simple|) thing |
|00001340| 31 20 6f 72 20 6d 6f 72 | 65 20 74 69 6d 65 73 2e |1 or mor|e times.|
|00001350| 20 2a 2f 0a 23 64 65 66 | 69 6e 65 20 42 4f 57 09 | */.#def|ine BOW.|
|00001360| 31 32 09 2f 2a 20 6e 6f | 09 4d 61 74 63 68 20 22 |12./* no|.Match "|
|00001370| 22 20 61 74 20 66 72 6f | 6e 74 20 6f 66 20 77 6f |" at fro|nt of wo|
|00001380| 72 64 20 2a 2f 0a 23 64 | 65 66 69 6e 65 20 45 4f |rd */.#d|efine EO|
|00001390| 57 09 31 33 09 2f 2a 20 | 6e 6f 09 4d 61 74 63 68 |W.13./* |no.Match|
|000013a0| 20 22 22 20 61 74 20 72 | 65 61 72 20 6f 66 20 77 | "" at r|ear of w|
|000013b0| 6f 72 64 20 2a 2f 0a 23 | 64 65 66 69 6e 65 09 4f |ord */.#|define.O|
|000013c0| 50 45 4e 09 32 30 09 2f | 2a 20 6e 6f 09 4d 61 72 |PEN.20./|* no.Mar|
|000013d0| 6b 20 74 68 69 73 20 70 | 6f 69 6e 74 20 69 6e 20 |k this p|oint in |
|000013e0| 69 6e 70 75 74 20 61 73 | 20 73 74 61 72 74 20 6f |input as| start o|
|000013f0| 66 20 23 6e 2e 20 2a 2f | 0a 09 09 2f 2a 09 4f 50 |f #n. */|.../*.OP|
|00001400| 45 4e 2b 31 20 69 73 20 | 6e 75 6d 62 65 72 20 31 |EN+1 is |number 1|
|00001410| 2c 20 65 74 63 2e 20 2a | 2f 0a 23 64 65 66 69 6e |, etc. *|/.#defin|
|00001420| 65 09 43 4c 4f 53 45 09 | 33 30 09 2f 2a 20 6e 6f |e.CLOSE.|30./* no|
|00001430| 09 41 6e 61 6c 6f 67 6f | 75 73 20 74 6f 20 4f 50 |.Analogo|us to OP|
|00001440| 45 4e 2e 20 2a 2f 0a 0a | 2f 2a 0a 20 2a 20 4f 70 |EN. */..|/*. * Op|
|00001450| 63 6f 64 65 20 6e 6f 74 | 65 73 3a 0a 20 2a 0a 20 |code not|es:. *. |
|00001460| 2a 20 42 52 41 4e 43 48 | 09 54 68 65 20 73 65 74 |* BRANCH|.The set|
|00001470| 20 6f 66 20 62 72 61 6e | 63 68 65 73 20 63 6f 6e | of bran|ches con|
|00001480| 73 74 69 74 75 74 69 6e | 67 20 61 20 73 69 6e 67 |stitutin|g a sing|
|00001490| 6c 65 20 63 68 6f 69 63 | 65 20 61 72 65 20 68 6f |le choic|e are ho|
|000014a0| 6f 6b 65 64 0a 20 2a 09 | 09 74 6f 67 65 74 68 65 |oked. *.|.togethe|
|000014b0| 72 20 77 69 74 68 20 74 | 68 65 69 72 20 22 6e 65 |r with t|heir "ne|
|000014c0| 78 74 22 20 70 6f 69 6e | 74 65 72 73 2c 20 73 69 |xt" poin|ters, si|
|000014d0| 6e 63 65 20 70 72 65 63 | 65 64 65 6e 63 65 20 70 |nce prec|edence p|
|000014e0| 72 65 76 65 6e 74 73 0a | 20 2a 09 09 61 6e 79 74 |revents.| *..anyt|
|000014f0| 68 69 6e 67 20 62 65 69 | 6e 67 20 63 6f 6e 63 61 |hing bei|ng conca|
|00001500| 74 65 6e 61 74 65 64 20 | 74 6f 20 61 6e 79 20 69 |tenated |to any i|
|00001510| 6e 64 69 76 69 64 75 61 | 6c 20 62 72 61 6e 63 68 |ndividua|l branch|
|00001520| 2e 20 20 54 68 65 0a 20 | 2a 09 09 22 6e 65 78 74 |. The. |*.."next|
|00001530| 22 20 70 6f 69 6e 74 65 | 72 20 6f 66 20 74 68 65 |" pointe|r of the|
|00001540| 20 6c 61 73 74 20 42 52 | 41 4e 43 48 20 69 6e 20 | last BR|ANCH in |
|00001550| 61 20 63 68 6f 69 63 65 | 20 70 6f 69 6e 74 73 20 |a choice| points |
|00001560| 74 6f 20 74 68 65 0a 20 | 2a 09 09 74 68 69 6e 67 |to the. |*..thing|
|00001570| 20 66 6f 6c 6c 6f 77 69 | 6e 67 20 74 68 65 20 77 | followi|ng the w|
|00001580| 68 6f 6c 65 20 63 68 6f | 69 63 65 2e 20 20 54 68 |hole cho|ice. Th|
|00001590| 69 73 20 69 73 20 61 6c | 73 6f 20 77 68 65 72 65 |is is al|so where|
|000015a0| 20 74 68 65 0a 20 2a 09 | 09 66 69 6e 61 6c 20 22 | the. *.|.final "|
|000015b0| 6e 65 78 74 22 20 70 6f | 69 6e 74 65 72 20 6f 66 |next" po|inter of|
|000015c0| 20 65 61 63 68 20 69 6e | 64 69 76 69 64 75 61 6c | each in|dividual|
|000015d0| 20 62 72 61 6e 63 68 20 | 70 6f 69 6e 74 73 3b 20 | branch |points; |
|000015e0| 65 61 63 68 0a 20 2a 09 | 09 62 72 61 6e 63 68 20 |each. *.|.branch |
|000015f0| 73 74 61 72 74 73 20 77 | 69 74 68 20 74 68 65 20 |starts w|ith the |
|00001600| 6f 70 65 72 61 6e 64 20 | 6e 6f 64 65 20 6f 66 20 |operand |node of |
|00001610| 61 20 42 52 41 4e 43 48 | 20 6e 6f 64 65 2e 0a 20 |a BRANCH| node.. |
|00001620| 2a 0a 20 2a 20 42 41 43 | 4b 09 09 4e 6f 72 6d 61 |*. * BAC|K..Norma|
|00001630| 6c 20 22 6e 65 78 74 22 | 20 70 6f 69 6e 74 65 72 |l "next"| pointer|
|00001640| 73 20 61 6c 6c 20 69 6d | 70 6c 69 63 69 74 6c 79 |s all im|plicitly|
|00001650| 20 70 6f 69 6e 74 20 66 | 6f 72 77 61 72 64 3b 20 | point f|orward; |
|00001660| 42 41 43 4b 0a 20 2a 09 | 09 65 78 69 73 74 73 20 |BACK. *.|.exists |
|00001670| 74 6f 20 6d 61 6b 65 20 | 6c 6f 6f 70 20 73 74 72 |to make |loop str|
|00001680| 75 63 74 75 72 65 73 20 | 70 6f 73 73 69 62 6c 65 |uctures |possible|
|00001690| 2e 0a 20 2a 0a 20 2a 20 | 53 54 41 52 2c 50 4c 55 |.. *. * |STAR,PLU|
|000016a0| 53 09 27 3f 27 2c 20 61 | 6e 64 20 63 6f 6d 70 6c |S.'?', a|nd compl|
|000016b0| 65 78 20 27 2a 27 20 61 | 6e 64 20 27 2b 27 2c 20 |ex '*' a|nd '+', |
|000016c0| 61 72 65 20 69 6d 70 6c | 65 6d 65 6e 74 65 64 20 |are impl|emented |
|000016d0| 61 73 20 63 69 72 63 75 | 6c 61 72 0a 20 2a 09 09 |as circu|lar. *..|
|000016e0| 42 52 41 4e 43 48 20 73 | 74 72 75 63 74 75 72 65 |BRANCH s|tructure|
|000016f0| 73 20 75 73 69 6e 67 20 | 42 41 43 4b 2e 20 20 53 |s using |BACK. S|
|00001700| 69 6d 70 6c 65 20 63 61 | 73 65 73 20 28 6f 6e 65 |imple ca|ses (one|
|00001710| 20 63 68 61 72 61 63 74 | 65 72 0a 20 2a 09 09 70 | charact|er. *..p|
|00001720| 65 72 20 6d 61 74 63 68 | 29 20 61 72 65 20 69 6d |er match|) are im|
|00001730| 70 6c 65 6d 65 6e 74 65 | 64 20 77 69 74 68 20 53 |plemente|d with S|
|00001740| 54 41 52 20 61 6e 64 20 | 50 4c 55 53 20 66 6f 72 |TAR and |PLUS for|
|00001750| 20 73 70 65 65 64 0a 20 | 2a 09 09 61 6e 64 20 74 | speed. |*..and t|
|00001760| 6f 20 6d 69 6e 69 6d 69 | 7a 65 20 72 65 63 75 72 |o minimi|ze recur|
|00001770| 73 69 76 65 20 70 6c 75 | 6e 67 65 73 2e 0a 20 2a |sive plu|nges.. *|
|00001780| 0a 20 2a 20 4f 50 45 4e | 2c 43 4c 4f 53 45 09 2e |. * OPEN|,CLOSE..|
|00001790| 2e 2e 61 72 65 20 6e 75 | 6d 62 65 72 65 64 20 61 |..are nu|mbered a|
|000017a0| 74 20 63 6f 6d 70 69 6c | 65 20 74 69 6d 65 2e 0a |t compil|e time..|
|000017b0| 20 2a 2f 0a 0a 2f 2a 0a | 20 2a 20 41 20 6e 6f 64 | */../*.| * A nod|
|000017c0| 65 20 69 73 20 6f 6e 65 | 20 63 68 61 72 20 6f 66 |e is one| char of|
|000017d0| 20 6f 70 63 6f 64 65 20 | 66 6f 6c 6c 6f 77 65 64 | opcode |followed|
|000017e0| 20 62 79 20 74 77 6f 20 | 63 68 61 72 73 20 6f 66 | by two |chars of|
|000017f0| 20 22 6e 65 78 74 22 20 | 70 6f 69 6e 74 65 72 2e | "next" |pointer.|
|00001800| 0a 20 2a 20 22 4e 65 78 | 74 22 20 70 6f 69 6e 74 |. * "Nex|t" point|
|00001810| 65 72 73 20 61 72 65 20 | 73 74 6f 72 65 64 20 61 |ers are |stored a|
|00001820| 73 20 74 77 6f 20 38 2d | 62 69 74 20 70 69 65 63 |s two 8-|bit piec|
|00001830| 65 73 2c 20 68 69 67 68 | 20 6f 72 64 65 72 20 66 |es, high| order f|
|00001840| 69 72 73 74 2e 20 20 54 | 68 65 0a 20 2a 20 76 61 |irst. T|he. * va|
|00001850| 6c 75 65 20 69 73 20 61 | 20 70 6f 73 69 74 69 76 |lue is a| positiv|
|00001860| 65 20 6f 66 66 73 65 74 | 20 66 72 6f 6d 20 74 68 |e offset| from th|
|00001870| 65 20 6f 70 63 6f 64 65 | 20 6f 66 20 74 68 65 20 |e opcode| of the |
|00001880| 6e 6f 64 65 20 63 6f 6e | 74 61 69 6e 69 6e 67 20 |node con|taining |
|00001890| 69 74 2e 0a 20 2a 20 41 | 6e 20 6f 70 65 72 61 6e |it.. * A|n operan|
|000018a0| 64 2c 20 69 66 20 61 6e | 79 2c 20 73 69 6d 70 6c |d, if an|y, simpl|
|000018b0| 79 20 66 6f 6c 6c 6f 77 | 73 20 74 68 65 20 6e 6f |y follow|s the no|
|000018c0| 64 65 2e 20 20 28 4e 6f | 74 65 20 74 68 61 74 20 |de. (No|te that |
|000018d0| 6d 75 63 68 20 6f 66 20 | 74 68 65 0a 20 2a 20 63 |much of |the. * c|
|000018e0| 6f 64 65 20 67 65 6e 65 | 72 61 74 69 6f 6e 20 6b |ode gene|ration k|
|000018f0| 6e 6f 77 73 20 61 62 6f | 75 74 20 74 68 69 73 20 |nows abo|ut this |
|00001900| 69 6d 70 6c 69 63 69 74 | 20 72 65 6c 61 74 69 6f |implicit| relatio|
|00001910| 6e 73 68 69 70 2e 29 0a | 20 2a 0a 20 2a 20 55 73 |nship.).| *. * Us|
|00001920| 69 6e 67 20 74 77 6f 20 | 62 79 74 65 73 20 66 6f |ing two |bytes fo|
|00001930| 72 20 74 68 65 20 22 6e | 65 78 74 22 20 70 6f 69 |r the "n|ext" poi|
|00001940| 6e 74 65 72 20 69 73 20 | 76 61 73 74 20 6f 76 65 |nter is |vast ove|
|00001950| 72 6b 69 6c 6c 20 66 6f | 72 20 6d 6f 73 74 20 74 |rkill fo|r most t|
|00001960| 68 69 6e 67 73 2c 0a 20 | 2a 20 62 75 74 20 61 6c |hings,. |* but al|
|00001970| 6c 6f 77 73 20 70 61 74 | 74 65 72 6e 73 20 74 6f |lows pat|terns to|
|00001980| 20 67 65 74 20 62 69 67 | 20 77 69 74 68 6f 75 74 | get big| without|
|00001990| 20 64 69 73 61 73 74 65 | 72 73 2e 0a 20 2a 2f 0a | disaste|rs.. */.|
|000019a0| 23 64 65 66 69 6e 65 09 | 4f 50 28 70 29 09 28 2a |#define.|OP(p).(*|
|000019b0| 28 70 29 29 0a 23 64 65 | 66 69 6e 65 09 4e 45 58 |(p)).#de|fine.NEX|
|000019c0| 54 28 70 29 09 28 28 28 | 2a 28 28 70 29 2b 31 29 |T(p).(((|*((p)+1)|
|000019d0| 26 30 33 37 37 29 3c 3c | 38 29 20 2b 20 28 2a 28 |&0377)<<|8) + (*(|
|000019e0| 28 70 29 2b 32 29 26 30 | 33 37 37 29 29 0a 23 64 |(p)+2)&0|377)).#d|
|000019f0| 65 66 69 6e 65 09 4f 50 | 45 52 41 4e 44 28 70 29 |efine.OP|ERAND(p)|
|00001a00| 09 28 28 70 29 20 2b 20 | 33 29 0a 0a 0a 0a 2f 2a |.((p) + |3)..../*|
|00001a10| 0a 20 2a 20 55 74 69 6c | 69 74 79 20 64 65 66 69 |. * Util|ity defi|
|00001a20| 6e 69 74 69 6f 6e 73 2e | 0a 20 2a 2f 0a 23 64 65 |nitions.|. */.#de|
|00001a30| 66 69 6e 65 09 55 43 48 | 41 52 41 54 28 70 29 09 |fine.UCH|ARAT(p).|
|00001a40| 55 43 48 41 52 28 2a 70 | 29 0a 0a 23 64 65 66 69 |UCHAR(*p|)..#defi|
|00001a50| 6e 65 09 46 41 49 4c 28 | 6d 29 09 7b 20 72 65 67 |ne.FAIL(|m).{ reg|
|00001a60| 65 72 72 6f 72 28 6d 29 | 3b 20 72 65 74 75 72 6e |error(m)|; return|
|00001a70| 20 30 3b 20 7d 0a 23 64 | 65 66 69 6e 65 09 49 53 | 0; }.#d|efine.IS|
|00001a80| 4d 55 4c 54 28 63 29 09 | 28 28 63 29 20 3d 3d 20 |MULT(c).|((c) == |
|00001a90| 27 2a 27 20 7c 7c 20 28 | 63 29 20 3d 3d 20 27 2b |'*' || (|c) == '+|
|00001aa0| 27 20 7c 7c 20 28 63 29 | 20 3d 3d 20 27 3f 27 29 |' || (c)| == '?')|
|00001ab0| 0a 23 64 65 66 69 6e 65 | 09 4d 45 54 41 09 22 5e |.#define|.META."^|
|00001ac0| 24 2e 5b 28 29 7c 3f 2b | 2a 5c 5c 22 0a 0a 2f 2a |$.[()|?+|*\\"../*|
|00001ad0| 0a 20 2a 20 46 6c 61 67 | 73 20 74 6f 20 62 65 20 |. * Flag|s to be |
|00001ae0| 70 61 73 73 65 64 20 75 | 70 20 61 6e 64 20 64 6f |passed u|p and do|
|00001af0| 77 6e 2e 0a 20 2a 2f 0a | 23 64 65 66 69 6e 65 09 |wn.. */.|#define.|
|00001b00| 48 41 53 57 49 44 54 48 | 09 30 31 09 2f 2a 20 4b |HASWIDTH|.01./* K|
|00001b10| 6e 6f 77 6e 20 6e 65 76 | 65 72 20 74 6f 20 6d 61 |nown nev|er to ma|
|00001b20| 74 63 68 20 6e 75 6c 6c | 20 73 74 72 69 6e 67 2e |tch null| string.|
|00001b30| 20 2a 2f 0a 23 64 65 66 | 69 6e 65 09 53 49 4d 50 | */.#def|ine.SIMP|
|00001b40| 4c 45 09 09 30 32 09 2f | 2a 20 53 69 6d 70 6c 65 |LE..02./|* Simple|
|00001b50| 20 65 6e 6f 75 67 68 20 | 74 6f 20 62 65 20 53 54 | enough |to be ST|
|00001b60| 41 52 2f 50 4c 55 53 20 | 6f 70 65 72 61 6e 64 2e |AR/PLUS |operand.|
|00001b70| 20 2a 2f 0a 23 64 65 66 | 69 6e 65 09 53 50 53 54 | */.#def|ine.SPST|
|00001b80| 41 52 54 09 09 30 34 09 | 2f 2a 20 53 74 61 72 74 |ART..04.|/* Start|
|00001b90| 73 20 77 69 74 68 20 2a | 20 6f 72 20 2b 2e 20 2a |s with *| or +. *|
|00001ba0| 2f 0a 23 64 65 66 69 6e | 65 09 57 4f 52 53 54 09 |/.#defin|e.WORST.|
|00001bb0| 09 30 09 2f 2a 20 57 6f | 72 73 74 20 63 61 73 65 |.0./* Wo|rst case|
|00001bc0| 2e 20 2a 2f 0a 0a 2f 2a | 0a 20 2a 20 47 6c 6f 62 |. */../*|. * Glob|
|00001bd0| 61 6c 20 77 6f 72 6b 20 | 76 61 72 69 61 62 6c 65 |al work |variable|
|00001be0| 73 20 66 6f 72 20 72 65 | 67 63 6f 6d 70 28 29 2e |s for re|gcomp().|
|00001bf0| 0a 20 2a 2f 0a 73 74 61 | 74 69 63 20 63 68 61 72 |. */.sta|tic char|
|00001c00| 20 2a 72 65 67 73 74 72 | 3b 09 09 2f 2a 20 74 68 | *regstr|;../* th|
|00001c10| 65 20 52 45 20 62 65 69 | 6e 67 20 63 6f 6d 70 69 |e RE bei|ng compi|
|00001c20| 6c 65 64 20 2a 2f 0a 73 | 74 61 74 69 63 20 63 68 |led */.s|tatic ch|
|00001c30| 61 72 20 2a 72 65 67 70 | 61 72 73 65 3b 09 09 2f |ar *regp|arse;../|
|00001c40| 2a 20 49 6e 70 75 74 2d | 73 63 61 6e 20 70 6f 69 |* Input-|scan poi|
|00001c50| 6e 74 65 72 2e 20 2a 2f | 0a 73 74 61 74 69 63 20 |nter. */|.static |
|00001c60| 69 6e 74 20 72 65 67 6e | 70 61 72 3b 09 09 2f 2a |int regn|par;../*|
|00001c70| 20 28 29 20 63 6f 75 6e | 74 2e 20 2a 2f 0a 73 74 | () coun|t. */.st|
|00001c80| 61 74 69 63 20 63 68 61 | 72 20 72 65 67 64 75 6d |atic cha|r regdum|
|00001c90| 6d 79 3b 0a 73 74 61 74 | 69 63 20 63 68 61 72 20 |my;.stat|ic char |
|00001ca0| 2a 72 65 67 63 6f 64 65 | 3b 09 09 2f 2a 20 43 6f |*regcode|;../* Co|
|00001cb0| 64 65 2d 65 6d 69 74 20 | 70 6f 69 6e 74 65 72 3b |de-emit |pointer;|
|00001cc0| 20 26 72 65 67 64 75 6d | 6d 79 20 3d 20 64 6f 6e | ®dum|my = don|
|00001cd0| 27 74 2e 20 2a 2f 0a 73 | 74 61 74 69 63 20 6c 6f |'t. */.s|tatic lo|
|00001ce0| 6e 67 20 72 65 67 73 69 | 7a 65 3b 09 09 2f 2a 20 |ng regsi|ze;../* |
|00001cf0| 43 6f 64 65 20 73 69 7a | 65 2e 20 2a 2f 0a 0a 2f |Code siz|e. */../|
|00001d00| 2a 0a 20 2a 20 46 6f 72 | 77 61 72 64 20 64 65 63 |*. * For|ward dec|
|00001d10| 6c 61 72 61 74 69 6f 6e | 73 20 66 6f 72 20 72 65 |laration|s for re|
|00001d20| 67 63 6f 6d 70 28 29 27 | 73 20 66 72 69 65 6e 64 |gcomp()'|s friend|
|00001d30| 73 2e 0a 20 2a 2f 0a 23 | 69 66 6e 64 65 66 20 53 |s.. */.#|ifndef S|
|00001d40| 54 41 54 49 43 0a 23 64 | 65 66 69 6e 65 09 53 54 |TATIC.#d|efine.ST|
|00001d50| 41 54 49 43 09 73 74 61 | 74 69 63 0a 23 65 6e 64 |ATIC.sta|tic.#end|
|00001d60| 69 66 0a 53 54 41 54 49 | 43 20 63 68 61 72 20 2a |if.STATI|C char *|
|00001d70| 72 65 67 28 29 3b 0a 53 | 54 41 54 49 43 20 63 68 |reg();.S|TATIC ch|
|00001d80| 61 72 20 2a 72 65 67 62 | 72 61 6e 63 68 28 29 3b |ar *regb|ranch();|
|00001d90| 0a 53 54 41 54 49 43 20 | 63 68 61 72 20 2a 72 65 |.STATIC |char *re|
|00001da0| 67 70 69 65 63 65 28 29 | 3b 0a 53 54 41 54 49 43 |gpiece()|;.STATIC|
|00001db0| 20 63 68 61 72 20 2a 72 | 65 67 61 74 6f 6d 28 29 | char *r|egatom()|
|00001dc0| 3b 0a 53 54 41 54 49 43 | 20 63 68 61 72 20 2a 72 |;.STATIC| char *r|
|00001dd0| 65 67 6e 6f 64 65 28 29 | 3b 0a 53 54 41 54 49 43 |egnode()|;.STATIC|
|00001de0| 20 63 68 61 72 20 2a 72 | 65 67 6e 65 78 74 28 29 | char *r|egnext()|
|00001df0| 3b 0a 53 54 41 54 49 43 | 20 76 6f 69 64 20 72 65 |;.STATIC| void re|
|00001e00| 67 63 28 29 3b 0a 53 54 | 41 54 49 43 20 76 6f 69 |gc();.ST|ATIC voi|
|00001e10| 64 20 72 65 67 69 6e 73 | 65 72 74 28 29 3b 0a 53 |d regins|ert();.S|
|00001e20| 54 41 54 49 43 20 76 6f | 69 64 20 72 65 67 74 61 |TATIC vo|id regta|
|00001e30| 69 6c 28 29 3b 0a 53 54 | 41 54 49 43 20 76 6f 69 |il();.ST|ATIC voi|
|00001e40| 64 20 72 65 67 6f 70 74 | 61 69 6c 28 29 3b 0a 0a |d regopt|ail();..|
|00001e50| 2f 2a 0a 20 2d 20 72 65 | 67 63 6f 6d 70 20 2d 20 |/*. - re|gcomp - |
|00001e60| 63 6f 6d 70 69 6c 65 20 | 61 20 72 65 67 75 6c 61 |compile |a regula|
|00001e70| 72 20 65 78 70 72 65 73 | 73 69 6f 6e 20 69 6e 74 |r expres|sion int|
|00001e80| 6f 20 69 6e 74 65 72 6e | 61 6c 20 63 6f 64 65 0a |o intern|al code.|
|00001e90| 20 2a 0a 20 2a 20 57 65 | 20 63 61 6e 27 74 20 61 | *. * We| can't a|
|00001ea0| 6c 6c 6f 63 61 74 65 20 | 73 70 61 63 65 20 75 6e |llocate |space un|
|00001eb0| 74 69 6c 20 77 65 20 6b | 6e 6f 77 20 68 6f 77 20 |til we k|now how |
|00001ec0| 62 69 67 20 74 68 65 20 | 63 6f 6d 70 69 6c 65 64 |big the |compiled|
|00001ed0| 20 66 6f 72 6d 20 77 69 | 6c 6c 20 62 65 2c 0a 20 | form wi|ll be,. |
|00001ee0| 2a 20 62 75 74 20 77 65 | 20 63 61 6e 27 74 20 63 |* but we| can't c|
|00001ef0| 6f 6d 70 69 6c 65 20 69 | 74 20 28 61 6e 64 20 74 |ompile i|t (and t|
|00001f00| 68 75 73 20 6b 6e 6f 77 | 20 68 6f 77 20 62 69 67 |hus know| how big|
|00001f10| 20 69 74 20 69 73 29 20 | 75 6e 74 69 6c 20 77 65 | it is) |until we|
|00001f20| 27 76 65 20 67 6f 74 20 | 61 0a 20 2a 20 70 6c 61 |'ve got |a. * pla|
|00001f30| 63 65 20 74 6f 20 70 75 | 74 20 74 68 65 20 63 6f |ce to pu|t the co|
|00001f40| 64 65 2e 20 20 53 6f 20 | 77 65 20 63 68 65 61 74 |de. So |we cheat|
|00001f50| 3a 20 20 77 65 20 63 6f | 6d 70 69 6c 65 20 69 74 |: we co|mpile it|
|00001f60| 20 74 77 69 63 65 2c 20 | 6f 6e 63 65 20 77 69 74 | twice, |once wit|
|00001f70| 68 20 63 6f 64 65 0a 20 | 2a 20 67 65 6e 65 72 61 |h code. |* genera|
|00001f80| 74 69 6f 6e 20 74 75 72 | 6e 65 64 20 6f 66 66 20 |tion tur|ned off |
|00001f90| 61 6e 64 20 73 69 7a 65 | 20 63 6f 75 6e 74 69 6e |and size| countin|
|00001fa0| 67 20 74 75 72 6e 65 64 | 20 6f 6e 2c 20 61 6e 64 |g turned| on, and|
|00001fb0| 20 6f 6e 63 65 20 22 66 | 6f 72 20 72 65 61 6c 22 | once "f|or real"|
|00001fc0| 2e 0a 20 2a 20 54 68 69 | 73 20 61 6c 73 6f 20 6d |.. * Thi|s also m|
|00001fd0| 65 61 6e 73 20 74 68 61 | 74 20 77 65 20 64 6f 6e |eans tha|t we don|
|00001fe0| 27 74 20 61 6c 6c 6f 63 | 61 74 65 20 73 70 61 63 |'t alloc|ate spac|
|00001ff0| 65 20 75 6e 74 69 6c 20 | 77 65 20 61 72 65 20 73 |e until |we are s|
|00002000| 75 72 65 20 74 68 61 74 | 20 74 68 65 0a 20 2a 20 |ure that| the. * |
|00002010| 74 68 69 6e 67 20 72 65 | 61 6c 6c 79 20 77 69 6c |thing re|ally wil|
|00002020| 6c 20 63 6f 6d 70 69 6c | 65 20 73 75 63 63 65 73 |l compil|e succes|
|00002030| 73 66 75 6c 6c 79 2c 20 | 61 6e 64 20 77 65 20 6e |sfully, |and we n|
|00002040| 65 76 65 72 20 68 61 76 | 65 20 74 6f 20 6d 6f 76 |ever hav|e to mov|
|00002050| 65 20 74 68 65 0a 20 2a | 20 63 6f 64 65 20 61 6e |e the. *| code an|
|00002060| 64 20 74 68 75 73 20 69 | 6e 76 61 6c 69 64 61 74 |d thus i|nvalidat|
|00002070| 65 20 70 6f 69 6e 74 65 | 72 73 20 69 6e 74 6f 20 |e pointe|rs into |
|00002080| 69 74 2e 20 20 28 4e 6f | 74 65 20 74 68 61 74 20 |it. (No|te that |
|00002090| 69 74 20 68 61 73 20 74 | 6f 20 62 65 20 69 6e 0a |it has t|o be in.|
|000020a0| 20 2a 20 6f 6e 65 20 70 | 69 65 63 65 20 62 65 63 | * one p|iece bec|
|000020b0| 61 75 73 65 20 66 72 65 | 65 28 29 20 6d 75 73 74 |ause fre|e() must|
|000020c0| 20 62 65 20 61 62 6c 65 | 20 74 6f 20 66 72 65 65 | be able| to free|
|000020d0| 20 69 74 20 61 6c 6c 2e | 29 0a 20 2a 0a 20 2a 20 | it all.|). *. * |
|000020e0| 42 65 77 61 72 65 20 74 | 68 61 74 20 74 68 65 20 |Beware t|hat the |
|000020f0| 6f 70 74 69 6d 69 7a 61 | 74 69 6f 6e 2d 70 72 65 |optimiza|tion-pre|
|00002100| 70 61 72 61 74 69 6f 6e | 20 63 6f 64 65 20 69 6e |paration| code in|
|00002110| 20 68 65 72 65 20 6b 6e | 6f 77 73 20 61 62 6f 75 | here kn|ows abou|
|00002120| 74 20 73 6f 6d 65 0a 20 | 2a 20 6f 66 20 74 68 65 |t some. |* of the|
|00002130| 20 73 74 72 75 63 74 75 | 72 65 20 6f 66 20 74 68 | structu|re of th|
|00002140| 65 20 63 6f 6d 70 69 6c | 65 64 20 72 65 67 65 78 |e compil|ed regex|
|00002150| 70 2e 0a 20 2a 2f 0a 72 | 65 67 65 78 70 20 2a 0a |p.. */.r|egexp *.|
|00002160| 72 65 67 63 6f 6d 70 28 | 65 78 70 29 0a 63 68 61 |regcomp(|exp).cha|
|00002170| 72 20 2a 65 78 70 3b 0a | 7b 0a 20 20 72 65 67 69 |r *exp;.|{. regi|
|00002180| 73 74 65 72 20 72 65 67 | 65 78 70 20 2a 72 3b 0a |ster reg|exp *r;.|
|00002190| 20 20 72 65 67 69 73 74 | 65 72 20 63 68 61 72 20 | regist|er char |
|000021a0| 2a 73 63 61 6e 3b 0a 20 | 20 72 65 67 69 73 74 65 |*scan;. | registe|
|000021b0| 72 20 63 68 61 72 20 2a | 6c 6f 6e 67 65 73 74 3b |r char *|longest;|
|000021c0| 0a 20 20 72 65 67 69 73 | 74 65 72 20 69 6e 74 20 |. regis|ter int |
|000021d0| 6c 65 6e 3b 0a 20 20 69 | 6e 74 20 66 6c 61 67 73 |len;. i|nt flags|
|000021e0| 3b 0a 0a 20 20 69 66 20 | 28 65 78 70 20 3d 3d 20 |;.. if |(exp == |
|000021f0| 4e 55 4c 4c 29 0a 09 46 | 41 49 4c 28 22 4e 55 4c |NULL)..F|AIL("NUL|
|00002200| 4c 20 61 72 67 75 6d 65 | 6e 74 22 29 3b 0a 0a 20 |L argume|nt");.. |
|00002210| 20 2f 2a 20 4d 61 6b 65 | 20 74 68 65 20 73 74 61 | /* Make| the sta|
|00002220| 72 74 20 61 64 64 72 65 | 73 73 20 6f 66 20 74 68 |rt addre|ss of th|
|00002230| 69 73 20 52 45 20 61 76 | 61 69 6c 61 62 6c 65 20 |is RE av|ailable |
|00002240| 74 6f 20 65 76 65 72 79 | 62 6f 64 79 20 2a 2f 0a |to every|body */.|
|00002250| 20 20 72 65 67 73 74 72 | 20 3d 20 65 78 70 3b 0a | regstr| = exp;.|
|00002260| 0a 20 20 2f 2a 20 46 69 | 72 73 74 20 70 61 73 73 |. /* Fi|rst pass|
|00002270| 3a 20 64 65 74 65 72 6d | 69 6e 65 20 73 69 7a 65 |: determ|ine size|
|00002280| 2c 20 6c 65 67 61 6c 69 | 74 79 2e 20 2a 2f 0a 20 |, legali|ty. */. |
|00002290| 20 72 65 67 70 61 72 73 | 65 20 3d 20 65 78 70 3b | regpars|e = exp;|
|000022a0| 0a 20 20 72 65 67 6e 70 | 61 72 20 3d 20 31 3b 0a |. regnp|ar = 1;.|
|000022b0| 20 20 72 65 67 73 69 7a | 65 20 3d 20 30 4c 3b 0a | regsiz|e = 0L;.|
|000022c0| 20 20 72 65 67 63 6f 64 | 65 20 3d 20 26 72 65 67 | regcod|e = ®|
|000022d0| 64 75 6d 6d 79 3b 0a 20 | 20 72 65 67 63 28 4d 41 |dummy;. | regc(MA|
|000022e0| 47 49 43 29 3b 0a 20 20 | 69 66 20 28 72 65 67 28 |GIC);. |if (reg(|
|000022f0| 30 2c 20 26 66 6c 61 67 | 73 29 20 3d 3d 20 4e 55 |0, &flag|s) == NU|
|00002300| 4c 4c 29 0a 09 72 65 74 | 75 72 6e 20 28 72 65 67 |LL)..ret|urn (reg|
|00002310| 65 78 70 20 2a 29 30 3b | 0a 0a 20 20 2f 2a 20 53 |exp *)0;|.. /* S|
|00002320| 6d 61 6c 6c 20 65 6e 6f | 75 67 68 20 66 6f 72 20 |mall eno|ugh for |
|00002330| 70 6f 69 6e 74 65 72 2d | 73 74 6f 72 61 67 65 20 |pointer-|storage |
|00002340| 63 6f 6e 76 65 6e 74 69 | 6f 6e 3f 20 2a 2f 0a 20 |conventi|on? */. |
|00002350| 20 69 66 20 28 72 65 67 | 73 69 7a 65 20 3e 3d 20 | if (reg|size >= |
|00002360| 33 32 37 36 37 4c 29 09 | 09 2f 2a 20 50 72 6f 62 |32767L).|./* Prob|
|00002370| 61 62 6c 79 20 63 6f 75 | 6c 64 20 62 65 20 36 35 |ably cou|ld be 65|
|00002380| 35 33 35 4c 2e 20 2a 2f | 0a 09 46 41 49 4c 28 22 |535L. */|..FAIL("|
|00002390| 72 65 67 65 78 70 20 74 | 6f 6f 20 62 69 67 22 29 |regexp t|oo big")|
|000023a0| 3b 0a 0a 20 20 2f 2a 20 | 41 6c 6c 6f 63 61 74 65 |;.. /* |Allocate|
|000023b0| 20 73 70 61 63 65 2e 20 | 2a 2f 0a 20 20 72 20 3d | space. |*/. r =|
|000023c0| 20 28 72 65 67 65 78 70 | 20 2a 29 6d 61 6c 6c 6f | (regexp| *)mallo|
|000023d0| 63 28 73 69 7a 65 6f 66 | 28 72 65 67 65 78 70 29 |c(sizeof|(regexp)|
|000023e0| 20 2b 20 28 75 6e 73 69 | 67 6e 65 64 29 72 65 67 | + (unsi|gned)reg|
|000023f0| 73 69 7a 65 29 3b 0a 20 | 20 69 66 20 28 21 72 29 |size);. | if (!r)|
|00002400| 0a 09 46 41 49 4c 28 22 | 6f 75 74 20 6f 66 20 73 |..FAIL("|out of s|
|00002410| 70 61 63 65 22 29 3b 0a | 0a 20 20 2f 2a 20 53 65 |pace");.|. /* Se|
|00002420| 63 6f 6e 64 20 70 61 73 | 73 3a 20 65 6d 69 74 20 |cond pas|s: emit |
|00002430| 63 6f 64 65 2e 20 2a 2f | 0a 20 20 72 65 67 70 61 |code. */|. regpa|
|00002440| 72 73 65 20 3d 20 65 78 | 70 3b 0a 20 20 72 65 67 |rse = ex|p;. reg|
|00002450| 6e 70 61 72 20 3d 20 31 | 3b 0a 20 20 72 65 67 63 |npar = 1|;. regc|
|00002460| 6f 64 65 20 3d 20 72 2d | 3e 70 72 6f 67 72 61 6d |ode = r-|>program|
|00002470| 3b 0a 20 20 72 65 67 63 | 28 4d 41 47 49 43 29 3b |;. regc|(MAGIC);|
|00002480| 0a 20 20 69 66 20 28 72 | 65 67 28 30 2c 20 26 66 |. if (r|eg(0, &f|
|00002490| 6c 61 67 73 29 20 3d 3d | 20 4e 55 4c 4c 29 0a 09 |lags) ==| NULL)..|
|000024a0| 72 65 74 75 72 6e 20 28 | 72 65 67 65 78 70 20 2a |return (|regexp *|
|000024b0| 29 30 3b 0a 0a 20 20 2f | 2a 20 44 69 67 20 6f 75 |)0;.. /|* Dig ou|
|000024c0| 74 20 69 6e 66 6f 72 6d | 61 74 69 6f 6e 20 66 6f |t inform|ation fo|
|000024d0| 72 20 6f 70 74 69 6d 69 | 7a 61 74 69 6f 6e 73 2e |r optimi|zations.|
|000024e0| 20 2a 2f 0a 20 20 72 2d | 3e 72 65 67 73 74 61 72 | */. r-|>regstar|
|000024f0| 74 20 3d 20 27 5c 30 27 | 3b 09 2f 2a 20 57 6f 72 |t = '\0'|;./* Wor|
|00002500| 73 74 2d 63 61 73 65 20 | 64 65 66 61 75 6c 74 73 |st-case |defaults|
|00002510| 2e 20 2a 2f 0a 20 20 72 | 2d 3e 72 65 67 61 6e 63 |. */. r|->reganc|
|00002520| 68 20 3d 20 30 3b 0a 20 | 20 72 2d 3e 72 65 67 6d |h = 0;. | r->regm|
|00002530| 75 73 74 20 3d 20 4e 55 | 4c 4c 3b 0a 20 20 72 2d |ust = NU|LL;. r-|
|00002540| 3e 72 65 67 6d 6c 65 6e | 20 3d 20 30 3b 0a 20 20 |>regmlen| = 0;. |
|00002550| 73 63 61 6e 20 3d 20 72 | 2d 3e 70 72 6f 67 72 61 |scan = r|->progra|
|00002560| 6d 2b 31 3b 09 09 09 2f | 2a 20 46 69 72 73 74 20 |m+1;.../|* First |
|00002570| 42 52 41 4e 43 48 2e 20 | 2a 2f 0a 20 20 69 66 20 |BRANCH. |*/. if |
|00002580| 28 4f 50 28 72 65 67 6e | 65 78 74 28 73 63 61 6e |(OP(regn|ext(scan|
|00002590| 29 29 20 3d 3d 20 45 4e | 44 29 20 7b 09 09 2f 2a |)) == EN|D) {../*|
|000025a0| 20 4f 6e 6c 79 20 6f 6e | 65 20 74 6f 70 2d 6c 65 | Only on|e top-le|
|000025b0| 76 65 6c 20 63 68 6f 69 | 63 65 2e 20 2a 2f 0a 09 |vel choi|ce. */..|
|000025c0| 73 63 61 6e 20 3d 20 4f | 50 45 52 41 4e 44 28 73 |scan = O|PERAND(s|
|000025d0| 63 61 6e 29 3b 0a 0a 09 | 2f 2a 20 53 74 61 72 74 |can);...|/* Start|
|000025e0| 69 6e 67 2d 70 6f 69 6e | 74 20 69 6e 66 6f 2e 20 |ing-poin|t info. |
|000025f0| 2a 2f 0a 09 69 66 20 28 | 4f 50 28 73 63 61 6e 29 |*/..if (|OP(scan)|
|00002600| 20 3d 3d 20 45 58 41 43 | 54 4c 59 29 0a 09 09 72 | == EXAC|TLY)...r|
|00002610| 2d 3e 72 65 67 73 74 61 | 72 74 20 3d 20 2a 4f 50 |->regsta|rt = *OP|
|00002620| 45 52 41 4e 44 28 73 63 | 61 6e 29 3b 0a 09 65 6c |ERAND(sc|an);..el|
|00002630| 73 65 20 69 66 20 28 4f | 50 28 73 63 61 6e 29 20 |se if (O|P(scan) |
|00002640| 3d 3d 20 42 4f 4c 29 0a | 09 09 72 2d 3e 72 65 67 |== BOL).|..r->reg|
|00002650| 61 6e 63 68 2b 2b 3b 0a | 0a 09 2f 2a 0a 09 20 2a |anch++;.|../*.. *|
|00002660| 20 49 66 20 74 68 65 72 | 65 27 73 20 73 6f 6d 65 | If ther|e's some|
|00002670| 74 68 69 6e 67 20 65 78 | 70 65 6e 73 69 76 65 20 |thing ex|pensive |
|00002680| 69 6e 20 74 68 65 20 72 | 2e 65 2e 2c 20 66 69 6e |in the r|.e., fin|
|00002690| 64 20 74 68 65 0a 09 20 | 2a 20 6c 6f 6e 67 65 73 |d the.. |* longes|
|000026a0| 74 20 6c 69 74 65 72 61 | 6c 20 73 74 72 69 6e 67 |t litera|l string|
|000026b0| 20 74 68 61 74 20 6d 75 | 73 74 20 61 70 70 65 61 | that mu|st appea|
|000026c0| 72 20 61 6e 64 20 6d 61 | 6b 65 20 69 74 20 74 68 |r and ma|ke it th|
|000026d0| 65 0a 09 20 2a 20 72 65 | 67 6d 75 73 74 2e 20 20 |e.. * re|gmust. |
|000026e0| 52 65 73 6f 6c 76 65 20 | 74 69 65 73 20 69 6e 20 |Resolve |ties in |
|000026f0| 66 61 76 6f 72 20 6f 66 | 20 6c 61 74 65 72 20 73 |favor of| later s|
|00002700| 74 72 69 6e 67 73 2c 20 | 73 69 6e 63 65 0a 09 20 |trings, |since.. |
|00002710| 2a 20 74 68 65 20 72 65 | 67 73 74 61 72 74 20 63 |* the re|gstart c|
|00002720| 68 65 63 6b 20 77 6f 72 | 6b 73 20 77 69 74 68 20 |heck wor|ks with |
|00002730| 74 68 65 20 62 65 67 69 | 6e 6e 69 6e 67 20 6f 66 |the begi|nning of|
|00002740| 20 74 68 65 20 72 2e 65 | 2e 0a 09 20 2a 20 61 6e | the r.e|... * an|
|00002750| 64 20 61 76 6f 69 64 69 | 6e 67 20 64 75 70 6c 69 |d avoidi|ng dupli|
|00002760| 63 61 74 69 6f 6e 20 73 | 74 72 65 6e 67 74 68 65 |cation s|trengthe|
|00002770| 6e 73 20 63 68 65 63 6b | 69 6e 67 2e 20 20 4e 6f |ns check|ing. No|
|00002780| 74 20 61 0a 09 20 2a 20 | 73 74 72 6f 6e 67 20 72 |t a.. * |strong r|
|00002790| 65 61 73 6f 6e 2c 20 62 | 75 74 20 73 75 66 66 69 |eason, b|ut suffi|
|000027a0| 63 69 65 6e 74 20 69 6e | 20 74 68 65 20 61 62 73 |cient in| the abs|
|000027b0| 65 6e 63 65 20 6f 66 20 | 6f 74 68 65 72 73 2e 0a |ence of |others..|
|000027c0| 09 20 2a 2f 0a 09 69 66 | 20 28 66 6c 61 67 73 26 |. */..if| (flags&|
|000027d0| 53 50 53 54 41 52 54 29 | 20 7b 0a 09 09 6c 6f 6e |SPSTART)| {...lon|
|000027e0| 67 65 73 74 20 3d 20 4e | 55 4c 4c 3b 0a 09 09 6c |gest = N|ULL;...l|
|000027f0| 65 6e 20 3d 20 30 3b 0a | 09 09 66 6f 72 20 28 3b |en = 0;.|..for (;|
|00002800| 20 73 63 61 6e 20 21 3d | 20 4e 55 4c 4c 3b 20 73 | scan !=| NULL; s|
|00002810| 63 61 6e 20 3d 20 72 65 | 67 6e 65 78 74 28 73 63 |can = re|gnext(sc|
|00002820| 61 6e 29 29 0a 09 09 09 | 69 66 20 28 4f 50 28 73 |an))....|if (OP(s|
|00002830| 63 61 6e 29 20 3d 3d 20 | 45 58 41 43 54 4c 59 20 |can) == |EXACTLY |
|00002840| 26 26 20 73 74 72 6c 65 | 6e 28 4f 50 45 52 41 4e |&& strle|n(OPERAN|
|00002850| 44 28 73 63 61 6e 29 29 | 20 3e 3d 20 6c 65 6e 29 |D(scan))| >= len)|
|00002860| 20 7b 0a 09 09 09 09 6c | 6f 6e 67 65 73 74 20 3d | {.....l|ongest =|
|00002870| 20 4f 50 45 52 41 4e 44 | 28 73 63 61 6e 29 3b 0a | OPERAND|(scan);.|
|00002880| 09 09 09 09 6c 65 6e 20 | 3d 20 73 74 72 6c 65 6e |....len |= strlen|
|00002890| 28 4f 50 45 52 41 4e 44 | 28 73 63 61 6e 29 29 3b |(OPERAND|(scan));|
|000028a0| 0a 09 09 09 7d 0a 09 09 | 72 2d 3e 72 65 67 6d 75 |....}...|r->regmu|
|000028b0| 73 74 20 3d 20 6c 6f 6e | 67 65 73 74 3b 0a 09 09 |st = lon|gest;...|
|000028c0| 72 2d 3e 72 65 67 6d 6c | 65 6e 20 3d 20 6c 65 6e |r->regml|en = len|
|000028d0| 3b 0a 09 7d 0a 20 20 7d | 0a 0a 20 20 72 65 74 75 |;..}. }|.. retu|
|000028e0| 72 6e 28 72 29 3b 0a 7d | 0a 0a 2f 2a 0a 20 2d 20 |rn(r);.}|../*. - |
|000028f0| 72 65 67 20 2d 20 72 65 | 67 75 6c 61 72 20 65 78 |reg - re|gular ex|
|00002900| 70 72 65 73 73 69 6f 6e | 2c 20 69 2e 65 2e 20 6d |pression|, i.e. m|
|00002910| 61 69 6e 20 62 6f 64 79 | 20 6f 72 20 70 61 72 65 |ain body| or pare|
|00002920| 6e 74 68 65 73 69 7a 65 | 64 20 74 68 69 6e 67 0a |nthesize|d thing.|
|00002930| 20 2a 0a 20 2a 20 43 61 | 6c 6c 65 72 20 6d 75 73 | *. * Ca|ller mus|
|00002940| 74 20 61 62 73 6f 72 62 | 20 6f 70 65 6e 69 6e 67 |t absorb| opening|
|00002950| 20 70 61 72 65 6e 74 68 | 65 73 69 73 2e 0a 20 2a | parenth|esis.. *|
|00002960| 0a 20 2a 20 43 6f 6d 62 | 69 6e 69 6e 67 20 70 61 |. * Comb|ining pa|
|00002970| 72 65 6e 74 68 65 73 69 | 73 20 68 61 6e 64 6c 69 |renthesi|s handli|
|00002980| 6e 67 20 77 69 74 68 20 | 74 68 65 20 62 61 73 65 |ng with |the base|
|00002990| 20 6c 65 76 65 6c 20 6f | 66 20 72 65 67 75 6c 61 | level o|f regula|
|000029a0| 72 20 65 78 70 72 65 73 | 73 69 6f 6e 0a 20 2a 20 |r expres|sion. * |
|000029b0| 69 73 20 61 20 74 72 69 | 66 6c 65 20 66 6f 72 63 |is a tri|fle forc|
|000029c0| 65 64 2c 20 62 75 74 20 | 74 68 65 20 6e 65 65 64 |ed, but |the need|
|000029d0| 20 74 6f 20 74 69 65 20 | 74 68 65 20 74 61 69 6c | to tie |the tail|
|000029e0| 73 20 6f 66 20 74 68 65 | 20 62 72 61 6e 63 68 65 |s of the| branche|
|000029f0| 73 20 74 6f 20 77 68 61 | 74 0a 20 2a 20 66 6f 6c |s to wha|t. * fol|
|00002a00| 6c 6f 77 73 20 6d 61 6b | 65 73 20 69 74 20 68 61 |lows mak|es it ha|
|00002a10| 72 64 20 74 6f 20 61 76 | 6f 69 64 2e 0a 20 2a 2f |rd to av|oid.. */|
|00002a20| 0a 73 74 61 74 69 63 20 | 63 68 61 72 20 2a 0a 72 |.static |char *.r|
|00002a30| 65 67 28 70 61 72 65 6e | 2c 20 66 6c 61 67 70 29 |eg(paren|, flagp)|
|00002a40| 0a 69 6e 74 20 70 61 72 | 65 6e 3b 09 09 09 2f 2a |.int par|en;.../*|
|00002a50| 20 50 61 72 65 6e 74 68 | 65 73 69 7a 65 64 3f 20 | Parenth|esized? |
|00002a60| 2a 2f 0a 69 6e 74 20 2a | 66 6c 61 67 70 3b 0a 7b |*/.int *|flagp;.{|
|00002a70| 0a 20 20 72 65 67 69 73 | 74 65 72 20 63 68 61 72 |. regis|ter char|
|00002a80| 20 2a 72 65 74 3b 0a 20 | 20 72 65 67 69 73 74 65 | *ret;. | registe|
|00002a90| 72 20 63 68 61 72 20 2a | 62 72 3b 0a 20 20 72 65 |r char *|br;. re|
|00002aa0| 67 69 73 74 65 72 20 63 | 68 61 72 20 2a 65 6e 64 |gister c|har *end|
|00002ab0| 65 72 3b 0a 20 20 72 65 | 67 69 73 74 65 72 20 69 |er;. re|gister i|
|00002ac0| 6e 74 20 70 61 72 6e 6f | 3b 0a 20 20 69 6e 74 20 |nt parno|;. int |
|00002ad0| 66 6c 61 67 73 3b 0a 0a | 20 20 2a 66 6c 61 67 70 |flags;..| *flagp|
|00002ae0| 20 3d 20 48 41 53 57 49 | 44 54 48 3b 09 2f 2a 20 | = HASWI|DTH;./* |
|00002af0| 54 65 6e 74 61 74 69 76 | 65 6c 79 2e 20 2a 2f 0a |Tentativ|ely. */.|
|00002b00| 0a 20 20 2f 2a 20 4d 61 | 6b 65 20 61 6e 20 4f 50 |. /* Ma|ke an OP|
|00002b10| 45 4e 20 6e 6f 64 65 2c | 20 69 66 20 70 61 72 65 |EN node,| if pare|
|00002b20| 6e 74 68 65 73 69 7a 65 | 64 2e 20 2a 2f 0a 20 20 |nthesize|d. */. |
|00002b30| 69 66 20 28 70 61 72 65 | 6e 29 20 7b 0a 09 69 66 |if (pare|n) {..if|
|00002b40| 20 28 72 65 67 6e 70 61 | 72 20 3e 3d 20 4e 53 55 | (regnpa|r >= NSU|
|00002b50| 42 45 58 50 29 0a 09 09 | 46 41 49 4c 28 22 74 6f |BEXP)...|FAIL("to|
|00002b60| 6f 20 6d 61 6e 79 20 28 | 29 22 29 3b 0a 09 70 61 |o many (|)");..pa|
|00002b70| 72 6e 6f 20 3d 20 72 65 | 67 6e 70 61 72 3b 0a 09 |rno = re|gnpar;..|
|00002b80| 72 65 67 6e 70 61 72 2b | 2b 3b 0a 09 72 65 74 20 |regnpar+|+;..ret |
|00002b90| 3d 20 72 65 67 6e 6f 64 | 65 28 4f 50 45 4e 2b 70 |= regnod|e(OPEN+p|
|00002ba0| 61 72 6e 6f 29 3b 0a 20 | 20 7d 20 65 6c 73 65 0a |arno);. | } else.|
|00002bb0| 09 72 65 74 20 3d 20 4e | 55 4c 4c 3b 0a 0a 20 20 |.ret = N|ULL;.. |
|00002bc0| 2f 2a 20 50 69 63 6b 20 | 75 70 20 74 68 65 20 62 |/* Pick |up the b|
|00002bd0| 72 61 6e 63 68 65 73 2c | 20 6c 69 6e 6b 69 6e 67 |ranches,| linking|
|00002be0| 20 74 68 65 6d 20 74 6f | 67 65 74 68 65 72 2e 20 | them to|gether. |
|00002bf0| 2a 2f 0a 20 20 62 72 20 | 3d 20 72 65 67 62 72 61 |*/. br |= regbra|
|00002c00| 6e 63 68 28 26 66 6c 61 | 67 73 29 3b 0a 20 20 69 |nch(&fla|gs);. i|
|00002c10| 66 20 28 62 72 20 3d 3d | 20 4e 55 4c 4c 29 0a 09 |f (br ==| NULL)..|
|00002c20| 72 65 74 75 72 6e 28 4e | 55 4c 4c 29 3b 0a 20 20 |return(N|ULL);. |
|00002c30| 69 66 20 28 72 65 74 20 | 21 3d 20 4e 55 4c 4c 29 |if (ret |!= NULL)|
|00002c40| 0a 09 72 65 67 74 61 69 | 6c 28 72 65 74 2c 20 62 |..regtai|l(ret, b|
|00002c50| 72 29 3b 09 2f 2a 20 4f | 50 45 4e 20 2d 3e 20 66 |r);./* O|PEN -> f|
|00002c60| 69 72 73 74 2e 20 2a 2f | 0a 20 20 65 6c 73 65 0a |irst. */|. else.|
|00002c70| 09 72 65 74 20 3d 20 62 | 72 3b 0a 20 20 69 66 20 |.ret = b|r;. if |
|00002c80| 28 21 28 66 6c 61 67 73 | 26 48 41 53 57 49 44 54 |(!(flags|&HASWIDT|
|00002c90| 48 29 29 0a 09 2a 66 6c | 61 67 70 20 26 3d 20 7e |H))..*fl|agp &= ~|
|00002ca0| 48 41 53 57 49 44 54 48 | 3b 0a 20 20 2a 66 6c 61 |HASWIDTH|;. *fla|
|00002cb0| 67 70 20 7c 3d 20 66 6c | 61 67 73 26 53 50 53 54 |gp |= fl|ags&SPST|
|00002cc0| 41 52 54 3b 0a 20 20 77 | 68 69 6c 65 20 28 72 65 |ART;. w|hile (re|
|00002cd0| 67 70 61 72 73 65 5b 30 | 5d 20 3d 3d 20 27 5c 5c |gparse[0|] == '\\|
|00002ce0| 27 20 26 26 20 72 65 67 | 70 61 72 73 65 5b 31 5d |' && reg|parse[1]|
|00002cf0| 20 3d 3d 20 27 7c 27 29 | 20 7b 0a 09 72 65 67 70 | == '|')| {..regp|
|00002d00| 61 72 73 65 20 2b 3d 20 | 32 3b 0a 09 62 72 20 3d |arse += |2;..br =|
|00002d10| 20 72 65 67 62 72 61 6e | 63 68 28 26 66 6c 61 67 | regbran|ch(&flag|
|00002d20| 73 29 3b 0a 09 69 66 20 | 28 62 72 20 3d 3d 20 4e |s);..if |(br == N|
|00002d30| 55 4c 4c 29 0a 09 09 72 | 65 74 75 72 6e 28 4e 55 |ULL)...r|eturn(NU|
|00002d40| 4c 4c 29 3b 0a 09 72 65 | 67 74 61 69 6c 28 72 65 |LL);..re|gtail(re|
|00002d50| 74 2c 20 62 72 29 3b 09 | 2f 2a 20 42 52 41 4e 43 |t, br);.|/* BRANC|
|00002d60| 48 20 2d 3e 20 42 52 41 | 4e 43 48 2e 20 2a 2f 0a |H -> BRA|NCH. */.|
|00002d70| 09 69 66 20 28 21 28 66 | 6c 61 67 73 26 48 41 53 |.if (!(f|lags&HAS|
|00002d80| 57 49 44 54 48 29 29 0a | 09 09 2a 66 6c 61 67 70 |WIDTH)).|..*flagp|
|00002d90| 20 26 3d 20 7e 48 41 53 | 57 49 44 54 48 3b 0a 09 | &= ~HAS|WIDTH;..|
|00002da0| 2a 66 6c 61 67 70 20 7c | 3d 20 66 6c 61 67 73 26 |*flagp ||= flags&|
|00002db0| 53 50 53 54 41 52 54 3b | 0a 20 20 7d 0a 0a 20 20 |SPSTART;|. }.. |
|00002dc0| 2f 2a 20 4d 61 6b 65 20 | 61 20 63 6c 6f 73 69 6e |/* Make |a closin|
|00002dd0| 67 20 6e 6f 64 65 2c 20 | 61 6e 64 20 68 6f 6f 6b |g node, |and hook|
|00002de0| 20 69 74 20 6f 6e 20 74 | 68 65 20 65 6e 64 2e 20 | it on t|he end. |
|00002df0| 2a 2f 0a 20 20 65 6e 64 | 65 72 20 3d 20 72 65 67 |*/. end|er = reg|
|00002e00| 6e 6f 64 65 28 28 70 61 | 72 65 6e 29 20 3f 20 43 |node((pa|ren) ? C|
|00002e10| 4c 4f 53 45 2b 70 61 72 | 6e 6f 20 3a 20 45 4e 44 |LOSE+par|no : END|
|00002e20| 29 3b 09 0a 20 20 72 65 | 67 74 61 69 6c 28 72 65 |);.. re|gtail(re|
|00002e30| 74 2c 20 65 6e 64 65 72 | 29 3b 0a 0a 20 20 2f 2a |t, ender|);.. /*|
|00002e40| 20 48 6f 6f 6b 20 74 68 | 65 20 74 61 69 6c 73 20 | Hook th|e tails |
|00002e50| 6f 66 20 74 68 65 20 62 | 72 61 6e 63 68 65 73 20 |of the b|ranches |
|00002e60| 74 6f 20 74 68 65 20 63 | 6c 6f 73 69 6e 67 20 6e |to the c|losing n|
|00002e70| 6f 64 65 2e 20 2a 2f 0a | 20 20 66 6f 72 20 28 62 |ode. */.| for (b|
|00002e80| 72 20 3d 20 72 65 74 3b | 20 62 72 20 21 3d 20 4e |r = ret;| br != N|
|00002e90| 55 4c 4c 3b 20 62 72 20 | 3d 20 72 65 67 6e 65 78 |ULL; br |= regnex|
|00002ea0| 74 28 62 72 29 29 0a 09 | 72 65 67 6f 70 74 61 69 |t(br))..|regoptai|
|00002eb0| 6c 28 62 72 2c 20 65 6e | 64 65 72 29 3b 0a 0a 20 |l(br, en|der);.. |
|00002ec0| 20 2f 2a 20 43 68 65 63 | 6b 20 66 6f 72 20 70 72 | /* Chec|k for pr|
|00002ed0| 6f 70 65 72 20 74 65 72 | 6d 69 6e 61 74 69 6f 6e |oper ter|mination|
|00002ee0| 2e 20 2a 2f 0a 20 20 69 | 66 20 28 70 61 72 65 6e |. */. i|f (paren|
|00002ef0| 20 26 26 20 28 2a 72 65 | 67 70 61 72 73 65 2b 2b | && (*re|gparse++|
|00002f00| 20 21 3d 20 27 5c 5c 27 | 20 7c 7c 20 2a 72 65 67 | != '\\'| || *reg|
|00002f10| 70 61 72 73 65 2b 2b 20 | 21 3d 20 27 29 27 29 29 |parse++ |!= ')'))|
|00002f20| 20 7b 0a 09 46 41 49 4c | 28 22 75 6e 6d 61 74 63 | {..FAIL|("unmatc|
|00002f30| 68 65 64 20 5c 5c 28 5c | 5c 29 22 29 3b 0a 20 20 |hed \\(\|\)");. |
|00002f40| 7d 20 65 6c 73 65 20 69 | 66 20 28 21 70 61 72 65 |} else i|f (!pare|
|00002f50| 6e 20 26 26 20 2a 72 65 | 67 70 61 72 73 65 20 21 |n && *re|gparse !|
|00002f60| 3d 20 27 5c 30 27 29 20 | 7b 0a 09 69 66 20 28 72 |= '\0') |{..if (r|
|00002f70| 65 67 70 61 72 73 65 5b | 30 5d 20 3d 3d 20 27 5c |egparse[|0] == '\|
|00002f80| 5c 27 20 26 26 20 72 65 | 67 70 61 72 73 65 5b 31 |\' && re|gparse[1|
|00002f90| 5d 20 3d 3d 20 27 29 27 | 29 20 7b 0a 09 09 46 41 |] == ')'|) {...FA|
|00002fa0| 49 4c 28 22 75 6e 6d 61 | 74 63 68 65 64 20 5c 5c |IL("unma|tched \\|
|00002fb0| 28 5c 5c 29 22 29 3b 0a | 09 7d 20 65 6c 73 65 0a |(\\)");.|.} else.|
|00002fc0| 09 09 46 41 49 4c 28 22 | 6a 75 6e 6b 20 6f 6e 20 |..FAIL("|junk on |
|00002fd0| 65 6e 64 22 29 3b 09 2f | 2a 20 22 43 61 6e 27 74 |end");./|* "Can't|
|00002fe0| 20 68 61 70 70 65 6e 22 | 2e 20 2a 2f 0a 09 2f 2a | happen"|. */../*|
|00002ff0| 20 4e 4f 54 52 45 41 43 | 48 45 44 20 2a 2f 0a 20 | NOTREAC|HED */. |
|00003000| 20 7d 0a 0a 20 20 72 65 | 74 75 72 6e 28 72 65 74 | }.. re|turn(ret|
|00003010| 29 3b 0a 7d 0a 0a 2f 2a | 0a 20 2d 20 72 65 67 62 |);.}../*|. - regb|
|00003020| 72 61 6e 63 68 20 2d 20 | 6f 6e 65 20 61 6c 74 65 |ranch - |one alte|
|00003030| 72 6e 61 74 69 76 65 20 | 6f 66 20 61 6e 20 7c 20 |rnative |of an | |
|00003040| 6f 70 65 72 61 74 6f 72 | 0a 20 2a 0a 20 2a 20 49 |operator|. *. * I|
|00003050| 6d 70 6c 65 6d 65 6e 74 | 73 20 74 68 65 20 63 6f |mplement|s the co|
|00003060| 6e 63 61 74 65 6e 61 74 | 69 6f 6e 20 6f 70 65 72 |ncatenat|ion oper|
|00003070| 61 74 6f 72 2e 0a 20 2a | 2f 0a 73 74 61 74 69 63 |ator.. *|/.static|
|00003080| 20 63 68 61 72 20 2a 0a | 72 65 67 62 72 61 6e 63 | char *.|regbranc|
|00003090| 68 28 66 6c 61 67 70 29 | 0a 69 6e 74 20 2a 66 6c |h(flagp)|.int *fl|
|000030a0| 61 67 70 3b 0a 7b 0a 20 | 20 72 65 67 69 73 74 65 |agp;.{. | registe|
|000030b0| 72 20 63 68 61 72 20 2a | 72 65 74 3b 0a 20 20 72 |r char *|ret;. r|
|000030c0| 65 67 69 73 74 65 72 20 | 63 68 61 72 20 2a 63 68 |egister |char *ch|
|000030d0| 61 69 6e 3b 0a 20 20 72 | 65 67 69 73 74 65 72 20 |ain;. r|egister |
|000030e0| 63 68 61 72 20 2a 6c 61 | 74 65 73 74 3b 0a 20 20 |char *la|test;. |
|000030f0| 69 6e 74 20 66 6c 61 67 | 73 3b 0a 0a 20 20 2a 66 |int flag|s;.. *f|
|00003100| 6c 61 67 70 20 3d 20 57 | 4f 52 53 54 3b 09 09 2f |lagp = W|ORST;../|
|00003110| 2a 20 54 65 6e 74 61 74 | 69 76 65 6c 79 2e 20 2a |* Tentat|ively. *|
|00003120| 2f 0a 0a 20 20 72 65 74 | 20 3d 20 72 65 67 6e 6f |/.. ret| = regno|
|00003130| 64 65 28 42 52 41 4e 43 | 48 29 3b 0a 20 20 63 68 |de(BRANC|H);. ch|
|00003140| 61 69 6e 20 3d 20 4e 55 | 4c 4c 3b 0a 20 20 77 68 |ain = NU|LL;. wh|
|00003150| 69 6c 65 20 28 2a 72 65 | 67 70 61 72 73 65 20 21 |ile (*re|gparse !|
|00003160| 3d 20 27 5c 30 27 20 26 | 26 20 28 72 65 67 70 61 |= '\0' &|& (regpa|
|00003170| 72 73 65 5b 30 5d 20 21 | 3d 20 27 5c 5c 27 20 7c |rse[0] !|= '\\' ||
|00003180| 7c 0a 09 09 09 09 72 65 | 67 70 61 72 73 65 5b 31 ||.....re|gparse[1|
|00003190| 5d 20 21 3d 20 27 7c 27 | 20 26 26 20 72 65 67 70 |] != '|'| && regp|
|000031a0| 61 72 73 65 5b 31 5d 20 | 21 3d 20 27 29 27 29 29 |arse[1] |!= ')'))|
|000031b0| 20 7b 0a 09 6c 61 74 65 | 73 74 20 3d 20 72 65 67 | {..late|st = reg|
|000031c0| 70 69 65 63 65 28 26 66 | 6c 61 67 73 29 3b 0a 09 |piece(&f|lags);..|
|000031d0| 69 66 20 28 6c 61 74 65 | 73 74 20 3d 3d 20 4e 55 |if (late|st == NU|
|000031e0| 4c 4c 29 0a 09 09 72 65 | 74 75 72 6e 28 4e 55 4c |LL)...re|turn(NUL|
|000031f0| 4c 29 3b 0a 09 2a 66 6c | 61 67 70 20 7c 3d 20 66 |L);..*fl|agp |= f|
|00003200| 6c 61 67 73 26 48 41 53 | 57 49 44 54 48 3b 0a 09 |lags&HAS|WIDTH;..|
|00003210| 69 66 20 28 63 68 61 69 | 6e 20 3d 3d 20 4e 55 4c |if (chai|n == NUL|
|00003220| 4c 29 09 2f 2a 20 46 69 | 72 73 74 20 70 69 65 63 |L)./* Fi|rst piec|
|00003230| 65 2e 20 2a 2f 0a 09 09 | 2a 66 6c 61 67 70 20 7c |e. */...|*flagp ||
|00003240| 3d 20 66 6c 61 67 73 26 | 53 50 53 54 41 52 54 3b |= flags&|SPSTART;|
|00003250| 0a 09 65 6c 73 65 0a 09 | 09 72 65 67 74 61 69 6c |..else..|.regtail|
|00003260| 28 63 68 61 69 6e 2c 20 | 6c 61 74 65 73 74 29 3b |(chain, |latest);|
|00003270| 0a 09 63 68 61 69 6e 20 | 3d 20 6c 61 74 65 73 74 |..chain |= latest|
|00003280| 3b 0a 20 20 7d 0a 20 20 | 69 66 20 28 63 68 61 69 |;. }. |if (chai|
|00003290| 6e 20 3d 3d 20 4e 55 4c | 4c 29 09 2f 2a 20 4c 6f |n == NUL|L)./* Lo|
|000032a0| 6f 70 20 72 61 6e 20 7a | 65 72 6f 20 74 69 6d 65 |op ran z|ero time|
|000032b0| 73 2e 20 2a 2f 0a 09 72 | 65 67 6e 6f 64 65 28 4e |s. */..r|egnode(N|
|000032c0| 4f 54 48 49 4e 47 29 3b | 0a 0a 20 20 72 65 74 75 |OTHING);|.. retu|
|000032d0| 72 6e 28 72 65 74 29 3b | 0a 7d 0a 0a 2f 2a 0a 20 |rn(ret);|.}../*. |
|000032e0| 2d 20 72 65 67 70 69 65 | 63 65 20 2d 20 73 6f 6d |- regpie|ce - som|
|000032f0| 65 74 68 69 6e 67 20 66 | 6f 6c 6c 6f 77 65 64 20 |ething f|ollowed |
|00003300| 62 79 20 70 6f 73 73 69 | 62 6c 65 20 5b 2a 2b 3f |by possi|ble [*+?|
|00003310| 5d 0a 20 2a 0a 20 2a 20 | 4e 6f 74 65 20 74 68 61 |]. *. * |Note tha|
|00003320| 74 20 74 68 65 20 62 72 | 61 6e 63 68 69 6e 67 20 |t the br|anching |
|00003330| 63 6f 64 65 20 73 65 71 | 75 65 6e 63 65 73 20 75 |code seq|uences u|
|00003340| 73 65 64 20 66 6f 72 20 | 3f 20 61 6e 64 20 74 68 |sed for |? and th|
|00003350| 65 20 67 65 6e 65 72 61 | 6c 20 63 61 73 65 73 0a |e genera|l cases.|
|00003360| 20 2a 20 6f 66 20 2a 20 | 61 6e 64 20 2b 20 61 72 | * of * |and + ar|
|00003370| 65 20 73 6f 6d 65 77 68 | 61 74 20 6f 70 74 69 6d |e somewh|at optim|
|00003380| 69 7a 65 64 3a 20 20 74 | 68 65 79 20 75 73 65 20 |ized: t|hey use |
|00003390| 74 68 65 20 73 61 6d 65 | 20 4e 4f 54 48 49 4e 47 |the same| NOTHING|
|000033a0| 20 6e 6f 64 65 20 61 73 | 0a 20 2a 20 62 6f 74 68 | node as|. * both|
|000033b0| 20 74 68 65 20 65 6e 64 | 6d 61 72 6b 65 72 20 66 | the end|marker f|
|000033c0| 6f 72 20 74 68 65 69 72 | 20 62 72 61 6e 63 68 20 |or their| branch |
|000033d0| 6c 69 73 74 20 61 6e 64 | 20 74 68 65 20 62 6f 64 |list and| the bod|
|000033e0| 79 20 6f 66 20 74 68 65 | 20 6c 61 73 74 20 62 72 |y of the| last br|
|000033f0| 61 6e 63 68 2e 0a 20 2a | 20 49 74 20 6d 69 67 68 |anch.. *| It migh|
|00003400| 74 20 73 65 65 6d 20 74 | 68 61 74 20 74 68 69 73 |t seem t|hat this|
|00003410| 20 6e 6f 64 65 20 63 6f | 75 6c 64 20 62 65 20 64 | node co|uld be d|
|00003420| 69 73 70 65 6e 73 65 64 | 20 77 69 74 68 20 65 6e |ispensed| with en|
|00003430| 74 69 72 65 6c 79 2c 20 | 62 75 74 20 74 68 65 0a |tirely, |but the.|
|00003440| 20 2a 20 65 6e 64 6d 61 | 72 6b 65 72 20 72 6f 6c | * endma|rker rol|
|00003450| 65 20 69 73 20 6e 6f 74 | 20 72 65 64 75 6e 64 61 |e is not| redunda|
|00003460| 6e 74 2e 0a 20 2a 2f 0a | 73 74 61 74 69 63 20 63 |nt.. */.|static c|
|00003470| 68 61 72 20 2a 0a 72 65 | 67 70 69 65 63 65 28 66 |har *.re|gpiece(f|
|00003480| 6c 61 67 70 29 0a 69 6e | 74 20 2a 66 6c 61 67 70 |lagp).in|t *flagp|
|00003490| 3b 0a 7b 0a 20 20 72 65 | 67 69 73 74 65 72 20 63 |;.{. re|gister c|
|000034a0| 68 61 72 20 2a 72 65 74 | 3b 0a 20 20 72 65 67 69 |har *ret|;. regi|
|000034b0| 73 74 65 72 20 63 68 61 | 72 20 6f 70 3b 0a 20 20 |ster cha|r op;. |
|000034c0| 72 65 67 69 73 74 65 72 | 20 63 68 61 72 20 2a 6e |register| char *n|
|000034d0| 65 78 74 3b 0a 20 20 69 | 6e 74 20 66 6c 61 67 73 |ext;. i|nt flags|
|000034e0| 3b 0a 0a 20 20 72 65 74 | 20 3d 20 72 65 67 61 74 |;.. ret| = regat|
|000034f0| 6f 6d 28 26 66 6c 61 67 | 73 29 3b 0a 20 20 69 66 |om(&flag|s);. if|
|00003500| 20 28 72 65 74 20 3d 3d | 20 4e 55 4c 4c 29 0a 09 | (ret ==| NULL)..|
|00003510| 72 65 74 75 72 6e 28 4e | 55 4c 4c 29 3b 0a 0a 20 |return(N|ULL);.. |
|00003520| 20 6f 70 20 3d 20 2a 72 | 65 67 70 61 72 73 65 3b | op = *r|egparse;|
|00003530| 0a 20 20 69 66 20 28 21 | 49 53 4d 55 4c 54 28 6f |. if (!|ISMULT(o|
|00003540| 70 29 29 20 7b 0a 09 2a | 66 6c 61 67 70 20 3d 20 |p)) {..*|flagp = |
|00003550| 66 6c 61 67 73 3b 0a 09 | 72 65 74 75 72 6e 28 72 |flags;..|return(r|
|00003560| 65 74 29 3b 0a 20 20 7d | 0a 0a 20 20 69 66 20 28 |et);. }|.. if (|
|00003570| 21 28 66 6c 61 67 73 26 | 48 41 53 57 49 44 54 48 |!(flags&|HASWIDTH|
|00003580| 29 20 26 26 20 6f 70 20 | 21 3d 20 27 3f 27 29 0a |) && op |!= '?').|
|00003590| 09 46 41 49 4c 28 22 2a | 2b 20 6f 70 65 72 61 6e |.FAIL("*|+ operan|
|000035a0| 64 20 63 6f 75 6c 64 20 | 62 65 20 65 6d 70 74 79 |d could |be empty|
|000035b0| 22 29 3b 0a 20 20 2a 66 | 6c 61 67 70 20 3d 20 28 |");. *f|lagp = (|
|000035c0| 6f 70 20 21 3d 20 27 2b | 27 29 20 3f 20 28 57 4f |op != '+|') ? (WO|
|000035d0| 52 53 54 7c 53 50 53 54 | 41 52 54 29 20 3a 20 28 |RST|SPST|ART) : (|
|000035e0| 57 4f 52 53 54 7c 48 41 | 53 57 49 44 54 48 29 3b |WORST|HA|SWIDTH);|
|000035f0| 0a 0a 20 20 69 66 20 28 | 6f 70 20 3d 3d 20 27 2a |.. if (|op == '*|
|00003600| 27 20 26 26 20 28 66 6c | 61 67 73 26 53 49 4d 50 |' && (fl|ags&SIMP|
|00003610| 4c 45 29 29 0a 09 72 65 | 67 69 6e 73 65 72 74 28 |LE))..re|ginsert(|
|00003620| 53 54 41 52 2c 20 72 65 | 74 29 3b 0a 20 20 65 6c |STAR, re|t);. el|
|00003630| 73 65 20 69 66 20 28 6f | 70 20 3d 3d 20 27 2a 27 |se if (o|p == '*'|
|00003640| 29 20 7b 0a 09 2f 2a 20 | 45 6d 69 74 20 78 2a 20 |) {../* |Emit x* |
|00003650| 61 73 20 28 78 26 7c 29 | 2c 20 77 68 65 72 65 20 |as (x&|)|, where |
|00003660| 26 20 6d 65 61 6e 73 20 | 22 73 65 6c 66 22 2e 20 |& means |"self". |
|00003670| 2a 2f 0a 09 72 65 67 69 | 6e 73 65 72 74 28 42 52 |*/..regi|nsert(BR|
|00003680| 41 4e 43 48 2c 20 72 65 | 74 29 3b 09 09 09 2f 2a |ANCH, re|t);.../*|
|00003690| 20 45 69 74 68 65 72 20 | 78 20 2a 2f 0a 09 72 65 | Either |x */..re|
|000036a0| 67 6f 70 74 61 69 6c 28 | 72 65 74 2c 20 72 65 67 |goptail(|ret, reg|
|000036b0| 6e 6f 64 65 28 42 41 43 | 4b 29 29 3b 09 09 2f 2a |node(BAC|K));../*|
|000036c0| 20 61 6e 64 20 6c 6f 6f | 70 20 2a 2f 0a 09 72 65 | and loo|p */..re|
|000036d0| 67 6f 70 74 61 69 6c 28 | 72 65 74 2c 20 72 65 74 |goptail(|ret, ret|
|000036e0| 29 3b 09 09 09 2f 2a 20 | 62 61 63 6b 20 2a 2f 0a |);.../* |back */.|
|000036f0| 09 72 65 67 74 61 69 6c | 28 72 65 74 2c 20 72 65 |.regtail|(ret, re|
|00003700| 67 6e 6f 64 65 28 42 52 | 41 4e 43 48 29 29 3b 09 |gnode(BR|ANCH));.|
|00003710| 09 2f 2a 20 6f 72 20 2a | 2f 0a 09 72 65 67 74 61 |./* or *|/..regta|
|00003720| 69 6c 28 72 65 74 2c 20 | 72 65 67 6e 6f 64 65 28 |il(ret, |regnode(|
|00003730| 4e 4f 54 48 49 4e 47 29 | 29 3b 09 09 2f 2a 20 6e |NOTHING)|);../* n|
|00003740| 75 6c 6c 2e 20 2a 2f 0a | 20 20 7d 20 65 6c 73 65 |ull. */.| } else|
|00003750| 20 69 66 20 28 6f 70 20 | 3d 3d 20 27 2b 27 20 26 | if (op |== '+' &|
|00003760| 26 20 28 66 6c 61 67 73 | 26 53 49 4d 50 4c 45 29 |& (flags|&SIMPLE)|
|00003770| 29 0a 09 72 65 67 69 6e | 73 65 72 74 28 50 4c 55 |)..regin|sert(PLU|
|00003780| 53 2c 20 72 65 74 29 3b | 0a 20 20 65 6c 73 65 20 |S, ret);|. else |
|00003790| 69 66 20 28 6f 70 20 3d | 3d 20 27 2b 27 29 20 7b |if (op =|= '+') {|
|000037a0| 0a 09 2f 2a 20 45 6d 69 | 74 20 78 2b 20 61 73 20 |../* Emi|t x+ as |
|000037b0| 78 28 26 7c 29 2c 20 77 | 68 65 72 65 20 26 20 6d |x(&|), w|here & m|
|000037c0| 65 61 6e 73 20 22 73 65 | 6c 66 22 2e 20 2a 2f 0a |eans "se|lf". */.|
|000037d0| 09 6e 65 78 74 20 3d 20 | 72 65 67 6e 6f 64 65 28 |.next = |regnode(|
|000037e0| 42 52 41 4e 43 48 29 3b | 09 09 09 2f 2a 20 45 69 |BRANCH);|.../* Ei|
|000037f0| 74 68 65 72 20 2a 2f 0a | 09 72 65 67 74 61 69 6c |ther */.|.regtail|
|00003800| 28 72 65 74 2c 20 6e 65 | 78 74 29 3b 0a 09 72 65 |(ret, ne|xt);..re|
|00003810| 67 74 61 69 6c 28 72 65 | 67 6e 6f 64 65 28 42 41 |gtail(re|gnode(BA|
|00003820| 43 4b 29 2c 20 72 65 74 | 29 3b 09 09 2f 2a 20 6c |CK), ret|);../* l|
|00003830| 6f 6f 70 20 62 61 63 6b | 20 2a 2f 0a 09 72 65 67 |oop back| */..reg|
|00003840| 74 61 69 6c 28 6e 65 78 | 74 2c 20 72 65 67 6e 6f |tail(nex|t, regno|
|00003850| 64 65 28 42 52 41 4e 43 | 48 29 29 3b 09 09 2f 2a |de(BRANC|H));../*|
|00003860| 20 6f 72 20 2a 2f 0a 09 | 72 65 67 74 61 69 6c 28 | or */..|regtail(|
|00003870| 72 65 74 2c 20 72 65 67 | 6e 6f 64 65 28 4e 4f 54 |ret, reg|node(NOT|
|00003880| 48 49 4e 47 29 29 3b 09 | 09 2f 2a 20 6e 75 6c 6c |HING));.|./* null|
|00003890| 2e 20 2a 2f 0a 20 20 7d | 20 65 6c 73 65 20 69 66 |. */. }| else if|
|000038a0| 20 28 6f 70 20 3d 3d 20 | 27 3f 27 29 20 7b 0a 09 | (op == |'?') {..|
|000038b0| 2f 2a 20 45 6d 69 74 20 | 78 3f 20 61 73 20 28 78 |/* Emit |x? as (x|
|000038c0| 7c 29 20 2a 2f 0a 09 72 | 65 67 69 6e 73 65 72 74 ||) */..r|eginsert|
|000038d0| 28 42 52 41 4e 43 48 2c | 20 72 65 74 29 3b 09 09 |(BRANCH,| ret);..|
|000038e0| 09 2f 2a 20 45 69 74 68 | 65 72 20 78 20 2a 2f 0a |./* Eith|er x */.|
|000038f0| 09 72 65 67 74 61 69 6c | 28 72 65 74 2c 20 72 65 |.regtail|(ret, re|
|00003900| 67 6e 6f 64 65 28 42 52 | 41 4e 43 48 29 29 3b 09 |gnode(BR|ANCH));.|
|00003910| 09 2f 2a 20 6f 72 20 2a | 2f 0a 09 6e 65 78 74 20 |./* or *|/..next |
|00003920| 3d 20 72 65 67 6e 6f 64 | 65 28 4e 4f 54 48 49 4e |= regnod|e(NOTHIN|
|00003930| 47 29 3b 09 09 2f 2a 20 | 6e 75 6c 6c 2e 20 2a 2f |G);../* |null. */|
|00003940| 0a 09 72 65 67 74 61 69 | 6c 28 72 65 74 2c 20 6e |..regtai|l(ret, n|
|00003950| 65 78 74 29 3b 0a 09 72 | 65 67 6f 70 74 61 69 6c |ext);..r|egoptail|
|00003960| 28 72 65 74 2c 20 6e 65 | 78 74 29 3b 0a 20 20 7d |(ret, ne|xt);. }|
|00003970| 0a 20 20 72 65 67 70 61 | 72 73 65 2b 2b 3b 0a 20 |. regpa|rse++;. |
|00003980| 20 69 66 20 28 49 53 4d | 55 4c 54 28 2a 72 65 67 | if (ISM|ULT(*reg|
|00003990| 70 61 72 73 65 29 29 0a | 09 46 41 49 4c 28 22 6e |parse)).|.FAIL("n|
|000039a0| 65 73 74 65 64 20 2a 3f | 2b 22 29 3b 0a 0a 20 20 |ested *?|+");.. |
|000039b0| 72 65 74 75 72 6e 28 72 | 65 74 29 3b 0a 7d 0a 0a |return(r|et);.}..|
|000039c0| 2f 2a 0a 20 2d 20 72 65 | 67 61 74 6f 6d 20 2d 20 |/*. - re|gatom - |
|000039d0| 74 68 65 20 6c 6f 77 65 | 73 74 20 6c 65 76 65 6c |the lowe|st level|
|000039e0| 0a 20 2a 0a 20 2a 20 4f | 70 74 69 6d 69 7a 61 74 |. *. * O|ptimizat|
|000039f0| 69 6f 6e 3a 20 20 67 6f | 62 62 6c 65 73 20 61 6e |ion: go|bbles an|
|00003a00| 20 65 6e 74 69 72 65 20 | 73 65 71 75 65 6e 63 65 | entire |sequence|
|00003a10| 20 6f 66 20 6f 72 64 69 | 6e 61 72 79 20 63 68 61 | of ordi|nary cha|
|00003a20| 72 61 63 74 65 72 73 20 | 73 6f 20 74 68 61 74 0a |racters |so that.|
|00003a30| 20 2a 20 69 74 20 63 61 | 6e 20 74 75 72 6e 20 74 | * it ca|n turn t|
|00003a40| 68 65 6d 20 69 6e 74 6f | 20 61 20 73 69 6e 67 6c |hem into| a singl|
|00003a50| 65 20 6e 6f 64 65 2c 20 | 77 68 69 63 68 20 69 73 |e node, |which is|
|00003a60| 20 73 6d 61 6c 6c 65 72 | 20 74 6f 20 73 74 6f 72 | smaller| to stor|
|00003a70| 65 20 61 6e 64 0a 20 2a | 20 66 61 73 74 65 72 20 |e and. *| faster |
|00003a80| 74 6f 20 72 75 6e 2e 20 | 20 42 61 63 6b 73 6c 61 |to run. | Backsla|
|00003a90| 73 68 65 64 20 63 68 61 | 72 61 63 74 65 72 73 20 |shed cha|racters |
|00003aa0| 61 72 65 20 65 78 63 65 | 70 74 69 6f 6e 73 2c 20 |are exce|ptions, |
|00003ab0| 65 61 63 68 20 62 65 63 | 6f 6d 69 6e 67 20 61 0a |each bec|oming a.|
|00003ac0| 20 2a 20 73 65 70 61 72 | 61 74 65 20 6e 6f 64 65 | * separ|ate node|
|00003ad0| 3b 20 74 68 65 20 63 6f | 64 65 20 69 73 20 73 69 |; the co|de is si|
|00003ae0| 6d 70 6c 65 72 20 74 68 | 61 74 20 77 61 79 20 61 |mpler th|at way a|
|00003af0| 6e 64 20 69 74 27 73 20 | 6e 6f 74 20 77 6f 72 74 |nd it's |not wort|
|00003b00| 68 20 66 69 78 69 6e 67 | 2e 0a 20 2a 0a 20 2a 20 |h fixing|.. *. * |
|00003b10| 21 73 6b 21 20 20 4d 6f | 73 74 20 6f 66 20 6d 79 |!sk! Mo|st of my|
|00003b20| 20 63 68 61 6e 67 65 73 | 20 61 72 65 20 6c 6f 63 | changes| are loc|
|00003b30| 61 74 65 64 20 68 65 72 | 65 2e 20 20 49 20 66 69 |ated her|e. I fi|
|00003b40| 78 65 64 20 74 68 65 20 | 62 61 63 6b 73 6c 61 73 |xed the |backslas|
|00003b50| 68 20 62 75 67 2c 20 61 | 6e 64 0a 20 2a 20 6d 6f |h bug, a|nd. * mo|
|00003b60| 64 69 66 69 65 64 20 74 | 68 69 6e 67 73 20 73 6f |dified t|hings so|
|00003b70| 20 74 68 61 74 20 28 29 | 3c 3e 7c 20 61 72 65 20 | that ()|<>| are |
|00003b80| 6f 6e 6c 79 20 73 70 65 | 63 69 61 6c 20 77 68 65 |only spe|cial whe|
|00003b90| 6e 20 70 72 65 63 65 64 | 65 64 20 62 79 20 61 20 |n preced|ed by a |
|00003ba0| 62 61 63 6b 73 6c 61 73 | 68 0a 20 2a 20 53 69 6e |backslas|h. * Sin|
|00003bb0| 63 65 20 49 27 6d 20 73 | 68 6f 65 68 6f 72 6e 69 |ce I'm s|hoehorni|
|00003bc0| 6e 67 20 74 68 69 73 20 | 69 6e 74 6f 20 63 6f 64 |ng this |into cod|
|00003bd0| 65 20 77 68 69 63 68 20 | 64 69 64 6e 27 74 20 70 |e which |didn't p|
|00003be0| 61 72 74 69 63 75 6c 61 | 72 6c 79 20 63 61 72 65 |articula|rly care|
|00003bf0| 20 61 62 6f 75 74 0a 20 | 2a 20 62 61 63 6b 73 6c | about. |* backsl|
|00003c00| 61 73 68 65 73 2c 20 69 | 6e 74 65 72 66 61 63 65 |ashes, i|nterface|
|00003c10| 73 20 61 72 65 20 61 20 | 62 69 74 20 72 6f 75 67 |s are a |bit roug|
|00003c20| 68 2e 20 20 54 68 69 73 | 20 72 6f 75 74 69 6e 65 |h. This| routine|
|00003c30| 20 65 78 70 65 63 74 73 | 20 74 6f 20 62 65 20 63 | expects| to be c|
|00003c40| 61 6c 6c 65 64 0a 20 2a | 20 77 69 74 68 20 72 65 |alled. *| with re|
|00003c50| 67 70 61 72 73 65 20 70 | 6f 69 6e 74 69 6e 67 20 |gparse p|ointing |
|00003c60| 74 6f 20 61 20 62 61 63 | 6b 73 6c 61 73 68 2c 20 |to a bac|kslash, |
|00003c70| 69 66 20 74 68 65 72 65 | 20 69 73 20 6f 6e 65 3b |if there| is one;|
|00003c80| 20 62 75 74 20 69 74 20 | 65 78 69 74 73 20 77 69 | but it |exits wi|
|00003c90| 74 68 0a 20 2a 20 72 65 | 67 70 61 72 73 65 20 70 |th. * re|gparse p|
|00003ca0| 6f 69 6e 74 69 6e 67 20 | 74 6f 20 74 68 65 20 28 |ointing |to the (|
|00003cb0| 29 7c 20 41 46 54 45 52 | 20 74 68 65 20 62 61 63 |)| AFTER| the bac|
|00003cc0| 6b 73 6c 61 73 68 2c 20 | 65 78 63 65 70 74 20 66 |kslash, |except f|
|00003cd0| 6f 72 20 5c 3c 20 61 6e | 64 20 5c 3e 2e 0a 20 2a |or \< an|d \>.. *|
|00003ce0| 20 59 65 61 68 2c 20 72 | 65 61 6c 6c 79 20 6d 65 | Yeah, r|eally me|
|00003cf0| 73 73 79 2e 0a 20 2a 2f | 0a 73 74 61 74 69 63 20 |ssy.. */|.static |
|00003d00| 63 68 61 72 20 2a 0a 72 | 65 67 61 74 6f 6d 28 66 |char *.r|egatom(f|
|00003d10| 6c 61 67 70 29 0a 69 6e | 74 20 2a 66 6c 61 67 70 |lagp).in|t *flagp|
|00003d20| 3b 0a 7b 0a 20 20 72 65 | 67 69 73 74 65 72 20 63 |;.{. re|gister c|
|00003d30| 68 61 72 20 2a 72 65 74 | 3b 0a 20 20 69 6e 74 20 |har *ret|;. int |
|00003d40| 66 6c 61 67 73 3b 0a 20 | 20 72 65 67 69 73 74 65 |flags;. | registe|
|00003d50| 72 20 69 6e 74 20 6c 65 | 6e 3b 0a 20 20 72 65 67 |r int le|n;. reg|
|00003d60| 69 73 74 65 72 20 63 68 | 61 72 20 65 6e 64 65 72 |ister ch|ar ender|
|00003d70| 3b 0a 20 20 69 6e 74 20 | 6d 6f 72 65 3b 0a 0a 20 |;. int |more;.. |
|00003d80| 20 2a 66 6c 61 67 70 20 | 3d 20 57 4f 52 53 54 3b | *flagp |= WORST;|
|00003d90| 09 09 2f 2a 20 54 65 6e | 74 61 74 69 76 65 6c 79 |../* Ten|tatively|
|00003da0| 2e 20 2a 2f 0a 0a 20 20 | 2f 2a 20 54 68 65 20 66 |. */.. |/* The f|
|00003db0| 69 72 73 74 20 63 68 61 | 72 61 63 74 65 72 20 6d |irst cha|racter m|
|00003dc0| 61 79 20 62 65 20 73 70 | 65 63 69 61 6c 20 2a 2f |ay be sp|ecial */|
|00003dd0| 0a 20 20 73 77 69 74 63 | 68 20 28 2a 72 65 67 70 |. switc|h (*regp|
|00003de0| 61 72 73 65 2b 2b 29 20 | 7b 0a 20 20 63 61 73 65 |arse++) |{. case|
|00003df0| 20 27 5e 27 3a 0a 09 72 | 65 74 75 72 6e 20 72 65 | '^':..r|eturn re|
|00003e00| 67 6e 6f 64 65 28 42 4f | 4c 29 3b 0a 0a 20 20 63 |gnode(BO|L);.. c|
|00003e10| 61 73 65 20 27 24 27 3a | 0a 09 72 65 74 75 72 6e |ase '$':|..return|
|00003e20| 20 72 65 67 6e 6f 64 65 | 28 45 4f 4c 29 3b 0a 0a | regnode|(EOL);..|
|00003e30| 20 20 63 61 73 65 20 27 | 2e 27 3a 0a 09 69 66 20 | case '|.':..if |
|00003e40| 28 2a 6f 5f 6d 61 67 69 | 63 29 20 7b 0a 09 09 72 |(*o_magi|c) {...r|
|00003e50| 65 74 20 3d 20 72 65 67 | 6e 6f 64 65 28 41 4e 59 |et = reg|node(ANY|
|00003e60| 29 3b 0a 09 09 2a 66 6c | 61 67 70 20 7c 3d 20 48 |);...*fl|agp |= H|
|00003e70| 41 53 57 49 44 54 48 7c | 53 49 4d 50 4c 45 3b 0a |ASWIDTH||SIMPLE;.|
|00003e80| 09 09 72 65 74 75 72 6e | 20 72 65 74 3b 0a 09 7d |..return| ret;..}|
|00003e90| 0a 09 62 72 65 61 6b 3b | 0a 20 20 63 61 73 65 20 |..break;|. case |
|00003ea0| 27 5b 27 3a 0a 09 69 66 | 20 28 2a 6f 5f 6d 61 67 |'[':..if| (*o_mag|
|00003eb0| 69 63 29 20 7b 0a 09 09 | 72 65 67 69 73 74 65 72 |ic) {...|register|
|00003ec0| 20 69 6e 74 20 63 6c 61 | 73 73 3b 0a 09 09 72 65 | int cla|ss;...re|
|00003ed0| 67 69 73 74 65 72 20 69 | 6e 74 20 63 6c 61 73 73 |gister i|nt class|
|00003ee0| 65 6e 64 3b 0a 0a 09 09 | 69 66 20 28 2a 72 65 67 |end;....|if (*reg|
|00003ef0| 70 61 72 73 65 20 3d 3d | 20 27 5e 27 29 20 7b 09 |parse ==| '^') {.|
|00003f00| 2f 2a 20 43 6f 6d 70 6c | 65 6d 65 6e 74 20 6f 66 |/* Compl|ement of|
|00003f10| 20 72 61 6e 67 65 2e 20 | 2a 2f 0a 09 09 09 72 65 | range. |*/....re|
|00003f20| 74 20 3d 20 72 65 67 6e | 6f 64 65 28 41 4e 59 42 |t = regn|ode(ANYB|
|00003f30| 55 54 29 3b 0a 09 09 09 | 72 65 67 70 61 72 73 65 |UT);....|regparse|
|00003f40| 2b 2b 3b 0a 09 09 7d 20 | 65 6c 73 65 0a 09 09 09 |++;...} |else....|
|00003f50| 72 65 74 20 3d 20 72 65 | 67 6e 6f 64 65 28 41 4e |ret = re|gnode(AN|
|00003f60| 59 4f 46 29 3b 0a 09 09 | 69 66 20 28 2a 72 65 67 |YOF);...|if (*reg|
|00003f70| 70 61 72 73 65 20 3d 3d | 20 27 5d 27 20 7c 7c 20 |parse ==| ']' || |
|00003f80| 2a 72 65 67 70 61 72 73 | 65 20 3d 3d 20 27 2d 27 |*regpars|e == '-'|
|00003f90| 29 0a 09 09 09 72 65 67 | 63 28 2a 72 65 67 70 61 |)....reg|c(*regpa|
|00003fa0| 72 73 65 2b 2b 29 3b 0a | 09 09 77 68 69 6c 65 20 |rse++);.|..while |
|00003fb0| 28 2a 72 65 67 70 61 72 | 73 65 20 21 3d 20 27 5c |(*regpar|se != '\|
|00003fc0| 30 27 20 26 26 20 2a 72 | 65 67 70 61 72 73 65 20 |0' && *r|egparse |
|00003fd0| 21 3d 20 27 5d 27 29 20 | 7b 0a 09 09 09 69 66 20 |!= ']') |{....if |
|00003fe0| 28 2a 72 65 67 70 61 72 | 73 65 20 3d 3d 20 27 2d |(*regpar|se == '-|
|00003ff0| 27 29 20 7b 0a 09 09 09 | 09 72 65 67 70 61 72 73 |') {....|.regpars|
|00004000| 65 2b 2b 3b 0a 09 09 09 | 09 69 66 20 28 2a 72 65 |e++;....|.if (*re|
|00004010| 67 70 61 72 73 65 20 3d | 3d 20 27 5d 27 20 7c 7c |gparse =|= ']' |||
|00004020| 20 2a 72 65 67 70 61 72 | 73 65 20 3d 3d 20 27 5c | *regpar|se == '\|
|00004030| 30 27 29 0a 09 09 09 09 | 09 72 65 67 63 28 27 2d |0').....|.regc('-|
|00004040| 27 29 3b 0a 09 09 09 09 | 65 6c 73 65 20 7b 0a 09 |');.....|else {..|
|00004050| 09 09 09 09 63 6c 61 73 | 73 20 3d 20 55 43 48 41 |....clas|s = UCHA|
|00004060| 52 41 54 28 72 65 67 70 | 61 72 73 65 2d 32 29 2b |RAT(regp|arse-2)+|
|00004070| 31 3b 0a 09 09 09 09 09 | 63 6c 61 73 73 65 6e 64 |1;......|classend|
|00004080| 20 3d 20 55 43 48 41 52 | 41 54 28 72 65 67 70 61 | = UCHAR|AT(regpa|
|00004090| 72 73 65 29 3b 0a 09 09 | 09 09 09 69 66 20 28 63 |rse);...|...if (c|
|000040a0| 6c 61 73 73 20 3e 20 63 | 6c 61 73 73 65 6e 64 2b |lass > c|lassend+|
|000040b0| 31 29 0a 09 09 09 09 09 | 09 46 41 49 4c 28 22 69 |1)......|.FAIL("i|
|000040c0| 6e 76 61 6c 69 64 20 5b | 5d 20 72 61 6e 67 65 22 |nvalid [|] range"|
|000040d0| 29 3b 0a 09 09 09 09 09 | 66 6f 72 20 28 3b 20 63 |);......|for (; c|
|000040e0| 6c 61 73 73 20 3c 3d 20 | 63 6c 61 73 73 65 6e 64 |lass <= |classend|
|000040f0| 3b 20 63 6c 61 73 73 2b | 2b 29 0a 09 09 09 09 09 |; class+|+)......|
|00004100| 09 72 65 67 63 28 63 6c | 61 73 73 29 3b 0a 09 09 |.regc(cl|ass);...|
|00004110| 09 09 09 72 65 67 70 61 | 72 73 65 2b 2b 3b 0a 09 |...regpa|rse++;..|
|00004120| 09 09 09 7d 0a 09 09 09 | 7d 20 65 6c 73 65 0a 09 |...}....|} else..|
|00004130| 09 09 09 72 65 67 63 28 | 2a 72 65 67 70 61 72 73 |...regc(|*regpars|
|00004140| 65 2b 2b 29 3b 0a 09 09 | 7d 0a 09 09 72 65 67 63 |e++);...|}...regc|
|00004150| 28 27 5c 30 27 29 3b 0a | 09 09 69 66 20 28 2a 72 |('\0');.|..if (*r|
|00004160| 65 67 70 61 72 73 65 20 | 21 3d 20 27 5d 27 29 0a |egparse |!= ']').|
|00004170| 09 09 09 46 41 49 4c 28 | 22 75 6e 6d 61 74 63 68 |...FAIL(|"unmatch|
|00004180| 65 64 20 5b 5d 22 29 3b | 0a 09 09 72 65 67 70 61 |ed []");|...regpa|
|00004190| 72 73 65 2b 2b 3b 0a 09 | 09 2a 66 6c 61 67 70 20 |rse++;..|.*flagp |
|000041a0| 7c 3d 20 48 41 53 57 49 | 44 54 48 7c 53 49 4d 50 ||= HASWI|DTH|SIMP|
|000041b0| 4c 45 3b 0a 0a 09 09 72 | 65 74 75 72 6e 20 72 65 |LE;....r|eturn re|
|000041c0| 74 3b 0a 09 7d 0a 09 62 | 72 65 61 6b 3b 0a 0a 20 |t;..}..b|reak;.. |
|000041d0| 20 63 61 73 65 20 27 5c | 5c 27 3a 0a 09 69 66 20 | case '\|\':..if |
|000041e0| 28 2a 6f 5f 6d 61 67 69 | 63 29 20 7b 0a 09 09 73 |(*o_magi|c) {...s|
|000041f0| 77 69 74 63 68 20 28 2a | 72 65 67 70 61 72 73 65 |witch (*|regparse|
|00004200| 2b 2b 29 20 7b 0a 09 09 | 63 61 73 65 20 27 28 27 |++) {...|case '('|
|00004210| 3a 0a 09 09 09 72 65 74 | 20 3d 20 72 65 67 28 31 |:....ret| = reg(1|
|00004220| 2c 20 26 66 6c 61 67 73 | 29 3b 0a 09 09 09 69 66 |, &flags|);....if|
|00004230| 20 28 72 65 74 20 3d 3d | 20 4e 55 4c 4c 29 0a 09 | (ret ==| NULL)..|
|00004240| 09 09 09 72 65 74 75 72 | 6e 28 4e 55 4c 4c 29 3b |...retur|n(NULL);|
|00004250| 0a 09 09 09 2a 66 6c 61 | 67 70 20 7c 3d 20 66 6c |....*fla|gp |= fl|
|00004260| 61 67 73 26 28 48 41 53 | 57 49 44 54 48 7c 53 50 |ags&(HAS|WIDTH|SP|
|00004270| 53 54 41 52 54 29 3b 0a | 09 09 09 72 65 74 75 72 |START);.|...retur|
|00004280| 6e 20 72 65 74 3b 0a 0a | 09 09 63 61 73 65 20 27 |n ret;..|..case '|
|00004290| 5c 30 27 3a 0a 09 09 63 | 61 73 65 20 27 7c 27 3a |\0':...c|ase '|':|
|000042a0| 0a 09 09 63 61 73 65 20 | 27 29 27 3a 0a 09 09 09 |...case |')':....|
|000042b0| 46 41 49 4c 28 22 69 6e | 74 65 72 6e 61 6c 20 75 |FAIL("in|ternal u|
|000042c0| 72 70 22 29 3b 09 2f 2a | 20 53 75 70 70 6f 73 65 |rp");./*| Suppose|
|000042d0| 64 20 74 6f 20 62 65 20 | 63 61 75 67 68 74 20 65 |d to be |caught e|
|000042e0| 61 72 6c 69 65 72 2e 20 | 2a 2f 0a 0a 09 09 63 61 |arlier. |*/....ca|
|000042f0| 73 65 20 27 3c 27 3a 0a | 09 09 09 72 65 74 75 72 |se '<':.|...retur|
|00004300| 6e 20 72 65 67 6e 6f 64 | 65 28 42 4f 57 29 3b 0a |n regnod|e(BOW);.|
|00004310| 0a 09 09 63 61 73 65 20 | 27 3e 27 3a 0a 09 09 09 |...case |'>':....|
|00004320| 72 65 74 75 72 6e 20 72 | 65 67 6e 6f 64 65 28 45 |return r|egnode(E|
|00004330| 4f 57 29 3b 0a 0a 09 09 | 7d 0a 09 09 72 65 67 70 |OW);....|}...regp|
|00004340| 61 72 73 65 2d 2d 3b 0a | 09 7d 0a 09 62 72 65 61 |arse--;.|.}..brea|
|00004350| 6b 3b 0a 0a 20 20 63 61 | 73 65 20 27 3f 27 3a 0a |k;.. ca|se '?':.|
|00004360| 20 20 63 61 73 65 20 27 | 2b 27 3a 0a 20 20 63 61 | case '|+':. ca|
|00004370| 73 65 20 27 2a 27 3a 0a | 09 69 66 20 28 2a 6f 5f |se '*':.|.if (*o_|
|00004380| 6d 61 67 69 63 29 0a 09 | 7b 0a 09 09 46 41 49 4c |magic)..|{...FAIL|
|00004390| 28 22 3f 2b 2a 20 66 6f | 6c 6c 6f 77 73 20 6e 6f |("?+* fo|llows no|
|000043a0| 74 68 69 6e 67 22 29 3b | 0a 09 7d 0a 09 62 72 65 |thing");|..}..bre|
|000043b0| 61 6b 3b 0a 20 20 7d 0a | 0a 20 20 2f 2a 20 54 68 |ak;. }.|. /* Th|
|000043c0| 65 20 66 69 72 73 74 20 | 63 68 61 72 20 77 61 73 |e first |char was|
|000043d0| 6e 27 74 20 73 70 65 63 | 69 61 6c 2c 20 73 6f 20 |n't spec|ial, so |
|000043e0| 73 74 61 72 74 20 62 75 | 69 6c 64 69 6e 67 20 61 |start bu|ilding a|
|000043f0| 6e 20 45 58 41 43 54 4c | 59 20 73 74 72 69 6e 67 |n EXACTL|Y string|
|00004400| 20 2a 2f 0a 20 20 72 65 | 67 70 61 72 73 65 2d 2d | */. re|gparse--|
|00004410| 3b 0a 20 20 66 6f 72 20 | 28 6c 65 6e 20 3d 20 30 |;. for |(len = 0|
|00004420| 2c 20 6d 6f 72 65 20 3d | 20 31 3b 20 72 65 67 70 |, more =| 1; regp|
|00004430| 61 72 73 65 5b 6c 65 6e | 5d 20 26 26 20 6d 6f 72 |arse[len|] && mor|
|00004440| 65 3b 20 6c 65 6e 2b 2b | 29 20 7b 0a 09 73 77 69 |e; len++|) {..swi|
|00004450| 74 63 68 20 28 72 65 67 | 70 61 72 73 65 5b 6c 65 |tch (reg|parse[le|
|00004460| 6e 5d 29 20 7b 0a 09 63 | 61 73 65 20 27 5e 27 3a |n]) {..c|ase '^':|
|00004470| 0a 09 63 61 73 65 20 27 | 24 27 3a 0a 09 09 6c 65 |..case '|$':...le|
|00004480| 6e 2d 2d 3b 0a 09 09 6d | 6f 72 65 20 3d 20 30 3b |n--;...m|ore = 0;|
|00004490| 0a 09 09 62 72 65 61 6b | 3b 0a 09 63 61 73 65 20 |...break|;..case |
|000044a0| 27 2b 27 3a 0a 09 63 61 | 73 65 20 27 2a 27 3a 0a |'+':..ca|se '*':.|
|000044b0| 09 63 61 73 65 20 27 3f | 27 3a 0a 09 63 61 73 65 |.case '?|':..case|
|000044c0| 20 27 2e 27 3a 0a 09 63 | 61 73 65 20 27 5b 27 3a | '.':..c|ase '[':|
|000044d0| 0a 09 09 69 66 20 28 2a | 6f 5f 6d 61 67 69 63 29 |...if (*|o_magic)|
|000044e0| 20 7b 0a 09 09 09 6c 65 | 6e 2d 2d 3b 0a 09 09 09 | {....le|n--;....|
|000044f0| 6d 6f 72 65 20 3d 20 30 | 3b 0a 09 09 7d 0a 09 09 |more = 0|;...}...|
|00004500| 62 72 65 61 6b 3b 0a 09 | 63 61 73 65 20 27 5c 5c |break;..|case '\\|
|00004510| 27 3a 0a 09 09 73 77 69 | 74 63 68 20 28 72 65 67 |':...swi|tch (reg|
|00004520| 70 61 72 73 65 5b 2b 2b | 6c 65 6e 5d 29 20 7b 0a |parse[++|len]) {.|
|00004530| 09 09 63 61 73 65 20 27 | 3c 27 3a 0a 09 09 63 61 |..case '|<':...ca|
|00004540| 73 65 20 27 3e 27 3a 0a | 09 09 63 61 73 65 20 27 |se '>':.|..case '|
|00004550| 28 27 3a 0a 09 09 63 61 | 73 65 20 27 29 27 3a 0a |(':...ca|se ')':.|
|00004560| 09 09 63 61 73 65 20 27 | 7c 27 3a 0a 09 09 09 6c |..case '||':....l|
|00004570| 65 6e 20 2d 3d 20 32 3b | 20 2f 2a 20 70 75 74 20 |en -= 2;| /* put |
|00004580| 74 68 65 20 77 68 6f 6c | 65 20 5c 3c 20 6f 72 20 |the whol|e \< or |
|00004590| 5c 3e 20 62 61 63 6b 20 | 69 6e 20 73 74 72 69 6e |\> back |in strin|
|000045a0| 67 20 2a 2f 0a 09 09 09 | 6d 6f 72 65 20 3d 20 30 |g */....|more = 0|
|000045b0| 3b 0a 09 09 09 62 72 65 | 61 6b 3b 0a 09 09 63 61 |;....bre|ak;...ca|
|000045c0| 73 65 20 27 5c 30 27 3a | 0a 09 09 09 46 41 49 4c |se '\0':|....FAIL|
|000045d0| 28 22 54 72 61 69 6c 69 | 6e 67 20 5c 5c 22 29 3b |("Traili|ng \\");|
|000045e0| 0a 0a 09 09 7d 0a 09 09 | 62 72 65 61 6b 3b 0a 09 |....}...|break;..|
|000045f0| 7d 0a 20 20 7d 0a 20 20 | 69 66 20 28 6c 65 6e 20 |}. }. |if (len |
|00004600| 3c 3d 20 30 29 0a 09 46 | 41 49 4c 28 22 69 6e 74 |<= 0)..F|AIL("int|
|00004610| 65 72 6e 61 6c 20 64 69 | 73 61 73 74 65 72 22 29 |ernal di|saster")|
|00004620| 3b 0a 20 20 65 6e 64 65 | 72 20 3d 20 2a 28 72 65 |;. ende|r = *(re|
|00004630| 67 70 61 72 73 65 2b 6c | 65 6e 29 3b 0a 20 20 69 |gparse+l|en);. i|
|00004640| 66 20 28 6c 65 6e 20 3e | 20 31 20 26 26 20 49 53 |f (len >| 1 && IS|
|00004650| 4d 55 4c 54 28 65 6e 64 | 65 72 29 29 0a 09 6c 65 |MULT(end|er))..le|
|00004660| 6e 2d 2d 3b 09 09 2f 2a | 20 42 61 63 6b 20 6f 66 |n--;../*| Back of|
|00004670| 66 20 63 6c 65 61 72 20 | 6f 66 20 3f 2b 2a 20 6f |f clear |of ?+* o|
|00004680| 70 65 72 61 6e 64 2e 20 | 2a 2f 0a 20 20 2a 66 6c |perand. |*/. *fl|
|00004690| 61 67 70 20 7c 3d 20 48 | 41 53 57 49 44 54 48 3b |agp |= H|ASWIDTH;|
|000046a0| 0a 20 20 69 66 20 28 6c | 65 6e 20 3d 3d 20 31 29 |. if (l|en == 1)|
|000046b0| 0a 09 2a 66 6c 61 67 70 | 20 7c 3d 20 53 49 4d 50 |..*flagp| |= SIMP|
|000046c0| 4c 45 3b 0a 20 20 72 65 | 74 20 3d 20 72 65 67 6e |LE;. re|t = regn|
|000046d0| 6f 64 65 28 45 58 41 43 | 54 4c 59 29 3b 0a 20 20 |ode(EXAC|TLY);. |
|000046e0| 77 68 69 6c 65 20 28 6c | 65 6e 20 3e 20 30 29 20 |while (l|en > 0) |
|000046f0| 7b 0a 09 69 66 20 28 2a | 72 65 67 70 61 72 73 65 |{..if (*|regparse|
|00004700| 20 3d 3d 20 27 5c 5c 27 | 29 20 7b 0a 09 09 72 65 | == '\\'|) {...re|
|00004710| 67 70 61 72 73 65 2b 2b | 3b 0a 09 09 6c 65 6e 2d |gparse++|;...len-|
|00004720| 2d 3b 0a 09 09 69 66 20 | 28 6c 65 6e 20 3d 3d 20 |-;...if |(len == |
|00004730| 30 29 0a 09 09 09 62 72 | 65 61 6b 3b 0a 09 7d 0a |0)....br|eak;..}.|
|00004740| 09 72 65 67 63 28 2a 72 | 65 67 70 61 72 73 65 2b |.regc(*r|egparse+|
|00004750| 2b 29 3b 0a 09 6c 65 6e | 2d 2d 3b 0a 20 20 7d 0a |+);..len|--;. }.|
|00004760| 20 20 72 65 67 63 28 27 | 5c 30 27 29 3b 0a 0a 20 | regc('|\0');.. |
|00004770| 20 72 65 74 75 72 6e 28 | 72 65 74 29 3b 0a 7d 0a | return(|ret);.}.|
|00004780| 0a 2f 2a 0a 20 2d 20 72 | 65 67 6e 6f 64 65 20 2d |./*. - r|egnode -|
|00004790| 20 65 6d 69 74 20 61 20 | 6e 6f 64 65 0a 20 2a 2f | emit a |node. */|
|000047a0| 0a 73 74 61 74 69 63 20 | 63 68 61 72 20 2a 09 09 |.static |char *..|
|000047b0| 09 2f 2a 20 4c 6f 63 61 | 74 69 6f 6e 2e 20 2a 2f |./* Loca|tion. */|
|000047c0| 0a 72 65 67 6e 6f 64 65 | 28 6f 70 29 0a 63 68 61 |.regnode|(op).cha|
|000047d0| 72 20 6f 70 3b 0a 7b 0a | 20 20 72 65 67 69 73 74 |r op;.{.| regist|
|000047e0| 65 72 20 63 68 61 72 20 | 2a 72 65 74 3b 0a 20 20 |er char |*ret;. |
|000047f0| 72 65 67 69 73 74 65 72 | 20 63 68 61 72 20 2a 70 |register| char *p|
|00004800| 74 72 3b 0a 0a 20 20 72 | 65 74 20 3d 20 72 65 67 |tr;.. r|et = reg|
|00004810| 63 6f 64 65 3b 0a 20 20 | 69 66 20 28 72 65 74 20 |code;. |if (ret |
|00004820| 3d 3d 20 26 72 65 67 64 | 75 6d 6d 79 29 20 7b 0a |== ®d|ummy) {.|
|00004830| 09 72 65 67 73 69 7a 65 | 20 2b 3d 20 33 3b 0a 09 |.regsize| += 3;..|
|00004840| 72 65 74 75 72 6e 28 72 | 65 74 29 3b 0a 20 20 7d |return(r|et);. }|
|00004850| 0a 0a 20 20 70 74 72 20 | 3d 20 72 65 74 3b 0a 20 |.. ptr |= ret;. |
|00004860| 20 2a 70 74 72 2b 2b 20 | 3d 20 6f 70 3b 0a 20 20 | *ptr++ |= op;. |
|00004870| 2a 70 74 72 2b 2b 20 3d | 20 27 5c 30 27 3b 09 09 |*ptr++ =| '\0';..|
|00004880| 2f 2a 20 4e 75 6c 6c 20 | 22 6e 65 78 74 22 20 70 |/* Null |"next" p|
|00004890| 6f 69 6e 74 65 72 2e 20 | 2a 2f 0a 20 20 2a 70 74 |ointer. |*/. *pt|
|000048a0| 72 2b 2b 20 3d 20 27 5c | 30 27 3b 0a 20 20 72 65 |r++ = '\|0';. re|
|000048b0| 67 63 6f 64 65 20 3d 20 | 70 74 72 3b 0a 0a 20 20 |gcode = |ptr;.. |
|000048c0| 72 65 74 75 72 6e 28 72 | 65 74 29 3b 0a 7d 0a 0a |return(r|et);.}..|
|000048d0| 2f 2a 0a 20 2d 20 72 65 | 67 63 20 2d 20 65 6d 69 |/*. - re|gc - emi|
|000048e0| 74 20 28 69 66 20 61 70 | 70 72 6f 70 72 69 61 74 |t (if ap|propriat|
|000048f0| 65 29 20 61 20 62 79 74 | 65 20 6f 66 20 63 6f 64 |e) a byt|e of cod|
|00004900| 65 0a 20 2a 2f 0a 73 74 | 61 74 69 63 20 76 6f 69 |e. */.st|atic voi|
|00004910| 64 0a 72 65 67 63 28 62 | 29 0a 63 68 61 72 20 62 |d.regc(b|).char b|
|00004920| 3b 0a 7b 0a 20 20 69 66 | 20 28 72 65 67 63 6f 64 |;.{. if| (regcod|
|00004930| 65 20 21 3d 20 26 72 65 | 67 64 75 6d 6d 79 29 0a |e != &re|gdummy).|
|00004940| 09 2a 72 65 67 63 6f 64 | 65 2b 2b 20 3d 20 62 3b |.*regcod|e++ = b;|
|00004950| 0a 20 20 65 6c 73 65 0a | 09 72 65 67 73 69 7a 65 |. else.|.regsize|
|00004960| 2b 2b 3b 0a 7d 0a 0a 2f | 2a 0a 20 2d 20 72 65 67 |++;.}../|*. - reg|
|00004970| 69 6e 73 65 72 74 20 2d | 20 69 6e 73 65 72 74 20 |insert -| insert |
|00004980| 61 6e 20 6f 70 65 72 61 | 74 6f 72 20 69 6e 20 66 |an opera|tor in f|
|00004990| 72 6f 6e 74 20 6f 66 20 | 61 6c 72 65 61 64 79 2d |ront of |already-|
|000049a0| 65 6d 69 74 74 65 64 20 | 6f 70 65 72 61 6e 64 0a |emitted |operand.|
|000049b0| 20 2a 0a 20 2a 20 4d 65 | 61 6e 73 20 72 65 6c 6f | *. * Me|ans relo|
|000049c0| 63 61 74 69 6e 67 20 74 | 68 65 20 6f 70 65 72 61 |cating t|he opera|
|000049d0| 6e 64 2e 0a 20 2a 2f 0a | 73 74 61 74 69 63 20 76 |nd.. */.|static v|
|000049e0| 6f 69 64 0a 72 65 67 69 | 6e 73 65 72 74 28 6f 70 |oid.regi|nsert(op|
|000049f0| 2c 20 6f 70 6e 64 29 0a | 63 68 61 72 20 6f 70 3b |, opnd).|char op;|
|00004a00| 0a 63 68 61 72 20 2a 6f | 70 6e 64 3b 0a 7b 0a 20 |.char *o|pnd;.{. |
|00004a10| 20 72 65 67 69 73 74 65 | 72 20 63 68 61 72 20 2a | registe|r char *|
|00004a20| 73 72 63 3b 0a 20 20 72 | 65 67 69 73 74 65 72 20 |src;. r|egister |
|00004a30| 63 68 61 72 20 2a 64 73 | 74 3b 0a 20 20 72 65 67 |char *ds|t;. reg|
|00004a40| 69 73 74 65 72 20 63 68 | 61 72 20 2a 70 6c 61 63 |ister ch|ar *plac|
|00004a50| 65 3b 0a 0a 20 20 69 66 | 20 28 72 65 67 63 6f 64 |e;.. if| (regcod|
|00004a60| 65 20 3d 3d 20 26 72 65 | 67 64 75 6d 6d 79 29 20 |e == &re|gdummy) |
|00004a70| 7b 0a 09 72 65 67 73 69 | 7a 65 20 2b 3d 20 33 3b |{..regsi|ze += 3;|
|00004a80| 0a 09 72 65 74 75 72 6e | 3b 0a 20 20 7d 0a 0a 20 |..return|;. }.. |
|00004a90| 20 73 72 63 20 3d 20 72 | 65 67 63 6f 64 65 3b 0a | src = r|egcode;.|
|00004aa0| 20 20 72 65 67 63 6f 64 | 65 20 2b 3d 20 33 3b 0a | regcod|e += 3;.|
|00004ab0| 20 20 64 73 74 20 3d 20 | 72 65 67 63 6f 64 65 3b | dst = |regcode;|
|00004ac0| 0a 20 20 77 68 69 6c 65 | 20 28 73 72 63 20 3e 20 |. while| (src > |
|00004ad0| 6f 70 6e 64 29 0a 09 2a | 2d 2d 64 73 74 20 3d 20 |opnd)..*|--dst = |
|00004ae0| 2a 2d 2d 73 72 63 3b 0a | 0a 20 20 70 6c 61 63 65 |*--src;.|. place|
|00004af0| 20 3d 20 6f 70 6e 64 3b | 09 09 2f 2a 20 4f 70 20 | = opnd;|../* Op |
|00004b00| 6e 6f 64 65 2c 20 77 68 | 65 72 65 20 6f 70 65 72 |node, wh|ere oper|
|00004b10| 61 6e 64 20 75 73 65 64 | 20 74 6f 20 62 65 2e 20 |and used| to be. |
|00004b20| 2a 2f 0a 20 20 2a 70 6c | 61 63 65 2b 2b 20 3d 20 |*/. *pl|ace++ = |
|00004b30| 6f 70 3b 0a 20 20 2a 70 | 6c 61 63 65 2b 2b 20 3d |op;. *p|lace++ =|
|00004b40| 20 27 5c 30 27 3b 0a 20 | 20 2a 70 6c 61 63 65 2b | '\0';. | *place+|
|00004b50| 2b 20 3d 20 27 5c 30 27 | 3b 0a 7d 0a 0a 2f 2a 0a |+ = '\0'|;.}../*.|
|00004b60| 20 2d 20 72 65 67 74 61 | 69 6c 20 2d 20 73 65 74 | - regta|il - set|
|00004b70| 20 74 68 65 20 6e 65 78 | 74 2d 70 6f 69 6e 74 65 | the nex|t-pointe|
|00004b80| 72 20 61 74 20 74 68 65 | 20 65 6e 64 20 6f 66 20 |r at the| end of |
|00004b90| 61 20 6e 6f 64 65 20 63 | 68 61 69 6e 0a 20 2a 2f |a node c|hain. */|
|00004ba0| 0a 73 74 61 74 69 63 20 | 76 6f 69 64 0a 72 65 67 |.static |void.reg|
|00004bb0| 74 61 69 6c 28 70 2c 20 | 76 61 6c 29 0a 63 68 61 |tail(p, |val).cha|
|00004bc0| 72 20 2a 70 3b 0a 63 68 | 61 72 20 2a 76 61 6c 3b |r *p;.ch|ar *val;|
|00004bd0| 0a 7b 0a 20 20 72 65 67 | 69 73 74 65 72 20 63 68 |.{. reg|ister ch|
|00004be0| 61 72 20 2a 73 63 61 6e | 3b 0a 20 20 72 65 67 69 |ar *scan|;. regi|
|00004bf0| 73 74 65 72 20 63 68 61 | 72 20 2a 74 65 6d 70 3b |ster cha|r *temp;|
|00004c00| 0a 20 20 72 65 67 69 73 | 74 65 72 20 69 6e 74 20 |. regis|ter int |
|00004c10| 6f 66 66 73 65 74 3b 0a | 0a 20 20 69 66 20 28 70 |offset;.|. if (p|
|00004c20| 20 3d 3d 20 26 72 65 67 | 64 75 6d 6d 79 29 0a 09 | == ®|dummy)..|
|00004c30| 72 65 74 75 72 6e 3b 0a | 0a 20 20 2f 2a 20 46 69 |return;.|. /* Fi|
|00004c40| 6e 64 20 6c 61 73 74 20 | 6e 6f 64 65 2e 20 2a 2f |nd last |node. */|
|00004c50| 0a 20 20 73 63 61 6e 20 | 3d 20 70 3b 0a 20 20 66 |. scan |= p;. f|
|00004c60| 6f 72 20 28 3b 3b 29 20 | 7b 0a 09 74 65 6d 70 20 |or (;;) |{..temp |
|00004c70| 3d 20 72 65 67 6e 65 78 | 74 28 73 63 61 6e 29 3b |= regnex|t(scan);|
|00004c80| 0a 09 69 66 20 28 74 65 | 6d 70 20 3d 3d 20 4e 55 |..if (te|mp == NU|
|00004c90| 4c 4c 29 0a 09 09 62 72 | 65 61 6b 3b 0a 09 73 63 |LL)...br|eak;..sc|
|00004ca0| 61 6e 20 3d 20 74 65 6d | 70 3b 0a 20 20 7d 0a 0a |an = tem|p;. }..|
|00004cb0| 20 20 69 66 20 28 4f 50 | 28 73 63 61 6e 29 20 3d | if (OP|(scan) =|
|00004cc0| 3d 20 42 41 43 4b 29 0a | 09 6f 66 66 73 65 74 20 |= BACK).|.offset |
|00004cd0| 3d 20 73 63 61 6e 20 2d | 20 76 61 6c 3b 0a 20 20 |= scan -| val;. |
|00004ce0| 65 6c 73 65 0a 09 6f 66 | 66 73 65 74 20 3d 20 76 |else..of|fset = v|
|00004cf0| 61 6c 20 2d 20 73 63 61 | 6e 3b 0a 20 20 2a 28 73 |al - sca|n;. *(s|
|00004d00| 63 61 6e 2b 31 29 20 3d | 20 28 6f 66 66 73 65 74 |can+1) =| (offset|
|00004d10| 3e 3e 38 29 26 30 33 37 | 37 3b 0a 20 20 2a 28 73 |>>8)&037|7;. *(s|
|00004d20| 63 61 6e 2b 32 29 20 3d | 20 6f 66 66 73 65 74 26 |can+2) =| offset&|
|00004d30| 30 33 37 37 3b 0a 7d 0a | 0a 2f 2a 0a 20 2d 20 72 |0377;.}.|./*. - r|
|00004d40| 65 67 6f 70 74 61 69 6c | 20 2d 20 72 65 67 74 61 |egoptail| - regta|
|00004d50| 69 6c 20 6f 6e 20 6f 70 | 65 72 61 6e 64 20 6f 66 |il on op|erand of|
|00004d60| 20 66 69 72 73 74 20 61 | 72 67 75 6d 65 6e 74 3b | first a|rgument;|
|00004d70| 20 6e 6f 70 20 69 66 20 | 6f 70 65 72 61 6e 64 6c | nop if |operandl|
|00004d80| 65 73 73 0a 20 2a 2f 0a | 73 74 61 74 69 63 20 76 |ess. */.|static v|
|00004d90| 6f 69 64 0a 72 65 67 6f | 70 74 61 69 6c 28 70 2c |oid.rego|ptail(p,|
|00004da0| 20 76 61 6c 29 0a 63 68 | 61 72 20 2a 70 3b 0a 63 | val).ch|ar *p;.c|
|00004db0| 68 61 72 20 2a 76 61 6c | 3b 0a 7b 0a 20 20 2f 2a |har *val|;.{. /*|
|00004dc0| 20 22 4f 70 65 72 61 6e | 64 6c 65 73 73 22 20 61 | "Operan|dless" a|
|00004dd0| 6e 64 20 22 6f 70 20 21 | 3d 20 42 52 41 4e 43 48 |nd "op !|= BRANCH|
|00004de0| 22 20 61 72 65 20 73 79 | 6e 6f 6e 79 6d 6f 75 73 |" are sy|nonymous|
|00004df0| 20 69 6e 20 70 72 61 63 | 74 69 63 65 2e 20 2a 2f | in prac|tice. */|
|00004e00| 0a 20 20 69 66 20 28 70 | 20 3d 3d 20 4e 55 4c 4c |. if (p| == NULL|
|00004e10| 20 7c 7c 20 70 20 3d 3d | 20 26 72 65 67 64 75 6d | || p ==| ®dum|
|00004e20| 6d 79 20 7c 7c 20 4f 50 | 28 70 29 20 21 3d 20 42 |my || OP|(p) != B|
|00004e30| 52 41 4e 43 48 29 0a 09 | 72 65 74 75 72 6e 3b 0a |RANCH)..|return;.|
|00004e40| 20 20 72 65 67 74 61 69 | 6c 28 4f 50 45 52 41 4e | regtai|l(OPERAN|
|00004e50| 44 28 70 29 2c 20 76 61 | 6c 29 3b 0a 7d 0a 0a 2f |D(p), va|l);.}../|
|00004e60| 2a 0a 20 2a 20 72 65 67 | 65 78 65 63 20 61 6e 64 |*. * reg|exec and|
|00004e70| 20 66 72 69 65 6e 64 73 | 0a 20 2a 2f 0a 0a 2f 2a | friends|. */../*|
|00004e80| 0a 20 2a 20 47 6c 6f 62 | 61 6c 20 77 6f 72 6b 20 |. * Glob|al work |
|00004e90| 76 61 72 69 61 62 6c 65 | 73 20 66 6f 72 20 72 65 |variable|s for re|
|00004ea0| 67 65 78 65 63 28 29 2e | 0a 20 2a 2f 0a 73 74 61 |gexec().|. */.sta|
|00004eb0| 74 69 63 20 63 68 61 72 | 20 2a 72 65 67 69 6e 70 |tic char| *reginp|
|00004ec0| 75 74 3b 09 09 2f 2a 20 | 53 74 72 69 6e 67 2d 69 |ut;../* |String-i|
|00004ed0| 6e 70 75 74 20 70 6f 69 | 6e 74 65 72 2e 20 2a 2f |nput poi|nter. */|
|00004ee0| 0a 73 74 61 74 69 63 20 | 63 68 61 72 20 2a 72 65 |.static |char *re|
|00004ef0| 67 62 6f 6c 3b 09 09 2f | 2a 20 42 65 67 69 6e 6e |gbol;../|* Beginn|
|00004f00| 69 6e 67 20 6f 66 20 69 | 6e 70 75 74 2c 20 66 6f |ing of i|nput, fo|
|00004f10| 72 20 5e 20 63 68 65 63 | 6b 2e 20 2a 2f 0a 73 74 |r ^ chec|k. */.st|
|00004f20| 61 74 69 63 20 63 68 61 | 72 20 2a 2a 72 65 67 73 |atic cha|r **regs|
|00004f30| 74 61 72 74 70 3b 09 2f | 2a 20 50 6f 69 6e 74 65 |tartp;./|* Pointe|
|00004f40| 72 20 74 6f 20 73 74 61 | 72 74 70 20 61 72 72 61 |r to sta|rtp arra|
|00004f50| 79 2e 20 2a 2f 0a 73 74 | 61 74 69 63 20 63 68 61 |y. */.st|atic cha|
|00004f60| 72 20 2a 2a 72 65 67 65 | 6e 64 70 3b 09 09 2f 2a |r **rege|ndp;../*|
|00004f70| 20 44 69 74 74 6f 20 66 | 6f 72 20 65 6e 64 70 2e | Ditto f|or endp.|
|00004f80| 20 2a 2f 0a 0a 2f 2a 0a | 20 2a 20 46 6f 72 77 61 | */../*.| * Forwa|
|00004f90| 72 64 73 2e 0a 20 2a 2f | 0a 53 54 41 54 49 43 20 |rds.. */|.STATIC |
|00004fa0| 69 6e 74 20 72 65 67 74 | 72 79 28 29 3b 0a 53 54 |int regt|ry();.ST|
|00004fb0| 41 54 49 43 20 69 6e 74 | 20 72 65 67 6d 61 74 63 |ATIC int| regmatc|
|00004fc0| 68 28 29 3b 0a 53 54 41 | 54 49 43 20 69 6e 74 20 |h();.STA|TIC int |
|00004fd0| 72 65 67 72 65 70 65 61 | 74 28 29 3b 0a 0a 23 69 |regrepea|t();..#i|
|00004fe0| 66 64 65 66 20 44 45 42 | 55 47 0a 69 6e 74 20 72 |fdef DEB|UG.int r|
|00004ff0| 65 67 6e 61 72 72 61 74 | 65 20 3d 20 30 3b 0a 76 |egnarrat|e = 0;.v|
|00005000| 6f 69 64 20 72 65 67 64 | 75 6d 70 28 29 3b 0a 53 |oid regd|ump();.S|
|00005010| 54 41 54 49 43 20 63 68 | 61 72 20 2a 72 65 67 70 |TATIC ch|ar *regp|
|00005020| 72 6f 70 28 29 3b 0a 23 | 65 6e 64 69 66 0a 0a 2f |rop();.#|endif../|
|00005030| 2a 0a 20 2d 20 72 65 67 | 65 78 65 63 20 2d 20 6d |*. - reg|exec - m|
|00005040| 61 74 63 68 20 61 20 72 | 65 67 65 78 70 20 61 67 |atch a r|egexp ag|
|00005050| 61 69 6e 73 74 20 61 20 | 73 74 72 69 6e 67 0a 20 |ainst a |string. |
|00005060| 2a 2f 0a 69 6e 74 0a 72 | 65 67 65 78 65 63 28 70 |*/.int.r|egexec(p|
|00005070| 72 6f 67 2c 20 73 74 72 | 69 6e 67 2c 20 62 6f 6c |rog, str|ing, bol|
|00005080| 66 6c 61 67 29 0a 72 65 | 67 69 73 74 65 72 20 72 |flag).re|gister r|
|00005090| 65 67 65 78 70 20 2a 70 | 72 6f 67 3b 0a 72 65 67 |egexp *p|rog;.reg|
|000050a0| 69 73 74 65 72 20 63 68 | 61 72 20 2a 73 74 72 69 |ister ch|ar *stri|
|000050b0| 6e 67 3b 0a 69 6e 74 20 | 62 6f 6c 66 6c 61 67 3b |ng;.int |bolflag;|
|000050c0| 0a 7b 0a 20 20 72 65 67 | 69 73 74 65 72 20 63 68 |.{. reg|ister ch|
|000050d0| 61 72 20 2a 73 3b 0a 20 | 20 65 78 74 65 72 6e 20 |ar *s;. | extern |
|000050e0| 63 68 61 72 20 2a 73 74 | 72 63 68 72 28 29 3b 0a |char *st|rchr();.|
|000050f0| 0a 20 20 2f 2a 20 42 65 | 20 70 61 72 61 6e 6f 69 |. /* Be| paranoi|
|00005100| 64 2e 2e 2e 20 2a 2f 0a | 20 20 69 66 20 28 21 70 |d... */.| if (!p|
|00005110| 72 6f 67 20 7c 7c 20 21 | 73 74 72 69 6e 67 29 20 |rog || !|string) |
|00005120| 7b 0a 09 72 65 67 65 72 | 72 6f 72 28 22 4e 55 4c |{..reger|ror("NUL|
|00005130| 4c 20 70 61 72 61 6d 65 | 74 65 72 22 29 3b 0a 09 |L parame|ter");..|
|00005140| 72 65 74 75 72 6e 28 30 | 29 3b 0a 20 20 7d 0a 0a |return(0|);. }..|
|00005150| 20 20 2f 2a 20 43 68 65 | 63 6b 20 76 61 6c 69 64 | /* Che|ck valid|
|00005160| 69 74 79 20 6f 66 20 70 | 72 6f 67 72 61 6d 2e 20 |ity of p|rogram. |
|00005170| 2a 2f 0a 20 20 69 66 20 | 28 55 43 48 41 52 41 54 |*/. if |(UCHARAT|
|00005180| 28 70 72 6f 67 2d 3e 70 | 72 6f 67 72 61 6d 29 20 |(prog->p|rogram) |
|00005190| 21 3d 20 4d 41 47 49 43 | 29 20 7b 0a 09 72 65 67 |!= MAGIC|) {..reg|
|000051a0| 65 72 72 6f 72 28 22 63 | 6f 72 72 75 70 74 65 64 |error("c|orrupted|
|000051b0| 20 70 72 6f 67 72 61 6d | 22 29 3b 0a 09 72 65 74 | program|");..ret|
|000051c0| 75 72 6e 28 30 29 3b 0a | 20 20 7d 0a 0a 20 20 2f |urn(0);.| }.. /|
|000051d0| 2a 20 49 66 20 74 68 65 | 72 65 20 69 73 20 61 20 |* If the|re is a |
|000051e0| 22 6d 75 73 74 20 61 70 | 70 65 61 72 22 20 73 74 |"must ap|pear" st|
|000051f0| 72 69 6e 67 2c 20 6c 6f | 6f 6b 20 66 6f 72 20 69 |ring, lo|ok for i|
|00005200| 74 2e 20 2a 2f 0a 20 20 | 69 66 20 28 70 72 6f 67 |t. */. |if (prog|
|00005210| 2d 3e 72 65 67 6d 75 73 | 74 20 21 3d 20 4e 55 4c |->regmus|t != NUL|
|00005220| 4c 29 20 7b 0a 09 73 20 | 3d 20 73 74 72 69 6e 67 |L) {..s |= string|
|00005230| 3b 0a 09 77 68 69 6c 65 | 20 28 28 73 20 3d 20 75 |;..while| ((s = u|
|00005240| 73 74 72 63 68 72 28 73 | 2c 20 70 72 6f 67 2d 3e |strchr(s|, prog->|
|00005250| 72 65 67 6d 75 73 74 5b | 30 5d 29 29 20 21 3d 20 |regmust[|0])) != |
|00005260| 4e 55 4c 4c 29 20 7b 0a | 09 09 69 66 20 28 75 73 |NULL) {.|..if (us|
|00005270| 74 72 6e 63 6d 70 28 73 | 2c 20 70 72 6f 67 2d 3e |trncmp(s|, prog->|
|00005280| 72 65 67 6d 75 73 74 2c | 20 70 72 6f 67 2d 3e 72 |regmust,| prog->r|
|00005290| 65 67 6d 6c 65 6e 29 20 | 3d 3d 20 30 29 0a 09 09 |egmlen) |== 0)...|
|000052a0| 09 62 72 65 61 6b 3b 09 | 2f 2a 20 46 6f 75 6e 64 |.break;.|/* Found|
|000052b0| 20 69 74 2e 20 2a 2f 0a | 09 09 73 2b 2b 3b 0a 09 | it. */.|..s++;..|
|000052c0| 7d 0a 09 69 66 20 28 73 | 20 3d 3d 20 4e 55 4c 4c |}..if (s| == NULL|
|000052d0| 29 09 2f 2a 20 4e 6f 74 | 20 70 72 65 73 65 6e 74 |)./* Not| present|
|000052e0| 2e 20 2a 2f 0a 09 09 72 | 65 74 75 72 6e 28 30 29 |. */...r|eturn(0)|
|000052f0| 3b 0a 20 20 7d 0a 0a 20 | 20 2f 2a 20 4d 61 72 6b |;. }.. | /* Mark|
|00005300| 20 62 65 67 69 6e 6e 69 | 6e 67 20 6f 66 20 6c 69 | beginni|ng of li|
|00005310| 6e 65 20 66 6f 72 20 5e | 20 2e 20 2a 2f 0a 20 20 |ne for ^| . */. |
|00005320| 69 66 28 62 6f 6c 66 6c | 61 67 29 0a 09 72 65 67 |if(bolfl|ag)..reg|
|00005330| 62 6f 6c 20 3d 20 73 74 | 72 69 6e 67 3b 0a 20 20 |bol = st|ring;. |
|00005340| 65 6c 73 65 0a 09 72 65 | 67 62 6f 6c 20 3d 20 4e |else..re|gbol = N|
|00005350| 55 4c 4c 3b 0a 0a 20 20 | 2f 2a 20 53 69 6d 70 6c |ULL;.. |/* Simpl|
|00005360| 65 73 74 20 63 61 73 65 | 3a 20 20 61 6e 63 68 6f |est case|: ancho|
|00005370| 72 65 64 20 6d 61 74 63 | 68 20 6e 65 65 64 20 62 |red matc|h need b|
|00005380| 65 20 74 72 69 65 64 20 | 6f 6e 6c 79 20 6f 6e 63 |e tried |only onc|
|00005390| 65 2e 20 2a 2f 0a 20 20 | 69 66 20 28 70 72 6f 67 |e. */. |if (prog|
|000053a0| 2d 3e 72 65 67 61 6e 63 | 68 29 0a 09 72 65 74 75 |->reganc|h)..retu|
|000053b0| 72 6e 28 72 65 67 74 72 | 79 28 70 72 6f 67 2c 20 |rn(regtr|y(prog, |
|000053c0| 73 74 72 69 6e 67 29 29 | 3b 0a 0a 20 20 2f 2a 20 |string))|;.. /* |
|000053d0| 4d 65 73 73 79 20 63 61 | 73 65 73 3a 20 20 75 6e |Messy ca|ses: un|
|000053e0| 61 6e 63 68 6f 72 65 64 | 20 6d 61 74 63 68 2e 20 |anchored| match. |
|000053f0| 2a 2f 0a 20 20 73 20 3d | 20 73 74 72 69 6e 67 3b |*/. s =| string;|
|00005400| 0a 20 20 69 66 20 28 70 | 72 6f 67 2d 3e 72 65 67 |. if (p|rog->reg|
|00005410| 73 74 61 72 74 20 21 3d | 20 27 5c 30 27 29 0a 09 |start !=| '\0')..|
|00005420| 2f 2a 20 57 65 20 6b 6e | 6f 77 20 77 68 61 74 20 |/* We kn|ow what |
|00005430| 63 68 61 72 20 69 74 20 | 6d 75 73 74 20 73 74 61 |char it |must sta|
|00005440| 72 74 20 77 69 74 68 2e | 20 2a 2f 0a 09 77 68 69 |rt with.| */..whi|
|00005450| 6c 65 20 28 28 73 20 3d | 20 75 73 74 72 63 68 72 |le ((s =| ustrchr|
|00005460| 28 73 2c 20 70 72 6f 67 | 2d 3e 72 65 67 73 74 61 |(s, prog|->regsta|
|00005470| 72 74 29 29 20 21 3d 20 | 4e 55 4c 4c 29 20 7b 0a |rt)) != |NULL) {.|
|00005480| 09 09 69 66 20 28 72 65 | 67 74 72 79 28 70 72 6f |..if (re|gtry(pro|
|00005490| 67 2c 20 73 29 29 0a 09 | 09 09 72 65 74 75 72 6e |g, s))..|..return|
|000054a0| 28 31 29 3b 0a 09 09 73 | 2b 2b 3b 0a 09 7d 0a 20 |(1);...s|++;..}. |
|000054b0| 20 65 6c 73 65 0a 09 2f | 2a 20 57 65 20 64 6f 6e | else../|* We don|
|000054c0| 27 74 20 2d 2d 20 67 65 | 6e 65 72 61 6c 20 63 61 |'t -- ge|neral ca|
|000054d0| 73 65 2e 20 2a 2f 0a 09 | 64 6f 20 7b 0a 09 09 69 |se. */..|do {...i|
|000054e0| 66 20 28 72 65 67 74 72 | 79 28 70 72 6f 67 2c 20 |f (regtr|y(prog, |
|000054f0| 73 29 29 0a 09 09 09 72 | 65 74 75 72 6e 28 31 29 |s))....r|eturn(1)|
|00005500| 3b 0a 09 7d 20 77 68 69 | 6c 65 20 28 2a 73 2b 2b |;..} whi|le (*s++|
|00005510| 20 21 3d 20 27 5c 30 27 | 29 3b 0a 0a 20 20 2f 2a | != '\0'|);.. /*|
|00005520| 20 46 61 69 6c 75 72 65 | 2e 20 2a 2f 0a 20 20 72 | Failure|. */. r|
|00005530| 65 74 75 72 6e 28 30 29 | 3b 0a 7d 0a 0a 2f 2a 0a |eturn(0)|;.}../*.|
|00005540| 20 2d 20 72 65 67 74 72 | 79 20 2d 20 74 72 79 20 | - regtr|y - try |
|00005550| 6d 61 74 63 68 20 61 74 | 20 73 70 65 63 69 66 69 |match at| specifi|
|00005560| 63 20 70 6f 69 6e 74 0a | 20 2a 2f 0a 73 74 61 74 |c point.| */.stat|
|00005570| 69 63 20 69 6e 74 09 09 | 09 2f 2a 20 30 20 66 61 |ic int..|./* 0 fa|
|00005580| 69 6c 75 72 65 2c 20 31 | 20 73 75 63 63 65 73 73 |ilure, 1| success|
|00005590| 20 2a 2f 0a 72 65 67 74 | 72 79 28 70 72 6f 67 2c | */.regt|ry(prog,|
|000055a0| 20 73 74 72 69 6e 67 29 | 0a 72 65 67 65 78 70 20 | string)|.regexp |
|000055b0| 2a 70 72 6f 67 3b 0a 63 | 68 61 72 20 2a 73 74 72 |*prog;.c|har *str|
|000055c0| 69 6e 67 3b 0a 7b 0a 20 | 20 72 65 67 69 73 74 65 |ing;.{. | registe|
|000055d0| 72 20 69 6e 74 20 69 3b | 0a 20 20 72 65 67 69 73 |r int i;|. regis|
|000055e0| 74 65 72 20 63 68 61 72 | 20 2a 2a 73 70 3b 0a 20 |ter char| **sp;. |
|000055f0| 20 72 65 67 69 73 74 65 | 72 20 63 68 61 72 20 2a | registe|r char *|
|00005600| 2a 65 70 3b 0a 0a 20 20 | 72 65 67 69 6e 70 75 74 |*ep;.. |reginput|
|00005610| 20 3d 20 73 74 72 69 6e | 67 3b 0a 20 20 72 65 67 | = strin|g;. reg|
|00005620| 73 74 61 72 74 70 20 3d | 20 70 72 6f 67 2d 3e 73 |startp =| prog->s|
|00005630| 74 61 72 74 70 3b 0a 20 | 20 72 65 67 65 6e 64 70 |tartp;. | regendp|
|00005640| 20 3d 20 70 72 6f 67 2d | 3e 65 6e 64 70 3b 0a 0a | = prog-|>endp;..|
|00005650| 20 20 73 70 20 3d 20 70 | 72 6f 67 2d 3e 73 74 61 | sp = p|rog->sta|
|00005660| 72 74 70 3b 0a 20 20 65 | 70 20 3d 20 70 72 6f 67 |rtp;. e|p = prog|
|00005670| 2d 3e 65 6e 64 70 3b 0a | 20 20 66 6f 72 20 28 69 |->endp;.| for (i|
|00005680| 20 3d 20 4e 53 55 42 45 | 58 50 3b 20 69 20 3e 20 | = NSUBE|XP; i > |
|00005690| 30 3b 20 69 2d 2d 29 20 | 7b 0a 09 2a 73 70 2b 2b |0; i--) |{..*sp++|
|000056a0| 20 3d 20 4e 55 4c 4c 3b | 0a 09 2a 65 70 2b 2b 20 | = NULL;|..*ep++ |
|000056b0| 3d 20 4e 55 4c 4c 3b 0a | 20 20 7d 0a 20 20 69 66 |= NULL;.| }. if|
|000056c0| 20 28 72 65 67 6d 61 74 | 63 68 28 70 72 6f 67 2d | (regmat|ch(prog-|
|000056d0| 3e 70 72 6f 67 72 61 6d | 20 2b 20 31 29 29 20 7b |>program| + 1)) {|
|000056e0| 0a 09 70 72 6f 67 2d 3e | 73 74 61 72 74 70 5b 30 |..prog->|startp[0|
|000056f0| 5d 20 3d 20 73 74 72 69 | 6e 67 3b 0a 09 70 72 6f |] = stri|ng;..pro|
|00005700| 67 2d 3e 65 6e 64 70 5b | 30 5d 20 3d 20 72 65 67 |g->endp[|0] = reg|
|00005710| 69 6e 70 75 74 3b 0a 09 | 72 65 74 75 72 6e 28 31 |input;..|return(1|
|00005720| 29 3b 0a 20 20 7d 20 65 | 6c 73 65 0a 09 72 65 74 |);. } e|lse..ret|
|00005730| 75 72 6e 28 30 29 3b 0a | 7d 0a 0a 2f 2a 0a 20 2d |urn(0);.|}../*. -|
|00005740| 20 72 65 67 6d 61 74 63 | 68 20 2d 20 6d 61 69 6e | regmatc|h - main|
|00005750| 20 6d 61 74 63 68 69 6e | 67 20 72 6f 75 74 69 6e | matchin|g routin|
|00005760| 65 0a 20 2a 0a 20 2a 20 | 43 6f 6e 63 65 70 74 75 |e. *. * |Conceptu|
|00005770| 61 6c 6c 79 20 74 68 65 | 20 73 74 72 61 74 65 67 |ally the| strateg|
|00005780| 79 20 69 73 20 73 69 6d | 70 6c 65 3a 20 20 63 68 |y is sim|ple: ch|
|00005790| 65 63 6b 20 74 6f 20 73 | 65 65 20 77 68 65 74 68 |eck to s|ee wheth|
|000057a0| 65 72 20 74 68 65 20 63 | 75 72 72 65 6e 74 0a 20 |er the c|urrent. |
|000057b0| 2a 20 6e 6f 64 65 20 6d | 61 74 63 68 65 73 2c 20 |* node m|atches, |
|000057c0| 63 61 6c 6c 20 73 65 6c | 66 20 72 65 63 75 72 73 |call sel|f recurs|
|000057d0| 69 76 65 6c 79 20 74 6f | 20 73 65 65 20 77 68 65 |ively to| see whe|
|000057e0| 74 68 65 72 20 74 68 65 | 20 72 65 73 74 20 6d 61 |ther the| rest ma|
|000057f0| 74 63 68 65 73 2c 0a 20 | 2a 20 61 6e 64 20 74 68 |tches,. |* and th|
|00005800| 65 6e 20 61 63 74 20 61 | 63 63 6f 72 64 69 6e 67 |en act a|ccording|
|00005810| 6c 79 2e 20 20 49 6e 20 | 70 72 61 63 74 69 63 65 |ly. In |practice|
|00005820| 20 77 65 20 6d 61 6b 65 | 20 73 6f 6d 65 20 65 66 | we make| some ef|
|00005830| 66 6f 72 74 20 74 6f 20 | 61 76 6f 69 64 0a 20 2a |fort to |avoid. *|
|00005840| 20 72 65 63 75 72 73 69 | 6f 6e 2c 20 69 6e 20 70 | recursi|on, in p|
|00005850| 61 72 74 69 63 75 6c 61 | 72 20 62 79 20 67 6f 69 |articula|r by goi|
|00005860| 6e 67 20 74 68 72 6f 75 | 67 68 20 22 6f 72 64 69 |ng throu|gh "ordi|
|00005870| 6e 61 72 79 22 20 6e 6f | 64 65 73 20 28 74 68 61 |nary" no|des (tha|
|00005880| 74 20 64 6f 6e 27 74 0a | 20 2a 20 6e 65 65 64 20 |t don't.| * need |
|00005890| 74 6f 20 6b 6e 6f 77 20 | 77 68 65 74 68 65 72 20 |to know |whether |
|000058a0| 74 68 65 20 72 65 73 74 | 20 6f 66 20 74 68 65 20 |the rest| of the |
|000058b0| 6d 61 74 63 68 20 66 61 | 69 6c 65 64 29 20 62 79 |match fa|iled) by|
|000058c0| 20 61 20 6c 6f 6f 70 20 | 69 6e 73 74 65 61 64 20 | a loop |instead |
|000058d0| 6f 66 0a 20 2a 20 62 79 | 20 72 65 63 75 72 73 69 |of. * by| recursi|
|000058e0| 6f 6e 2e 0a 20 2a 2f 0a | 73 74 61 74 69 63 20 69 |on.. */.|static i|
|000058f0| 6e 74 09 09 09 2f 2a 20 | 30 20 66 61 69 6c 75 72 |nt.../* |0 failur|
|00005900| 65 2c 20 31 20 73 75 63 | 63 65 73 73 20 2a 2f 0a |e, 1 suc|cess */.|
|00005910| 72 65 67 6d 61 74 63 68 | 28 70 72 6f 67 29 0a 63 |regmatch|(prog).c|
|00005920| 68 61 72 20 2a 70 72 6f | 67 3b 0a 7b 0a 20 20 72 |har *pro|g;.{. r|
|00005930| 65 67 69 73 74 65 72 20 | 63 68 61 72 20 2a 73 63 |egister |char *sc|
|00005940| 61 6e 3b 09 2f 2a 20 43 | 75 72 72 65 6e 74 20 6e |an;./* C|urrent n|
|00005950| 6f 64 65 2e 20 2a 2f 0a | 20 20 63 68 61 72 20 2a |ode. */.| char *|
|00005960| 6e 65 78 74 3b 09 09 2f | 2a 20 4e 65 78 74 20 6e |next;../|* Next n|
|00005970| 6f 64 65 2e 20 2a 2f 0a | 20 20 65 78 74 65 72 6e |ode. */.| extern|
|00005980| 20 63 68 61 72 20 2a 73 | 74 72 63 68 72 28 29 3b | char *s|trchr();|
|00005990| 0a 0a 20 20 73 63 61 6e | 20 3d 20 70 72 6f 67 3b |.. scan| = prog;|
|000059a0| 0a 23 69 66 64 65 66 20 | 44 45 42 55 47 0a 20 20 |.#ifdef |DEBUG. |
|000059b0| 69 66 20 28 73 63 61 6e | 20 21 3d 20 4e 55 4c 4c |if (scan| != NULL|
|000059c0| 20 26 26 20 72 65 67 6e | 61 72 72 61 74 65 29 0a | && regn|arrate).|
|000059d0| 09 77 70 72 69 6e 74 77 | 28 73 74 64 73 63 72 2c |.wprintw|(stdscr,|
|000059e0| 20 22 25 73 28 5c 6e 22 | 2c 20 72 65 67 70 72 6f | "%s(\n"|, regpro|
|000059f0| 70 28 73 63 61 6e 29 29 | 3b 0a 23 65 6e 64 69 66 |p(scan))|;.#endif|
|00005a00| 0a 20 20 77 68 69 6c 65 | 20 28 73 63 61 6e 20 21 |. while| (scan !|
|00005a10| 3d 20 4e 55 4c 4c 29 20 | 7b 0a 23 69 66 64 65 66 |= NULL) |{.#ifdef|
|00005a20| 20 44 45 42 55 47 0a 09 | 69 66 20 28 72 65 67 6e | DEBUG..|if (regn|
|00005a30| 61 72 72 61 74 65 29 0a | 09 09 77 70 72 69 6e 74 |arrate).|..wprint|
|00005a40| 77 28 73 74 64 73 63 72 | 2c 20 22 25 73 2e 2e 2e |w(stdscr|, "%s...|
|00005a50| 5c 6e 22 2c 20 72 65 67 | 70 72 6f 70 28 73 63 61 |\n", reg|prop(sca|
|00005a60| 6e 29 29 3b 0a 23 65 6e | 64 69 66 0a 09 6e 65 78 |n));.#en|dif..nex|
|00005a70| 74 20 3d 20 72 65 67 6e | 65 78 74 28 73 63 61 6e |t = regn|ext(scan|
|00005a80| 29 3b 0a 0a 09 73 77 69 | 74 63 68 20 28 4f 50 28 |);...swi|tch (OP(|
|00005a90| 73 63 61 6e 29 29 20 7b | 0a 09 63 61 73 65 20 42 |scan)) {|..case B|
|00005aa0| 4f 4c 3a 0a 09 09 69 66 | 20 28 72 65 67 69 6e 70 |OL:...if| (reginp|
|00005ab0| 75 74 20 21 3d 20 72 65 | 67 62 6f 6c 29 0a 09 09 |ut != re|gbol)...|
|00005ac0| 09 72 65 74 75 72 6e 28 | 30 29 3b 0a 09 09 62 72 |.return(|0);...br|
|00005ad0| 65 61 6b 3b 0a 09 63 61 | 73 65 20 45 4f 4c 3a 0a |eak;..ca|se EOL:.|
|00005ae0| 09 09 69 66 20 28 2a 72 | 65 67 69 6e 70 75 74 20 |..if (*r|eginput |
|00005af0| 21 3d 20 27 5c 30 27 20 | 26 26 20 2a 72 65 67 69 |!= '\0' |&& *regi|
|00005b00| 6e 70 75 74 20 21 3d 20 | 27 5c 6e 27 29 0a 09 09 |nput != |'\n')...|
|00005b10| 09 72 65 74 75 72 6e 28 | 30 29 3b 0a 09 09 62 72 |.return(|0);...br|
|00005b20| 65 61 6b 3b 0a 09 63 61 | 73 65 20 42 4f 57 3a 0a |eak;..ca|se BOW:.|
|00005b30| 09 09 69 66 20 28 72 65 | 67 69 6e 70 75 74 20 21 |..if (re|ginput !|
|00005b40| 3d 20 72 65 67 62 6f 6c | 0a 09 09 20 26 26 20 28 |= regbol|... && (|
|00005b50| 69 73 61 6c 6e 75 6d 28 | 72 65 67 69 6e 70 75 74 |isalnum(|reginput|
|00005b60| 5b 2d 31 5d 29 20 7c 7c | 20 72 65 67 69 6e 70 75 |[-1]) ||| reginpu|
|00005b70| 74 5b 2d 31 5d 20 3d 3d | 20 27 5f 27 29 29 0a 09 |t[-1] ==| '_'))..|
|00005b80| 09 09 72 65 74 75 72 6e | 28 30 29 3b 0a 09 09 62 |..return|(0);...b|
|00005b90| 72 65 61 6b 3b 0a 09 63 | 61 73 65 20 45 4f 57 3a |reak;..c|ase EOW:|
|00005ba0| 0a 09 09 69 66 20 28 69 | 73 61 6c 6e 75 6d 28 2a |...if (i|salnum(*|
|00005bb0| 72 65 67 69 6e 70 75 74 | 29 20 7c 7c 20 2a 72 65 |reginput|) || *re|
|00005bc0| 67 69 6e 70 75 74 20 3d | 3d 20 27 5f 27 29 0a 09 |ginput =|= '_')..|
|00005bd0| 09 09 72 65 74 75 72 6e | 28 30 29 3b 0a 09 09 62 |..return|(0);...b|
|00005be0| 72 65 61 6b 3b 0a 09 63 | 61 73 65 20 41 4e 59 3a |reak;..c|ase ANY:|
|00005bf0| 0a 09 09 69 66 20 28 2a | 72 65 67 69 6e 70 75 74 |...if (*|reginput|
|00005c00| 20 3d 3d 20 27 5c 30 27 | 20 7c 7c 20 2a 72 65 67 | == '\0'| || *reg|
|00005c10| 69 6e 70 75 74 20 3d 3d | 20 27 5c 6e 27 29 0a 09 |input ==| '\n')..|
|00005c20| 09 09 72 65 74 75 72 6e | 28 30 29 3b 0a 09 09 72 |..return|(0);...r|
|00005c30| 65 67 69 6e 70 75 74 2b | 2b 3b 0a 09 09 62 72 65 |eginput+|+;...bre|
|00005c40| 61 6b 3b 0a 09 63 61 73 | 65 20 45 58 41 43 54 4c |ak;..cas|e EXACTL|
|00005c50| 59 3a 20 7b 0a 09 09 09 | 72 65 67 69 73 74 65 72 |Y: {....|register|
|00005c60| 20 69 6e 74 20 6c 65 6e | 3b 0a 09 09 09 72 65 67 | int len|;....reg|
|00005c70| 69 73 74 65 72 20 63 68 | 61 72 20 2a 6f 70 6e 64 |ister ch|ar *opnd|
|00005c80| 3b 0a 0a 09 09 09 6f 70 | 6e 64 20 3d 20 4f 50 45 |;.....op|nd = OPE|
|00005c90| 52 41 4e 44 28 73 63 61 | 6e 29 3b 0a 0a 09 09 09 |RAND(sca|n);.....|
|00005ca0| 2f 2a 20 49 6e 6c 69 6e | 65 20 74 68 65 20 66 69 |/* Inlin|e the fi|
|00005cb0| 72 73 74 20 63 68 61 72 | 61 63 74 65 72 2c 20 66 |rst char|acter, f|
|00005cc0| 6f 72 20 73 70 65 65 64 | 2e 20 2a 2f 0a 09 09 09 |or speed|. */....|
|00005cd0| 69 66 20 28 21 2a 6f 5f | 69 67 6e 6f 72 65 63 61 |if (!*o_|ignoreca|
|00005ce0| 73 65 20 26 26 20 2a 6f | 70 6e 64 20 21 3d 20 2a |se && *o|pnd != *|
|00005cf0| 72 65 67 69 6e 70 75 74 | 29 0a 09 09 09 09 72 65 |reginput|).....re|
|00005d00| 74 75 72 6e 28 30 29 3b | 0a 09 09 09 6c 65 6e 20 |turn(0);|....len |
|00005d10| 3d 20 73 74 72 6c 65 6e | 28 6f 70 6e 64 29 3b 0a |= strlen|(opnd);.|
|00005d20| 09 09 09 69 66 20 28 6c | 65 6e 20 3e 20 31 20 26 |...if (l|en > 1 &|
|00005d30| 26 20 75 73 74 72 6e 63 | 6d 70 28 6f 70 6e 64 2c |& ustrnc|mp(opnd,|
|00005d40| 20 72 65 67 69 6e 70 75 | 74 2c 20 6c 65 6e 29 20 | reginpu|t, len) |
|00005d50| 21 3d 20 30 29 0a 09 09 | 09 09 72 65 74 75 72 6e |!= 0)...|..return|
|00005d60| 28 30 29 3b 0a 09 09 09 | 72 65 67 69 6e 70 75 74 |(0);....|reginput|
|00005d70| 20 2b 3d 20 6c 65 6e 3b | 0a 09 09 7d 0a 09 09 62 | += len;|...}...b|
|00005d80| 72 65 61 6b 3b 0a 09 63 | 61 73 65 20 41 4e 59 4f |reak;..c|ase ANYO|
|00005d90| 46 3a 0a 09 09 69 66 20 | 28 2a 72 65 67 69 6e 70 |F:...if |(*reginp|
|00005da0| 75 74 20 3d 3d 20 27 5c | 30 27 20 7c 7c 20 2a 72 |ut == '\|0' || *r|
|00005db0| 65 67 69 6e 70 75 74 20 | 3d 3d 20 27 5c 6e 27 0a |eginput |== '\n'.|
|00005dc0| 09 09 20 7c 7c 20 73 74 | 72 63 68 72 28 4f 50 45 |.. || st|rchr(OPE|
|00005dd0| 52 41 4e 44 28 73 63 61 | 6e 29 2c 20 2a 72 65 67 |RAND(sca|n), *reg|
|00005de0| 69 6e 70 75 74 29 20 3d | 3d 20 4e 55 4c 4c 29 0a |input) =|= NULL).|
|00005df0| 09 09 09 72 65 74 75 72 | 6e 28 30 29 3b 0a 09 09 |...retur|n(0);...|
|00005e00| 72 65 67 69 6e 70 75 74 | 2b 2b 3b 0a 09 09 62 72 |reginput|++;...br|
|00005e10| 65 61 6b 3b 0a 09 63 61 | 73 65 20 41 4e 59 42 55 |eak;..ca|se ANYBU|
|00005e20| 54 3a 0a 09 09 69 66 20 | 28 2a 72 65 67 69 6e 70 |T:...if |(*reginp|
|00005e30| 75 74 20 3d 3d 20 27 5c | 30 27 20 7c 7c 20 2a 72 |ut == '\|0' || *r|
|00005e40| 65 67 69 6e 70 75 74 20 | 3d 3d 20 27 5c 6e 27 0a |eginput |== '\n'.|
|00005e50| 09 09 20 7c 7c 20 73 74 | 72 63 68 72 28 4f 50 45 |.. || st|rchr(OPE|
|00005e60| 52 41 4e 44 28 73 63 61 | 6e 29 2c 20 2a 72 65 67 |RAND(sca|n), *reg|
|00005e70| 69 6e 70 75 74 29 20 21 | 3d 20 4e 55 4c 4c 29 0a |input) !|= NULL).|
|00005e80| 09 09 09 72 65 74 75 72 | 6e 28 30 29 3b 0a 09 09 |...retur|n(0);...|
|00005e90| 72 65 67 69 6e 70 75 74 | 2b 2b 3b 0a 09 09 62 72 |reginput|++;...br|
|00005ea0| 65 61 6b 3b 0a 09 63 61 | 73 65 20 4e 4f 54 48 49 |eak;..ca|se NOTHI|
|00005eb0| 4e 47 3a 0a 09 09 62 72 | 65 61 6b 3b 0a 09 63 61 |NG:...br|eak;..ca|
|00005ec0| 73 65 20 42 41 43 4b 3a | 0a 09 09 62 72 65 61 6b |se BACK:|...break|
|00005ed0| 3b 0a 09 63 61 73 65 20 | 4f 50 45 4e 2b 31 3a 0a |;..case |OPEN+1:.|
|00005ee0| 09 63 61 73 65 20 4f 50 | 45 4e 2b 32 3a 0a 09 63 |.case OP|EN+2:..c|
|00005ef0| 61 73 65 20 4f 50 45 4e | 2b 33 3a 0a 09 63 61 73 |ase OPEN|+3:..cas|
|00005f00| 65 20 4f 50 45 4e 2b 34 | 3a 0a 09 63 61 73 65 20 |e OPEN+4|:..case |
|00005f10| 4f 50 45 4e 2b 35 3a 0a | 09 63 61 73 65 20 4f 50 |OPEN+5:.|.case OP|
|00005f20| 45 4e 2b 36 3a 0a 09 63 | 61 73 65 20 4f 50 45 4e |EN+6:..c|ase OPEN|
|00005f30| 2b 37 3a 0a 09 63 61 73 | 65 20 4f 50 45 4e 2b 38 |+7:..cas|e OPEN+8|
|00005f40| 3a 0a 09 63 61 73 65 20 | 4f 50 45 4e 2b 39 3a 20 |:..case |OPEN+9: |
|00005f50| 7b 0a 09 09 09 72 65 67 | 69 73 74 65 72 20 69 6e |{....reg|ister in|
|00005f60| 74 20 6e 6f 3b 0a 09 09 | 09 72 65 67 69 73 74 65 |t no;...|.registe|
|00005f70| 72 20 63 68 61 72 20 2a | 73 61 76 65 3b 0a 0a 09 |r char *|save;...|
|00005f80| 09 09 6e 6f 20 3d 20 4f | 50 28 73 63 61 6e 29 20 |..no = O|P(scan) |
|00005f90| 2d 20 4f 50 45 4e 3b 0a | 09 09 09 73 61 76 65 20 |- OPEN;.|...save |
|00005fa0| 3d 20 72 65 67 69 6e 70 | 75 74 3b 0a 0a 09 09 09 |= reginp|ut;.....|
|00005fb0| 69 66 20 28 72 65 67 6d | 61 74 63 68 28 6e 65 78 |if (regm|atch(nex|
|00005fc0| 74 29 29 20 7b 0a 09 09 | 09 09 2f 2a 0a 09 09 09 |t)) {...|../*....|
|00005fd0| 09 20 2a 20 44 6f 6e 27 | 74 20 73 65 74 20 73 74 |. * Don'|t set st|
|00005fe0| 61 72 74 70 20 69 66 20 | 73 6f 6d 65 20 6c 61 74 |artp if |some lat|
|00005ff0| 65 72 0a 09 09 09 09 20 | 2a 20 69 6e 76 6f 63 61 |er..... |* invoca|
|00006000| 74 69 6f 6e 20 6f 66 20 | 74 68 65 20 73 61 6d 65 |tion of |the same|
|00006010| 20 70 61 72 65 6e 74 68 | 65 73 65 73 0a 09 09 09 | parenth|eses....|
|00006020| 09 20 2a 20 61 6c 72 65 | 61 64 79 20 68 61 73 2e |. * alre|ady has.|
|00006030| 0a 09 09 09 09 20 2a 2f | 0a 09 09 09 09 69 66 20 |..... */|.....if |
|00006040| 28 72 65 67 73 74 61 72 | 74 70 5b 6e 6f 5d 20 3d |(regstar|tp[no] =|
|00006050| 3d 20 4e 55 4c 4c 29 0a | 09 09 09 09 09 72 65 67 |= NULL).|.....reg|
|00006060| 73 74 61 72 74 70 5b 6e | 6f 5d 20 3d 20 73 61 76 |startp[n|o] = sav|
|00006070| 65 3b 0a 09 09 09 09 72 | 65 74 75 72 6e 28 31 29 |e;.....r|eturn(1)|
|00006080| 3b 0a 09 09 09 7d 20 65 | 6c 73 65 0a 09 09 09 09 |;....} e|lse.....|
|00006090| 72 65 74 75 72 6e 28 30 | 29 3b 0a 09 09 7d 0a 0a |return(0|);...}..|
|000060a0| 09 63 61 73 65 20 43 4c | 4f 53 45 2b 31 3a 0a 09 |.case CL|OSE+1:..|
|000060b0| 63 61 73 65 20 43 4c 4f | 53 45 2b 32 3a 0a 09 63 |case CLO|SE+2:..c|
|000060c0| 61 73 65 20 43 4c 4f 53 | 45 2b 33 3a 0a 09 63 61 |ase CLOS|E+3:..ca|
|000060d0| 73 65 20 43 4c 4f 53 45 | 2b 34 3a 0a 09 63 61 73 |se CLOSE|+4:..cas|
|000060e0| 65 20 43 4c 4f 53 45 2b | 35 3a 0a 09 63 61 73 65 |e CLOSE+|5:..case|
|000060f0| 20 43 4c 4f 53 45 2b 36 | 3a 0a 09 63 61 73 65 20 | CLOSE+6|:..case |
|00006100| 43 4c 4f 53 45 2b 37 3a | 0a 09 63 61 73 65 20 43 |CLOSE+7:|..case C|
|00006110| 4c 4f 53 45 2b 38 3a 0a | 09 63 61 73 65 20 43 4c |LOSE+8:.|.case CL|
|00006120| 4f 53 45 2b 39 3a 20 7b | 0a 09 09 09 72 65 67 69 |OSE+9: {|....regi|
|00006130| 73 74 65 72 20 69 6e 74 | 20 6e 6f 3b 0a 09 09 09 |ster int| no;....|
|00006140| 72 65 67 69 73 74 65 72 | 20 63 68 61 72 20 2a 73 |register| char *s|
|00006150| 61 76 65 3b 0a 0a 09 09 | 09 6e 6f 20 3d 20 4f 50 |ave;....|.no = OP|
|00006160| 28 73 63 61 6e 29 20 2d | 20 43 4c 4f 53 45 3b 0a |(scan) -| CLOSE;.|
|00006170| 09 09 09 73 61 76 65 20 | 3d 20 72 65 67 69 6e 70 |...save |= reginp|
|00006180| 75 74 3b 0a 0a 09 09 09 | 69 66 20 28 72 65 67 6d |ut;.....|if (regm|
|00006190| 61 74 63 68 28 6e 65 78 | 74 29 29 20 7b 0a 09 09 |atch(nex|t)) {...|
|000061a0| 09 09 2f 2a 0a 09 09 09 | 09 20 2a 20 44 6f 6e 27 |../*....|. * Don'|
|000061b0| 74 20 73 65 74 20 65 6e | 64 70 20 69 66 20 73 6f |t set en|dp if so|
|000061c0| 6d 65 20 6c 61 74 65 72 | 0a 09 09 09 09 20 2a 20 |me later|..... * |
|000061d0| 69 6e 76 6f 63 61 74 69 | 6f 6e 20 6f 66 20 74 68 |invocati|on of th|
|000061e0| 65 20 73 61 6d 65 20 70 | 61 72 65 6e 74 68 65 73 |e same p|arenthes|
|000061f0| 65 73 0a 09 09 09 09 20 | 2a 20 61 6c 72 65 61 64 |es..... |* alread|
|00006200| 79 20 68 61 73 2e 0a 09 | 09 09 09 20 2a 2f 0a 09 |y has...|... */..|
|00006210| 09 09 09 69 66 20 28 72 | 65 67 65 6e 64 70 5b 6e |...if (r|egendp[n|
|00006220| 6f 5d 20 3d 3d 20 4e 55 | 4c 4c 29 0a 09 09 09 09 |o] == NU|LL).....|
|00006230| 09 72 65 67 65 6e 64 70 | 5b 6e 6f 5d 20 3d 20 73 |.regendp|[no] = s|
|00006240| 61 76 65 3b 0a 09 09 09 | 09 72 65 74 75 72 6e 28 |ave;....|.return(|
|00006250| 31 29 3b 0a 09 09 09 7d | 20 65 6c 73 65 0a 09 09 |1);....}| else...|
|00006260| 09 09 72 65 74 75 72 6e | 28 30 29 3b 0a 09 09 7d |..return|(0);...}|
|00006270| 0a 0a 09 63 61 73 65 20 | 42 52 41 4e 43 48 3a 20 |...case |BRANCH: |
|00006280| 7b 0a 09 09 09 72 65 67 | 69 73 74 65 72 20 63 68 |{....reg|ister ch|
|00006290| 61 72 20 2a 73 61 76 65 | 3b 0a 0a 09 09 09 69 66 |ar *save|;.....if|
|000062a0| 20 28 4f 50 28 6e 65 78 | 74 29 20 21 3d 20 42 52 | (OP(nex|t) != BR|
|000062b0| 41 4e 43 48 29 09 09 2f | 2a 20 4e 6f 20 63 68 6f |ANCH)../|* No cho|
|000062c0| 69 63 65 2e 20 2a 2f 0a | 09 09 09 09 6e 65 78 74 |ice. */.|....next|
|000062d0| 20 3d 20 4f 50 45 52 41 | 4e 44 28 73 63 61 6e 29 | = OPERA|ND(scan)|
|000062e0| 3b 09 2f 2a 20 41 76 6f | 69 64 20 72 65 63 75 72 |;./* Avo|id recur|
|000062f0| 73 69 6f 6e 2e 20 2a 2f | 0a 09 09 09 65 6c 73 65 |sion. */|....else|
|00006300| 20 7b 0a 09 09 09 09 64 | 6f 20 7b 0a 09 09 09 09 | {.....d|o {.....|
|00006310| 09 73 61 76 65 20 3d 20 | 72 65 67 69 6e 70 75 74 |.save = |reginput|
|00006320| 3b 0a 09 09 09 09 09 69 | 66 20 28 72 65 67 6d 61 |;......i|f (regma|
|00006330| 74 63 68 28 4f 50 45 52 | 41 4e 44 28 73 63 61 6e |tch(OPER|AND(scan|
|00006340| 29 29 29 0a 09 09 09 09 | 09 09 72 65 74 75 72 6e |))).....|..return|
|00006350| 28 31 29 3b 0a 09 09 09 | 09 09 72 65 67 69 6e 70 |(1);....|..reginp|
|00006360| 75 74 20 3d 20 73 61 76 | 65 3b 0a 09 09 09 09 09 |ut = sav|e;......|
|00006370| 73 63 61 6e 20 3d 20 72 | 65 67 6e 65 78 74 28 73 |scan = r|egnext(s|
|00006380| 63 61 6e 29 3b 0a 09 09 | 09 09 7d 20 77 68 69 6c |can);...|..} whil|
|00006390| 65 20 28 73 63 61 6e 20 | 21 3d 20 4e 55 4c 4c 20 |e (scan |!= NULL |
|000063a0| 26 26 20 4f 50 28 73 63 | 61 6e 29 20 3d 3d 20 42 |&& OP(sc|an) == B|
|000063b0| 52 41 4e 43 48 29 3b 0a | 09 09 09 09 72 65 74 75 |RANCH);.|....retu|
|000063c0| 72 6e 28 30 29 3b 0a 09 | 09 09 09 2f 2a 20 4e 4f |rn(0);..|.../* NO|
|000063d0| 54 52 45 41 43 48 45 44 | 20 2a 2f 0a 09 09 09 7d |TREACHED| */....}|
|000063e0| 0a 09 09 7d 0a 09 09 62 | 72 65 61 6b 3b 0a 09 63 |...}...b|reak;..c|
|000063f0| 61 73 65 20 53 54 41 52 | 3a 0a 09 63 61 73 65 20 |ase STAR|:..case |
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.