home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 October / usenetsourcesnewsgroupsinfomagicoctober1994disk2.iso / misc / volume29 / regex-glob / part01 next >
SHell self-extracting ARchive  |  1992-04-06  |  17.1 KB

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


This file was processed as: SHell self-extracting ARchive (archive/shar).

ConfidenceProgramDetectionMatch TypeSupport
100% dexvert SHell self-extracting ARchive (archive/shar) magic Supported
1% dexvert Text File (text/txt) fallback Supported
100% file makefile script, ASCII text 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)



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 4e 65 77 73 67 72 6f 75 | 70 73 3a 20 63 6f 6d 70 |Newsgrou|ps: comp|
|00000010| 2e 73 6f 75 72 63 65 73 | 2e 6d 69 73 63 0a 46 72 |.sources|.misc.Fr|
|00000020| 6f 6d 3a 20 6a 6f 68 6e | 6b 40 77 72 71 2e 63 6f |om: john|k@wrq.co|
|00000030| 6d 20 28 4a 6f 68 6e 20 | 4b 65 72 63 68 65 76 61 |m (John |Kercheva|
|00000040| 6c 29 0a 53 75 62 6a 65 | 63 74 3a 20 20 76 32 39 |l).Subje|ct: v29|
|00000050| 69 30 35 37 3a 20 20 72 | 65 67 65 78 2d 67 6c 6f |i057: r|egex-glo|
|00000060| 62 20 2d 20 41 20 2a 49 | 58 20 73 68 20 73 74 79 |b - A *I|X sh sty|
|00000070| 6c 65 20 52 45 47 45 58 | 20 47 6c 6f 62 62 65 72 |le REGEX| Globber|
|00000080| 2c 20 50 61 72 74 30 31 | 2f 30 31 0a 4d 65 73 73 |, Part01|/01.Mess|
|00000090| 61 67 65 2d 49 44 3a 20 | 3c 31 39 39 32 41 70 72 |age-ID: |<1992Apr|
|000000a0| 35 2e 30 33 31 33 31 30 | 2e 32 39 34 39 39 40 73 |5.031310|.29499@s|
|000000b0| 70 61 72 6b 79 2e 69 6d | 64 2e 73 74 65 72 6c 69 |parky.im|d.sterli|
|000000c0| 6e 67 2e 63 6f 6d 3e 0a | 58 2d 4d 64 34 2d 53 69 |ng.com>.|X-Md4-Si|
|000000d0| 67 6e 61 74 75 72 65 3a | 20 65 63 61 35 31 36 30 |gnature:| eca5160|
|000000e0| 64 33 31 63 38 63 31 63 | 61 35 33 32 33 32 33 32 |d31c8c1c|a5323232|
|000000f0| 66 61 35 35 62 63 35 65 | 35 0a 44 61 74 65 3a 20 |fa55bc5e|5.Date: |
|00000100| 53 75 6e 2c 20 35 20 41 | 70 72 20 31 39 39 32 20 |Sun, 5 A|pr 1992 |
|00000110| 30 33 3a 31 33 3a 31 30 | 20 47 4d 54 0a 41 70 70 |03:13:10| GMT.App|
|00000120| 72 6f 76 65 64 3a 20 6b | 65 6e 74 40 73 70 61 72 |roved: k|ent@spar|
|00000130| 6b 79 2e 69 6d 64 2e 73 | 74 65 72 6c 69 6e 67 2e |ky.imd.s|terling.|
|00000140| 63 6f 6d 0a 0a 53 75 62 | 6d 69 74 74 65 64 2d 62 |com..Sub|mitted-b|
|00000150| 79 3a 20 6a 6f 68 6e 6b | 40 77 72 71 2e 63 6f 6d |y: johnk|@wrq.com|
|00000160| 20 28 4a 6f 68 6e 20 4b | 65 72 63 68 65 76 61 6c | (John K|ercheval|
|00000170| 29 0a 50 6f 73 74 69 6e | 67 2d 6e 75 6d 62 65 72 |).Postin|g-number|
|00000180| 3a 20 56 6f 6c 75 6d 65 | 20 32 39 2c 20 49 73 73 |: Volume| 29, Iss|
|00000190| 75 65 20 35 37 0a 41 72 | 63 68 69 76 65 2d 6e 61 |ue 57.Ar|chive-na|
|000001a0| 6d 65 3a 20 72 65 67 65 | 78 2d 67 6c 6f 62 2f 70 |me: rege|x-glob/p|
|000001b0| 61 72 74 30 31 0a 45 6e | 76 69 72 6f 6e 6d 65 6e |art01.En|vironmen|
|000001c0| 74 3a 20 43 0a 0a 48 65 | 72 65 20 69 73 20 61 20 |t: C..He|re is a |
|000001d0| 2a 49 58 20 77 69 6c 64 | 63 61 72 64 20 67 6c 6f |*IX wild|card glo|
|000001e0| 62 62 65 72 20 49 20 62 | 75 74 63 68 65 72 65 64 |bber I b|utchered|
|000001f0| 2c 20 68 61 63 6b 65 64 | 20 61 6e 64 20 63 61 6a |, hacked| and caj|
|00000200| 6f 6c 65 64 20 74 6f 67 | 65 74 68 65 72 0a 61 66 |oled tog|ether.af|
|00000210| 74 65 72 20 73 65 65 69 | 6e 67 20 61 6e 64 20 68 |ter seei|ng and h|
|00000220| 65 61 72 69 6e 67 20 61 | 62 6f 75 74 20 61 6e 64 |earing a|bout and|
|00000230| 20 62 65 63 6f 6d 69 6e | 67 20 64 69 73 67 75 73 | becomin|g disgus|
|00000240| 74 65 64 20 77 69 74 68 | 20 73 65 76 65 72 61 6c |ted with| several|
|00000250| 20 73 69 6d 69 6c 61 72 | 0a 72 6f 75 74 69 6e 65 | similar|.routine|
|00000260| 73 20 77 68 69 63 68 20 | 68 61 64 20 6f 6e 65 20 |s which |had one |
|00000270| 6f 72 20 6d 6f 72 65 20 | 6f 66 20 74 68 65 20 66 |or more |of the f|
|00000280| 6f 6c 6c 6f 77 69 6e 67 | 20 61 74 74 72 69 62 75 |ollowing| attribu|
|00000290| 74 65 73 3a 20 20 73 6c | 6f 77 2c 20 62 75 67 67 |tes: sl|ow, bugg|
|000002a0| 79 2c 0a 72 65 71 75 69 | 72 65 64 20 6c 61 72 67 |y,.requi|red larg|
|000002b0| 65 20 6c 65 76 65 6c 73 | 20 6f 66 20 72 65 63 75 |e levels| of recu|
|000002c0| 72 73 69 6f 6e 20 6f 6e | 20 6d 61 74 63 68 65 73 |rsion on| matches|
|000002d0| 2c 20 72 65 71 75 69 72 | 65 64 20 67 72 6f 74 65 |, requir|ed grote|
|000002e0| 73 71 75 65 20 6c 65 76 | 65 6c 73 0a 6f 66 20 72 |sque lev|els.of r|
|000002f0| 65 63 75 72 73 69 6f 6e | 20 6f 6e 20 66 61 69 6c |ecursion| on fail|
|00000300| 69 6e 67 20 6d 61 74 63 | 68 65 73 20 75 73 69 6e |ing matc|hes usin|
|00000310| 67 20 27 2a 27 2c 20 66 | 75 6c 6c 20 6f 66 20 63 |g '*', f|ull of c|
|00000320| 61 76 65 61 74 73 20 61 | 62 6f 75 74 20 75 73 61 |aveats a|bout usa|
|00000330| 62 69 6c 69 74 79 0a 6f | 72 20 63 6f 70 79 72 69 |bility.o|r copyri|
|00000340| 67 68 74 73 2e 0a 0a 49 | 20 73 75 62 6d 69 74 20 |ghts...I| submit |
|00000350| 74 68 69 73 20 77 69 74 | 68 6f 75 74 20 63 6f 70 |this wit|hout cop|
|00000360| 79 72 69 67 68 74 20 61 | 6e 64 20 77 69 74 68 20 |yright a|nd with |
|00000370| 74 68 65 20 63 6c 65 61 | 72 20 75 6e 64 65 72 73 |the clea|r unders|
|00000380| 74 61 6e 64 69 6e 67 20 | 74 68 61 74 0a 74 68 69 |tanding |that.thi|
|00000390| 73 20 63 6f 64 65 20 6d | 61 79 20 62 65 20 75 73 |s code m|ay be us|
|000003a0| 65 64 20 62 79 20 61 6e | 79 6f 6e 65 2c 20 66 6f |ed by an|yone, fo|
|000003b0| 72 20 61 6e 79 20 72 65 | 61 73 6f 6e 2c 20 77 69 |r any re|ason, wi|
|000003c0| 74 68 20 61 6e 79 20 6d | 6f 64 69 66 69 63 61 74 |th any m|odificat|
|000003d0| 69 6f 6e 73 0a 61 6e 64 | 20 77 69 74 68 6f 75 74 |ions.and| without|
|000003e0| 20 61 6e 79 20 67 75 61 | 72 61 6e 74 65 65 73 2c | any gua|rantees,|
|000003f0| 20 77 61 72 72 61 6e 74 | 65 65 20 6f 72 20 73 74 | warrant|ee or st|
|00000400| 61 74 65 6d 65 6e 74 73 | 20 6f 66 20 75 73 61 62 |atements| of usab|
|00000410| 69 6c 69 74 79 20 6f 66 | 20 61 6e 79 0a 73 6f 72 |ility of| any.sor|
|00000420| 74 2e 0a 0a 48 61 76 69 | 6e 67 20 67 6f 74 74 65 |t...Havi|ng gotte|
|00000430| 6e 20 74 68 6f 73 65 20 | 63 6f 77 20 63 68 69 70 |n those |cow chip|
|00000440| 73 20 6f 75 74 20 6f 66 | 20 74 68 65 20 77 61 79 |s out of| the way|
|00000450| 2c 20 74 68 65 73 65 20 | 72 6f 75 74 69 6e 65 73 |, these |routines|
|00000460| 20 61 72 65 20 66 61 69 | 72 6c 79 0a 77 65 6c 6c | are fai|rly.well|
|00000470| 20 74 65 73 74 65 64 20 | 61 6e 64 20 72 65 61 73 | tested |and reas|
|00000480| 6f 6e 61 62 6c 79 20 66 | 61 73 74 2e 20 20 54 68 |onably f|ast. Th|
|00000490| 69 73 20 70 61 72 73 65 | 72 20 68 61 73 20 62 65 |is parse|r has be|
|000004a0| 65 6e 20 73 75 62 6d 69 | 74 74 65 64 20 74 6f 20 |en submi|tted to |
|000004b0| 70 72 6f 66 69 6c 65 72 | 73 20 0a 61 74 20 76 61 |profiler|s .at va|
|000004c0| 72 69 6f 75 73 20 73 74 | 61 67 65 73 20 6f 66 20 |rious st|ages of |
|000004d0| 64 65 76 65 6c 6f 70 6d | 65 6e 74 20 61 6e 64 20 |developm|ent and |
|000004e0| 68 61 73 20 63 6f 6d 65 | 20 74 68 72 6f 75 67 68 |has come| through|
|000004f0| 20 71 75 69 74 65 20 77 | 65 6c 6c 2e 20 20 0a 0a | quite w|ell. ..|
|00000500| 48 65 72 65 20 69 73 20 | 6d 79 20 6f 77 6e 20 72 |Here is |my own r|
|00000510| 65 69 6e 76 65 6e 74 69 | 6f 6e 20 6f 66 20 74 68 |einventi|on of th|
|00000520| 65 20 77 68 65 65 6c 2e | 20 20 50 6c 65 61 73 65 |e wheel.| Please|
|00000530| 20 65 6e 6a 6f 79 20 69 | 74 27 73 20 75 73 65 20 | enjoy i|t's use |
|00000540| 61 6e 64 20 49 20 0a 68 | 6f 70 65 20 69 74 20 69 |and I .h|ope it i|
|00000550| 73 20 6f 66 20 73 6f 6d | 65 20 68 65 6c 70 20 74 |s of som|e help t|
|00000560| 6f 20 74 68 6f 73 65 20 | 77 69 74 68 20 6e 65 65 |o those |with nee|
|00000570| 64 20 2e 2e 2e 2e 0a 0a | 20 20 20 20 20 20 20 20 |d ......| |
|00000580| 20 20 20 20 20 20 20 20 | 20 20 6a 62 6b 0a 2d 2d | | jbk.--|
|00000590| 2d 2d 2d 2d 2d 2d 2d 2d | 0a 23 21 20 2f 62 69 6e |--------|.#! /bin|
|000005a0| 2f 73 68 0a 23 20 54 68 | 69 73 20 69 73 20 61 20 |/sh.# Th|is is a |
|000005b0| 73 68 65 6c 6c 20 61 72 | 63 68 69 76 65 2e 20 20 |shell ar|chive. |
|000005c0| 52 65 6d 6f 76 65 20 61 | 6e 79 74 68 69 6e 67 20 |Remove a|nything |
|000005d0| 62 65 66 6f 72 65 20 74 | 68 69 73 20 6c 69 6e 65 |before t|his line|
|000005e0| 2c 20 74 68 65 6e 20 75 | 6e 70 61 63 6b 0a 23 20 |, then u|npack.# |
|000005f0| 69 74 20 62 79 20 73 61 | 76 69 6e 67 20 69 74 20 |it by sa|ving it |
|00000600| 69 6e 74 6f 20 61 20 66 | 69 6c 65 20 61 6e 64 20 |into a f|ile and |
|00000610| 74 79 70 69 6e 67 20 22 | 73 68 20 66 69 6c 65 22 |typing "|sh file"|
|00000620| 2e 20 20 54 6f 20 6f 76 | 65 72 77 72 69 74 65 20 |. To ov|erwrite |
|00000630| 65 78 69 73 74 69 6e 67 | 0a 23 20 66 69 6c 65 73 |existing|.# files|
|00000640| 2c 20 74 79 70 65 20 22 | 73 68 20 66 69 6c 65 20 |, type "|sh file |
|00000650| 2d 63 22 2e 20 20 59 6f | 75 20 63 61 6e 20 61 6c |-c". Yo|u can al|
|00000660| 73 6f 20 66 65 65 64 20 | 74 68 69 73 20 61 73 20 |so feed |this as |
|00000670| 73 74 61 6e 64 61 72 64 | 20 69 6e 70 75 74 20 76 |standard| input v|
|00000680| 69 61 0a 23 20 75 6e 73 | 68 61 72 2c 20 6f 72 20 |ia.# uns|har, or |
|00000690| 62 79 20 74 79 70 69 6e | 67 20 22 73 68 20 3c 66 |by typin|g "sh <f|
|000006a0| 69 6c 65 22 2c 20 65 2e | 67 2e 2e 20 20 49 66 20 |ile", e.|g.. If |
|000006b0| 74 68 69 73 20 61 72 63 | 68 69 76 65 20 69 73 20 |this arc|hive is |
|000006c0| 63 6f 6d 70 6c 65 74 65 | 2c 20 79 6f 75 0a 23 20 |complete|, you.# |
|000006d0| 77 69 6c 6c 20 73 65 65 | 20 74 68 65 20 66 6f 6c |will see| the fol|
|000006e0| 6c 6f 77 69 6e 67 20 6d | 65 73 73 61 67 65 20 61 |lowing m|essage a|
|000006f0| 74 20 74 68 65 20 65 6e | 64 3a 0a 23 09 09 22 45 |t the en|d:.#.."E|
|00000700| 6e 64 20 6f 66 20 73 68 | 65 6c 6c 20 61 72 63 68 |nd of sh|ell arch|
|00000710| 69 76 65 2e 22 0a 23 20 | 43 6f 6e 74 65 6e 74 73 |ive.".# |Contents|
|00000720| 3a 20 20 4d 61 6b 65 66 | 69 6c 65 20 52 45 41 44 |: Makef|ile READ|
|00000730| 4d 45 20 6d 61 74 63 68 | 2e 63 20 6d 61 74 63 68 |ME match|.c match|
|00000740| 2e 68 0a 23 20 57 72 61 | 70 70 65 64 20 62 79 20 |.h.# Wra|pped by |
|00000750| 76 69 78 69 65 40 63 6f | 67 6e 69 74 69 6f 6e 2e |vixie@co|gnition.|
|00000760| 70 61 2e 64 65 63 2e 63 | 6f 6d 20 6f 6e 20 54 75 |pa.dec.c|om on Tu|
|00000770| 65 20 4d 61 72 20 31 30 | 20 32 32 3a 33 38 3a 31 |e Mar 10| 22:38:1|
|00000780| 36 20 31 39 39 32 0a 50 | 41 54 48 3d 2f 62 69 6e |6 1992.P|ATH=/bin|
|00000790| 3a 2f 75 73 72 2f 62 69 | 6e 3a 2f 75 73 72 2f 75 |:/usr/bi|n:/usr/u|
|000007a0| 63 62 20 3b 20 65 78 70 | 6f 72 74 20 50 41 54 48 |cb ; exp|ort PATH|
|000007b0| 0a 69 66 20 74 65 73 74 | 20 2d 66 20 27 4d 61 6b |.if test| -f 'Mak|
|000007c0| 65 66 69 6c 65 27 20 2d | 61 20 22 24 7b 31 7d 22 |efile' -|a "${1}"|
|000007d0| 20 21 3d 20 22 2d 63 22 | 20 3b 20 74 68 65 6e 20 | != "-c"| ; then |
|000007e0| 0a 20 20 65 63 68 6f 20 | 73 68 61 72 3a 20 57 69 |. echo |shar: Wi|
|000007f0| 6c 6c 20 6e 6f 74 20 63 | 6c 6f 62 62 65 72 20 65 |ll not c|lobber e|
|00000800| 78 69 73 74 69 6e 67 20 | 66 69 6c 65 20 5c 22 27 |xisting |file \"'|
|00000810| 4d 61 6b 65 66 69 6c 65 | 27 5c 22 0a 65 6c 73 65 |Makefile|'\".else|
|00000820| 0a 65 63 68 6f 20 73 68 | 61 72 3a 20 45 78 74 72 |.echo sh|ar: Extr|
|00000830| 61 63 74 69 6e 67 20 5c | 22 27 4d 61 6b 65 66 69 |acting \|"'Makefi|
|00000840| 6c 65 27 5c 22 20 5c 28 | 34 34 36 20 63 68 61 72 |le'\" \(|446 char|
|00000850| 61 63 74 65 72 73 5c 29 | 0a 73 65 64 20 22 73 2f |acters\)|.sed "s/|
|00000860| 5e 58 2f 2f 22 20 3e 27 | 4d 61 6b 65 66 69 6c 65 |^X//" >'|Makefile|
|00000870| 27 20 3c 3c 27 45 4e 44 | 5f 4f 46 5f 46 49 4c 45 |' <<'END|_OF_FILE|
|00000880| 27 0a 58 23 20 4d 61 6b | 65 66 69 6c 65 20 62 79 |'.X# Mak|efile by|
|00000890| 20 76 69 78 69 65 40 64 | 65 63 77 72 6c 2c 20 39 | vixie@d|ecwrl, 9|
|000008a0| 2d 6d 61 72 2d 39 32 0a | 58 0a 44 45 53 54 52 4f |-mar-92.|X.DESTRO|
|000008b0| 4f 54 20 3d 0a 44 45 53 | 54 53 59 53 20 3d 20 24 |OT =.DES|TSYS = $|
|000008c0| 7b 44 45 53 54 52 4f 4f | 54 7d 2f 75 73 72 2f 6c |{DESTROO|T}/usr/l|
|000008d0| 6f 63 61 6c 73 79 73 0a | 44 45 53 54 53 48 52 20 |ocalsys.|DESTSHR |
|000008e0| 3d 20 24 7b 44 45 53 54 | 52 4f 4f 54 7d 2f 75 73 |= ${DEST|ROOT}/us|
|000008f0| 72 2f 6c 6f 63 61 6c 73 | 68 72 0a 44 45 53 54 49 |r/locals|hr.DESTI|
|00000900| 4e 43 20 3d 20 24 7b 44 | 45 53 54 53 48 52 7d 2f |NC = ${D|ESTSHR}/|
|00000910| 69 6e 63 6c 75 64 65 0a | 44 45 53 54 4c 49 42 20 |include.|DESTLIB |
|00000920| 3d 20 24 7b 44 45 53 54 | 53 59 53 7d 2f 6c 69 62 |= ${DEST|SYS}/lib|
|00000930| 0a 58 0a 61 6c 6c 3a 20 | 6d 61 74 63 68 2e 68 20 |.X.all: |match.h |
|00000940| 6c 69 62 6d 61 74 63 68 | 2e 61 0a 58 0a 63 6c 65 |libmatch|.a.X.cle|
|00000950| 61 6e 3a 0a 58 09 72 6d | 20 2d 66 20 2a 2e 43 4b |an:.X.rm| -f *.CK|
|00000960| 50 20 2a 2e 42 41 4b 20 | 2a 7e 20 2a 2e 6f 0a 58 |P *.BAK |*~ *.o.X|
|00000970| 09 72 6d 20 2d 66 20 6c | 69 62 6d 61 74 63 68 2e |.rm -f l|ibmatch.|
|00000980| 61 0a 58 0a 69 6e 73 74 | 61 6c 6c 3a 20 61 6c 6c |a.X.inst|all: all|
|00000990| 0a 58 09 69 6e 73 74 61 | 6c 6c 20 2d 63 20 6d 61 |.X.insta|ll -c ma|
|000009a0| 74 63 68 2e 68 20 24 7b | 44 45 53 54 49 4e 43 7d |tch.h ${|DESTINC}|
|000009b0| 2f 6d 61 74 63 68 2e 68 | 0a 58 09 69 6e 73 74 61 |/match.h|.X.insta|
|000009c0| 6c 6c 20 2d 63 20 6c 69 | 62 6d 61 74 63 68 2e 61 |ll -c li|bmatch.a|
|000009d0| 20 24 7b 44 45 53 54 4c | 49 42 7d 2f 6c 69 62 6d | ${DESTL|IB}/libm|
|000009e0| 61 74 63 68 2e 61 0a 58 | 0a 6c 69 62 6d 61 74 63 |atch.a.X|.libmatc|
|000009f0| 68 2e 61 3a 20 6d 61 74 | 63 68 2e 68 20 6d 61 74 |h.a: mat|ch.h mat|
|00000a00| 63 68 2e 63 0a 58 09 24 | 7b 43 43 7d 20 2d 63 20 |ch.c.X.$|{CC} -c |
|00000a10| 24 7b 43 46 4c 41 47 53 | 7d 20 6d 61 74 63 68 2e |${CFLAGS|} match.|
|00000a20| 63 0a 58 09 72 6d 20 2d | 66 20 6c 69 62 6d 61 74 |c.X.rm -|f libmat|
|00000a30| 63 68 2e 61 0a 58 09 6d | 76 20 6d 61 74 63 68 2e |ch.a.X.m|v match.|
|00000a40| 6f 20 6c 69 62 6d 61 74 | 63 68 2e 61 0a 45 4e 44 |o libmat|ch.a.END|
|00000a50| 5f 4f 46 5f 46 49 4c 45 | 0a 69 66 20 74 65 73 74 |_OF_FILE|.if test|
|00000a60| 20 34 34 36 20 2d 6e 65 | 20 60 77 63 20 2d 63 20 | 446 -ne| `wc -c |
|00000a70| 3c 27 4d 61 6b 65 66 69 | 6c 65 27 60 3b 20 74 68 |<'Makefi|le'`; th|
|00000a80| 65 6e 0a 20 20 20 20 65 | 63 68 6f 20 73 68 61 72 |en. e|cho shar|
|00000a90| 3a 20 5c 22 27 4d 61 6b | 65 66 69 6c 65 27 5c 22 |: \"'Mak|efile'\"|
|00000aa0| 20 75 6e 70 61 63 6b 65 | 64 20 77 69 74 68 20 77 | unpacke|d with w|
|00000ab0| 72 6f 6e 67 20 73 69 7a | 65 21 0a 66 69 0a 23 20 |rong siz|e!.fi.# |
|00000ac0| 65 6e 64 20 6f 66 20 27 | 4d 61 6b 65 66 69 6c 65 |end of '|Makefile|
|00000ad0| 27 0a 66 69 0a 69 66 20 | 74 65 73 74 20 2d 66 20 |'.fi.if |test -f |
|00000ae0| 27 52 45 41 44 4d 45 27 | 20 2d 61 20 22 24 7b 31 |'README'| -a "${1|
|00000af0| 7d 22 20 21 3d 20 22 2d | 63 22 20 3b 20 74 68 65 |}" != "-|c" ; the|
|00000b00| 6e 20 0a 20 20 65 63 68 | 6f 20 73 68 61 72 3a 20 |n . ech|o shar: |
|00000b10| 57 69 6c 6c 20 6e 6f 74 | 20 63 6c 6f 62 62 65 72 |Will not| clobber|
|00000b20| 20 65 78 69 73 74 69 6e | 67 20 66 69 6c 65 20 5c | existin|g file \|
|00000b30| 22 27 52 45 41 44 4d 45 | 27 5c 22 0a 65 6c 73 65 |"'README|'\".else|
|00000b40| 0a 65 63 68 6f 20 73 68 | 61 72 3a 20 45 78 74 72 |.echo sh|ar: Extr|
|00000b50| 61 63 74 69 6e 67 20 5c | 22 27 52 45 41 44 4d 45 |acting \|"'README|
|00000b60| 27 5c 22 20 5c 28 32 32 | 34 37 20 63 68 61 72 61 |'\" \(22|47 chara|
|00000b70| 63 74 65 72 73 5c 29 0a | 73 65 64 20 22 73 2f 5e |cters\).|sed "s/^|
|00000b80| 58 2f 2f 22 20 3e 27 52 | 45 41 44 4d 45 27 20 3c |X//" >'R|EADME' <|
|00000b90| 3c 27 45 4e 44 5f 4f 46 | 5f 46 49 4c 45 27 0a 58 |<'END_OF|_FILE'.X|
|00000ba0| 30 32 2d 32 30 2d 39 31 | 20 53 65 61 74 74 6c 65 |02-20-91| Seattle|
|00000bb0| 2c 20 57 41 0a 58 0a 58 | 0a 48 65 72 65 20 69 73 |, WA.X.X|.Here is|
|00000bc0| 20 61 20 2a 49 58 20 77 | 69 6c 64 63 61 72 64 20 | a *IX w|ildcard |
|00000bd0| 67 6c 6f 62 62 65 72 20 | 49 20 62 75 74 63 68 65 |globber |I butche|
|00000be0| 72 65 64 2c 20 68 61 63 | 6b 65 64 20 61 6e 64 20 |red, hac|ked and |
|00000bf0| 63 61 6a 6f 6c 65 64 20 | 74 6f 67 65 74 68 65 72 |cajoled |together|
|00000c00| 0a 61 66 74 65 72 20 73 | 65 65 69 6e 67 20 61 6e |.after s|eeing an|
|00000c10| 64 20 68 65 61 72 69 6e | 67 20 61 62 6f 75 74 20 |d hearin|g about |
|00000c20| 61 6e 64 20 62 65 63 6f | 6d 69 6e 67 20 64 69 73 |and beco|ming dis|
|00000c30| 67 75 73 74 65 64 20 77 | 69 74 68 20 73 65 76 65 |gusted w|ith seve|
|00000c40| 72 61 6c 20 73 69 6d 69 | 6c 61 72 0a 72 6f 75 74 |ral simi|lar.rout|
|00000c50| 69 6e 65 73 20 77 68 69 | 63 68 20 68 61 64 20 6f |ines whi|ch had o|
|00000c60| 6e 65 20 6f 72 20 6d 6f | 72 65 20 6f 66 20 74 68 |ne or mo|re of th|
|00000c70| 65 20 66 6f 6c 6c 6f 77 | 69 6e 67 20 61 74 74 72 |e follow|ing attr|
|00000c80| 69 62 75 74 65 73 3a 20 | 20 73 6c 6f 77 2c 20 62 |ibutes: | slow, b|
|00000c90| 75 67 67 79 2c 0a 72 65 | 71 75 69 72 65 64 20 6c |uggy,.re|quired l|
|00000ca0| 61 72 67 65 20 6c 65 76 | 65 6c 73 20 6f 66 20 72 |arge lev|els of r|
|00000cb0| 65 63 75 72 73 69 6f 6e | 20 6f 6e 20 6d 61 74 63 |ecursion| on matc|
|00000cc0| 68 65 73 2c 20 72 65 71 | 75 69 72 65 64 20 67 72 |hes, req|uired gr|
|00000cd0| 6f 74 65 73 71 75 65 20 | 6c 65 76 65 6c 73 0a 6f |otesque |levels.o|
|00000ce0| 66 20 72 65 63 75 72 73 | 69 6f 6e 20 6f 6e 20 66 |f recurs|ion on f|
|00000cf0| 61 69 6c 69 6e 67 20 6d | 61 74 63 68 65 73 20 75 |ailing m|atches u|
|00000d00| 73 69 6e 67 20 27 2a 27 | 2c 20 66 75 6c 6c 20 6f |sing '*'|, full o|
|00000d10| 66 20 63 61 76 65 61 74 | 73 20 61 62 6f 75 74 20 |f caveat|s about |
|00000d20| 75 73 61 62 69 6c 69 74 | 79 0a 6f 72 20 63 6f 70 |usabilit|y.or cop|
|00000d30| 79 72 69 67 68 74 73 2e | 0a 58 0a 49 20 73 75 62 |yrights.|.X.I sub|
|00000d40| 6d 69 74 20 74 68 69 73 | 20 77 69 74 68 6f 75 74 |mit this| without|
|00000d50| 20 63 6f 70 79 72 69 67 | 68 74 20 61 6e 64 20 77 | copyrig|ht and w|
|00000d60| 69 74 68 20 74 68 65 20 | 63 6c 65 61 72 20 75 6e |ith the |clear un|
|00000d70| 64 65 72 73 74 61 6e 64 | 69 6e 67 20 74 68 61 74 |derstand|ing that|
|00000d80| 0a 74 68 69 73 20 63 6f | 64 65 20 6d 61 79 20 62 |.this co|de may b|
|00000d90| 65 20 75 73 65 64 20 62 | 79 20 61 6e 79 6f 6e 65 |e used b|y anyone|
|00000da0| 2c 20 66 6f 72 20 61 6e | 79 20 72 65 61 73 6f 6e |, for an|y reason|
|00000db0| 2c 20 77 69 74 68 20 61 | 6e 79 20 6d 6f 64 69 66 |, with a|ny modif|
|00000dc0| 69 63 61 74 69 6f 6e 73 | 0a 61 6e 64 20 77 69 74 |ications|.and wit|
|00000dd0| 68 6f 75 74 20 61 6e 79 | 20 67 75 61 72 61 6e 74 |hout any| guarant|
|00000de0| 65 65 73 2c 20 77 61 72 | 72 61 6e 74 65 65 20 6f |ees, war|rantee o|
|00000df0| 72 20 73 74 61 74 65 6d | 65 6e 74 73 20 6f 66 20 |r statem|ents of |
|00000e00| 75 73 61 62 69 6c 69 74 | 79 20 6f 66 20 61 6e 79 |usabilit|y of any|
|00000e10| 0a 73 6f 72 74 2e 0a 58 | 0a 48 61 76 69 6e 67 20 |.sort..X|.Having |
|00000e20| 67 6f 74 74 65 6e 20 74 | 68 6f 73 65 20 63 6f 77 |gotten t|hose cow|
|00000e30| 20 63 68 69 70 73 20 6f | 75 74 20 6f 66 20 74 68 | chips o|ut of th|
|00000e40| 65 20 77 61 79 2c 20 74 | 68 65 73 65 20 72 6f 75 |e way, t|hese rou|
|00000e50| 74 69 6e 65 73 20 61 72 | 65 20 66 61 69 72 6c 79 |tines ar|e fairly|
|00000e60| 0a 77 65 6c 6c 20 74 65 | 73 74 65 64 20 61 6e 64 |.well te|sted and|
|00000e70| 20 72 65 61 73 6f 6e 61 | 62 6c 79 20 66 61 73 74 | reasona|bly fast|
|00000e80| 2e 20 20 49 20 68 61 76 | 65 20 6d 61 64 65 20 61 |. I hav|e made a|
|00000e90| 6e 20 65 66 66 6f 72 74 | 20 74 6f 20 66 61 69 6c |n effort| to fail|
|00000ea0| 20 6f 6e 20 61 6c 6c 0a | 62 61 64 20 70 61 74 74 | on all.|bad patt|
|00000eb0| 65 72 6e 73 20 61 6e 64 | 20 74 6f 20 71 75 69 63 |erns and| to quic|
|00000ec0| 6b 6c 79 20 64 65 74 65 | 72 6d 69 6e 65 20 66 61 |kly dete|rmine fa|
|00000ed0| 69 6c 69 6e 67 20 27 2a | 27 20 70 61 74 74 65 72 |iling '*|' patter|
|00000ee0| 6e 73 2e 20 20 54 68 69 | 73 20 70 61 72 73 65 72 |ns. Thi|s parser|
|00000ef0| 0a 77 69 6c 6c 20 61 6c | 73 6f 20 64 6f 20 71 75 |.will al|so do qu|
|00000f00| 69 74 65 20 61 20 62 69 | 74 20 6f 66 20 74 68 65 |ite a bi|t of the|
|00000f10| 20 27 2a 27 20 6d 61 74 | 63 68 69 6e 67 20 76 69 | '*' mat|ching vi|
|00000f20| 61 20 71 75 69 63 6b 20 | 6c 69 6e 65 61 72 20 6c |a quick |linear l|
|00000f30| 6f 6f 70 73 20 76 65 72 | 73 75 73 0a 74 68 65 20 |oops ver|sus.the |
|00000f40| 73 74 61 6e 64 61 72 64 | 20 62 6c 69 6e 64 20 72 |standard| blind r|
|00000f50| 65 63 75 72 73 69 76 65 | 20 64 65 73 63 65 6e 74 |ecursive| descent|
|00000f60| 2e 0a 58 0a 54 68 69 73 | 20 70 61 72 73 65 72 20 |..X.This| parser |
|00000f70| 68 61 73 20 62 65 65 6e | 20 73 75 62 6d 69 74 74 |has been| submitt|
|00000f80| 65 64 20 74 6f 20 70 72 | 6f 66 69 6c 65 72 73 20 |ed to pr|ofilers |
|00000f90| 61 74 20 76 61 72 69 6f | 75 73 20 73 74 61 67 65 |at vario|us stage|
|00000fa0| 73 20 6f 66 20 64 65 76 | 65 6c 6f 70 6d 65 6e 74 |s of dev|elopment|
|00000fb0| 0a 61 6e 64 20 68 61 73 | 20 63 6f 6d 65 20 74 68 |.and has| come th|
|00000fc0| 72 6f 75 67 68 20 71 75 | 69 74 65 20 77 65 6c 6c |rough qu|ite well|
|00000fd0| 2e 20 20 49 66 20 74 68 | 65 20 6c 61 73 74 20 6d |. If th|e last m|
|00000fe0| 69 6c 6c 69 73 65 63 6f | 6e 64 20 69 73 20 69 6d |illiseco|nd is im|
|00000ff0| 70 6f 72 74 61 6e 74 20 | 74 6f 0a 79 6f 75 20 74 |portant |to.you t|
|00001000| 68 65 6e 20 73 6f 6d 65 | 20 74 69 6d 65 20 63 61 |hen some| time ca|
|00001010| 6e 20 62 65 20 73 68 61 | 76 65 64 20 62 79 20 75 |n be sha|ved by u|
|00001020| 73 69 6e 67 20 73 74 61 | 63 6b 20 61 6c 6c 6f 63 |sing sta|ck alloc|
|00001030| 61 74 65 64 20 76 61 72 | 69 61 62 6c 65 73 20 69 |ated var|iables i|
|00001040| 6e 0a 70 6c 61 63 65 20 | 6f 66 20 6d 61 6e 79 20 |n.place |of many |
|00001050| 6f 66 20 74 68 65 20 70 | 6f 69 6e 74 65 72 20 66 |of the p|ointer f|
|00001060| 6f 6c 6c 6f 77 73 20 28 | 77 68 69 63 68 20 6d 61 |ollows (|which ma|
|00001070| 79 20 62 65 20 64 6f 6e | 65 20 66 61 69 72 6c 79 |y be don|e fairly|
|00001080| 20 6f 66 74 65 6e 29 20 | 66 6f 75 6e 64 0a 69 6e | often) |found.in|
|00001090| 20 72 65 67 65 78 5f 6d | 61 74 63 68 20 61 6e 64 | regex_m|atch and|
|000010a0| 20 72 65 67 65 78 5f 6d | 61 74 63 68 5f 61 66 74 | regex_m|atch_aft|
|000010b0| 65 72 5f 73 74 61 72 20 | 28 69 65 20 2a 70 2c 20 |er_star |(ie *p, |
|000010c0| 2a 74 29 2e 0a 58 0a 4e | 6f 20 61 74 74 65 6d 70 |*t)..X.N|o attemp|
|000010d0| 74 20 69 73 20 6d 61 64 | 65 20 74 6f 20 70 72 6f |t is mad|e to pro|
|000010e0| 76 69 64 65 20 67 65 6e | 65 72 61 6c 20 5b 70 61 |vide gen|eral [pa|
|000010f0| 74 2c 70 61 74 5d 20 63 | 6f 6d 70 61 72 69 73 6f |t,pat] c|ompariso|
|00001100| 6e 73 2e 20 20 54 68 65 | 20 73 70 65 63 69 66 69 |ns. The| specifi|
|00001110| 63 0a 73 75 62 63 61 73 | 65 73 20 73 75 70 70 6c |c.subcas|es suppl|
|00001120| 69 65 64 20 62 79 20 74 | 68 65 73 65 20 72 6f 75 |ied by t|hese rou|
|00001130| 74 69 6e 65 73 20 69 73 | 20 5b 70 61 74 2c 74 65 |tines is| [pat,te|
|00001140| 78 74 5d 20 77 68 69 63 | 68 20 69 73 20 73 75 66 |xt] whic|h is suf|
|00001150| 66 69 63 69 65 6e 74 0a | 66 6f 72 20 74 68 65 20 |ficient.|for the |
|00001160| 6c 61 72 67 65 20 6d 61 | 6a 6f 72 69 74 79 20 6f |large ma|jority o|
|00001170| 66 20 63 61 73 65 73 20 | 28 73 68 6f 75 6c 64 20 |f cases |(should |
|00001180| 79 6f 75 20 63 61 72 65 | 29 2e 0a 58 0a 53 69 6e |you care|)..X.Sin|
|00001190| 63 65 20 72 65 67 65 78 | 5f 6d 61 74 63 68 20 6d |ce regex|_match m|
|000011a0| 61 79 20 72 65 74 75 72 | 6e 20 6f 6e 65 20 6f 66 |ay retur|n one of|
|000011b0| 20 74 68 72 65 65 20 64 | 69 66 66 65 72 65 6e 74 | three d|ifferent|
|000011c0| 20 76 61 6c 75 65 73 20 | 64 65 70 65 6e 64 69 6e | values |dependin|
|000011d0| 67 20 75 70 6f 6e 0a 74 | 68 65 20 70 61 74 74 65 |g upon.t|he patte|
|000011e0| 72 6e 20 61 6e 64 20 74 | 65 78 74 20 49 20 68 61 |rn and t|ext I ha|
|000011f0| 76 65 20 6d 61 64 65 20 | 61 20 73 69 6d 70 6c 65 |ve made |a simple|
|00001200| 20 73 68 65 6c 6c 20 66 | 6f 72 20 63 6f 6e 76 65 | shell f|or conve|
|00001210| 6e 69 65 6e 63 65 20 28 | 6d 61 74 63 68 28 29 29 |nience (|match())|
|00001220| 2e 0a 41 6c 73 6f 20 69 | 6e 63 6c 75 64 65 64 20 |..Also i|ncluded |
|00001230| 69 73 20 61 6e 20 69 73 | 5f 70 61 74 74 65 72 6e |is an is|_pattern|
|00001240| 20 72 6f 75 74 69 6e 65 | 20 74 6f 20 71 75 69 63 | routine| to quic|
|00001250| 6b 6c 79 20 63 68 65 63 | 6b 20 61 20 70 6f 74 65 |kly chec|k a pote|
|00001260| 6e 74 69 61 6c 20 70 61 | 74 74 65 72 6e 0a 66 6f |ntial pa|ttern.fo|
|00001270| 72 20 72 65 67 65 78 20 | 73 70 65 63 69 61 6c 20 |r regex |special |
|00001280| 63 68 61 72 61 63 74 65 | 72 73 2e 20 20 49 20 65 |characte|rs. I e|
|00001290| 76 65 6e 20 70 6c 61 63 | 65 64 20 74 68 69 73 20 |ven plac|ed this |
|000012a0| 61 6c 6c 20 69 6e 20 61 | 20 68 65 61 64 65 72 20 |all in a| header |
|000012b0| 66 69 6c 65 20 66 6f 72 | 0a 79 6f 75 20 6c 61 7a |file for|.you laz|
|000012c0| 79 20 66 6f 6c 6b 73 21 | 0a 58 0a 48 61 76 69 6e |y folks!|.X.Havin|
|000012d0| 67 20 73 61 69 64 20 61 | 6c 6c 20 74 68 61 74 2c |g said a|ll that,|
|000012e0| 20 68 65 72 65 20 69 73 | 20 6d 79 20 6f 77 6e 20 | here is| my own |
|000012f0| 72 65 69 6e 76 65 6e 74 | 69 6f 6e 20 6f 66 20 74 |reinvent|ion of t|
|00001300| 68 65 20 77 68 65 65 6c | 2e 20 20 50 6c 65 61 73 |he wheel|. Pleas|
|00001310| 65 0a 65 6e 6a 6f 79 20 | 69 74 27 73 20 75 73 65 |e.enjoy |it's use|
|00001320| 20 61 6e 64 20 49 20 68 | 6f 70 65 20 69 74 20 69 | and I h|ope it i|
|00001330| 73 20 6f 66 20 73 6f 6d | 65 20 68 65 6c 70 20 74 |s of som|e help t|
|00001340| 6f 20 74 68 6f 73 65 20 | 77 69 74 68 20 6e 65 65 |o those |with nee|
|00001350| 64 20 2e 2e 2e 2e 0a 58 | 0a 58 0a 58 20 20 20 20 |d .....X|.X.X |
|00001360| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00001370| 20 20 20 20 20 20 20 20 | 20 20 20 20 6a 62 6b 0a | | jbk.|
|00001380| 58 0a 58 46 72 6f 6d 3a | 20 6a 6f 68 6e 6b 40 77 |X.XFrom:| johnk@w|
|00001390| 72 71 2e 63 6f 6d 0a 44 | 61 74 65 3a 20 32 32 20 |rq.com.D|ate: 22 |
|000013a0| 46 65 62 20 39 31 20 30 | 31 3a 31 35 3a 34 33 20 |Feb 91 0|1:15:43 |
|000013b0| 47 4d 54 0a 4f 72 67 61 | 6e 69 7a 61 74 69 6f 6e |GMT.Orga|nization|
|000013c0| 3a 20 57 61 6c 6b 65 72 | 20 52 69 63 68 65 72 20 |: Walker| Richer |
|000013d0| 26 20 51 75 69 6e 6e 2c | 20 49 6e 63 2e 2c 20 53 |& Quinn,| Inc., S|
|000013e0| 65 61 74 74 6c 65 2c 20 | 57 41 0a 58 0a 4a 6f 68 |eattle, |WA.X.Joh|
|000013f0| 6e 20 4b 65 72 63 68 65 | 76 61 6c 20 2d 2d 20 31 |n Kerche|val -- 1|
|00001400| 32 37 20 4e 57 20 42 6f | 77 64 69 6f 6e 20 50 6c |27 NW Bo|wdion Pl|
|00001410| 20 23 31 30 35 20 2d 2d | 20 53 65 61 74 74 6c 65 | #105 --| Seattle|
|00001420| 2c 20 57 41 20 20 39 38 | 31 30 37 2d 34 39 36 30 |, WA 98|107-4960|
|00001430| 0a 48 6f 6d 65 28 56 6f | 69 63 65 29 3a 20 28 32 |.Home(Vo|ice): (2|
|00001440| 30 36 29 20 35 34 37 2d | 34 36 37 36 20 20 2d 2d |06) 547-|4676 --|
|00001450| 2d 2d 2d 2d 2d 2d 20 20 | 57 6f 72 6b 20 28 56 6f |------ |Work (Vo|
|00001460| 69 63 65 29 3a 20 28 32 | 30 36 29 20 33 32 34 2d |ice): (2|06) 324-|
|00001470| 30 33 35 30 0a 45 4e 44 | 5f 4f 46 5f 46 49 4c 45 |0350.END|_OF_FILE|
|00001480| 0a 69 66 20 74 65 73 74 | 20 32 32 34 37 20 2d 6e |.if test| 2247 -n|
|00001490| 65 20 60 77 63 20 2d 63 | 20 3c 27 52 45 41 44 4d |e `wc -c| <'READM|
|000014a0| 45 27 60 3b 20 74 68 65 | 6e 0a 20 20 20 20 65 63 |E'`; the|n. ec|
|000014b0| 68 6f 20 73 68 61 72 3a | 20 5c 22 27 52 45 41 44 |ho shar:| \"'READ|
|000014c0| 4d 45 27 5c 22 20 75 6e | 70 61 63 6b 65 64 20 77 |ME'\" un|packed w|
|000014d0| 69 74 68 20 77 72 6f 6e | 67 20 73 69 7a 65 21 0a |ith wron|g size!.|
|000014e0| 66 69 0a 23 20 65 6e 64 | 20 6f 66 20 27 52 45 41 |fi.# end| of 'REA|
|000014f0| 44 4d 45 27 0a 66 69 0a | 69 66 20 74 65 73 74 20 |DME'.fi.|if test |
|00001500| 2d 66 20 27 6d 61 74 63 | 68 2e 63 27 20 2d 61 20 |-f 'matc|h.c' -a |
|00001510| 22 24 7b 31 7d 22 20 21 | 3d 20 22 2d 63 22 20 3b |"${1}" !|= "-c" ;|
|00001520| 20 74 68 65 6e 20 0a 20 | 20 65 63 68 6f 20 73 68 | then . | echo sh|
|00001530| 61 72 3a 20 57 69 6c 6c | 20 6e 6f 74 20 63 6c 6f |ar: Will| not clo|
|00001540| 62 62 65 72 20 65 78 69 | 73 74 69 6e 67 20 66 69 |bber exi|sting fi|
|00001550| 6c 65 20 5c 22 27 6d 61 | 74 63 68 2e 63 27 5c 22 |le \"'ma|tch.c'\"|
|00001560| 0a 65 6c 73 65 0a 65 63 | 68 6f 20 73 68 61 72 3a |.else.ec|ho shar:|
|00001570| 20 45 78 74 72 61 63 74 | 69 6e 67 20 5c 22 27 6d | Extract|ing \"'m|
|00001580| 61 74 63 68 2e 63 27 5c | 22 20 5c 28 39 33 35 34 |atch.c'\|" \(9354|
|00001590| 20 63 68 61 72 61 63 74 | 65 72 73 5c 29 0a 73 65 | charact|ers\).se|
|000015a0| 64 20 22 73 2f 5e 58 2f | 2f 22 20 3e 27 6d 61 74 |d "s/^X/|/" >'mat|
|000015b0| 63 68 2e 63 27 20 3c 3c | 27 45 4e 44 5f 4f 46 5f |ch.c' <<|'END_OF_|
|000015c0| 46 49 4c 45 27 0a 58 2f | 2a 0a 58 20 45 50 53 48 |FILE'.X/|*.X EPSH|
|000015d0| 65 61 64 65 72 0a 58 0a | 58 20 20 20 46 69 6c 65 |eader.X.|X File|
|000015e0| 3a 20 6d 61 74 63 68 2e | 63 0a 58 20 20 20 41 75 |: match.|c.X Au|
|000015f0| 74 68 6f 72 3a 20 4a 2e | 20 4b 65 72 63 68 65 76 |thor: J.| Kerchev|
|00001600| 61 6c 0a 58 20 20 20 43 | 72 65 61 74 65 64 3a 20 |al.X C|reated: |
|00001610| 53 61 74 2c 20 30 31 2f | 30 35 2f 31 39 39 31 20 |Sat, 01/|05/1991 |
|00001620| 20 32 32 3a 32 31 3a 34 | 39 0a 58 2a 2f 0a 58 2f | 22:21:4|9.X*/.X/|
|00001630| 2a 0a 58 20 45 50 53 52 | 65 76 69 73 69 6f 6e 20 |*.X EPSR|evision |
|00001640| 48 69 73 74 6f 72 79 0a | 58 0a 58 20 20 20 4a 2e |History.|X.X J.|
|00001650| 20 4b 65 72 63 68 65 76 | 61 6c 20 20 57 65 64 2c | Kerchev|al Wed,|
|00001660| 20 30 32 2f 32 30 2f 31 | 39 39 31 20 20 32 32 3a | 02/20/1|991 22:|
|00001670| 32 39 3a 30 31 20 20 52 | 65 6c 65 61 73 65 64 20 |29:01 R|eleased |
|00001680| 74 6f 20 50 75 62 6c 69 | 63 20 44 6f 6d 61 69 6e |to Publi|c Domain|
|00001690| 0a 58 2a 2f 0a 58 0a 58 | 2f 2a 0a 58 20 20 20 57 |.X*/.X.X|/*.X W|
|000016a0| 69 6c 64 63 61 72 64 20 | 50 61 74 74 65 72 6e 20 |ildcard |Pattern |
|000016b0| 4d 61 74 63 68 69 6e 67 | 0a 58 2a 2f 0a 58 0a 58 |Matching|.X*/.X.X|
|000016c0| 0a 58 23 69 6e 63 6c 75 | 64 65 20 22 6d 61 74 63 |.X#inclu|de "matc|
|000016d0| 68 2e 68 22 0a 58 0a 58 | 23 64 65 66 69 6e 65 20 |h.h".X.X|#define |
|000016e0| 41 42 4f 52 54 20 32 20 | 20 20 20 20 2f 2a 20 65 |ABORT 2 | /* e|
|000016f0| 6e 64 20 6f 66 20 73 65 | 61 72 63 68 20 69 6e 64 |nd of se|arch ind|
|00001700| 69 63 61 74 6f 72 20 2a | 2f 0a 58 0a 42 4f 4f 4c |icator *|/.X.BOOL|
|00001710| 45 41 4e 20 72 65 67 65 | 78 5f 6d 61 74 63 68 5f |EAN rege|x_match_|
|00001720| 61 66 74 65 72 5f 73 74 | 61 72 20 28 63 68 61 72 |after_st|ar (char|
|00001730| 20 2a 70 61 74 74 65 72 | 6e 2c 20 63 68 61 72 20 | *patter|n, char |
|00001740| 2a 74 65 78 74 29 3b 0a | 58 0a 58 2f 2a 2d 2d 2d |*text);.|X.X/*---|
|00001750| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001760| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001770| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001780| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001790| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 0a 58 2a 0a 58 2a 20 |--------|-.X*.X* |
|000017a0| 52 65 74 75 72 6e 20 54 | 52 55 45 20 69 66 20 50 |Return T|RUE if P|
|000017b0| 41 54 54 45 52 4e 20 68 | 61 73 20 61 6e 79 20 73 |ATTERN h|as any s|
|000017c0| 70 65 63 69 61 6c 20 77 | 69 6c 64 63 61 72 64 20 |pecial w|ildcard |
|000017d0| 63 68 61 72 61 63 74 65 | 72 73 0a 58 2a 0a 58 2d |characte|rs.X*.X-|
|000017e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000017f0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001800| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001810| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001820| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2a 2f 0a 58 0a |--------|---*/.X.|
|00001830| 42 4f 4f 4c 45 41 4e 20 | 69 73 5f 70 61 74 74 65 |BOOLEAN |is_patte|
|00001840| 72 6e 20 28 63 68 61 72 | 20 2a 70 29 0a 58 7b 0a |rn (char| *p).X{.|
|00001850| 58 20 20 20 20 77 68 69 | 6c 65 20 28 20 2a 70 20 |X whi|le ( *p |
|00001860| 29 20 7b 0a 58 20 20 20 | 20 20 20 20 20 73 77 69 |) {.X | swi|
|00001870| 74 63 68 20 28 20 2a 70 | 2b 2b 20 29 20 7b 0a 58 |tch ( *p|++ ) {.X|
|00001880| 20 20 20 20 20 20 20 20 | 20 20 20 20 63 61 73 65 | | case|
|00001890| 20 27 3f 27 3a 0a 58 20 | 20 20 20 20 20 20 20 20 | '?':.X | |
|000018a0| 20 20 20 63 61 73 65 20 | 27 2a 27 3a 0a 58 20 20 | case |'*':.X |
|000018b0| 20 20 20 20 20 20 20 20 | 20 20 63 61 73 65 20 27 | | case '|
|000018c0| 5b 27 3a 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |[':.X | |
|000018d0| 20 20 20 20 20 72 65 74 | 75 72 6e 20 54 52 55 45 | ret|urn TRUE|
|000018e0| 3b 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 63 |;.X | c|
|000018f0| 61 73 65 20 27 5c 5c 27 | 3a 0a 58 20 20 20 20 20 |ase '\\'|:.X |
|00001900| 20 20 20 20 20 20 20 20 | 20 20 20 69 66 20 28 20 | | if ( |
|00001910| 21 2a 70 2b 2b 20 29 20 | 72 65 74 75 72 6e 20 46 |!*p++ ) |return F|
|00001920| 41 4c 53 45 3b 0a 58 20 | 20 20 20 20 20 20 20 7d |ALSE;.X | }|
|00001930| 0a 58 20 20 20 20 7d 0a | 58 20 20 20 20 72 65 74 |.X }.|X ret|
|00001940| 75 72 6e 20 46 41 4c 53 | 45 3b 0a 58 7d 0a 58 0a |urn FALS|E;.X}.X.|
|00001950| 58 0a 58 2f 2a 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |X.X/*---|--------|
|00001960| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001970| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001980| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001990| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000019a0| 2d 0a 58 2a 0a 58 2a 20 | 20 4d 61 74 63 68 20 74 |-.X*.X* | Match t|
|000019b0| 68 65 20 70 61 74 74 65 | 72 6e 20 50 41 54 54 45 |he patte|rn PATTE|
|000019c0| 52 4e 20 61 67 61 69 6e | 73 74 20 74 68 65 20 73 |RN again|st the s|
|000019d0| 74 72 69 6e 67 20 54 45 | 58 54 3b 0a 58 2a 20 20 |tring TE|XT;.X* |
|000019e0| 72 65 74 75 72 6e 20 54 | 52 55 45 20 69 66 20 69 |return T|RUE if i|
|000019f0| 74 20 6d 61 74 63 68 65 | 73 2c 20 46 41 4c 53 45 |t matche|s, FALSE|
|00001a00| 20 6f 74 68 65 72 77 69 | 73 65 2e 0a 58 2a 0a 58 | otherwi|se..X*.X|
|00001a10| 2a 20 20 41 20 6d 61 74 | 63 68 20 6d 65 61 6e 73 |* A mat|ch means|
|00001a20| 20 74 68 65 20 65 6e 74 | 69 72 65 20 73 74 72 69 | the ent|ire stri|
|00001a30| 6e 67 20 54 45 58 54 20 | 69 73 20 75 73 65 64 20 |ng TEXT |is used |
|00001a40| 75 70 20 69 6e 20 6d 61 | 74 63 68 69 6e 67 2e 0a |up in ma|tching..|
|00001a50| 58 2a 0a 58 2a 20 20 49 | 6e 20 74 68 65 20 70 61 |X*.X* I|n the pa|
|00001a60| 74 74 65 72 6e 20 73 74 | 72 69 6e 67 3a 0a 58 2a |ttern st|ring:.X*|
|00001a70| 20 20 20 20 20 20 20 60 | 2a 27 20 6d 61 74 63 68 | `|*' match|
|00001a80| 65 73 20 61 6e 79 20 73 | 65 71 75 65 6e 63 65 20 |es any s|equence |
|00001a90| 6f 66 20 63 68 61 72 61 | 63 74 65 72 73 0a 58 2a |of chara|cters.X*|
|00001aa0| 20 20 20 20 20 20 20 60 | 3f 27 20 6d 61 74 63 68 | `|?' match|
|00001ab0| 65 73 20 61 6e 79 20 63 | 68 61 72 61 63 74 65 72 |es any c|haracter|
|00001ac0| 0a 58 2a 20 20 20 20 20 | 20 20 5b 53 45 54 5d 20 |.X* | [SET] |
|00001ad0| 6d 61 74 63 68 65 73 20 | 61 6e 79 20 63 68 61 72 |matches |any char|
|00001ae0| 61 63 74 65 72 20 69 6e | 20 74 68 65 20 73 70 65 |acter in| the spe|
|00001af0| 63 69 66 69 65 64 20 73 | 65 74 2c 0a 58 2a 20 20 |cified s|et,.X* |
|00001b00| 20 20 20 20 20 5b 21 53 | 45 54 5d 20 6f 72 20 5b | [!S|ET] or [|
|00001b10| 5e 53 45 54 5d 20 6d 61 | 74 63 68 65 73 20 61 6e |^SET] ma|tches an|
|00001b20| 79 20 63 68 61 72 61 63 | 74 65 72 20 6e 6f 74 20 |y charac|ter not |
|00001b30| 69 6e 20 74 68 65 20 73 | 70 65 63 69 66 69 65 64 |in the s|pecified|
|00001b40| 20 73 65 74 2e 0a 58 2a | 0a 58 2a 20 20 4e 6f 74 | set..X*|.X* Not|
|00001b50| 65 3a 20 74 68 65 20 73 | 74 61 6e 64 61 72 64 20 |e: the s|tandard |
|00001b60| 72 65 67 65 78 20 63 68 | 61 72 61 63 74 65 72 20 |regex ch|aracter |
|00001b70| 27 2b 27 20 28 6f 6e 65 | 20 6f 72 20 6d 6f 72 65 |'+' (one| or more|
|00001b80| 29 20 73 68 6f 75 6c 64 | 20 62 79 0a 58 2a 20 20 |) should| by.X* |
|00001b90| 20 20 20 20 20 20 73 69 | 6d 75 6c 61 74 65 64 20 | si|mulated |
|00001ba0| 62 79 20 75 73 69 6e 67 | 20 22 3f 2a 22 20 77 68 |by using| "?*" wh|
|00001bb0| 69 63 68 20 69 73 20 65 | 71 75 69 76 65 6c 61 6e |ich is e|quivelan|
|00001bc0| 74 20 68 65 72 65 2e 0a | 58 2a 0a 58 2a 20 20 41 |t here..|X*.X* A|
|00001bd0| 20 73 65 74 20 69 73 20 | 63 6f 6d 70 6f 73 65 64 | set is |composed|
|00001be0| 20 6f 66 20 63 68 61 72 | 61 63 74 65 72 73 20 6f | of char|acters o|
|00001bf0| 72 20 72 61 6e 67 65 73 | 3b 20 61 20 72 61 6e 67 |r ranges|; a rang|
|00001c00| 65 20 6c 6f 6f 6b 73 20 | 6c 69 6b 65 0a 58 2a 20 |e looks |like.X* |
|00001c10| 20 63 68 61 72 61 63 74 | 65 72 20 68 79 70 68 65 | charact|er hyphe|
|00001c20| 6e 20 63 68 61 72 61 63 | 74 65 72 20 28 61 73 20 |n charac|ter (as |
|00001c30| 69 6e 20 30 2d 39 20 6f | 72 20 41 2d 5a 29 2e 0a |in 0-9 o|r A-Z)..|
|00001c40| 58 2a 20 20 5b 30 2d 39 | 61 2d 7a 41 2d 5a 5f 5d |X* [0-9|a-zA-Z_]|
|00001c50| 20 69 73 20 74 68 65 20 | 73 65 74 20 6f 66 20 63 | is the |set of c|
|00001c60| 68 61 72 61 63 74 65 72 | 73 20 61 6c 6c 6f 77 65 |haracter|s allowe|
|00001c70| 64 20 69 6e 20 43 20 69 | 64 65 6e 74 69 66 69 65 |d in C i|dentifie|
|00001c80| 72 73 2e 0a 58 2a 20 20 | 41 6e 79 20 6f 74 68 65 |rs..X* |Any othe|
|00001c90| 72 20 63 68 61 72 61 63 | 74 65 72 20 69 6e 20 74 |r charac|ter in t|
|00001ca0| 68 65 20 70 61 74 74 65 | 72 6e 20 6d 75 73 74 20 |he patte|rn must |
|00001cb0| 62 65 20 6d 61 74 63 68 | 65 64 20 65 78 61 63 74 |be match|ed exact|
|00001cc0| 6c 79 2e 0a 58 2a 0a 58 | 2a 20 20 54 6f 20 73 75 |ly..X*.X|* To su|
|00001cd0| 70 70 72 65 73 73 20 74 | 68 65 20 73 70 65 63 69 |ppress t|he speci|
|00001ce0| 61 6c 20 73 79 6e 74 61 | 63 74 69 63 20 73 69 67 |al synta|ctic sig|
|00001cf0| 6e 69 66 69 63 61 6e 63 | 65 20 6f 66 20 61 6e 79 |nificanc|e of any|
|00001d00| 20 6f 66 20 60 5b 5d 2a | 3f 21 5e 2d 5c 27 2c 0a | of `[]*|?!^-\',.|
|00001d10| 58 2a 20 20 61 6e 64 20 | 6d 61 74 63 68 20 74 68 |X* and |match th|
|00001d20| 65 20 63 68 61 72 61 63 | 74 65 72 20 65 78 61 63 |e charac|ter exac|
|00001d30| 74 6c 79 2c 20 70 72 65 | 63 65 64 65 20 69 74 20 |tly, pre|cede it |
|00001d40| 77 69 74 68 20 61 20 60 | 5c 27 2e 0a 58 2a 0a 58 |with a `|\'..X*.X|
|00001d50| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001d60| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001d70| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001d80| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00001d90| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2a 2f 0a 58 |--------|----*/.X|
|00001da0| 0a 42 4f 4f 4c 45 41 4e | 20 72 65 67 65 78 5f 6d |.BOOLEAN| regex_m|
|00001db0| 61 74 63 68 20 28 20 72 | 65 67 69 73 74 65 72 20 |atch ( r|egister |
|00001dc0| 63 68 61 72 20 2a 70 2c | 20 72 65 67 69 73 74 65 |char *p,| registe|
|00001dd0| 72 20 63 68 61 72 20 2a | 74 20 29 0a 58 7b 0a 58 |r char *|t ).X{.X|
|00001de0| 20 20 20 20 72 65 67 69 | 73 74 65 72 20 63 68 61 | regi|ster cha|
|00001df0| 72 20 72 61 6e 67 65 5f | 73 74 61 72 74 2c 20 72 |r range_|start, r|
|00001e00| 61 6e 67 65 5f 65 6e 64 | 3b 20 20 2f 2a 20 73 74 |ange_end|; /* st|
|00001e10| 61 72 74 20 61 6e 64 20 | 65 6e 64 20 69 6e 20 72 |art and |end in r|
|00001e20| 61 6e 67 65 20 2a 2f 0a | 58 0a 58 20 20 20 20 42 |ange */.|X.X B|
|00001e30| 4f 4f 4c 45 41 4e 20 69 | 6e 76 65 72 74 3b 20 20 |OOLEAN i|nvert; |
|00001e40| 20 20 20 20 20 20 20 20 | 20 20 20 2f 2a 20 69 73 | | /* is|
|00001e50| 20 74 68 69 73 20 5b 2e | 2e 5d 20 6f 72 20 5b 21 | this [.|.] or [!|
|00001e60| 2e 2e 5d 20 2a 2f 0a 58 | 20 20 20 20 42 4f 4f 4c |..] */.X| BOOL|
|00001e70| 45 41 4e 20 6d 65 6d 62 | 65 72 5f 6d 61 74 63 68 |EAN memb|er_match|
|00001e80| 3b 20 20 20 20 20 20 20 | 2f 2a 20 68 61 76 65 20 |; |/* have |
|00001e90| 49 20 6d 61 74 63 68 65 | 64 20 74 68 65 20 5b 2e |I matche|d the [.|
|00001ea0| 2e 5d 20 63 6f 6e 73 74 | 72 75 63 74 3f 20 2a 2f |.] const|ruct? */|
|00001eb0| 0a 58 20 20 20 20 42 4f | 4f 4c 45 41 4e 20 6c 6f |.X BO|OLEAN lo|
|00001ec0| 6f 70 3b 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |op; | |
|00001ed0| 20 20 2f 2a 20 73 68 6f | 75 6c 64 20 49 20 74 65 | /* sho|uld I te|
|00001ee0| 72 6d 69 6e 61 74 65 3f | 20 2a 2f 0a 58 0a 58 20 |rminate?| */.X.X |
|00001ef0| 20 20 20 66 6f 72 20 28 | 20 3b 20 2a 70 3b 20 70 | for (| ; *p; p|
|00001f00| 2b 2b 2c 20 74 2b 2b 20 | 29 20 7b 0a 58 0a 58 20 |++, t++ |) {.X.X |
|00001f10| 20 20 20 20 20 20 20 2f | 2a 20 69 66 20 74 68 69 | /|* if thi|
|00001f20| 73 20 69 73 20 74 68 65 | 20 65 6e 64 20 6f 66 20 |s is the| end of |
|00001f30| 74 68 65 20 74 65 78 74 | 20 74 68 65 6e 20 74 68 |the text| then th|
|00001f40| 69 73 20 69 73 20 74 68 | 65 20 65 6e 64 20 6f 66 |is is th|e end of|
|00001f50| 20 74 68 65 20 6d 61 74 | 63 68 20 2a 2f 0a 58 20 | the mat|ch */.X |
|00001f60| 20 20 20 20 20 20 20 69 | 66 20 28 21 2a 74 29 20 | i|f (!*t) |
|00001f70| 7b 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 72 |{.X | r|
|00001f80| 65 74 75 72 6e 20 28 20 | 2a 70 20 3d 3d 20 27 2a |eturn ( |*p == '*|
|00001f90| 27 20 26 26 20 2a 2b 2b | 70 20 3d 3d 20 27 5c 30 |' && *++|p == '\0|
|00001fa0| 27 20 29 20 3f 20 54 52 | 55 45 20 3a 20 41 42 4f |' ) ? TR|UE : ABO|
|00001fb0| 52 54 3b 0a 58 20 20 20 | 20 20 20 20 20 7d 0a 58 |RT;.X | }.X|
|00001fc0| 0a 58 20 20 20 20 20 20 | 20 20 2f 2a 20 64 65 74 |.X | /* det|
|00001fd0| 65 72 6d 69 6e 65 20 61 | 6e 64 20 72 65 61 63 74 |ermine a|nd react|
|00001fe0| 20 74 6f 20 70 61 74 74 | 65 72 6e 20 74 79 70 65 | to patt|ern type|
|00001ff0| 20 2a 2f 0a 58 20 20 20 | 20 20 20 20 20 73 77 69 | */.X | swi|
|00002000| 74 63 68 20 28 20 2a 70 | 20 29 20 7b 0a 58 0a 58 |tch ( *p| ) {.X.X|
|00002010| 20 20 20 20 20 20 20 20 | 20 20 20 20 2f 2a 20 73 | | /* s|
|00002020| 69 6e 67 6c 65 20 61 6e | 79 20 63 68 61 72 61 63 |ingle an|y charac|
|00002030| 74 65 72 20 6d 61 74 63 | 68 20 2a 2f 0a 58 20 20 |ter matc|h */.X |
|00002040| 20 20 20 20 20 20 20 20 | 20 20 63 61 73 65 20 27 | | case '|
|00002050| 3f 27 3a 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |?':.X | |
|00002060| 20 20 20 20 20 62 72 65 | 61 6b 3b 0a 58 0a 58 20 | bre|ak;.X.X |
|00002070| 20 20 20 20 20 20 20 20 | 20 20 20 2f 2a 20 6d 75 | | /* mu|
|00002080| 6c 74 69 70 6c 65 20 61 | 6e 79 20 63 68 61 72 61 |ltiple a|ny chara|
|00002090| 63 74 65 72 20 6d 61 74 | 63 68 20 2a 2f 0a 58 20 |cter mat|ch */.X |
|000020a0| 20 20 20 20 20 20 20 20 | 20 20 20 63 61 73 65 20 | | case |
|000020b0| 27 2a 27 3a 0a 58 20 20 | 20 20 20 20 20 20 20 20 |'*':.X | |
|000020c0| 20 20 20 20 20 20 72 65 | 74 75 72 6e 20 72 65 67 | re|turn reg|
|000020d0| 65 78 5f 6d 61 74 63 68 | 5f 61 66 74 65 72 5f 73 |ex_match|_after_s|
|000020e0| 74 61 72 20 28 70 2c 20 | 74 29 3b 0a 58 0a 58 20 |tar (p, |t);.X.X |
|000020f0| 20 20 20 20 20 20 20 20 | 20 20 20 2f 2a 20 5b 2e | | /* [.|
|00002100| 2e 5d 20 63 6f 6e 73 74 | 72 75 63 74 2c 20 73 69 |.] const|ruct, si|
|00002110| 6e 67 6c 65 20 6d 65 6d | 62 65 72 2f 65 78 63 6c |ngle mem|ber/excl|
|00002120| 75 73 69 6f 6e 20 63 68 | 61 72 61 63 74 65 72 20 |usion ch|aracter |
|00002130| 6d 61 74 63 68 20 2a 2f | 0a 58 20 20 20 20 20 20 |match */|.X |
|00002140| 20 20 20 20 20 20 63 61 | 73 65 20 27 5b 27 3a 20 | ca|se '[': |
|00002150| 7b 0a 58 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |{.X.X | |
|00002160| 20 20 20 20 20 2f 2a 20 | 6d 6f 76 65 20 74 6f 20 | /* |move to |
|00002170| 62 65 67 69 6e 6e 69 6e | 67 20 6f 66 20 72 61 6e |beginnin|g of ran|
|00002180| 67 65 20 2a 2f 0a 58 20 | 20 20 20 20 20 20 20 20 |ge */.X | |
|00002190| 20 20 20 20 20 20 20 70 | 2b 2b 3b 0a 58 0a 58 20 | p|++;.X.X |
|000021a0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 2f | | /|
|000021b0| 2a 20 63 68 65 63 6b 20 | 69 66 20 74 68 69 73 20 |* check |if this |
|000021c0| 69 73 20 61 20 6d 65 6d | 62 65 72 20 6d 61 74 63 |is a mem|ber matc|
|000021d0| 68 20 6f 72 20 65 78 63 | 6c 75 73 69 6f 6e 20 6d |h or exc|lusion m|
|000021e0| 61 74 63 68 20 2a 2f 0a | 58 20 20 20 20 20 20 20 |atch */.|X |
|000021f0| 20 20 20 20 20 20 20 20 | 20 69 6e 76 65 72 74 20 | | invert |
|00002200| 3d 20 46 41 4c 53 45 3b | 0a 58 20 20 20 20 20 20 |= FALSE;|.X |
|00002210| 20 20 20 20 20 20 20 20 | 20 20 69 66 20 28 20 2a | | if ( *|
|00002220| 70 20 3d 3d 20 27 21 27 | 20 7c 7c 20 2a 70 20 3d |p == '!'| || *p =|
|00002230| 3d 20 27 5e 27 29 20 7b | 0a 58 20 20 20 20 20 20 |= '^') {|.X |
|00002240| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 69 6e | | in|
|00002250| 76 65 72 74 20 3d 20 54 | 52 55 45 3b 0a 58 20 20 |vert = T|RUE;.X |
|00002260| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002270| 20 20 70 2b 2b 3b 0a 58 | 20 20 20 20 20 20 20 20 | p++;.X| |
|00002280| 20 20 20 20 20 20 20 20 | 7d 0a 58 0a 58 20 20 20 | |}.X.X |
|00002290| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 2f 2a 20 | | /* |
|000022a0| 69 66 20 63 6c 6f 73 69 | 6e 67 20 62 72 61 63 6b |if closi|ng brack|
|000022b0| 65 74 20 68 65 72 65 20 | 6f 72 20 61 74 20 72 61 |et here |or at ra|
|000022c0| 6e 67 65 20 73 74 61 72 | 74 20 74 68 65 6e 20 77 |nge star|t then w|
|000022d0| 65 20 68 61 76 65 20 61 | 0a 58 20 20 20 20 20 20 |e have a|.X |
|000022e0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 6d 61 6c | | mal|
|000022f0| 66 6f 72 6d 65 64 20 70 | 61 74 74 65 72 6e 20 2a |formed p|attern *|
|00002300| 2f 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |/.X | |
|00002310| 20 20 20 69 66 20 28 20 | 2a 70 20 3d 3d 20 27 5d | if ( |*p == ']|
|00002320| 27 20 29 20 7b 0a 58 20 | 20 20 20 20 20 20 20 20 |' ) {.X | |
|00002330| 20 20 20 20 20 20 20 20 | 20 20 20 72 65 74 75 72 | | retur|
|00002340| 6e 20 41 42 4f 52 54 3b | 0a 58 20 20 20 20 20 20 |n ABORT;|.X |
|00002350| 20 20 20 20 20 20 20 20 | 20 20 7d 0a 58 0a 58 20 | | }.X.X |
|00002360| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 6d | | m|
|00002370| 65 6d 62 65 72 5f 6d 61 | 74 63 68 20 3d 20 46 41 |ember_ma|tch = FA|
|00002380| 4c 53 45 3b 0a 58 20 20 | 20 20 20 20 20 20 20 20 |LSE;.X | |
|00002390| 20 20 20 20 20 20 6c 6f | 6f 70 20 3d 20 54 52 55 | lo|op = TRU|
|000023a0| 45 3b 0a 58 0a 58 20 20 | 20 20 20 20 20 20 20 20 |E;.X.X | |
|000023b0| 20 20 20 20 20 20 77 68 | 69 6c 65 20 28 20 6c 6f | wh|ile ( lo|
|000023c0| 6f 70 20 29 20 7b 0a 58 | 0a 58 20 20 20 20 20 20 |op ) {.X|.X |
|000023d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 2f 2a | | /*|
|000023e0| 20 69 66 20 65 6e 64 20 | 6f 66 20 63 6f 6e 73 74 | if end |of const|
|000023f0| 72 75 63 74 20 74 68 65 | 6e 20 6c 6f 6f 70 20 69 |ruct the|n loop i|
|00002400| 73 20 64 6f 6e 65 20 2a | 2f 0a 58 20 20 20 20 20 |s done *|/.X |
|00002410| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 69 | | i|
|00002420| 66 20 28 2a 70 20 3d 3d | 20 27 5d 27 29 20 7b 0a |f (*p ==| ']') {.|
|00002430| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X | |
|00002440| 20 20 20 20 20 20 20 20 | 20 6c 6f 6f 70 20 3d 20 | | loop = |
|00002450| 46 41 4c 53 45 3b 0a 58 | 20 20 20 20 20 20 20 20 |FALSE;.X| |
|00002460| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002470| 63 6f 6e 74 69 6e 75 65 | 3b 0a 58 20 20 20 20 20 |continue|;.X |
|00002480| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 7d | | }|
|00002490| 0a 58 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X.X | |
|000024a0| 20 20 20 20 20 20 20 20 | 2f 2a 20 6d 61 74 63 68 | |/* match|
|000024b0| 69 6e 67 20 61 20 27 21 | 27 2c 20 27 5e 27 2c 20 |ing a '!|', '^', |
|000024c0| 27 2d 27 2c 20 27 5c 27 | 20 6f 72 20 61 20 27 5d |'-', '\'| or a ']|
|000024d0| 27 20 2a 2f 0a 58 20 20 | 20 20 20 20 20 20 20 20 |' */.X | |
|000024e0| 20 20 20 20 20 20 20 20 | 20 20 69 66 20 28 20 2a | | if ( *|
|000024f0| 70 20 3d 3d 20 27 5c 5c | 27 20 29 20 7b 0a 58 20 |p == '\\|' ) {.X |
|00002500| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002510| 20 20 20 20 20 20 20 72 | 61 6e 67 65 5f 73 74 61 | r|ange_sta|
|00002520| 72 74 20 3d 20 72 61 6e | 67 65 5f 65 6e 64 20 3d |rt = ran|ge_end =|
|00002530| 20 2a 2b 2b 70 3b 0a 58 | 20 20 20 20 20 20 20 20 | *++p;.X| |
|00002540| 20 20 20 20 20 20 20 20 | 20 20 20 20 7d 0a 58 20 | | }.X |
|00002550| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002560| 20 20 20 65 6c 73 65 20 | 7b 0a 58 20 20 20 20 20 | else |{.X |
|00002570| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002580| 20 20 20 72 61 6e 67 65 | 5f 73 74 61 72 74 20 3d | range|_start =|
|00002590| 20 72 61 6e 67 65 5f 65 | 6e 64 20 3d 20 2a 70 3b | range_e|nd = *p;|
|000025a0| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|000025b0| 20 20 20 20 20 20 7d 0a | 58 0a 58 20 20 20 20 20 | }.|X.X |
|000025c0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 2f | | /|
|000025d0| 2a 20 69 66 20 65 6e 64 | 20 6f 66 20 70 61 74 74 |* if end| of patt|
|000025e0| 65 72 6e 20 74 68 65 6e | 20 62 61 64 20 70 61 74 |ern then| bad pat|
|000025f0| 74 65 72 6e 20 28 4d 69 | 73 73 69 6e 67 20 27 5d |tern (Mi|ssing ']|
|00002600| 27 29 20 2a 2f 0a 58 20 | 20 20 20 20 20 20 20 20 |') */.X | |
|00002610| 20 20 20 20 20 20 20 20 | 20 20 20 69 66 20 28 21 | | if (!|
|00002620| 72 61 6e 67 65 5f 73 74 | 61 72 74 29 0a 58 20 20 |range_st|art).X |
|00002630| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002640| 20 20 20 20 20 20 72 65 | 74 75 72 6e 20 41 42 4f | re|turn ABO|
|00002650| 52 54 3b 0a 58 0a 58 20 | 20 20 20 20 20 20 20 20 |RT;.X.X | |
|00002660| 20 20 20 20 20 20 20 20 | 20 20 20 2f 2a 20 6d 6f | | /* mo|
|00002670| 76 65 20 74 6f 20 6e 65 | 78 74 20 70 61 74 74 65 |ve to ne|xt patte|
|00002680| 72 6e 20 63 68 61 72 20 | 2a 2f 0a 58 20 20 20 20 |rn char |*/.X |
|00002690| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000026a0| 70 2b 2b 3b 0a 58 0a 58 | 20 20 20 20 20 20 20 20 |p++;.X.X| |
|000026b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 2f 2a 20 63 | | /* c|
|000026c0| 68 65 63 6b 20 66 6f 72 | 20 72 61 6e 67 65 20 62 |heck for| range b|
|000026d0| 61 72 20 2a 2f 0a 58 20 | 20 20 20 20 20 20 20 20 |ar */.X | |
|000026e0| 20 20 20 20 20 20 20 20 | 20 20 20 69 66 20 28 2a | | if (*|
|000026f0| 70 20 3d 3d 20 27 2d 27 | 29 20 7b 0a 58 0a 58 20 |p == '-'|) {.X.X |
|00002700| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002710| 20 20 20 20 20 20 20 2f | 2a 20 67 65 74 20 74 68 | /|* get th|
|00002720| 65 20 72 61 6e 67 65 20 | 65 6e 64 20 2a 2f 0a 58 |e range |end */.X|
|00002730| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002740| 20 20 20 20 20 20 20 20 | 72 61 6e 67 65 5f 65 6e | |range_en|
|00002750| 64 20 3d 20 2a 2b 2b 70 | 3b 0a 58 0a 58 20 20 20 |d = *++p|;.X.X |
|00002760| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002770| 20 20 20 20 20 2f 2a 20 | 73 70 65 63 69 61 6c 20 | /* |special |
|00002780| 63 68 61 72 61 63 74 65 | 72 20 72 61 6e 67 65 20 |characte|r range |
|00002790| 65 6e 64 20 2a 2f 0a 58 | 20 20 20 20 20 20 20 20 |end */.X| |
|000027a0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000027b0| 69 66 20 28 72 61 6e 67 | 65 5f 65 6e 64 20 3d 3d |if (rang|e_end ==|
|000027c0| 20 27 5c 5c 27 29 0a 58 | 20 20 20 20 20 20 20 20 | '\\').X| |
|000027d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000027e0| 20 20 20 20 72 61 6e 67 | 65 5f 65 6e 64 20 3d 20 | rang|e_end = |
|000027f0| 2a 2b 2b 70 3b 0a 58 0a | 58 20 20 20 20 20 20 20 |*++p;.X.|X |
|00002800| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002810| 20 2f 2a 20 69 66 20 65 | 6e 64 20 6f 66 20 70 61 | /* if e|nd of pa|
|00002820| 74 74 65 72 6e 20 6f 72 | 20 63 6f 6e 73 74 72 75 |ttern or| constru|
|00002830| 63 74 20 74 68 65 6e 20 | 62 61 64 20 70 61 74 74 |ct then |bad patt|
|00002840| 65 72 6e 20 2a 2f 0a 58 | 20 20 20 20 20 20 20 20 |ern */.X| |
|00002850| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002860| 69 66 20 28 72 61 6e 67 | 65 5f 65 6e 64 20 3d 3d |if (rang|e_end ==|
|00002870| 20 27 5c 30 27 20 7c 7c | 20 72 61 6e 67 65 5f 65 | '\0' ||| range_e|
|00002880| 6e 64 20 3d 3d 20 27 5d | 27 29 0a 58 20 20 20 20 |nd == ']|').X |
|00002890| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000028a0| 20 20 20 20 20 20 20 20 | 72 65 74 75 72 6e 20 41 | |return A|
|000028b0| 42 4f 52 54 3b 0a 58 20 | 20 20 20 20 20 20 20 20 |BORT;.X | |
|000028c0| 20 20 20 20 20 20 20 20 | 20 20 20 7d 0a 58 0a 58 | | }.X.X|
|000028d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000028e0| 20 20 20 20 2f 2a 20 69 | 66 20 74 68 65 20 74 65 | /* i|f the te|
|000028f0| 78 74 20 63 68 61 72 61 | 63 74 65 72 20 69 73 20 |xt chara|cter is |
|00002900| 69 6e 20 72 61 6e 67 65 | 20 74 68 65 6e 20 6d 61 |in range| then ma|
|00002910| 74 63 68 20 66 6f 75 6e | 64 2e 0a 58 20 20 20 20 |tch foun|d..X |
|00002920| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002930| 20 20 20 6d 61 6b 65 20 | 73 75 72 65 20 74 68 65 | make |sure the|
|00002940| 20 72 61 6e 67 65 20 6c | 65 74 74 65 72 73 20 68 | range l|etters h|
|00002950| 61 76 65 20 74 68 65 20 | 70 72 6f 70 65 72 0a 58 |ave the |proper.X|
|00002960| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002970| 20 20 20 20 20 20 20 72 | 65 6c 61 74 69 6f 6e 73 | r|elations|
|00002980| 68 69 70 20 74 6f 20 6f | 6e 65 20 61 6e 6f 74 68 |hip to o|ne anoth|
|00002990| 65 72 20 62 65 66 6f 72 | 65 20 63 6f 6d 70 61 72 |er befor|e compar|
|000029a0| 69 73 6f 6e 20 2a 2f 0a | 58 20 20 20 20 20 20 20 |ison */.|X |
|000029b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 69 66 20 | | if |
|000029c0| 28 20 72 61 6e 67 65 5f | 73 74 61 72 74 20 3c 20 |( range_|start < |
|000029d0| 72 61 6e 67 65 5f 65 6e | 64 20 20 29 20 7b 0a 58 |range_en|d ) {.X|
|000029e0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000029f0| 20 20 20 20 20 20 20 20 | 69 66 20 28 2a 74 20 3e | |if (*t >|
|00002a00| 3d 20 72 61 6e 67 65 5f | 73 74 61 72 74 20 26 26 |= range_|start &&|
|00002a10| 20 2a 74 20 3c 3d 20 72 | 61 6e 67 65 5f 65 6e 64 | *t <= r|ange_end|
|00002a20| 29 20 7b 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |) {.X | |
|00002a30| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002a40| 20 6d 65 6d 62 65 72 5f | 6d 61 74 63 68 20 3d 20 | member_|match = |
|00002a50| 54 52 55 45 3b 0a 58 20 | 20 20 20 20 20 20 20 20 |TRUE;.X | |
|00002a60| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002a70| 20 20 20 6c 6f 6f 70 20 | 3d 20 46 41 4c 53 45 3b | loop |= FALSE;|
|00002a80| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00002a90| 20 20 20 20 20 20 20 20 | 20 20 7d 0a 58 20 20 20 | | }.X |
|00002aa0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002ab0| 20 7d 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 | }.X | |
|00002ac0| 20 20 20 20 20 20 20 20 | 65 6c 73 65 20 7b 0a 58 | |else {.X|
|00002ad0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002ae0| 20 20 20 20 20 20 20 20 | 69 66 20 28 2a 74 20 3e | |if (*t >|
|00002af0| 3d 20 72 61 6e 67 65 5f | 65 6e 64 20 26 26 20 2a |= range_|end && *|
|00002b00| 74 20 3c 3d 20 72 61 6e | 67 65 5f 73 74 61 72 74 |t <= ran|ge_start|
|00002b10| 29 20 7b 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |) {.X | |
|00002b20| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002b30| 20 6d 65 6d 62 65 72 5f | 6d 61 74 63 68 20 3d 20 | member_|match = |
|00002b40| 54 52 55 45 3b 0a 58 20 | 20 20 20 20 20 20 20 20 |TRUE;.X | |
|00002b50| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002b60| 20 20 20 6c 6f 6f 70 20 | 3d 20 46 41 4c 53 45 3b | loop |= FALSE;|
|00002b70| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00002b80| 20 20 20 20 20 20 20 20 | 20 20 7d 0a 58 20 20 20 | | }.X |
|00002b90| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002ba0| 20 7d 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 | }.X | |
|00002bb0| 20 20 20 20 7d 0a 58 0a | 58 20 20 20 20 20 20 20 | }.X.|X |
|00002bc0| 20 20 20 20 20 20 20 20 | 20 2f 2a 20 69 66 20 74 | | /* if t|
|00002bd0| 68 65 72 65 20 77 61 73 | 20 61 20 6d 61 74 63 68 |here was| a match|
|00002be0| 20 69 6e 20 61 6e 20 65 | 78 63 6c 75 73 69 6f 6e | in an e|xclusion|
|00002bf0| 20 73 65 74 20 74 68 65 | 6e 20 6e 6f 20 6d 61 74 | set the|n no mat|
|00002c00| 63 68 20 2a 2f 0a 58 20 | 20 20 20 20 20 20 20 20 |ch */.X | |
|00002c10| 20 20 20 20 20 20 20 2f | 2a 20 69 66 20 74 68 65 | /|* if the|
|00002c20| 72 65 20 77 61 73 20 6e | 6f 20 6d 61 74 63 68 20 |re was n|o match |
|00002c30| 69 6e 20 61 20 6d 65 6d | 62 65 72 20 73 65 74 20 |in a mem|ber set |
|00002c40| 74 68 65 6e 20 6e 6f 20 | 6d 61 74 63 68 20 2a 2f |then no |match */|
|00002c50| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00002c60| 20 20 69 66 20 28 28 69 | 6e 76 65 72 74 20 26 26 | if ((i|nvert &&|
|00002c70| 20 6d 65 6d 62 65 72 5f | 6d 61 74 63 68 29 20 7c | member_|match) ||
|00002c80| 7c 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 20 ||.X | |
|00002c90| 20 20 20 20 20 20 21 28 | 69 6e 76 65 72 74 20 7c | !(|invert ||
|00002ca0| 7c 20 6d 65 6d 62 65 72 | 5f 6d 61 74 63 68 29 29 || member|_match))|
|00002cb0| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00002cc0| 20 20 20 20 20 20 72 65 | 74 75 72 6e 20 46 41 4c | re|turn FAL|
|00002cd0| 53 45 3b 0a 58 0a 58 20 | 20 20 20 20 20 20 20 20 |SE;.X.X | |
|00002ce0| 20 20 20 20 20 20 20 2f | 2a 20 69 66 20 74 68 69 | /|* if thi|
|00002cf0| 73 20 69 73 20 6e 6f 74 | 20 61 6e 20 65 78 63 6c |s is not| an excl|
|00002d00| 75 73 69 6f 6e 20 74 68 | 65 6e 20 73 6b 69 70 20 |usion th|en skip |
|00002d10| 74 68 65 20 72 65 73 74 | 20 6f 66 20 74 68 65 20 |the rest| of the |
|00002d20| 5b 2e 2e 2e 5d 0a 58 20 | 20 20 20 20 20 20 20 20 |[...].X | |
|00002d30| 20 20 20 20 20 20 20 20 | 20 20 20 63 6f 6e 73 74 | | const|
|00002d40| 72 75 63 74 20 74 68 61 | 74 20 61 6c 72 65 61 64 |ruct tha|t alread|
|00002d50| 79 20 6d 61 74 63 68 65 | 64 2e 20 2a 2f 0a 58 20 |y matche|d. */.X |
|00002d60| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 69 | | i|
|00002d70| 66 20 28 6d 65 6d 62 65 | 72 5f 6d 61 74 63 68 29 |f (membe|r_match)|
|00002d80| 20 7b 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 | {.X | |
|00002d90| 20 20 20 20 20 20 20 20 | 77 68 69 6c 65 20 28 2a | |while (*|
|00002da0| 70 20 21 3d 20 27 5d 27 | 29 20 7b 0a 58 0a 58 20 |p != ']'|) {.X.X |
|00002db0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002dc0| 20 20 20 20 20 20 20 2f | 2a 20 62 61 64 20 70 61 | /|* bad pa|
|00002dd0| 74 74 65 72 6e 20 28 4d | 69 73 73 69 6e 67 20 27 |ttern (M|issing '|
|00002de0| 5d 27 29 20 2a 2f 0a 58 | 20 20 20 20 20 20 20 20 |]') */.X| |
|00002df0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002e00| 69 66 20 28 21 2a 70 29 | 0a 58 20 20 20 20 20 20 |if (!*p)|.X |
|00002e10| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002e20| 20 20 20 20 20 20 72 65 | 74 75 72 6e 20 41 42 4f | re|turn ABO|
|00002e30| 52 54 3b 0a 58 0a 58 20 | 20 20 20 20 20 20 20 20 |RT;.X.X | |
|00002e40| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 2f | | /|
|00002e50| 2a 20 73 6b 69 70 20 65 | 78 61 63 74 20 6d 61 74 |* skip e|xact mat|
|00002e60| 63 68 20 2a 2f 0a 58 20 | 20 20 20 20 20 20 20 20 |ch */.X | |
|00002e70| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 69 | | i|
|00002e80| 66 20 28 2a 70 20 3d 3d | 20 27 5c 5c 27 29 20 7b |f (*p ==| '\\') {|
|00002e90| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00002ea0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 70 2b | | p+|
|00002eb0| 2b 3b 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 |+;.X | |
|00002ec0| 20 20 20 20 20 20 20 20 | 20 20 20 20 7d 0a 58 0a | | }.X.|
|00002ed0| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X | |
|00002ee0| 20 20 20 20 20 20 20 20 | 20 2f 2a 20 6d 6f 76 65 | | /* move|
|00002ef0| 20 74 6f 20 6e 65 78 74 | 20 70 61 74 74 65 72 6e | to next| pattern|
|00002f00| 20 63 68 61 72 20 2a 2f | 0a 58 20 20 20 20 20 20 | char */|.X |
|00002f10| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002f20| 20 20 70 2b 2b 3b 0a 58 | 20 20 20 20 20 20 20 20 | p++;.X| |
|00002f30| 20 20 20 20 20 20 20 20 | 20 20 20 20 7d 0a 58 20 | | }.X |
|00002f40| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 7d | | }|
|00002f50| 0a 58 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X.X | |
|00002f60| 20 20 20 20 62 72 65 61 | 6b 3b 0a 58 20 20 20 20 | brea|k;.X |
|00002f70| 20 20 20 20 20 20 20 20 | 7d 0a 58 0a 58 20 20 20 | |}.X.X |
|00002f80| 20 20 20 20 20 20 20 20 | 20 2f 2a 20 6e 65 78 74 | | /* next|
|00002f90| 20 63 68 61 72 61 63 74 | 65 72 20 69 73 20 71 75 | charact|er is qu|
|00002fa0| 6f 74 65 64 20 61 6e 64 | 20 6d 75 73 74 20 6d 61 |oted and| must ma|
|00002fb0| 74 63 68 20 65 78 61 63 | 74 6c 79 20 2a 2f 0a 58 |tch exac|tly */.X|
|00002fc0| 20 20 20 20 20 20 20 20 | 20 20 20 20 63 61 73 65 | | case|
|00002fd0| 20 27 5c 5c 27 3a 0a 58 | 0a 58 20 20 20 20 20 20 | '\\':.X|.X |
|00002fe0| 20 20 20 20 20 20 20 20 | 20 20 2f 2a 20 6d 6f 76 | | /* mov|
|00002ff0| 65 20 70 61 74 74 65 72 | 6e 20 70 6f 69 6e 74 65 |e patter|n pointe|
|00003000| 72 20 74 6f 20 71 75 6f | 74 65 64 20 63 68 61 72 |r to quo|ted char|
|00003010| 20 61 6e 64 20 66 61 6c | 6c 20 74 68 72 6f 75 67 | and fal|l throug|
|00003020| 68 20 2a 2f 0a 58 20 20 | 20 20 20 20 20 20 20 20 |h */.X | |
|00003030| 20 20 20 20 20 20 70 2b | 2b 3b 0a 58 0a 58 20 20 | p+|+;.X.X |
|00003040| 20 20 20 20 20 20 20 20 | 20 20 2f 2a 20 6d 75 73 | | /* mus|
|00003050| 74 20 6d 61 74 63 68 20 | 74 68 69 73 20 63 68 61 |t match |this cha|
|00003060| 72 61 63 74 65 72 20 65 | 78 61 63 74 6c 79 20 2a |racter e|xactly *|
|00003070| 2f 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 64 |/.X | d|
|00003080| 65 66 61 75 6c 74 3a 0a | 58 20 20 20 20 20 20 20 |efault:.|X |
|00003090| 20 20 20 20 20 20 20 20 | 20 69 66 20 28 2a 70 20 | | if (*p |
|000030a0| 21 3d 20 2a 74 29 0a 58 | 20 20 20 20 20 20 20 20 |!= *t).X| |
|000030b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 72 65 74 75 | | retu|
|000030c0| 72 6e 20 46 41 4c 53 45 | 3b 0a 58 20 20 20 20 20 |rn FALSE|;.X |
|000030d0| 20 20 20 7d 0a 58 20 20 | 20 20 7d 0a 58 0a 58 20 | }.X | }.X.X |
|000030e0| 20 20 20 2f 2a 20 69 66 | 20 65 6e 64 20 6f 66 20 | /* if| end of |
|000030f0| 74 65 78 74 20 6e 6f 74 | 20 72 65 61 63 68 65 64 |text not| reached|
|00003100| 20 74 68 65 6e 20 74 68 | 65 20 70 61 74 74 65 72 | then th|e patter|
|00003110| 6e 20 66 61 69 6c 73 20 | 2a 2f 0a 58 20 20 20 20 |n fails |*/.X |
|00003120| 72 65 74 75 72 6e 20 21 | 2a 74 3b 0a 58 7d 0a 58 |return !|*t;.X}.X|
|00003130| 0a 58 0a 58 2f 2a 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |.X.X/*--|--------|
|00003140| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003150| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003160| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003170| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003180| 2d 2d 0a 58 2a 0a 58 2a | 20 72 65 63 75 72 73 69 |--.X*.X*| recursi|
|00003190| 76 65 6c 79 20 63 61 6c | 6c 20 72 65 67 65 78 5f |vely cal|l regex_|
|000031a0| 6d 61 74 63 68 20 77 69 | 74 68 20 66 69 6e 61 6c |match wi|th final|
|000031b0| 20 73 65 67 6d 65 6e 74 | 20 6f 66 20 50 41 54 54 | segment| of PATT|
|000031c0| 45 52 4e 20 61 6e 64 20 | 6f 66 20 54 45 58 54 2e |ERN and |of TEXT.|
|000031d0| 0a 58 2a 0a 58 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |.X*.X---|--------|
|000031e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000031f0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003200| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003210| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003220| 2d 2a 2f 0a 58 0a 42 4f | 4f 4c 45 41 4e 20 72 65 |-*/.X.BO|OLEAN re|
|00003230| 67 65 78 5f 6d 61 74 63 | 68 5f 61 66 74 65 72 5f |gex_matc|h_after_|
|00003240| 73 74 61 72 20 28 72 65 | 67 69 73 74 65 72 20 63 |star (re|gister c|
|00003250| 68 61 72 20 2a 70 2c 20 | 72 65 67 69 73 74 65 72 |har *p, |register|
|00003260| 20 63 68 61 72 20 2a 74 | 29 0a 58 7b 0a 58 20 20 | char *t|).X{.X |
|00003270| 20 20 72 65 67 69 73 74 | 65 72 20 42 4f 4f 4c 45 | regist|er BOOLE|
|00003280| 41 4e 20 6d 61 74 63 68 | 3b 0a 58 20 20 20 20 72 |AN match|;.X r|
|00003290| 65 67 69 73 74 65 72 20 | 6e 65 78 74 70 3b 0a 58 |egister |nextp;.X|
|000032a0| 0a 58 20 20 20 20 2f 2a | 20 70 61 73 73 20 6f 76 |.X /*| pass ov|
|000032b0| 65 72 20 65 78 69 73 74 | 69 6e 67 20 3f 20 61 6e |er exist|ing ? an|
|000032c0| 64 20 2a 20 69 6e 20 70 | 61 74 74 65 72 6e 20 2a |d * in p|attern *|
|000032d0| 2f 0a 58 20 20 20 20 77 | 68 69 6c 65 20 28 20 2a |/.X w|hile ( *|
|000032e0| 70 20 3d 3d 20 27 3f 27 | 20 7c 7c 20 2a 70 20 3d |p == '?'| || *p =|
|000032f0| 3d 20 27 2a 27 20 29 20 | 7b 0a 58 0a 58 20 20 20 |= '*' ) |{.X.X |
|00003300| 20 20 20 20 20 2f 2a 20 | 74 61 6b 65 20 6f 6e 65 | /* |take one|
|00003310| 20 63 68 61 72 20 66 6f | 72 20 65 61 63 68 20 3f | char fo|r each ?|
|00003320| 20 2a 2f 0a 58 20 20 20 | 20 20 20 20 20 69 66 20 | */.X | if |
|00003330| 28 20 2a 70 20 3d 3d 20 | 27 3f 27 20 29 20 7b 0a |( *p == |'?' ) {.|
|00003340| 58 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 2f |X.X | /|
|00003350| 2a 20 69 66 20 65 6e 64 | 20 6f 66 20 74 65 78 74 |* if end| of text|
|00003360| 20 74 68 65 6e 20 6e 6f | 20 6d 61 74 63 68 20 2a | then no| match *|
|00003370| 2f 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 69 |/.X | i|
|00003380| 66 20 28 20 21 2a 74 2b | 2b 20 29 20 7b 0a 58 20 |f ( !*t+|+ ) {.X |
|00003390| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 72 | | r|
|000033a0| 65 74 75 72 6e 20 41 42 | 4f 52 54 3b 0a 58 20 20 |eturn AB|ORT;.X |
|000033b0| 20 20 20 20 20 20 20 20 | 20 20 7d 0a 58 20 20 20 | | }.X |
|000033c0| 20 20 20 20 20 7d 0a 58 | 0a 58 20 20 20 20 20 20 | }.X|.X |
|000033d0| 20 20 2f 2a 20 6d 6f 76 | 65 20 74 6f 20 6e 65 78 | /* mov|e to nex|
|000033e0| 74 20 63 68 61 72 20 69 | 6e 20 70 61 74 74 65 72 |t char i|n patter|
|000033f0| 6e 20 2a 2f 0a 58 20 20 | 20 20 20 20 20 20 70 2b |n */.X | p+|
|00003400| 2b 3b 0a 58 20 20 20 20 | 7d 0a 58 0a 58 20 20 20 |+;.X |}.X.X |
|00003410| 20 2f 2a 20 69 66 20 65 | 6e 64 20 6f 66 20 70 61 | /* if e|nd of pa|
|00003420| 74 74 65 72 6e 20 77 65 | 20 68 61 76 65 20 6d 61 |ttern we| have ma|
|00003430| 74 63 68 65 64 20 72 65 | 67 61 72 64 6c 65 73 73 |tched re|gardless|
|00003440| 20 6f 66 20 74 65 78 74 | 20 6c 65 66 74 20 2a 2f | of text| left */|
|00003450| 0a 58 20 20 20 20 69 66 | 20 28 20 21 2a 70 20 29 |.X if| ( !*p )|
|00003460| 20 7b 0a 58 20 20 20 20 | 20 20 20 20 72 65 74 75 | {.X | retu|
|00003470| 72 6e 20 54 52 55 45 3b | 0a 58 20 20 20 20 7d 0a |rn TRUE;|.X }.|
|00003480| 58 0a 58 20 20 20 20 2f | 2a 20 67 65 74 20 74 68 |X.X /|* get th|
|00003490| 65 20 6e 65 78 74 20 63 | 68 61 72 61 63 74 65 72 |e next c|haracter|
|000034a0| 20 74 6f 20 6d 61 74 63 | 68 20 77 68 69 63 68 20 | to matc|h which |
|000034b0| 6d 75 73 74 20 62 65 20 | 61 20 6c 69 74 65 72 61 |must be |a litera|
|000034c0| 6c 20 6f 72 20 27 5b 27 | 20 2a 2f 0a 58 20 20 20 |l or '['| */.X |
|000034d0| 20 6e 65 78 74 70 20 3d | 20 2a 70 3b 0a 58 20 20 | nextp =| *p;.X |
|000034e0| 20 20 69 66 20 28 20 6e | 65 78 74 70 20 3d 3d 20 | if ( n|extp == |
|000034f0| 27 5c 5c 27 20 29 0a 58 | 20 20 20 20 20 20 20 20 |'\\' ).X| |
|00003500| 6e 65 78 74 70 20 3d 20 | 70 5b 31 5d 3b 0a 58 0a |nextp = |p[1];.X.|
|00003510| 58 20 20 20 20 2f 2a 20 | 43 6f 6e 74 69 6e 75 65 |X /* |Continue|
|00003520| 20 75 6e 74 69 6c 20 77 | 65 20 72 75 6e 20 6f 75 | until w|e run ou|
|00003530| 74 20 6f 66 20 74 65 78 | 74 20 6f 72 20 64 65 66 |t of tex|t or def|
|00003540| 69 6e 69 74 65 20 72 65 | 73 75 6c 74 20 73 65 65 |inite re|sult see|
|00003550| 6e 20 2a 2f 0a 58 20 20 | 20 20 6d 61 74 63 68 20 |n */.X | match |
|00003560| 3d 20 46 41 4c 53 45 3b | 0a 58 20 20 20 20 77 68 |= FALSE;|.X wh|
|00003570| 69 6c 65 20 28 20 6d 61 | 74 63 68 20 3d 3d 20 46 |ile ( ma|tch == F|
|00003580| 41 4c 53 45 20 29 20 7b | 0a 58 0a 58 20 20 20 20 |ALSE ) {|.X.X |
|00003590| 20 20 20 20 2f 2a 20 61 | 20 70 72 65 63 6f 6e 64 | /* a| precond|
|000035a0| 69 74 69 6f 6e 20 66 6f | 72 20 6d 61 74 63 68 69 |ition fo|r matchi|
|000035b0| 6e 67 20 69 73 20 74 68 | 61 74 20 74 68 65 20 6e |ng is th|at the n|
|000035c0| 65 78 74 20 63 68 61 72 | 61 63 74 65 72 0a 58 20 |ext char|acter.X |
|000035d0| 20 20 20 20 20 20 20 20 | 20 20 69 6e 20 74 68 65 | | in the|
|000035e0| 20 70 61 74 74 65 72 6e | 20 6d 61 74 63 68 20 74 | pattern| match t|
|000035f0| 68 65 20 6e 65 78 74 20 | 63 68 61 72 61 63 74 65 |he next |characte|
|00003600| 72 20 69 6e 20 74 68 65 | 20 74 65 78 74 20 6f 72 |r in the| text or|
|00003610| 20 74 68 61 74 0a 58 20 | 20 20 20 20 20 20 20 20 | that.X | |
|00003620| 20 20 74 68 65 20 6e 65 | 78 74 20 70 61 74 74 65 | the ne|xt patte|
|00003630| 72 6e 20 69 73 20 74 68 | 65 20 62 65 67 69 6e 6e |rn is th|e beginn|
|00003640| 69 6e 67 20 6f 66 20 61 | 20 72 61 6e 67 65 2e 20 |ing of a| range. |
|00003650| 20 49 6e 63 72 65 6d 65 | 6e 74 20 74 65 78 74 0a | Increme|nt text.|
|00003660| 58 20 20 20 20 20 20 20 | 20 20 20 20 70 6f 69 6e |X | poin|
|00003670| 74 65 72 20 61 73 20 77 | 65 20 67 6f 20 68 65 72 |ter as w|e go her|
|00003680| 65 20 2a 2f 0a 58 20 20 | 20 20 20 20 20 20 69 66 |e */.X | if|
|00003690| 20 28 20 2a 70 20 3d 3d | 20 2a 74 20 7c 7c 20 6e | ( *p ==| *t || n|
|000036a0| 65 78 74 70 20 3d 3d 20 | 27 5b 27 20 29 20 7b 0a |extp == |'[' ) {.|
|000036b0| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 6d 61 74 |X | mat|
|000036c0| 63 68 20 3d 20 72 65 67 | 65 78 5f 6d 61 74 63 68 |ch = reg|ex_match|
|000036d0| 28 70 2c 20 74 29 3b 0a | 58 20 20 20 20 20 20 20 |(p, t);.|X |
|000036e0| 20 7d 0a 58 0a 58 20 20 | 20 20 20 20 20 20 2f 2a | }.X.X | /*|
|000036f0| 20 69 66 20 74 68 65 20 | 65 6e 64 20 6f 66 20 74 | if the |end of t|
|00003700| 65 78 74 20 69 73 20 72 | 65 61 63 68 65 64 20 74 |ext is r|eached t|
|00003710| 68 65 6e 20 6e 6f 20 6d | 61 74 63 68 20 2a 2f 0a |hen no m|atch */.|
|00003720| 58 20 20 20 20 20 20 20 | 20 69 66 20 28 20 21 2a |X | if ( !*|
|00003730| 74 2b 2b 20 29 20 6d 61 | 74 63 68 20 3d 20 41 42 |t++ ) ma|tch = AB|
|00003740| 4f 52 54 3b 0a 58 20 20 | 20 20 7d 0a 58 0a 58 20 |ORT;.X | }.X.X |
|00003750| 20 20 20 2f 2a 20 72 65 | 74 75 72 6e 20 72 65 73 | /* re|turn res|
|00003760| 75 6c 74 20 2a 2f 0a 58 | 20 20 20 20 72 65 74 75 |ult */.X| retu|
|00003770| 72 6e 20 6d 61 74 63 68 | 3b 0a 58 7d 0a 58 0a 58 |rn match|;.X}.X.X|
|00003780| 2f 2a 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |/*------|--------|
|00003790| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000037a0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000037b0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000037c0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 0a 58 |--------|------.X|
|000037d0| 2a 0a 58 2a 20 54 68 69 | 73 20 69 73 20 61 20 73 |*.X* Thi|s is a s|
|000037e0| 68 65 6c 6c 20 74 6f 20 | 72 65 67 65 78 5f 6d 61 |hell to |regex_ma|
|000037f0| 74 63 68 20 74 6f 20 72 | 65 74 75 72 6e 20 6f 6e |tch to r|eturn on|
|00003800| 6c 79 20 61 20 74 72 75 | 65 20 42 4f 4f 4c 45 41 |ly a tru|e BOOLEA|
|00003810| 4e 20 76 61 6c 75 65 0a | 58 2a 0a 58 2d 2d 2d 2d |N value.|X*.X----|
|00003820| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003830| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003840| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003850| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003860| 2d 2d 2d 2d 2d 2d 2d 2d | 2a 2f 0a 58 0a 42 4f 4f |--------|*/.X.BOO|
|00003870| 4c 45 41 4e 20 6d 61 74 | 63 68 28 20 63 68 61 72 |LEAN mat|ch( char|
|00003880| 20 2a 70 2c 20 63 68 61 | 72 20 2a 74 29 0a 58 7b | *p, cha|r *t).X{|
|00003890| 0a 58 20 20 20 20 72 65 | 74 75 72 6e 20 28 20 72 |.X re|turn ( r|
|000038a0| 65 67 65 78 5f 6d 61 74 | 63 68 28 70 2c 74 29 20 |egex_mat|ch(p,t) |
|000038b0| 3d 3d 20 54 52 55 45 20 | 29 20 3f 20 54 52 55 45 |== TRUE |) ? TRUE|
|000038c0| 20 3a 20 46 41 4c 53 45 | 3b 0a 58 7d 0a 58 0a 58 | : FALSE|;.X}.X.X|
|000038d0| 0a 58 23 69 66 64 65 66 | 20 54 45 53 54 0a 58 0a |.X#ifdef| TEST.X.|
|000038e0| 58 20 20 20 20 2f 2a 0a | 58 20 20 20 20 2a 20 54 |X /*.|X * T|
|000038f0| 68 69 73 20 74 65 73 74 | 20 6d 61 69 6e 20 65 78 |his test| main ex|
|00003900| 70 65 63 74 73 20 61 73 | 20 66 69 72 73 74 20 61 |pects as| first a|
|00003910| 72 67 20 74 68 65 20 70 | 61 74 74 65 72 6e 20 61 |rg the p|attern a|
|00003920| 6e 64 20 61 73 20 73 65 | 63 6f 6e 64 20 61 72 67 |nd as se|cond arg|
|00003930| 0a 58 20 20 20 20 2a 20 | 74 68 65 20 6d 61 74 63 |.X * |the matc|
|00003940| 68 20 73 74 72 69 6e 67 | 2e 20 20 4f 75 74 70 75 |h string|. Outpu|
|00003950| 74 20 69 73 20 79 61 65 | 68 20 6f 72 20 6e 61 79 |t is yae|h or nay|
|00003960| 20 6f 6e 20 6d 61 74 63 | 68 2e 0a 58 20 20 20 20 | on matc|h..X |
|00003970| 2a 2f 0a 58 0a 58 23 69 | 6e 63 6c 75 64 65 20 3c |*/.X.X#i|nclude <|
|00003980| 73 74 64 69 6f 2e 68 3e | 0a 58 0a 58 20 20 20 20 |stdio.h>|.X.X |
|00003990| 69 6e 74 20 6d 61 69 6e | 28 69 6e 74 20 61 72 67 |int main|(int arg|
|000039a0| 63 2c 20 63 68 61 72 20 | 2a 61 72 67 76 5b 5d 29 |c, char |*argv[])|
|000039b0| 0a 58 20 20 20 20 7b 0a | 58 20 20 20 20 20 20 20 |.X {.|X |
|000039c0| 20 69 66 20 28 61 72 67 | 63 20 3d 3d 20 33 29 20 | if (arg|c == 3) |
|000039d0| 7b 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 69 |{.X | i|
|000039e0| 66 20 28 69 73 5f 70 61 | 74 74 65 72 6e 28 61 72 |f (is_pa|ttern(ar|
|000039f0| 67 76 5b 31 5d 29 29 20 | 7b 0a 58 20 20 20 20 20 |gv[1])) |{.X |
|00003a00| 20 20 20 20 20 20 20 20 | 20 20 20 69 66 20 28 6d | | if (m|
|00003a10| 61 74 63 68 28 61 72 67 | 76 5b 31 5d 2c 61 72 67 |atch(arg|v[1],arg|
|00003a20| 76 5b 32 5d 29 29 20 7b | 0a 58 20 20 20 20 20 20 |v[2])) {|.X |
|00003a30| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 70 72 | | pr|
|00003a40| 69 6e 74 66 28 22 20 20 | 20 20 4d 61 74 63 68 20 |intf(" | Match |
|00003a50| 53 75 63 63 65 73 73 66 | 75 6c 5c 6e 22 29 3b 0a |Successf|ul\n");.|
|00003a60| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X | |
|00003a70| 20 7d 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 | }.X | |
|00003a80| 20 20 20 20 65 6c 73 65 | 20 7b 0a 58 20 20 20 20 | else| {.X |
|00003a90| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003aa0| 70 72 69 6e 74 66 28 22 | 20 20 20 20 4d 61 74 63 |printf("| Matc|
|00003ab0| 68 20 46 61 69 6c 73 5c | 6e 22 29 3b 0a 58 20 20 |h Fails\|n");.X |
|00003ac0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 7d 0a | | }.|
|00003ad0| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 7d 0a 58 |X | }.X|
|00003ae0| 20 20 20 20 20 20 20 20 | 20 20 20 20 65 6c 73 65 | | else|
|00003af0| 20 7b 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 | {.X | |
|00003b00| 20 20 20 20 70 72 69 6e | 74 66 28 22 20 20 20 20 | prin|tf(" |
|00003b10| 42 61 64 20 50 61 74 74 | 65 72 6e 5c 6e 22 29 3b |Bad Patt|ern\n");|
|00003b20| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 7d 0a |.X | }.|
|00003b30| 58 20 20 20 20 20 20 20 | 20 7d 0a 58 20 20 20 20 |X | }.X |
|00003b40| 20 20 20 20 65 6c 73 65 | 20 70 72 69 6e 74 66 28 | else| printf(|
|00003b50| 22 20 20 20 20 42 61 64 | 20 42 72 65 61 74 68 5c |" Bad| Breath\|
|00003b60| 6e 22 29 3b 0a 58 20 20 | 20 20 20 20 20 20 72 65 |n");.X | re|
|00003b70| 74 75 72 6e 28 30 29 3b | 0a 58 20 20 20 20 7d 0a |turn(0);|.X }.|
|00003b80| 58 0a 58 23 65 6e 64 69 | 66 0a 45 4e 44 5f 4f 46 |X.X#endi|f.END_OF|
|00003b90| 5f 46 49 4c 45 0a 69 66 | 20 74 65 73 74 20 39 33 |_FILE.if| test 93|
|00003ba0| 35 34 20 2d 6e 65 20 60 | 77 63 20 2d 63 20 3c 27 |54 -ne `|wc -c <'|
|00003bb0| 6d 61 74 63 68 2e 63 27 | 60 3b 20 74 68 65 6e 0a |match.c'|`; then.|
|00003bc0| 20 20 20 20 65 63 68 6f | 20 73 68 61 72 3a 20 5c | echo| shar: \|
|00003bd0| 22 27 6d 61 74 63 68 2e | 63 27 5c 22 20 75 6e 70 |"'match.|c'\" unp|
|00003be0| 61 63 6b 65 64 20 77 69 | 74 68 20 77 72 6f 6e 67 |acked wi|th wrong|
|00003bf0| 20 73 69 7a 65 21 0a 66 | 69 0a 23 20 65 6e 64 20 | size!.f|i.# end |
|00003c00| 6f 66 20 27 6d 61 74 63 | 68 2e 63 27 0a 66 69 0a |of 'matc|h.c'.fi.|
|00003c10| 69 66 20 74 65 73 74 20 | 2d 66 20 27 6d 61 74 63 |if test |-f 'matc|
|00003c20| 68 2e 68 27 20 2d 61 20 | 22 24 7b 31 7d 22 20 21 |h.h' -a |"${1}" !|
|00003c30| 3d 20 22 2d 63 22 20 3b | 20 74 68 65 6e 20 0a 20 |= "-c" ;| then . |
|00003c40| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 57 69 6c 6c | echo sh|ar: Will|
|00003c50| 20 6e 6f 74 20 63 6c 6f | 62 62 65 72 20 65 78 69 | not clo|bber exi|
|00003c60| 73 74 69 6e 67 20 66 69 | 6c 65 20 5c 22 27 6d 61 |sting fi|le \"'ma|
|00003c70| 74 63 68 2e 68 27 5c 22 | 0a 65 6c 73 65 0a 65 63 |tch.h'\"|.else.ec|
|00003c80| 68 6f 20 73 68 61 72 3a | 20 45 78 74 72 61 63 74 |ho shar:| Extract|
|00003c90| 69 6e 67 20 5c 22 27 6d | 61 74 63 68 2e 68 27 5c |ing \"'m|atch.h'\|
|00003ca0| 22 20 5c 28 31 36 39 31 | 20 63 68 61 72 61 63 74 |" \(1691| charact|
|00003cb0| 65 72 73 5c 29 0a 73 65 | 64 20 22 73 2f 5e 58 2f |ers\).se|d "s/^X/|
|00003cc0| 2f 22 20 3e 27 6d 61 74 | 63 68 2e 68 27 20 3c 3c |/" >'mat|ch.h' <<|
|00003cd0| 27 45 4e 44 5f 4f 46 5f | 46 49 4c 45 27 0a 58 2f |'END_OF_|FILE'.X/|
|00003ce0| 2a 0a 58 20 45 50 53 48 | 65 61 64 65 72 0a 58 0a |*.X EPSH|eader.X.|
|00003cf0| 58 20 20 20 46 69 6c 65 | 3a 20 6d 61 74 63 68 2e |X File|: match.|
|00003d00| 68 0a 58 20 20 20 41 75 | 74 68 6f 72 3a 20 4a 2e |h.X Au|thor: J.|
|00003d10| 20 4b 65 72 63 68 65 76 | 61 6c 0a 58 20 20 20 43 | Kerchev|al.X C|
|00003d20| 72 65 61 74 65 64 3a 20 | 53 61 74 2c 20 30 31 2f |reated: |Sat, 01/|
|00003d30| 30 35 2f 31 39 39 31 20 | 20 32 32 3a 32 37 3a 31 |05/1991 | 22:27:1|
|00003d40| 38 0a 58 2a 2f 0a 58 2f | 2a 0a 58 20 45 50 53 52 |8.X*/.X/|*.X EPSR|
|00003d50| 65 76 69 73 69 6f 6e 20 | 48 69 73 74 6f 72 79 0a |evision |History.|
|00003d60| 58 0a 58 20 20 20 4a 2e | 20 4b 65 72 63 68 65 76 |X.X J.| Kerchev|
|00003d70| 61 6c 20 20 57 65 64 2c | 20 30 32 2f 32 30 2f 31 |al Wed,| 02/20/1|
|00003d80| 39 39 31 20 20 32 32 3a | 32 38 3a 33 37 20 20 52 |991 22:|28:37 R|
|00003d90| 65 6c 65 61 73 65 64 20 | 74 6f 20 50 75 62 6c 69 |eleased |to Publi|
|00003da0| 63 20 44 6f 6d 61 69 6e | 0a 58 2a 2f 0a 58 0a 58 |c Domain|.X*/.X.X|
|00003db0| 2f 2a 0a 58 20 20 20 57 | 69 6c 64 63 61 72 64 20 |/*.X W|ildcard |
|00003dc0| 50 61 74 74 65 72 6e 20 | 4d 61 74 63 68 69 6e 67 |Pattern |Matching|
|00003dd0| 0a 58 2a 2f 0a 58 0a 58 | 23 69 66 6e 64 65 66 20 |.X*/.X.X|#ifndef |
|00003de0| 42 4f 4f 4c 45 41 4e 0a | 58 23 20 64 65 66 69 6e |BOOLEAN.|X# defin|
|00003df0| 65 20 42 4f 4f 4c 45 41 | 4e 20 69 6e 74 0a 58 23 |e BOOLEA|N int.X#|
|00003e00| 20 64 65 66 69 6e 65 20 | 54 52 55 45 20 31 0a 58 | define |TRUE 1.X|
|00003e10| 23 20 64 65 66 69 6e 65 | 20 46 41 4c 53 45 20 30 |# define| FALSE 0|
|00003e20| 0a 58 23 65 6e 64 69 66 | 0a 58 0a 58 2f 2a 2d 2d |.X#endif|.X.X/*--|
|00003e30| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003e40| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003e50| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003e60| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003e70| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 0a 58 2a 0a 58 2a |--------|--.X*.X*|
|00003e80| 20 20 4d 61 74 63 68 20 | 74 68 65 20 70 61 74 74 | Match |the patt|
|00003e90| 65 72 6e 20 50 41 54 54 | 45 52 4e 20 61 67 61 69 |ern PATT|ERN agai|
|00003ea0| 6e 73 74 20 74 68 65 20 | 73 74 72 69 6e 67 20 54 |nst the |string T|
|00003eb0| 45 58 54 3b 0a 58 2a 20 | 20 72 65 74 75 72 6e 20 |EXT;.X* | return |
|00003ec0| 54 52 55 45 20 69 66 20 | 69 74 20 6d 61 74 63 68 |TRUE if |it match|
|00003ed0| 65 73 2c 20 46 41 4c 53 | 45 20 6f 74 68 65 72 77 |es, FALS|E otherw|
|00003ee0| 69 73 65 2e 0a 58 2a 0a | 58 2a 20 20 41 20 6d 61 |ise..X*.|X* A ma|
|00003ef0| 74 63 68 20 6d 65 61 6e | 73 20 74 68 65 20 65 6e |tch mean|s the en|
|00003f00| 74 69 72 65 20 73 74 72 | 69 6e 67 20 54 45 58 54 |tire str|ing TEXT|
|00003f10| 20 69 73 20 75 73 65 64 | 20 75 70 20 69 6e 20 6d | is used| up in m|
|00003f20| 61 74 63 68 69 6e 67 2e | 0a 58 2a 0a 58 2a 20 20 |atching.|.X*.X* |
|00003f30| 49 6e 20 74 68 65 20 70 | 61 74 74 65 72 6e 20 73 |In the p|attern s|
|00003f40| 74 72 69 6e 67 3a 0a 58 | 2a 20 20 20 20 20 20 20 |tring:.X|* |
|00003f50| 60 2a 27 20 6d 61 74 63 | 68 65 73 20 61 6e 79 20 |`*' matc|hes any |
|00003f60| 73 65 71 75 65 6e 63 65 | 20 6f 66 20 63 68 61 72 |sequence| of char|
|00003f70| 61 63 74 65 72 73 0a 58 | 2a 20 20 20 20 20 20 20 |acters.X|* |
|00003f80| 60 3f 27 20 6d 61 74 63 | 68 65 73 20 61 6e 79 20 |`?' matc|hes any |
|00003f90| 63 68 61 72 61 63 74 65 | 72 0a 58 2a 20 20 20 20 |characte|r.X* |
|00003fa0| 20 20 20 5b 53 45 54 5d | 20 6d 61 74 63 68 65 73 | [SET]| matches|
|00003fb0| 20 61 6e 79 20 63 68 61 | 72 61 63 74 65 72 20 69 | any cha|racter i|
|00003fc0| 6e 20 74 68 65 20 73 70 | 65 63 69 66 69 65 64 20 |n the sp|ecified |
|00003fd0| 73 65 74 2c 0a 58 2a 20 | 20 20 20 20 20 20 5b 21 |set,.X* | [!|
|00003fe0| 53 45 54 5d 20 6f 72 20 | 5b 5e 53 45 54 5d 20 6d |SET] or |[^SET] m|
|00003ff0| 61 74 63 68 65 73 20 61 | 6e 79 20 63 68 61 72 61 |atches a|ny chara|
|00004000| 63 74 65 72 20 6e 6f 74 | 20 69 6e 20 74 68 65 20 |cter not| in the |
|00004010| 73 70 65 63 69 66 69 65 | 64 20 73 65 74 2e 0a 58 |specifie|d set..X|
|00004020| 2a 0a 58 2a 20 20 4e 6f | 74 65 3a 20 74 68 65 20 |*.X* No|te: the |
|00004030| 73 74 61 6e 64 61 72 64 | 20 72 65 67 65 78 20 63 |standard| regex c|
|00004040| 68 61 72 61 63 74 65 72 | 20 27 2b 27 20 28 6f 6e |haracter| '+' (on|
|00004050| 65 20 6f 72 20 6d 6f 72 | 65 29 20 73 68 6f 75 6c |e or mor|e) shoul|
|00004060| 64 20 62 79 0a 58 2a 20 | 20 20 20 20 20 20 20 73 |d by.X* | s|
|00004070| 69 6d 75 6c 61 74 65 64 | 20 62 79 20 75 73 69 6e |imulated| by usin|
|00004080| 67 20 22 3f 2a 22 20 77 | 68 69 63 68 20 69 73 20 |g "?*" w|hich is |
|00004090| 65 71 75 69 76 65 6c 61 | 6e 74 20 68 65 72 65 2e |equivela|nt here.|
|000040a0| 0a 58 2a 0a 58 2a 20 20 | 41 20 73 65 74 20 69 73 |.X*.X* |A set is|
|000040b0| 20 63 6f 6d 70 6f 73 65 | 64 20 6f 66 20 63 68 61 | compose|d of cha|
|000040c0| 72 61 63 74 65 72 73 20 | 6f 72 20 72 61 6e 67 65 |racters |or range|
|000040d0| 73 3b 20 61 20 72 61 6e | 67 65 20 6c 6f 6f 6b 73 |s; a ran|ge looks|
|000040e0| 20 6c 69 6b 65 0a 58 2a | 20 20 63 68 61 72 61 63 | like.X*| charac|
|000040f0| 74 65 72 20 68 79 70 68 | 65 6e 20 63 68 61 72 61 |ter hyph|en chara|
|00004100| 63 74 65 72 20 28 61 73 | 20 69 6e 20 30 2d 39 20 |cter (as| in 0-9 |
|00004110| 6f 72 20 41 2d 5a 29 2e | 0a 58 2a 20 20 5b 30 2d |or A-Z).|.X* [0-|
|00004120| 39 61 2d 7a 41 2d 5a 5f | 5d 20 69 73 20 74 68 65 |9a-zA-Z_|] is the|
|00004130| 20 73 65 74 20 6f 66 20 | 63 68 61 72 61 63 74 65 | set of |characte|
|00004140| 72 73 20 61 6c 6c 6f 77 | 65 64 20 69 6e 20 43 20 |rs allow|ed in C |
|00004150| 69 64 65 6e 74 69 66 69 | 65 72 73 2e 0a 58 2a 20 |identifi|ers..X* |
|00004160| 20 41 6e 79 20 6f 74 68 | 65 72 20 63 68 61 72 61 | Any oth|er chara|
|00004170| 63 74 65 72 20 69 6e 20 | 74 68 65 20 70 61 74 74 |cter in |the patt|
|00004180| 65 72 6e 20 6d 75 73 74 | 20 62 65 20 6d 61 74 63 |ern must| be matc|
|00004190| 68 65 64 20 65 78 61 63 | 74 6c 79 2e 0a 58 2a 0a |hed exac|tly..X*.|
|000041a0| 58 2a 20 20 54 6f 20 73 | 75 70 70 72 65 73 73 20 |X* To s|uppress |
|000041b0| 74 68 65 20 73 70 65 63 | 69 61 6c 20 73 79 6e 74 |the spec|ial synt|
|000041c0| 61 63 74 69 63 20 73 69 | 67 6e 69 66 69 63 61 6e |actic si|gnifican|
|000041d0| 63 65 20 6f 66 20 61 6e | 79 20 6f 66 20 60 5b 5d |ce of an|y of `[]|
|000041e0| 2a 3f 21 5e 2d 5c 27 2c | 0a 58 2a 20 20 61 6e 64 |*?!^-\',|.X* and|
|000041f0| 20 6d 61 74 63 68 20 74 | 68 65 20 63 68 61 72 61 | match t|he chara|
|00004200| 63 74 65 72 20 65 78 61 | 63 74 6c 79 2c 20 70 72 |cter exa|ctly, pr|
|00004210| 65 63 65 64 65 20 69 74 | 20 77 69 74 68 20 61 20 |ecede it| with a |
|00004220| 60 5c 27 2e 0a 58 2a 0a | 58 2d 2d 2d 2d 2d 2d 2d |`\'..X*.|X-------|
|00004230| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004240| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004250| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004260| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004270| 2d 2d 2d 2d 2d 2a 2f 0a | 58 0a 42 4f 4f 4c 45 41 |-----*/.|X.BOOLEA|
|00004280| 4e 20 6d 61 74 63 68 20 | 28 63 68 61 72 20 2a 70 |N match |(char *p|
|00004290| 61 74 74 65 72 6e 2c 20 | 63 68 61 72 20 2a 74 65 |attern, |char *te|
|000042a0| 78 74 29 3b 0a 58 0a 58 | 2f 2a 2d 2d 2d 2d 2d 2d |xt);.X.X|/*------|
|000042b0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000042c0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000042d0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000042e0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|000042f0| 2d 2d 2d 2d 2d 2d 0a 58 | 2a 0a 58 2a 20 52 65 74 |------.X|*.X* Ret|
|00004300| 75 72 6e 20 54 52 55 45 | 20 69 66 20 50 41 54 54 |urn TRUE| if PATT|
|00004310| 45 52 4e 20 68 61 73 20 | 61 6e 79 20 73 70 65 63 |ERN has |any spec|
|00004320| 69 61 6c 20 77 69 6c 64 | 63 61 72 64 20 63 68 61 |ial wild|card cha|
|00004330| 72 61 63 74 65 72 73 0a | 58 2a 0a 58 2d 2d 2d 2d |racters.|X*.X----|
|00004340| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004350| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004360| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004370| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00004380| 2d 2d 2d 2d 2d 2d 2d 2d | 2a 2f 0a 58 0a 42 4f 4f |--------|*/.X.BOO|
|00004390| 4c 45 41 4e 20 69 73 5f | 70 61 74 74 65 72 6e 20 |LEAN is_|pattern |
|000043a0| 28 63 68 61 72 20 2a 70 | 61 74 74 65 72 6e 29 3b |(char *p|attern);|
|000043b0| 0a 45 4e 44 5f 4f 46 5f | 46 49 4c 45 0a 69 66 20 |.END_OF_|FILE.if |
|000043c0| 74 65 73 74 20 31 36 39 | 31 20 2d 6e 65 20 60 77 |test 169|1 -ne `w|
|000043d0| 63 20 2d 63 20 3c 27 6d | 61 74 63 68 2e 68 27 60 |c -c <'m|atch.h'`|
|000043e0| 3b 20 74 68 65 6e 0a 20 | 20 20 20 65 63 68 6f 20 |; then. | echo |
|000043f0| 73 68 61 72 3a 20 5c 22 | 27 6d 61 74 63 68 2e 68 |shar: \"|'match.h|
|00004400| 27 5c 22 20 75 6e 70 61 | 63 6b 65 64 20 77 69 74 |'\" unpa|cked wit|
|00004410| 68 20 77 72 6f 6e 67 20 | 73 69 7a 65 21 0a 66 69 |h wrong |size!.fi|
|00004420| 0a 23 20 65 6e 64 20 6f | 66 20 27 6d 61 74 63 68 |.# end o|f 'match|
|00004430| 2e 68 27 0a 66 69 0a 65 | 63 68 6f 20 73 68 61 72 |.h'.fi.e|cho shar|
|00004440| 3a 20 45 6e 64 20 6f 66 | 20 73 68 65 6c 6c 20 61 |: End of| shell a|
|00004450| 72 63 68 69 76 65 2e 0a | 65 78 69 74 20 30 0a 0a |rchive..|exit 0..|
|00004460| 65 78 69 74 20 30 20 23 | 20 4a 75 73 74 20 69 6e |exit 0 #| Just in|
|00004470| 20 63 61 73 65 2e 2e 2e | 0a | case...|. |
+--------+-------------------------+-------------------------+--------+--------+