home *** CD-ROM | disk | FTP | other *** search
/ NetNews Usenet Archive 1992 #27 / NN_1992_27.iso / spool / alt / sources / 2537 < prev    next >
SHell self-extracting ARchive  |  1992-11-17  |  36.8 KB

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: 2537

ConfidenceProgramDetectionMatch TypeSupport
100% dexvert SHell self-extracting ARchive (archive/shar) magic Supported
10% dexvert Text File (text/txt) fallback Supported
100% file ISO-8859 text default (weak)
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 61 6c 74 2e |Newsgrou|ps: alt.|
|00000010| 73 6f 75 72 63 65 73 0a | 50 61 74 68 3a 20 73 70 |sources.|Path: sp|
|00000020| 61 72 6b 79 21 75 75 6e | 65 74 21 7a 61 70 68 6f |arky!uun|et!zapho|
|00000030| 64 2e 6d 70 73 2e 6f 68 | 69 6f 2d 73 74 61 74 65 |d.mps.oh|io-state|
|00000040| 2e 65 64 75 21 6d 65 6e | 75 64 6f 2e 75 68 2e 65 |.edu!men|udo.uh.e|
|00000050| 64 75 21 73 75 67 61 72 | 21 70 65 74 65 72 0a 46 |du!sugar|!peter.F|
|00000060| 72 6f 6d 3a 20 70 65 74 | 65 72 40 4e 65 6f 53 6f |rom: pet|er@NeoSo|
|00000070| 66 74 2e 63 6f 6d 20 28 | 50 65 74 65 72 20 64 61 |ft.com (|Peter da|
|00000080| 20 53 69 6c 76 61 29 0a | 53 75 62 6a 65 63 74 3a | Silva).|Subject:|
|00000090| 20 46 6f 72 20 72 65 76 | 69 65 77 20 61 6e 64 20 | For rev|iew and |
|000000a0| 63 6f 6d 6d 65 6e 74 3a | 20 67 65 6e 65 72 69 63 |comment:| generic|
|000000b0| 20 74 65 78 74 20 62 75 | 66 66 65 72 20 72 6f 75 | text bu|ffer rou|
|000000c0| 74 69 6e 65 73 0a 4f 72 | 67 61 6e 69 7a 61 74 69 |tines.Or|ganizati|
|000000d0| 6f 6e 3a 20 4e 65 6f 53 | 6f 66 74 20 43 6f 6d 6d |on: NeoS|oft Comm|
|000000e0| 75 6e 69 63 61 74 69 6f | 6e 73 20 53 65 72 76 69 |unicatio|ns Servi|
|000000f0| 63 65 73 20 2d 2d 20 28 | 37 31 33 29 20 36 38 34 |ces -- (|713) 684|
|00000100| 2d 35 39 30 30 0a 44 61 | 74 65 3a 20 54 75 65 2c |-5900.Da|te: Tue,|
|00000110| 20 31 37 20 4e 6f 76 20 | 31 39 39 32 20 31 32 3a | 17 Nov |1992 12:|
|00000120| 31 33 3a 30 36 20 47 4d | 54 0a 4d 65 73 73 61 67 |13:06 GM|T.Messag|
|00000130| 65 2d 49 44 3a 20 3c 42 | 78 76 30 4d 32 2e 49 78 |e-ID: <B|xv0M2.Ix|
|00000140| 70 40 4e 65 6f 53 6f 66 | 74 2e 63 6f 6d 3e 0a 4c |p@NeoSof|t.com>.L|
|00000150| 69 6e 65 73 3a 20 31 34 | 35 33 0a 0a 41 72 63 68 |ines: 14|53..Arch|
|00000160| 69 76 65 2d 6e 61 6d 65 | 3a 20 62 75 66 66 65 72 |ive-name|: buffer|
|00000170| 2e 39 32 31 31 31 37 0a | 0a 54 68 65 20 66 6f 6c |.921117.|.The fol|
|00000180| 6c 6f 77 69 6e 67 20 63 | 6f 64 65 20 70 72 6f 76 |lowing c|ode prov|
|00000190| 69 64 65 73 20 61 20 68 | 69 67 68 20 6c 65 76 65 |ides a h|igh leve|
|000001a0| 6c 20 69 6e 74 65 72 66 | 61 63 65 20 74 6f 20 61 |l interf|ace to a|
|000001b0| 20 67 65 6e 65 72 69 63 | 20 74 65 78 74 0a 62 75 | generic| text.bu|
|000001c0| 66 66 65 72 20 6f 62 6a | 65 63 74 2e 20 49 74 20 |ffer obj|ect. It |
|000001d0| 69 73 20 69 6e 74 65 6e | 64 65 64 20 74 6f 20 61 |is inten|ded to a|
|000001e0| 6c 6c 6f 77 20 66 61 69 | 72 6c 79 20 72 61 64 69 |llow fai|rly radi|
|000001f0| 63 61 6c 20 63 68 61 6e | 67 65 73 20 74 6f 20 74 |cal chan|ges to t|
|00000200| 68 65 0a 75 6e 64 65 72 | 6c 79 69 6e 67 20 69 6d |he.under|lying im|
|00000210| 70 6c 65 6d 65 6e 74 61 | 74 69 6f 6e 20 77 69 74 |plementa|tion wit|
|00000220| 68 6f 75 74 20 61 66 66 | 65 63 74 69 6e 67 20 74 |hout aff|ecting t|
|00000230| 68 65 20 41 50 49 2e 0a | 0a 54 68 69 73 20 69 73 |he API..|.This is|
|00000240| 20 74 68 65 20 66 69 72 | 73 74 20 63 75 74 20 61 | the fir|st cut a|
|00000250| 74 20 61 20 70 75 62 6c | 69 63 20 72 65 6c 65 61 |t a publ|ic relea|
|00000260| 73 65 2e 20 49 20 77 61 | 73 20 67 6f 69 6e 67 20 |se. I wa|s going |
|00000270| 74 6f 20 75 73 65 20 74 | 68 65 73 65 0a 72 6f 75 |to use t|hese.rou|
|00000280| 74 69 6e 65 73 20 69 6e | 20 6d 79 20 22 73 61 6d |tines in| my "sam|
|00000290| 22 20 63 6c 6f 6e 65 2c | 20 62 75 74 20 77 69 74 |" clone,| but wit|
|000002a0| 68 20 74 68 65 20 72 65 | 61 6c 20 74 68 69 6e 67 |h the re|al thing|
|000002b0| 20 75 70 20 66 6f 72 20 | 46 54 50 20 49 0a 66 69 | up for |FTP I.fi|
|000002c0| 67 75 72 65 64 20 49 20 | 6d 69 67 68 74 20 61 73 |gured I |might as|
|000002d0| 20 77 65 6c 6c 20 6a 75 | 73 74 20 73 68 69 70 20 | well ju|st ship |
|000002e0| 69 74 2e 2e 2e 0a 0a 23 | 21 20 2f 62 69 6e 2f 73 |it.....#|! /bin/s|
|000002f0| 68 0a 23 20 54 68 69 73 | 20 69 73 20 61 20 73 68 |h.# This| is a sh|
|00000300| 65 6c 6c 20 61 72 63 68 | 69 76 65 2e 20 20 52 65 |ell arch|ive. Re|
|00000310| 6d 6f 76 65 20 61 6e 79 | 74 68 69 6e 67 20 62 65 |move any|thing be|
|00000320| 66 6f 72 65 20 74 68 69 | 73 20 6c 69 6e 65 2c 20 |fore thi|s line, |
|00000330| 74 68 65 6e 20 66 65 65 | 64 20 69 74 0a 23 20 69 |then fee|d it.# i|
|00000340| 6e 74 6f 20 61 20 73 68 | 65 6c 6c 20 76 69 61 20 |nto a sh|ell via |
|00000350| 22 73 68 20 66 69 6c 65 | 22 20 6f 72 20 73 69 6d |"sh file|" or sim|
|00000360| 69 6c 61 72 2e 20 20 54 | 6f 20 6f 76 65 72 77 72 |ilar. T|o overwr|
|00000370| 69 74 65 20 65 78 69 73 | 74 69 6e 67 20 66 69 6c |ite exis|ting fil|
|00000380| 65 73 2c 0a 23 20 74 79 | 70 65 20 22 73 68 20 66 |es,.# ty|pe "sh f|
|00000390| 69 6c 65 20 2d 63 22 2e | 0a 23 20 54 68 65 20 74 |ile -c".|.# The t|
|000003a0| 6f 6f 6c 20 74 68 61 74 | 20 67 65 6e 65 72 61 74 |ool that| generat|
|000003b0| 65 64 20 74 68 69 73 20 | 61 70 70 65 61 72 65 64 |ed this |appeared|
|000003c0| 20 69 6e 20 74 68 65 20 | 63 6f 6d 70 2e 73 6f 75 | in the |comp.sou|
|000003d0| 72 63 65 73 2e 75 6e 69 | 78 20 6e 65 77 73 67 72 |rces.uni|x newsgr|
|000003e0| 6f 75 70 3b 0a 23 20 73 | 65 6e 64 20 6d 61 69 6c |oup;.# s|end mail|
|000003f0| 20 74 6f 20 63 6f 6d 70 | 2d 73 6f 75 72 63 65 73 | to comp|-sources|
|00000400| 2d 75 6e 69 78 40 75 75 | 6e 65 74 2e 75 75 2e 6e |-unix@uu|net.uu.n|
|00000410| 65 74 20 69 66 20 79 6f | 75 20 77 61 6e 74 20 74 |et if yo|u want t|
|00000420| 68 61 74 20 74 6f 6f 6c | 2e 0a 23 20 49 66 20 74 |hat tool|..# If t|
|00000430| 68 69 73 20 61 72 63 68 | 69 76 65 20 69 73 20 63 |his arch|ive is c|
|00000440| 6f 6d 70 6c 65 74 65 2c | 20 79 6f 75 20 77 69 6c |omplete,| you wil|
|00000450| 6c 20 73 65 65 20 74 68 | 65 20 66 6f 6c 6c 6f 77 |l see th|e follow|
|00000460| 69 6e 67 20 6d 65 73 73 | 61 67 65 20 61 74 20 74 |ing mess|age at t|
|00000470| 68 65 20 65 6e 64 3a 0a | 23 09 09 22 45 6e 64 20 |he end:.|#.."End |
|00000480| 6f 66 20 73 68 65 6c 6c | 20 61 72 63 68 69 76 65 |of shell| archive|
|00000490| 2e 22 0a 23 20 43 6f 6e | 74 65 6e 74 73 3a 20 20 |.".# Con|tents: |
|000004a0| 62 75 66 66 65 72 2e 31 | 20 4d 61 6b 65 66 69 6c |buffer.1| Makefil|
|000004b0| 65 20 62 75 66 66 65 72 | 2e 68 20 62 75 66 66 65 |e buffer|.h buffe|
|000004c0| 72 2e 63 20 62 74 2e 63 | 20 62 6f 79 65 72 6d 6f |r.c bt.c| boyermo|
|000004d0| 6f 2e 63 0a 23 20 57 72 | 61 70 70 65 64 20 62 79 |o.c.# Wr|apped by|
|000004e0| 20 70 65 74 65 72 40 74 | 61 72 6f 6e 67 61 20 6f | peter@t|aronga o|
|000004f0| 6e 20 53 75 6e 20 4e 6f | 76 20 31 35 20 31 36 3a |n Sun No|v 15 16:|
|00000500| 31 30 3a 34 31 20 31 39 | 39 32 0a 50 41 54 48 3d |10:41 19|92.PATH=|
|00000510| 2f 62 69 6e 3a 2f 75 73 | 72 2f 62 69 6e 3a 2f 75 |/bin:/us|r/bin:/u|
|00000520| 73 72 2f 75 63 62 20 3b | 20 65 78 70 6f 72 74 20 |sr/ucb ;| export |
|00000530| 50 41 54 48 0a 69 66 20 | 74 65 73 74 20 2d 66 20 |PATH.if |test -f |
|00000540| 27 62 75 66 66 65 72 2e | 31 27 20 2d 61 20 22 24 |'buffer.|1' -a "$|
|00000550| 7b 31 7d 22 20 21 3d 20 | 22 2d 63 22 20 3b 20 74 |{1}" != |"-c" ; t|
|00000560| 68 65 6e 20 0a 20 20 65 | 63 68 6f 20 73 68 61 72 |hen . e|cho shar|
|00000570| 3a 20 57 69 6c 6c 20 6e | 6f 74 20 63 6c 6f 62 62 |: Will n|ot clobb|
|00000580| 65 72 20 65 78 69 73 74 | 69 6e 67 20 66 69 6c 65 |er exist|ing file|
|00000590| 20 5c 22 27 62 75 66 66 | 65 72 2e 31 27 5c 22 0a | \"'buff|er.1'\".|
|000005a0| 65 6c 73 65 0a 65 63 68 | 6f 20 73 68 61 72 3a 20 |else.ech|o shar: |
|000005b0| 45 78 74 72 61 63 74 69 | 6e 67 20 5c 22 27 62 75 |Extracti|ng \"'bu|
|000005c0| 66 66 65 72 2e 31 27 5c | 22 20 5c 28 38 31 35 30 |ffer.1'\|" \(8150|
|000005d0| 20 63 68 61 72 61 63 74 | 65 72 73 5c 29 0a 73 65 | charact|ers\).se|
|000005e0| 64 20 22 73 2f 5e 58 2f | 2f 22 20 3e 27 62 75 66 |d "s/^X/|/" >'buf|
|000005f0| 66 65 72 2e 31 27 20 3c | 3c 27 45 4e 44 5f 4f 46 |fer.1' <|<'END_OF|
|00000600| 5f 46 49 4c 45 27 0a 58 | 2e 54 48 20 42 55 46 46 |_FILE'.X|.TH BUFF|
|00000610| 45 52 20 31 20 22 31 35 | 20 4e 4f 56 20 39 32 22 |ER 1 "15| NOV 92"|
|00000620| 20 22 50 64 53 22 0a 58 | 2e 53 48 20 4e 41 4d 45 | "PdS".X|.SH NAME|
|00000630| 0a 58 42 55 46 46 45 52 | 20 5c 2d 20 62 75 66 66 |.XBUFFER| \- buff|
|00000640| 65 72 20 68 61 6e 64 6c | 69 6e 67 20 75 74 69 6c |er handl|ing util|
|00000650| 69 74 79 20 72 6f 75 74 | 69 6e 65 73 20 77 69 74 |ity rout|ines wit|
|00000660| 68 20 61 20 68 69 67 68 | 2d 6c 65 76 65 6c 20 69 |h a high|-level i|
|00000670| 6e 74 65 72 66 61 63 65 | 2e 0a 58 2e 53 48 20 53 |nterface|..X.SH S|
|00000680| 59 4e 4f 50 53 49 53 0a | 58 2e 42 20 22 23 69 6e |YNOPSIS.|X.B "#in|
|00000690| 63 6c 75 64 65 20 3c 62 | 75 66 66 65 72 2e 68 3e |clude <b|uffer.h>|
|000006a0| 22 0a 58 0a 58 5c 66 49 | 62 75 66 66 65 72 5c 66 |".X.X\fI|buffer\f|
|000006b0| 52 20 3d 20 5c 66 42 6e | 65 77 5f 62 75 66 66 65 |R = \fBn|ew_buffe|
|000006c0| 72 5c 66 52 28 29 3b 0a | 58 2e 62 72 0a 58 5c 66 |r\fR();.|X.br.X\f|
|000006d0| 42 64 65 6c 65 74 65 5f | 62 75 66 66 65 72 5c 66 |Bdelete_|buffer\f|
|000006e0| 52 28 5c 66 49 62 75 66 | 66 65 72 5c 66 52 29 3b |R(\fIbuf|fer\fR);|
|000006f0| 0a 58 2e 62 72 0a 58 5c | 66 49 6d 61 72 6b 5c 66 |.X.br.X\|fImark\f|
|00000700| 52 20 3d 20 5c 66 42 63 | 6f 70 79 5f 6d 61 72 6b |R = \fBc|opy_mark|
|00000710| 5c 66 52 28 5c 66 49 62 | 75 66 66 65 72 5c 66 52 |\fR(\fIb|uffer\fR|
|00000720| 2c 20 5c 66 49 6d 61 72 | 6b 5c 66 52 29 3b 0a 58 |, \fImar|k\fR);.X|
|00000730| 2e 62 72 0a 58 5c 66 49 | 6d 61 72 6b 5c 66 52 20 |.br.X\fI|mark\fR |
|00000740| 3d 20 5c 66 42 73 65 61 | 72 63 68 5c 66 52 28 5c |= \fBsea|rch\fR(\|
|00000750| 66 49 62 75 66 66 65 72 | 5c 66 52 2c 20 5c 66 49 |fIbuffer|\fR, \fI|
|00000760| 6d 61 72 6b 31 5c 66 52 | 2c 20 5c 66 49 6d 61 72 |mark1\fR|, \fImar|
|00000770| 6b 32 5c 66 52 2c 20 5c | 66 49 73 74 72 69 6e 67 |k2\fR, \|fIstring|
|00000780| 5c 66 52 29 3b 0a 58 2e | 62 72 0a 58 5c 66 49 73 |\fR);.X.|br.X\fIs|
|00000790| 74 61 74 5c 66 52 20 3d | 20 5c 66 42 64 65 6c 65 |tat\fR =| \fBdele|
|000007a0| 74 65 5f 6d 61 72 6b 5c | 66 52 28 5c 66 49 62 75 |te_mark\|fR(\fIbu|
|000007b0| 66 66 65 72 5c 66 52 2c | 20 5c 66 49 6d 61 72 6b |ffer\fR,| \fImark|
|000007c0| 5c 66 52 29 3b 0a 58 2e | 62 72 0a 58 5c 66 49 73 |\fR);.X.|br.X\fIs|
|000007d0| 74 61 74 5c 66 52 20 3d | 20 5c 66 42 6d 6f 76 65 |tat\fR =| \fBmove|
|000007e0| 5f 6d 61 72 6b 5c 66 52 | 28 5c 66 49 62 75 66 66 |_mark\fR|(\fIbuff|
|000007f0| 65 72 5c 66 52 2c 20 5c | 66 49 6d 61 72 6b 5c 66 |er\fR, \|fImark\f|
|00000800| 52 2c 20 5c 66 49 6f 66 | 66 5c 66 52 29 3b 0a 58 |R, \fIof|f\fR);.X|
|00000810| 2e 62 72 0a 58 5c 66 49 | 6f 66 66 5c 66 52 20 3d |.br.X\fI|off\fR =|
|00000820| 20 5c 66 42 6c 6f 63 61 | 74 65 5f 6d 61 72 6b 5c | \fBloca|te_mark\|
|00000830| 66 52 28 5c 66 49 62 75 | 66 66 65 72 5c 66 52 2c |fR(\fIbu|ffer\fR,|
|00000840| 20 5c 66 49 6d 61 72 6b | 5c 66 52 29 3b 0a 58 2e | \fImark|\fR);.X.|
|00000850| 62 72 0a 58 5c 66 49 70 | 74 72 5c 66 52 20 3d 20 |br.X\fIp|tr\fR = |
|00000860| 5c 66 42 74 65 78 74 5c | 66 52 28 5c 66 49 62 75 |\fBtext\|fR(\fIbu|
|00000870| 66 66 65 72 5c 66 52 2c | 20 5c 66 49 6d 61 72 6b |ffer\fR,| \fImark|
|00000880| 31 5c 66 52 2c 20 5c 66 | 49 6d 61 72 6b 32 5c 66 |1\fR, \f|Imark2\f|
|00000890| 52 2c 20 26 5c 66 49 6c | 65 6e 67 74 68 5c 66 52 |R, &\fIl|ength\fR|
|000008a0| 29 3b 0a 58 2e 62 72 0a | 58 5c 66 49 70 74 72 5c |);.X.br.|X\fIptr\|
|000008b0| 66 52 20 3d 20 5c 66 42 | 6f 70 65 6e 5f 74 65 78 |fR = \fB|open_tex|
|000008c0| 74 5c 66 52 28 5c 66 49 | 62 75 66 66 65 72 5c 66 |t\fR(\fI|buffer\f|
|000008d0| 52 2c 20 5c 66 49 6d 61 | 72 6b 5c 66 52 2c 20 5c |R, \fIma|rk\fR, \|
|000008e0| 66 49 6c 65 6e 67 74 68 | 5c 66 52 29 3b 0a 58 2e |fIlength|\fR);.X.|
|000008f0| 62 72 0a 58 5c 66 42 63 | 6c 6f 73 65 5f 74 65 78 |br.X\fBc|lose_tex|
|00000900| 74 5c 66 52 28 5c 66 49 | 62 75 66 66 65 72 5c 66 |t\fR(\fI|buffer\f|
|00000910| 52 2c 20 5c 66 49 6e 65 | 77 5f 6c 65 6e 67 74 68 |R, \fIne|w_length|
|00000920| 5c 66 52 29 3b 0a 58 2e | 62 72 0a 58 5c 66 49 73 |\fR);.X.|br.X\fIs|
|00000930| 74 61 74 5c 66 52 20 3d | 20 5c 66 42 64 65 6c 65 |tat\fR =| \fBdele|
|00000940| 74 65 5f 74 65 78 74 5c | 66 52 28 5c 66 49 62 75 |te_text\|fR(\fIbu|
|00000950| 66 66 65 72 5c 66 52 2c | 20 5c 66 49 6d 61 72 6b |ffer\fR,| \fImark|
|00000960| 31 5c 66 52 2c 20 5c 66 | 49 6d 61 72 6b 32 5c 66 |1\fR, \f|Imark2\f|
|00000970| 52 29 3b 0a 58 2e 62 72 | 0a 58 5c 66 42 65 78 74 |R);.X.br|.X\fBext|
|00000980| 65 72 6e 20 63 68 61 72 | 20 2a 62 75 66 66 65 72 |ern char| *buffer|
|00000990| 5f 65 72 72 6f 72 3b 5c | 66 52 0a 58 0a 58 5c 66 |_error;\|fR.X.X\f|
|000009a0| 42 42 55 46 46 45 52 20 | 5c 66 49 62 75 66 66 65 |BBUFFER |\fIbuffe|
|000009b0| 72 5c 66 52 3b 0a 58 2e | 62 72 0a 58 5c 66 42 4d |r\fR;.X.|br.X\fBM|
|000009c0| 41 52 4b 20 5c 66 49 6d | 61 72 6b 5c 66 52 2c 20 |ARK \fIm|ark\fR, |
|000009d0| 5c 66 49 6d 61 72 6b 31 | 5c 66 52 2c 20 2e 2e 2e |\fImark1|\fR, ...|
|000009e0| 3b 0a 58 2e 62 72 0a 58 | 5c 66 42 73 69 7a 65 5f |;.X.br.X|\fBsize_|
|000009f0| 74 20 5c 66 49 6f 66 66 | 5c 66 52 2c 20 5c 66 49 |t \fIoff|\fR, \fI|
|00000a00| 6f 66 66 31 5c 66 52 2c | 20 2e 2e 2e 3b 0a 58 2e |off1\fR,| ...;.X.|
|00000a10| 62 72 0a 58 5c 66 42 69 | 6e 74 20 5c 66 49 73 74 |br.X\fBi|nt \fIst|
|00000a20| 61 74 5c 66 52 2c 20 5c | 66 49 63 6e 74 5c 66 52 |at\fR, \|fIcnt\fR|
|00000a30| 3b 0a 58 2e 62 72 0a 58 | 5c 66 42 63 68 61 72 5c |;.X.br.X|\fBchar\|
|00000a40| 66 52 20 2a 5c 66 49 70 | 74 72 5c 66 52 3b 0a 58 |fR *\fIp|tr\fR;.X|
|00000a50| 2e 53 48 20 44 45 53 43 | 52 49 50 54 49 4f 4e 0a |.SH DESC|RIPTION.|
|00000a60| 58 54 68 65 73 65 20 72 | 6f 75 74 69 6e 65 73 20 |XThese r|outines |
|00000a70| 70 72 6f 76 69 64 65 20 | 61 6e 20 69 6e 74 65 72 |provide |an inter|
|00000a80| 66 61 63 65 20 74 6f 20 | 61 20 67 65 6e 65 72 69 |face to |a generi|
|00000a90| 63 20 63 68 61 72 61 63 | 74 65 72 2d 6f 72 69 65 |c charac|ter-orie|
|00000aa0| 6e 74 65 64 0a 58 74 65 | 78 74 20 62 75 66 66 65 |nted.Xte|xt buffe|
|00000ab0| 72 20 6f 62 6a 65 63 74 | 2e 20 54 68 65 20 64 65 |r object|. The de|
|00000ac0| 74 61 69 6c 73 20 6f 66 | 20 74 68 65 20 69 6d 70 |tails of| the imp|
|00000ad0| 6c 65 6d 65 6e 74 61 74 | 69 6f 6e 20 61 72 65 20 |lementat|ion are |
|00000ae0| 72 65 6c 61 74 69 76 65 | 6c 79 0a 58 77 65 6c 6c |relative|ly.Xwell|
|00000af0| 20 68 69 64 64 65 6e 20 | 28 66 6f 72 20 65 78 61 | hidden |(for exa|
|00000b00| 6d 70 6c 65 2c 20 5c 66 | 42 42 55 46 46 45 52 5c |mple, \f|BBUFFER\|
|00000b10| 66 52 20 61 6e 64 20 5c | 66 42 4d 41 52 4b 5c 66 |fR and \|fBMARK\f|
|00000b20| 52 20 61 72 65 20 63 75 | 72 72 65 6e 74 6c 79 0a |R are cu|rrently.|
|00000b30| 58 69 6e 74 65 67 72 61 | 6c 2c 20 62 75 74 20 74 |Xintegra|l, but t|
|00000b40| 68 65 20 72 6f 75 74 69 | 6e 65 73 20 63 6f 75 6c |he routi|nes coul|
|00000b50| 64 20 62 65 20 6d 6f 64 | 69 66 69 65 64 20 74 6f |d be mod|ified to|
|00000b60| 20 6f 70 65 72 61 74 65 | 20 6f 6e 20 70 6f 69 6e | operate| on poin|
|00000b70| 74 65 72 73 0a 58 6f 72 | 20 61 6e 79 20 6f 74 68 |ters.Xor| any oth|
|00000b80| 65 72 20 74 6f 6b 65 6e | 29 2c 20 61 6e 64 20 74 |er token|), and t|
|00000b90| 68 65 72 65 20 61 72 65 | 20 65 6e 6f 75 67 68 20 |here are| enough |
|00000ba0| 68 6f 6f 6b 73 20 74 68 | 61 74 20 69 74 20 73 68 |hooks th|at it sh|
|00000bb0| 6f 75 6c 64 20 6e 6f 74 | 20 62 65 0a 58 6e 65 63 |ould not| be.Xnec|
|00000bc0| 65 73 73 61 72 79 20 66 | 6f 72 20 61 6e 20 61 70 |essary f|or an ap|
|00000bd0| 70 6c 69 63 61 74 69 6f | 6e 20 74 6f 20 6c 6f 6f |plicatio|n to loo|
|00000be0| 6b 20 75 6e 64 65 72 20 | 74 68 65 20 69 6e 74 65 |k under |the inte|
|00000bf0| 72 66 61 63 65 2e 0a 58 | 2e 53 53 20 42 55 46 46 |rface..X|.SS BUFF|
|00000c00| 45 52 53 0a 58 5c 66 42 | 42 55 46 46 45 52 20 5c |ERS.X\fB|BUFFER \|
|00000c10| 66 49 62 75 66 66 65 72 | 5c 66 52 3b 0a 58 2e 62 |fIbuffer|\fR;.X.b|
|00000c20| 72 0a 58 5c 66 42 42 55 | 46 46 45 52 5f 45 52 52 |r.X\fBBU|FFER_ERR|
|00000c30| 4f 52 5c 66 52 0a 58 2e | 50 50 0a 58 41 20 5c 66 |OR\fR.X.|PP.XA \f|
|00000c40| 42 42 55 46 46 45 52 5c | 66 52 20 69 73 20 61 6e |BBUFFER\|fR is an|
|00000c50| 20 6f 70 61 71 75 65 20 | 74 6f 6b 65 6e 20 75 73 | opaque |token us|
|00000c60| 65 64 20 74 6f 20 72 65 | 66 65 72 65 6e 63 65 20 |ed to re|ference |
|00000c70| 61 20 74 65 78 74 20 62 | 75 66 66 65 72 2e 20 49 |a text b|uffer. I|
|00000c80| 74 0a 58 69 73 20 72 65 | 74 75 72 6e 65 64 20 62 |t.Xis re|turned b|
|00000c90| 79 20 5c 66 42 6e 65 77 | 5f 62 75 66 66 65 72 5c |y \fBnew|_buffer\|
|00000ca0| 66 52 2c 20 61 6e 64 20 | 6d 61 6e 69 70 75 6c 61 |fR, and |manipula|
|00000cb0| 74 65 64 20 62 79 20 74 | 68 65 20 72 65 73 74 20 |ted by t|he rest |
|00000cc0| 6f 66 20 74 68 65 0a 58 | 72 6f 75 74 69 6e 65 73 |of the.X|routines|
|00000cd0| 2e 20 41 66 74 65 72 20 | 75 73 65 20 61 20 5c 66 |. After |use a \f|
|00000ce0| 42 42 55 46 46 45 52 5c | 66 52 20 61 6e 64 20 61 |BBUFFER\|fR and a|
|00000cf0| 6e 79 20 61 73 73 6f 63 | 69 61 74 65 64 20 5c 66 |ny assoc|iated \f|
|00000d00| 42 4d 41 52 4b 5c 66 52 | 73 20 61 72 65 0a 58 64 |BMARK\fR|s are.Xd|
|00000d10| 65 6c 65 74 65 64 20 62 | 79 20 74 68 65 20 72 6f |eleted b|y the ro|
|00000d20| 75 74 69 6e 65 20 5c 66 | 42 64 65 6c 65 74 65 5f |utine \f|Bdelete_|
|00000d30| 62 75 66 66 65 72 5c 66 | 52 2e 0a 58 2e 50 50 0a |buffer\f|R..X.PP.|
|00000d40| 58 2e 42 20 42 55 46 46 | 45 52 5f 45 52 52 4f 52 |X.B BUFF|ER_ERROR|
|00000d50| 0a 58 69 73 20 61 20 75 | 6e 69 71 75 65 20 76 61 |.Xis a u|nique va|
|00000d60| 6c 75 65 20 72 65 74 75 | 72 6e 65 64 20 6f 6e 20 |lue retu|rned on |
|00000d70| 65 72 72 6f 72 2e 0a 58 | 2e 53 53 20 4d 41 52 4b |error..X|.SS MARK|
|00000d80| 53 0a 58 5c 66 42 4d 41 | 52 4b 20 5c 66 49 6d 61 |S.X\fBMA|RK \fIma|
|00000d90| 72 6b 5c 66 52 2c 20 5c | 66 49 6d 61 72 6b 31 5c |rk\fR, \|fImark1\|
|00000da0| 66 52 2c 20 2e 2e 2e 3b | 0a 58 2e 62 72 0a 58 5c |fR, ...;|.X.br.X\|
|00000db0| 66 42 4d 41 52 4b 5f 42 | 45 47 49 4e 5c 66 52 0a |fBMARK_B|EGIN\fR.|
|00000dc0| 58 2e 62 72 0a 58 5c 66 | 42 4d 41 52 4b 5f 45 4e |X.br.X\f|BMARK_EN|
|00000dd0| 44 5c 66 52 0a 58 2e 50 | 50 0a 58 41 20 5c 66 42 |D\fR.X.P|P.XA \fB|
|00000de0| 4d 41 52 4b 5c 66 52 20 | 69 73 20 61 6e 20 6f 70 |MARK\fR |is an op|
|00000df0| 61 71 75 65 20 74 6f 6b | 65 6e 20 75 73 65 64 20 |aque tok|en used |
|00000e00| 74 6f 20 72 65 66 65 72 | 65 6e 63 65 20 61 20 63 |to refer|ence a c|
|00000e10| 68 61 72 61 63 74 65 72 | 20 70 6f 73 69 74 69 6f |haracter| positio|
|00000e20| 6e 0a 58 77 69 74 68 69 | 6e 20 61 20 5c 66 42 42 |n.Xwithi|n a \fBB|
|00000e30| 55 46 46 45 52 5c 66 52 | 2e 0a 58 41 20 5c 66 42 |UFFER\fR|..XA \fB|
|00000e40| 4d 41 52 4b 5c 66 52 20 | 69 73 20 61 75 74 6f 6d |MARK\fR |is autom|
|00000e50| 61 74 69 63 61 6c 6c 79 | 20 75 70 64 61 74 65 64 |atically| updated|
|00000e60| 20 61 73 20 74 65 78 74 | 20 69 73 20 61 64 64 65 | as text| is adde|
|00000e70| 64 20 74 6f 20 6f 72 20 | 64 65 6c 65 74 65 64 0a |d to or |deleted.|
|00000e80| 58 66 72 6f 6d 20 74 68 | 65 20 5c 66 42 42 55 46 |Xfrom th|e \fBBUF|
|00000e90| 46 45 52 5c 66 52 2e 0a | 58 41 6c 6c 20 72 65 66 |FER\fR..|XAll ref|
|00000ea0| 65 72 65 6e 63 65 73 20 | 74 6f 20 6c 6f 63 61 74 |erences |to locat|
|00000eb0| 69 6f 6e 73 20 77 69 74 | 68 69 6e 20 61 20 62 75 |ions wit|hin a bu|
|00000ec0| 66 66 65 72 20 61 72 65 | 20 76 69 61 20 5c 66 42 |ffer are| via \fB|
|00000ed0| 4d 41 52 4b 5c 66 52 73 | 2e 0a 58 41 0a 58 2e 42 |MARK\fRs|..XA.X.B|
|00000ee0| 20 4d 41 52 4b 0a 58 69 | 73 20 63 6f 6e 73 69 64 | MARK.Xi|s consid|
|00000ef0| 65 72 65 64 20 74 6f 20 | 62 65 20 62 65 74 77 65 |ered to |be betwe|
|00000f00| 65 6e 20 63 68 61 72 61 | 63 74 65 72 73 20 69 6e |en chara|cters in|
|00000f10| 20 74 65 78 74 2c 20 61 | 6e 64 20 74 6f 20 68 61 | text, a|nd to ha|
|00000f20| 76 65 20 61 6e 20 61 66 | 66 69 6e 69 74 79 0a 58 |ve an af|finity.X|
|00000f30| 66 6f 72 20 74 68 65 20 | 66 6f 6c 6c 6f 77 69 6e |for the |followin|
|00000f40| 67 20 74 65 78 74 2e 2e | 2e 20 73 65 65 20 5c 66 |g text..|. see \f|
|00000f50| 42 6f 70 65 6e 5f 74 65 | 78 74 5c 66 52 20 61 6e |Bopen_te|xt\fR an|
|00000f60| 64 20 5c 66 42 64 65 6c | 65 74 65 5f 74 65 78 74 |d \fBdel|ete_text|
|00000f70| 5c 66 52 20 66 6f 72 0a | 58 6d 6f 72 65 20 69 6e |\fR for.|Xmore in|
|00000f80| 66 6f 72 6d 61 74 69 6f | 6e 2e 0a 58 2e 50 50 0a |formatio|n..X.PP.|
|00000f90| 58 54 68 65 20 73 70 65 | 63 69 61 6c 20 5c 66 42 |XThe spe|cial \fB|
|00000fa0| 4d 41 52 4b 5c 66 52 73 | 20 5c 66 42 4d 41 52 4b |MARK\fRs| \fBMARK|
|00000fb0| 5f 42 45 47 49 4e 5c 66 | 52 20 61 6e 64 20 5c 66 |_BEGIN\f|R and \f|
|00000fc0| 42 4d 41 52 4b 5f 45 4e | 44 5c 66 52 20 61 72 65 |BMARK_EN|D\fR are|
|00000fd0| 20 76 61 6c 69 64 0a 58 | 61 74 20 61 6c 6c 20 74 | valid.X|at all t|
|00000fe0| 69 6d 65 73 20 66 6f 72 | 20 61 6c 6c 20 62 75 66 |imes for| all buf|
|00000ff0| 66 65 72 73 2e 0a 58 2e | 42 20 4d 41 52 4b 5f 42 |fers..X.|B MARK_B|
|00001000| 45 47 49 4e 0a 58 72 65 | 66 65 72 73 20 74 6f 20 |EGIN.Xre|fers to |
|00001010| 74 68 65 20 62 65 67 69 | 6e 6e 69 6e 67 20 6f 66 |the begi|nning of|
|00001020| 20 74 68 65 20 62 75 66 | 66 65 72 2c 20 62 65 66 | the buf|fer, bef|
|00001030| 6f 72 65 20 74 68 65 20 | 66 69 72 73 74 20 63 68 |ore the |first ch|
|00001040| 61 72 61 63 74 65 72 20 | 6f 66 20 74 65 78 74 2e |aracter |of text.|
|00001050| 0a 58 2e 42 20 4d 41 52 | 4b 5f 45 4e 44 0a 58 72 |.X.B MAR|K_END.Xr|
|00001060| 65 66 65 72 73 20 74 6f | 20 74 68 65 20 65 6e 64 |efers to| the end|
|00001070| 20 6f 66 20 74 68 65 20 | 62 75 66 66 65 72 2c 20 | of the |buffer, |
|00001080| 61 66 74 65 72 20 74 68 | 65 20 6c 61 73 74 20 63 |after th|e last c|
|00001090| 68 61 72 61 63 74 65 72 | 2e 0a 58 2e 53 53 20 22 |haracter|..X.SS "|
|000010a0| 43 72 65 61 74 69 6e 67 | 20 4d 41 52 4b 73 22 0a |Creating| MARKs".|
|000010b0| 58 5c 66 49 6d 61 72 6b | 5c 66 52 20 3d 20 5c 66 |X\fImark|\fR = \f|
|000010c0| 42 63 6f 70 79 5f 6d 61 | 72 6b 5c 66 52 28 5c 66 |Bcopy_ma|rk\fR(\f|
|000010d0| 49 62 75 66 66 65 72 5c | 66 52 2c 20 5c 66 49 6d |Ibuffer\|fR, \fIm|
|000010e0| 61 72 6b 5c 66 52 29 3b | 0a 58 2e 62 72 0a 58 5c |ark\fR);|.X.br.X\|
|000010f0| 66 49 6d 61 72 6b 5c 66 | 52 20 3d 20 5c 66 42 6e |fImark\f|R = \fBn|
|00001100| 65 77 5f 6d 61 72 6b 5c | 66 52 28 5c 66 49 62 75 |ew_mark\|fR(\fIbu|
|00001110| 66 66 65 72 5c 66 52 2c | 20 5c 66 49 6f 66 66 5c |ffer\fR,| \fIoff\|
|00001120| 66 52 29 3b 0a 58 2e 62 | 72 0a 58 5c 66 49 6d 61 |fR);.X.b|r.X\fIma|
|00001130| 72 6b 5c 66 52 20 3d 20 | 5c 66 42 73 65 61 72 63 |rk\fR = |\fBsearc|
|00001140| 68 5c 66 52 28 5c 66 49 | 62 75 66 66 65 72 5c 66 |h\fR(\fI|buffer\f|
|00001150| 52 2c 20 5c 66 49 6d 61 | 72 6b 31 5c 66 52 2c 20 |R, \fIma|rk1\fR, |
|00001160| 5c 66 49 6d 61 72 6b 32 | 5c 66 52 2c 20 5c 66 49 |\fImark2|\fR, \fI|
|00001170| 73 74 72 69 6e 67 5c 66 | 52 29 3b 0a 58 2e 50 50 |string\f|R);.X.PP|
|00001180| 0a 58 2e 42 20 43 6f 70 | 79 5f 6d 61 72 6b 0a 58 |.X.B Cop|y_mark.X|
|00001190| 63 72 65 61 74 65 73 20 | 61 20 64 75 70 6c 69 63 |creates |a duplic|
|000011a0| 61 74 65 20 6f 66 20 61 | 6e 20 65 78 69 73 74 69 |ate of a|n existi|
|000011b0| 6e 67 20 5c 66 42 4d 41 | 52 4b 5c 66 52 2e 0a 58 |ng \fBMA|RK\fR..X|
|000011c0| 2e 42 20 4e 65 77 5f 6d | 61 72 6b 0a 58 63 72 65 |.B New_m|ark.Xcre|
|000011d0| 61 74 65 73 20 61 20 5c | 66 42 4d 41 52 4b 5c 66 |ates a \|fBMARK\f|
|000011e0| 52 20 61 74 20 61 20 67 | 69 76 65 6e 20 6f 66 66 |R at a g|iven off|
|000011f0| 73 65 74 20 66 72 6f 6d | 20 74 68 65 20 62 65 67 |set from| the beg|
|00001200| 69 6e 6e 69 6e 67 20 6f | 66 20 61 20 5c 66 42 42 |inning o|f a \fBB|
|00001210| 55 46 46 45 52 5c 66 52 | 2e 0a 58 2e 42 20 53 65 |UFFER\fR|..X.B Se|
|00001220| 61 72 63 68 0a 58 73 65 | 61 72 63 68 65 73 20 62 |arch.Xse|arches b|
|00001230| 65 74 77 65 65 6e 20 61 | 20 70 61 69 72 20 6f 66 |etween a| pair of|
|00001240| 20 5c 66 42 4d 41 52 4b | 5c 66 52 73 20 66 6f 72 | \fBMARK|\fRs for|
|00001250| 20 61 20 73 70 65 63 69 | 66 69 63 20 73 74 72 69 | a speci|fic stri|
|00001260| 6e 67 2e 0a 58 2e 50 50 | 0a 58 2e 42 20 53 65 61 |ng..X.PP|.X.B Sea|
|00001270| 72 63 68 0a 58 64 6f 65 | 73 20 6e 6f 74 20 70 65 |rch.Xdoe|s not pe|
|00001280| 72 66 6f 72 6d 20 72 65 | 67 75 6c 61 72 20 65 78 |rform re|gular ex|
|00001290| 70 72 65 73 73 69 6f 6e | 20 6f 70 65 72 61 74 69 |pression| operati|
|000012a0| 6f 6e 73 2e 20 49 6e 20 | 74 68 65 20 63 75 72 72 |ons. In |the curr|
|000012b0| 65 6e 74 20 69 6d 70 6c | 65 6d 65 6e 74 61 74 69 |ent impl|ementati|
|000012c0| 6f 6e 0a 58 69 74 20 75 | 73 65 73 20 74 68 65 20 |on.Xit u|ses the |
|000012d0| 42 6f 79 65 72 2d 4d 6f | 6f 72 65 20 61 6c 67 6f |Boyer-Mo|ore algo|
|000012e0| 72 69 74 68 6d 2e 20 54 | 68 65 20 73 65 61 72 63 |rithm. T|he searc|
|000012f0| 68 20 69 73 20 61 6c 77 | 61 79 73 20 70 65 72 66 |h is alw|ays perf|
|00001300| 6f 72 6d 65 64 20 66 72 | 6f 6d 20 74 68 65 0a 58 |ormed fr|om the.X|
|00001310| 62 65 67 69 6e 6e 69 6e | 67 20 6f 66 20 74 68 65 |beginnin|g of the|
|00001320| 20 69 6e 64 69 63 61 74 | 65 64 20 72 61 6e 67 65 | indicat|ed range|
|00001330| 20 74 6f 20 74 68 65 20 | 65 6e 64 2c 20 72 65 67 | to the |end, reg|
|00001340| 61 72 64 6c 65 73 73 20 | 6f 66 20 74 68 65 20 6f |ardless |of the o|
|00001350| 72 64 65 72 20 6f 66 20 | 74 68 65 0a 58 5c 66 42 |rder of |the.X\fB|
|00001360| 4d 41 52 4b 5c 66 52 73 | 20 73 70 65 63 69 66 69 |MARK\fRs| specifi|
|00001370| 65 64 2e 0a 58 2e 53 53 | 20 22 44 65 6c 65 74 69 |ed..X.SS| "Deleti|
|00001380| 6e 67 20 4d 41 52 4b 73 | 22 0a 58 5c 66 49 73 74 |ng MARKs|".X\fIst|
|00001390| 61 74 5c 66 52 20 3d 20 | 5c 66 42 64 65 6c 65 74 |at\fR = |\fBdelet|
|000013a0| 65 5f 6d 61 72 6b 5c 66 | 52 28 5c 66 49 62 75 66 |e_mark\f|R(\fIbuf|
|000013b0| 66 65 72 5c 66 52 2c 20 | 5c 66 49 6d 61 72 6b 5c |fer\fR, |\fImark\|
|000013c0| 66 52 29 3b 0a 58 2e 50 | 50 0a 58 2e 42 20 44 65 |fR);.X.P|P.X.B De|
|000013d0| 6c 65 74 65 5f 6d 61 72 | 6b 0a 58 73 69 6d 70 6c |lete_mar|k.Xsimpl|
|000013e0| 79 20 64 65 6c 65 74 65 | 73 20 74 68 65 0a 58 2e |y delete|s the.X.|
|000013f0| 42 20 4d 41 52 4b 0a 58 | 69 6e 64 69 63 61 74 65 |B MARK.X|indicate|
|00001400| 64 2e 20 49 74 20 64 6f | 65 73 20 6e 6f 74 20 6d |d. It do|es not m|
|00001410| 6f 64 69 66 79 20 74 68 | 65 20 63 6f 6e 74 65 6e |odify th|e conten|
|00001420| 74 73 0a 58 6f 66 20 74 | 68 65 0a 58 2e 42 20 42 |ts.Xof t|he.X.B B|
|00001430| 55 46 46 45 52 0a 58 69 | 6e 20 61 6e 79 20 77 61 |UFFER.Xi|n any wa|
|00001440| 79 2e 0a 58 2e 53 53 20 | 22 45 78 61 6d 69 6e 69 |y..X.SS |"Examini|
|00001450| 6e 67 20 4d 41 52 4b 73 | 22 0a 58 5c 66 49 73 74 |ng MARKs|".X\fIst|
|00001460| 61 74 5c 66 52 20 3d 20 | 5c 66 42 6d 6f 76 65 5f |at\fR = |\fBmove_|
|00001470| 6d 61 72 6b 5c 66 52 28 | 5c 66 49 62 75 66 66 65 |mark\fR(|\fIbuffe|
|00001480| 72 5c 66 52 2c 20 5c 66 | 49 6d 61 72 6b 5c 66 52 |r\fR, \f|Imark\fR|
|00001490| 2c 20 5c 66 49 6f 66 66 | 5c 66 52 29 3b 0a 58 2e |, \fIoff|\fR);.X.|
|000014a0| 62 72 0a 58 5c 66 49 6f | 66 66 5c 66 52 20 3d 20 |br.X\fIo|ff\fR = |
|000014b0| 5c 66 42 6c 6f 63 61 74 | 65 5f 6d 61 72 6b 5c 66 |\fBlocat|e_mark\f|
|000014c0| 52 28 5c 66 49 62 75 66 | 66 65 72 5c 66 52 2c 20 |R(\fIbuf|fer\fR, |
|000014d0| 5c 66 49 6d 61 72 6b 5c | 66 52 29 3b 0a 58 2e 50 |\fImark\|fR);.X.P|
|000014e0| 50 0a 58 2e 42 20 4d 6f | 76 65 5f 6d 61 72 6b 0a |P.X.B Mo|ve_mark.|
|000014f0| 58 6d 6f 76 65 73 20 61 | 20 5c 66 42 4d 41 52 4b |Xmoves a| \fBMARK|
|00001500| 5c 66 52 20 62 79 20 61 | 20 73 70 65 63 69 66 69 |\fR by a| specifi|
|00001510| 65 64 20 6e 75 6d 62 65 | 72 20 6f 66 20 63 68 61 |ed numbe|r of cha|
|00001520| 72 61 63 74 65 72 73 2e | 0a 58 2e 50 50 0a 58 2e |racters.|.X.PP.X.|
|00001530| 42 20 4c 6f 63 61 74 65 | 5f 6d 61 72 6b 20 73 69 |B Locate|_mark si|
|00001540| 6d 70 6c 79 20 72 65 74 | 75 72 6e 73 20 74 68 65 |mply ret|urns the|
|00001550| 20 6f 66 66 73 65 74 20 | 6f 66 20 74 68 65 20 6d | offset |of the m|
|00001560| 61 72 6b 20 66 72 6f 6d | 20 74 68 65 20 62 65 67 |ark from| the beg|
|00001570| 69 6e 6e 69 6e 67 0a 58 | 6f 66 20 74 68 65 20 62 |inning.X|of the b|
|00001580| 75 66 66 65 72 2e 20 54 | 68 65 20 63 75 72 72 65 |uffer. T|he curre|
|00001590| 6e 74 20 6c 65 6e 67 74 | 68 20 6f 66 20 74 68 65 |nt lengt|h of the|
|000015a0| 20 62 75 66 66 65 72 20 | 69 73 20 6f 62 74 61 69 | buffer |is obtai|
|000015b0| 6e 65 64 20 62 79 20 6c | 6f 63 61 74 69 6e 67 0a |ned by l|ocating.|
|000015c0| 58 5c 66 42 4d 41 52 4b | 5f 45 4e 44 5c 66 52 2e |X\fBMARK|_END\fR.|
|000015d0| 0a 58 2e 53 53 20 22 4d | 61 6e 69 70 75 6c 61 74 |.X.SS "M|anipulat|
|000015e0| 69 6e 67 20 74 68 65 20 | 63 6f 6e 74 65 6e 74 73 |ing the |contents|
|000015f0| 20 6f 66 20 61 20 62 75 | 66 66 65 72 22 0a 58 5c | of a bu|ffer".X\|
|00001600| 66 49 70 74 72 5c 66 52 | 20 3d 20 5c 66 42 74 65 |fIptr\fR| = \fBte|
|00001610| 78 74 5c 66 52 28 5c 66 | 49 62 75 66 66 65 72 5c |xt\fR(\f|Ibuffer\|
|00001620| 66 52 2c 20 5c 66 49 6d | 61 72 6b 31 5c 66 52 2c |fR, \fIm|ark1\fR,|
|00001630| 20 5c 66 49 6d 61 72 6b | 32 5c 66 52 2c 20 26 5c | \fImark|2\fR, &\|
|00001640| 66 49 6c 65 6e 67 74 68 | 5c 66 52 29 3b 0a 58 2e |fIlength|\fR);.X.|
|00001650| 62 72 0a 58 5c 66 49 70 | 74 72 5c 66 52 20 3d 20 |br.X\fIp|tr\fR = |
|00001660| 5c 66 42 6f 70 65 6e 5f | 74 65 78 74 5c 66 52 28 |\fBopen_|text\fR(|
|00001670| 5c 66 49 62 75 66 66 65 | 72 5c 66 52 2c 20 5c 66 |\fIbuffe|r\fR, \f|
|00001680| 49 6d 61 72 6b 5c 66 52 | 2c 20 5c 66 49 6c 65 6e |Imark\fR|, \fIlen|
|00001690| 67 74 68 5c 66 52 29 3b | 0a 58 2e 62 72 0a 58 5c |gth\fR);|.X.br.X\|
|000016a0| 66 42 63 6c 6f 73 65 5f | 74 65 78 74 5c 66 52 28 |fBclose_|text\fR(|
|000016b0| 5c 66 49 62 75 66 66 65 | 72 5c 66 52 2c 20 5c 66 |\fIbuffe|r\fR, \f|
|000016c0| 49 6e 65 77 5f 6c 65 6e | 67 74 68 5c 66 52 29 3b |Inew_len|gth\fR);|
|000016d0| 0a 58 2e 62 72 0a 58 5c | 66 49 73 74 61 74 5c 66 |.X.br.X\|fIstat\f|
|000016e0| 52 20 3d 20 5c 66 42 64 | 65 6c 65 74 65 5f 74 65 |R = \fBd|elete_te|
|000016f0| 78 74 5c 66 52 28 5c 66 | 49 62 75 66 66 65 72 5c |xt\fR(\f|Ibuffer\|
|00001700| 66 52 2c 20 5c 66 49 6d | 61 72 6b 31 5c 66 52 2c |fR, \fIm|ark1\fR,|
|00001710| 20 5c 66 49 6d 61 72 6b | 32 5c 66 52 29 3b 0a 58 | \fImark|2\fR);.X|
|00001720| 2e 50 50 0a 58 2e 42 20 | 54 65 78 74 0a 58 61 74 |.PP.X.B |Text.Xat|
|00001730| 74 65 6d 70 74 73 20 74 | 6f 20 72 65 74 75 72 6e |tempts t|o return|
|00001740| 20 61 20 70 6f 69 6e 74 | 65 72 20 74 6f 20 74 68 | a point|er to th|
|00001750| 65 20 74 65 78 74 20 62 | 65 74 77 65 65 6e 20 61 |e text b|etween a|
|00001760| 20 70 61 69 72 20 6f 66 | 20 5c 66 42 4d 41 52 4b | pair of| \fBMARK|
|00001770| 5c 66 52 73 2e 0a 58 54 | 68 65 20 6c 65 6e 67 74 |\fRs..XT|he lengt|
|00001780| 68 20 6f 66 20 74 68 65 | 20 74 65 78 74 20 69 73 |h of the| text is|
|00001790| 20 72 65 74 75 72 6e 65 | 64 20 76 69 61 20 6c 65 | returne|d via le|
|000017a0| 6e 67 74 68 2e 0a 58 49 | 66 20 74 68 65 20 5c 66 |ngth..XI|f the \f|
|000017b0| 42 42 55 46 46 45 52 5c | 66 52 20 69 73 20 6d 61 |BBUFFER\|fR is ma|
|000017c0| 69 6e 74 61 69 6e 65 64 | 20 6f 6e 20 73 65 63 6f |intained| on seco|
|000017d0| 6e 64 61 72 79 20 73 74 | 6f 72 61 67 65 2c 0a 58 |ndary st|orage,.X|
|000017e0| 74 68 69 73 20 6d 61 79 | 20 6e 6f 74 20 62 65 20 |this may| not be |
|000017f0| 70 6f 73 73 69 62 6c 65 | 2c 0a 58 73 6f 20 79 6f |possible|,.Xso yo|
|00001800| 75 20 73 68 6f 75 6c 64 | 20 6b 65 65 70 20 6d 6f |u should| keep mo|
|00001810| 76 69 6e 67 20 74 68 65 | 20 66 69 72 73 74 20 5c |ving the| first \|
|00001820| 66 42 4d 41 52 4b 5c 66 | 52 20 61 6e 64 20 63 61 |fBMARK\f|R and ca|
|00001830| 6c 6c 69 6e 67 20 5c 66 | 42 74 65 78 74 5c 66 52 |lling \f|Btext\fR|
|00001840| 20 75 6e 74 69 6c 0a 58 | 74 68 65 20 72 65 74 75 | until.X|the retu|
|00001850| 72 6e 65 64 20 6c 65 6e | 67 74 68 20 69 73 20 7a |rned len|gth is z|
|00001860| 65 72 6f 2e 20 54 68 69 | 73 20 70 6f 69 6e 74 65 |ero. Thi|s pointe|
|00001870| 72 20 69 73 20 69 6e 76 | 61 6c 69 64 61 74 65 64 |r is inv|alidated|
|00001880| 20 61 66 74 65 72 20 61 | 6e 79 20 66 75 72 74 68 | after a|ny furth|
|00001890| 65 72 0a 58 6f 70 65 72 | 61 74 69 6f 6e 73 20 6f |er.Xoper|ations o|
|000018a0| 6e 20 74 68 65 20 62 75 | 66 66 65 72 2e 0a 58 2e |n the bu|ffer..X.|
|000018b0| 50 50 0a 58 2e 42 20 4f | 70 65 6e 5f 74 65 78 74 |PP.X.B O|pen_text|
|000018c0| 0a 58 65 78 74 65 6e 64 | 73 20 74 68 65 20 62 75 |.Xextend|s the bu|
|000018d0| 66 66 65 72 20 62 79 20 | 74 68 65 20 69 6e 64 69 |ffer by |the indi|
|000018e0| 63 61 74 65 64 20 6e 75 | 6d 62 65 72 20 6f 66 20 |cated nu|mber of |
|000018f0| 63 68 61 72 61 63 74 65 | 72 73 2c 20 61 6e 64 20 |characte|rs, and |
|00001900| 72 65 74 75 72 6e 73 20 | 61 0a 58 70 6f 69 6e 74 |returns |a.Xpoint|
|00001910| 65 72 20 74 6f 20 61 74 | 20 6c 65 61 73 74 20 74 |er to at| least t|
|00001920| 68 61 74 20 6d 61 6e 79 | 20 62 79 74 65 73 20 6f |hat many| bytes o|
|00001930| 66 20 6d 65 6d 6f 72 79 | 2e 20 49 66 20 69 74 20 |f memory|. If it |
|00001940| 69 73 20 6e 6f 74 20 70 | 6f 73 73 69 62 6c 65 20 |is not p|ossible |
|00001950| 74 6f 0a 58 61 6c 6c 6f | 63 61 74 65 20 74 68 61 |to.Xallo|cate tha|
|00001960| 74 20 6d 75 63 68 20 6d | 65 6d 6f 72 79 2c 0a 58 |t much m|emory,.X|
|00001970| 2e 42 20 6f 70 65 6e 5f | 74 65 78 74 0a 58 72 65 |.B open_|text.Xre|
|00001980| 74 75 72 6e 73 0a 58 2e | 42 52 20 4e 55 4c 4c 20 |turns.X.|BR NULL |
|00001990| 2e 0a 58 54 68 65 20 70 | 6f 69 6e 74 65 72 20 72 |..XThe p|ointer r|
|000019a0| 65 74 75 72 6e 65 64 20 | 69 73 20 69 6e 76 61 6c |eturned |is inval|
|000019b0| 69 64 61 74 65 64 20 61 | 66 74 65 72 20 61 6e 79 |idated a|fter any|
|000019c0| 20 66 75 72 74 68 65 72 | 20 6f 70 65 72 61 74 69 | further| operati|
|000019d0| 6f 6e 73 20 6f 6e 20 74 | 68 65 0a 58 62 75 66 66 |ons on t|he.Xbuff|
|000019e0| 65 72 2e 0a 58 2e 50 50 | 0a 58 2e 42 20 43 6c 6f |er..X.PP|.X.B Clo|
|000019f0| 73 65 5f 74 65 78 74 0a | 58 63 6f 6d 70 6c 65 74 |se_text.|Xcomplet|
|00001a00| 65 73 20 74 68 65 20 74 | 72 61 6e 73 61 63 74 69 |es the t|ransacti|
|00001a10| 6f 6e 20 73 74 61 72 74 | 65 64 20 62 79 0a 58 2e |on start|ed by.X.|
|00001a20| 42 52 20 6f 70 65 6e 5f | 74 65 78 74 20 2e 0a 58 |BR open_|text ..X|
|00001a30| 4c 65 6e 67 74 68 20 73 | 68 6f 75 6c 64 20 69 6e |Length s|hould in|
|00001a40| 64 69 63 61 74 65 20 74 | 68 65 20 6e 75 6d 62 65 |dicate t|he numbe|
|00001a50| 72 20 6f 66 20 63 68 61 | 72 61 63 74 65 72 73 20 |r of cha|racters |
|00001a60| 63 6f 70 69 65 64 20 69 | 6e 74 6f 20 74 68 65 0a |copied i|nto the.|
|00001a70| 58 6d 65 6d 6f 72 79 20 | 72 65 74 75 72 6e 65 64 |Xmemory |returned|
|00001a80| 20 66 72 6f 6d 0a 58 2e | 42 52 20 6f 70 65 6e 5f | from.X.|BR open_|
|00001a90| 74 65 78 74 20 2c 0a 58 | 61 6e 64 20 74 68 61 74 |text ,.X|and that|
|00001aa0| 20 6d 61 6e 79 20 63 68 | 61 72 61 63 74 65 72 73 | many ch|aracters|
|00001ab0| 20 77 69 6c 6c 20 62 65 | 20 69 6e 63 6f 72 70 6f | will be| incorpo|
|00001ac0| 72 61 74 65 64 20 69 6e | 20 74 68 65 20 62 75 66 |rated in| the buf|
|00001ad0| 66 65 72 2e 0a 58 2e 50 | 50 0a 58 46 6f 72 20 65 |fer..X.P|P.XFor e|
|00001ae0| 78 61 6d 70 6c 65 2c 20 | 74 6f 20 61 70 70 65 6e |xample, |to appen|
|00001af0| 64 20 74 68 65 20 77 6f | 72 64 20 22 48 65 6c 6c |d the wo|rd "Hell|
|00001b00| 6f 22 20 74 6f 20 61 20 | 62 75 66 66 65 72 2c 20 |o" to a |buffer, |
|00001b10| 79 6f 75 20 63 61 6e 20 | 70 65 72 66 6f 72 6d 20 |you can |perform |
|00001b20| 74 68 65 0a 58 66 6f 6c | 6c 6f 77 69 6e 67 20 6f |the.Xfol|lowing o|
|00001b30| 70 65 72 61 74 69 6f 6e | 73 3a 0a 58 2e 50 50 0a |peration|s:.X.PP.|
|00001b40| 58 2e 52 53 0a 58 2e 6e | 66 0a 58 69 66 28 70 74 |X.RS.X.n|f.Xif(pt|
|00001b50| 72 20 3d 20 6f 70 65 6e | 5f 74 65 78 74 28 62 75 |r = open|_text(bu|
|00001b60| 66 66 65 72 2c 20 4d 41 | 52 4b 5f 45 4e 44 2c 20 |ffer, MA|RK_END, |
|00001b70| 35 29 29 20 7b 0a 58 09 | 73 74 72 6e 63 70 79 28 |5)) {.X.|strncpy(|
|00001b80| 70 74 72 2c 20 22 48 65 | 6c 6c 6f 22 2c 20 35 29 |ptr, "He|llo", 5)|
|00001b90| 3b 0a 58 09 63 6c 6f 73 | 65 5f 74 65 78 74 28 62 |;.X.clos|e_text(b|
|00001ba0| 75 66 66 65 72 2c 20 35 | 29 3b 0a 58 7d 0a 58 2e |uffer, 5|);.X}.X.|
|00001bb0| 66 69 0a 58 2e 52 45 0a | 58 2e 50 50 0a 58 4e 6f |fi.X.RE.|X.PP.XNo|
|00001bc0| 74 65 20 74 68 61 74 20 | 73 69 6e 63 65 20 61 20 |te that |since a |
|00001bd0| 6d 61 72 6b 20 69 73 20 | 63 6f 6e 73 69 64 65 72 |mark is |consider|
|00001be0| 65 64 20 74 6f 20 68 61 | 76 65 20 61 6e 20 61 66 |ed to ha|ve an af|
|00001bf0| 66 69 6e 69 74 79 20 66 | 6f 72 20 66 6f 6c 6c 6f |finity f|or follo|
|00001c00| 77 69 6e 67 0a 58 74 65 | 78 74 2c 20 74 68 65 20 |wing.Xte|xt, the |
|00001c10| 5c 66 42 4d 41 52 4b 5c | 66 52 20 70 61 73 73 65 |\fBMARK\|fR passe|
|00001c20| 64 20 74 6f 20 5c 66 42 | 6f 70 65 6e 5f 74 65 78 |d to \fB|open_tex|
|00001c30| 74 5c 66 52 0a 58 28 75 | 6e 6c 65 73 73 20 69 74 |t\fR.X(u|nless it|
|00001c40| 20 77 61 73 20 4d 41 52 | 4b 5f 42 45 47 49 4e 29 | was MAR|K_BEGIN)|
|00001c50| 20 77 69 6c 6c 20 66 6f | 6c 6c 6f 77 20 74 68 65 | will fo|llow the|
|00001c60| 20 6e 65 77 6c 79 2d 69 | 6e 73 65 72 74 65 64 20 | newly-i|nserted |
|00001c70| 74 65 78 74 2e 0a 58 2e | 50 50 0a 58 2e 42 20 44 |text..X.|PP.X.B D|
|00001c80| 65 6c 65 74 65 5f 74 65 | 78 74 0a 58 73 69 6d 70 |elete_te|xt.Xsimp|
|00001c90| 6c 79 20 64 65 6c 65 74 | 65 73 20 74 68 65 20 74 |ly delet|es the t|
|00001ca0| 65 78 74 20 62 65 74 77 | 65 65 6e 20 74 68 65 20 |ext betw|een the |
|00001cb0| 74 77 6f 20 5c 66 42 4d | 41 52 4b 5c 66 52 73 20 |two \fBM|ARK\fRs |
|00001cc0| 66 72 6f 6d 20 74 68 65 | 20 62 75 66 66 65 72 2e |from the| buffer.|
|00001cd0| 0a 58 54 68 65 20 66 69 | 72 73 74 20 6f 66 20 74 |.XThe fi|rst of t|
|00001ce0| 68 65 20 74 77 6f 20 6d | 61 72 6b 73 20 69 73 20 |he two m|arks is |
|00001cf0| 61 6c 73 6f 20 64 65 6c | 65 74 65 64 20 28 61 67 |also del|eted (ag|
|00001d00| 61 69 6e 2c 20 61 20 6d | 61 72 6b 20 69 73 20 63 |ain, a m|ark is c|
|00001d10| 6f 6e 73 69 64 65 72 65 | 64 0a 58 74 6f 20 62 65 |onsidere|d.Xto be|
|00001d20| 20 61 74 74 61 63 68 65 | 64 20 74 6f 20 74 68 65 | attache|d to the|
|00001d30| 20 66 6f 6c 6c 6f 77 69 | 6e 67 20 74 65 78 74 29 | followi|ng text)|
|00001d40| 2e 0a 58 2e 53 53 20 22 | 43 6f 6e 76 65 6e 69 65 |..X.SS "|Convenie|
|00001d50| 6e 63 65 20 72 6f 75 74 | 69 6e 65 73 20 61 6e 64 |nce rout|ines and|
|00001d60| 20 6f 70 74 69 6d 69 7a | 61 74 69 6f 6e 73 22 0a | optimiz|ations".|
|00001d70| 58 5c 66 49 6d 61 72 6b | 5c 66 52 20 3d 20 5c 66 |X\fImark|\fR = \f|
|00001d80| 42 6e 65 77 5f 6d 61 72 | 6b 5c 66 52 28 5c 66 49 |Bnew_mar|k\fR(\fI|
|00001d90| 62 75 66 66 65 72 5c 66 | 52 2c 20 5c 66 49 6f 66 |buffer\f|R, \fIof|
|00001da0| 66 5c 66 52 29 3b 0a 58 | 2e 62 72 0a 58 5c 66 49 |f\fR);.X|.br.X\fI|
|00001db0| 63 6e 74 5c 66 52 20 3d | 20 5c 66 42 63 6f 75 6e |cnt\fR =| \fBcoun|
|00001dc0| 74 5f 63 68 61 72 73 5c | 66 52 28 5c 66 49 62 75 |t_chars\|fR(\fIbu|
|00001dd0| 66 66 65 72 5c 66 52 2c | 20 5c 66 49 6d 61 72 6b |ffer\fR,| \fImark|
|00001de0| 31 5c 66 52 2c 20 5c 66 | 49 6d 61 72 6b 32 5c 66 |1\fR, \f|Imark2\f|
|00001df0| 52 2c 20 5c 66 49 63 5c | 66 52 29 3b 0a 58 2e 62 |R, \fIc\|fR);.X.b|
|00001e00| 72 0a 58 5c 66 49 73 74 | 61 74 5c 66 52 20 3d 20 |r.X\fIst|at\fR = |
|00001e10| 5c 66 42 63 6f 70 79 5f | 74 65 78 74 5c 66 52 28 |\fBcopy_|text\fR(|
|00001e20| 5c 66 49 62 75 66 66 65 | 72 5c 66 52 2c 0a 58 5c |\fIbuffe|r\fR,.X\|
|00001e30| 66 49 6d 61 72 6b 31 5c | 66 52 2c 20 5c 66 49 6d |fImark1\|fR, \fIm|
|00001e40| 61 72 6b 32 5c 66 52 2c | 20 5c 66 49 73 74 72 69 |ark2\fR,| \fIstri|
|00001e50| 6e 67 5c 66 52 2c 20 5c | 66 49 6c 65 6e 67 74 68 |ng\fR, \|fIlength|
|00001e60| 5c 66 52 29 3b 0a 58 2e | 62 72 0a 58 5c 66 49 73 |\fR);.X.|br.X\fIs|
|00001e70| 74 61 74 5c 66 52 20 3d | 20 5c 66 42 63 75 74 5f |tat\fR =| \fBcut_|
|00001e80| 74 65 78 74 5c 66 52 28 | 5c 66 49 62 75 66 66 65 |text\fR(|\fIbuffe|
|00001e90| 72 5c 66 52 2c 0a 58 5c | 66 49 6d 61 72 6b 31 5c |r\fR,.X\|fImark1\|
|00001ea0| 66 52 2c 20 5c 66 49 6d | 61 72 6b 32 5c 66 52 2c |fR, \fIm|ark2\fR,|
|00001eb0| 20 5c 66 49 73 74 72 69 | 6e 67 5c 66 52 2c 20 5c | \fIstri|ng\fR, \|
|00001ec0| 66 49 6c 65 6e 67 74 68 | 5c 66 52 29 3b 0a 58 2e |fIlength|\fR);.X.|
|00001ed0| 62 72 0a 58 5c 66 49 73 | 74 61 74 5c 66 52 20 3d |br.X\fIs|tat\fR =|
|00001ee0| 20 5c 66 42 69 6e 73 65 | 72 74 5f 74 65 78 74 5c | \fBinse|rt_text\|
|00001ef0| 66 52 28 5c 66 49 62 75 | 66 66 65 72 5c 66 52 2c |fR(\fIbu|ffer\fR,|
|00001f00| 0a 58 5c 66 49 6d 61 72 | 6b 5c 66 52 2c 20 5c 66 |.X\fImar|k\fR, \f|
|00001f10| 49 73 74 72 69 6e 67 5c | 66 52 2c 20 5c 66 49 6c |Istring\|fR, \fIl|
|00001f20| 65 6e 67 74 68 5c 66 52 | 29 3b 0a 58 2e 50 50 0a |ength\fR|);.X.PP.|
|00001f30| 58 2e 42 20 4e 65 77 5f | 6d 61 72 6b 0a 58 69 73 |X.B New_|mark.Xis|
|00001f40| 20 65 71 75 69 76 61 6c | 65 6e 74 20 74 6f 20 63 | equival|ent to c|
|00001f50| 61 6c 6c 69 6e 67 0a 58 | 2e 42 20 63 6f 70 79 5f |alling.X|.B copy_|
|00001f60| 6d 61 72 6b 0a 58 6f 6e | 0a 58 2e 42 52 20 4d 41 |mark.Xon|.X.BR MA|
|00001f70| 52 4b 5f 42 45 47 49 4e | 20 2e 0a 58 2e 50 50 0a |RK_BEGIN| ..X.PP.|
|00001f80| 58 2e 42 20 43 6f 75 6e | 74 5f 63 68 61 72 73 0a |X.B Coun|t_chars.|
|00001f90| 58 69 73 20 69 6e 74 65 | 6e 64 65 64 20 74 6f 20 |Xis inte|nded to |
|00001fa0| 6d 61 6b 65 20 6c 69 6e | 65 2d 6f 72 69 6e 74 65 |make lin|e-orinte|
|00001fb0| 64 20 6d 61 6e 69 70 75 | 6c 61 74 69 6f 6e 73 20 |d manipu|lations |
|00001fc0| 65 61 73 69 65 72 2e 20 | 53 69 6d 70 6c 79 20 63 |easier. |Simply c|
|00001fd0| 6f 75 6e 74 20 6e 65 77 | 6c 69 6e 65 73 0a 58 62 |ount new|lines.Xb|
|00001fe0| 65 74 77 65 65 6e 20 5c | 66 42 4d 41 52 4b 5f 42 |etween \|fBMARK_B|
|00001ff0| 45 47 49 4e 5c 66 52 20 | 61 6e 64 20 74 68 65 20 |EGIN\fR |and the |
|00002000| 63 75 72 72 65 6e 74 20 | 5c 66 42 4d 41 52 4b 5c |current |\fBMARK\|
|00002010| 66 52 20 74 6f 20 66 69 | 6e 64 20 79 6f 75 72 20 |fR to fi|nd your |
|00002020| 63 75 72 72 65 6e 74 0a | 58 6c 69 6e 65 20 6e 75 |current.|Xline nu|
|00002030| 6d 62 65 72 2e 0a 58 2e | 50 50 0a 58 2e 42 20 43 |mber..X.|PP.X.B C|
|00002040| 6f 70 79 5f 74 65 78 74 | 0a 58 69 73 20 65 71 75 |opy_text|.Xis equ|
|00002050| 69 76 61 6c 65 6e 74 20 | 74 6f 20 63 61 6c 6c 69 |ivalent |to calli|
|00002060| 6e 67 0a 58 2e 42 20 74 | 65 78 74 0a 58 61 6e 64 |ng.X.B t|ext.Xand|
|00002070| 20 63 6f 70 79 69 6e 67 | 20 74 68 65 20 72 65 74 | copying| the ret|
|00002080| 75 72 6e 65 64 20 74 65 | 78 74 20 74 6f 20 61 20 |urned te|xt to a |
|00002090| 6e 65 77 20 73 74 72 69 | 6e 67 2e 0a 58 2e 42 20 |new stri|ng..X.B |
|000020a0| 43 75 74 5f 74 65 78 74 | 0a 58 69 73 20 65 71 75 |Cut_text|.Xis equ|
|000020b0| 69 76 61 6c 65 6e 74 20 | 74 6f 20 63 61 6c 6c 69 |ivalent |to calli|
|000020c0| 6e 67 0a 58 2e 42 20 63 | 6f 70 79 5f 74 65 78 74 |ng.X.B c|opy_text|
|000020d0| 0a 58 66 6f 6c 6c 6f 77 | 65 64 20 62 79 0a 58 2e |.Xfollow|ed by.X.|
|000020e0| 42 52 20 64 65 6c 65 74 | 65 5f 74 65 78 74 20 2e |BR delet|e_text .|
|000020f0| 0a 58 2e 42 20 49 6e 73 | 65 72 74 5f 74 65 78 74 |.X.B Ins|ert_text|
|00002100| 0a 58 69 73 20 65 71 75 | 69 76 61 6c 65 6e 74 20 |.Xis equ|ivalent |
|00002110| 74 6f 20 74 68 65 20 69 | 6e 73 65 72 74 69 6f 6e |to the i|nsertion|
|00002120| 20 73 65 71 75 65 6e 63 | 65 20 6c 69 73 74 65 64 | sequenc|e listed|
|00002130| 20 61 62 6f 76 65 2e 0a | 58 2e 53 53 20 4e 6f 74 | above..|X.SS Not|
|00002140| 65 73 0a 58 4e 6f 6e 65 | 20 6f 66 20 74 68 65 73 |es.XNone| of thes|
|00002150| 65 20 72 6f 75 74 69 6e | 65 73 20 70 72 65 63 6c |e routin|es precl|
|00002160| 75 64 65 20 61 20 64 69 | 73 6b 20 62 75 66 66 65 |ude a di|sk buffe|
|00002170| 72 20 6f 72 20 61 20 6c | 69 6e 65 20 62 75 66 66 |r or a l|ine buff|
|00002180| 65 72 0a 58 69 6d 70 6c | 65 6d 65 6e 74 61 74 69 |er.Ximpl|ementati|
|00002190| 6f 6e 73 2c 20 61 6e 64 | 20 61 67 61 69 6e 20 74 |ons, and| again t|
|000021a0| 68 65 79 20 61 6c 6c 6f | 77 20 65 64 69 74 69 6e |hey allo|w editin|
|000021b0| 67 20 6f 66 20 61 72 62 | 69 74 72 61 72 79 20 38 |g of arb|itrary 8|
|000021c0| 2d 62 69 74 20 64 61 74 | 61 0a 58 69 6e 63 6c 75 |-bit dat|a.Xinclu|
|000021d0| 64 69 6e 67 20 6e 75 6c | 6c 73 2e 0a 58 2e 50 50 |ding nul|ls..X.PP|
|000021e0| 0a 58 49 6e 20 74 68 65 | 20 62 75 66 66 65 72 2d |.XIn the| buffer-|
|000021f0| 67 61 70 20 69 6d 70 6c | 65 6d 65 6e 74 61 74 69 |gap impl|ementati|
|00002200| 6f 6e 2c 20 74 68 65 20 | 67 61 70 20 77 69 6c 6c |on, the |gap will|
|00002210| 20 62 65 20 6d 6f 76 65 | 64 20 69 66 20 6e 65 65 | be move|d if nee|
|00002220| 64 65 64 20 62 65 66 6f | 72 65 0a 58 64 6f 69 6e |ded befo|re.Xdoin|
|00002230| 67 20 61 20 73 65 61 72 | 63 68 2c 20 63 75 74 2c |g a sear|ch, cut,|
|00002240| 20 63 6f 70 79 2c 20 65 | 74 63 65 74 65 72 61 2e | copy, e|tcetera.|
|00002250| 0a 58 2e 50 50 0a 58 4f | 74 68 65 72 20 6f 70 74 |.X.PP.XO|ther opt|
|00002260| 69 6d 69 7a 61 74 69 6f | 6e 73 20 74 68 61 74 20 |imizatio|ns that |
|00002270| 68 61 76 65 6e 27 74 20 | 62 65 65 6e 20 69 6d 70 |haven't |been imp|
|00002280| 6c 65 6d 65 6e 74 65 64 | 20 69 6e 20 74 68 65 20 |lemented| in the |
|00002290| 6c 69 62 72 61 72 79 20 | 61 72 65 0a 58 2e 42 20 |library |are.X.B |
|000022a0| 69 6e 73 65 72 74 5f 66 | 69 6c 65 0a 58 61 6e 64 |insert_f|ile.Xand|
|000022b0| 0a 58 2e 42 52 20 63 6f | 70 79 5f 66 69 6c 65 20 |.X.BR co|py_file |
|000022c0| 2e 0a 58 48 65 72 65 20 | 69 73 20 61 20 73 61 6d |..XHere |is a sam|
|000022d0| 70 6c 65 20 69 6d 70 6c | 65 6d 65 6e 74 61 74 69 |ple impl|ementati|
|000022e0| 6f 6e 2c 20 66 6f 72 20 | 61 20 62 75 66 66 65 72 |on, for |a buffer|
|000022f0| 20 67 61 70 20 76 65 72 | 73 69 6f 6e 20 6f 66 20 | gap ver|sion of |
|00002300| 74 68 65 20 6c 69 62 72 | 61 72 79 2e 0a 58 2e 50 |the libr|ary..X.P|
|00002310| 50 0a 58 2e 52 53 0a 58 | 2e 6e 66 0a 58 69 6e 73 |P.X.RS.X|.nf.Xins|
|00002320| 65 72 74 5f 66 69 6c 65 | 28 69 2c 20 6d 61 72 6b |ert_file|(i, mark|
|00002330| 2c 20 66 70 2c 20 6c 65 | 6e 67 74 68 29 0a 58 69 |, fp, le|ngth).Xi|
|00002340| 6e 74 20 69 3b 0a 58 69 | 6e 74 20 6d 61 72 6b 3b |nt i;.Xi|nt mark;|
|00002350| 0a 58 46 49 4c 45 20 2a | 66 70 3b 0a 58 69 6e 74 |.XFILE *|fp;.Xint|
|00002360| 20 6c 65 6e 67 74 68 3b | 0a 58 7b 0a 58 09 63 68 | length;|.X{.X.ch|
|00002370| 61 72 20 2a 70 3b 0a 58 | 0a 58 09 70 20 3d 20 6f |ar *p;.X|.X.p = o|
|00002380| 70 65 6e 5f 74 65 78 74 | 28 69 2c 20 6d 61 72 6b |pen_text|(i, mark|
|00002390| 2c 20 6c 65 6e 67 74 68 | 29 3b 0a 58 09 69 66 28 |, length|);.X.if(|
|000023a0| 21 70 29 20 72 65 74 75 | 72 6e 20 2d 31 3b 0a 58 |!p) retu|rn -1;.X|
|000023b0| 0a 58 09 6c 65 6e 67 74 | 68 20 3d 20 66 72 65 61 |.X.lengt|h = frea|
|000023c0| 64 28 70 2c 20 31 2c 20 | 6c 65 6e 67 74 68 2c 20 |d(p, 1, |length, |
|000023d0| 66 70 29 3b 0a 58 09 69 | 66 28 6c 65 6e 67 74 68 |fp);.X.i|f(length|
|000023e0| 20 3c 20 30 29 20 7b 0a | 58 09 09 65 78 74 65 72 | < 0) {.|X..exter|
|000023f0| 6e 20 69 6e 74 20 65 72 | 72 6e 6f 3b 0a 58 09 09 |n int er|rno;.X..|
|00002400| 65 78 74 65 72 6e 20 63 | 68 61 72 20 2a 73 79 73 |extern c|har *sys|
|00002410| 5f 65 72 72 6c 69 73 74 | 5b 5d 3b 0a 58 0a 58 09 |_errlist|[];.X.X.|
|00002420| 09 62 75 66 66 65 72 5f | 65 72 72 6f 72 20 3d 20 |.buffer_|error = |
|00002430| 73 79 73 5f 65 72 72 6c | 69 73 74 5b 65 72 72 6e |sys_errl|ist[errn|
|00002440| 6f 5d 3b 0a 58 09 09 72 | 65 74 75 72 6e 20 2d 31 |o];.X..r|eturn -1|
|00002450| 3b 0a 58 09 7d 0a 58 0a | 58 09 63 6c 6f 73 65 5f |;.X.}.X.|X.close_|
|00002460| 74 65 78 74 28 69 2c 20 | 6c 65 6e 67 74 68 29 3b |text(i, |length);|
|00002470| 0a 58 0a 58 09 72 65 74 | 75 72 6e 20 6c 65 6e 67 |.X.X.ret|urn leng|
|00002480| 74 68 3b 0a 58 7d 0a 58 | 0a 58 63 6f 70 79 5f 66 |th;.X}.X|.Xcopy_f|
|00002490| 69 6c 65 28 69 2c 20 6d | 31 2c 20 6d 32 2c 20 66 |ile(i, m|1, m2, f|
|000024a0| 70 29 0a 58 69 6e 74 20 | 69 3b 0a 58 69 6e 74 20 |p).Xint |i;.Xint |
|000024b0| 6d 31 2c 20 6d 32 3b 0a | 58 46 49 4c 45 20 2a 66 |m1, m2;.|XFILE *f|
|000024c0| 70 3b 0a 58 7b 0a 58 09 | 63 68 61 72 20 2a 70 3b |p;.X{.X.|char *p;|
|000024d0| 0a 58 09 69 6e 74 20 64 | 65 6c 74 61 3b 0a 58 0a |.X.int d|elta;.X.|
|000024e0| 58 09 70 20 3d 20 74 65 | 78 74 28 69 2c 20 6d 31 |X.p = te|xt(i, m1|
|000024f0| 2c 20 6d 32 2c 20 26 64 | 65 6c 74 61 29 3b 0a 58 |, m2, &d|elta);.X|
|00002500| 0a 58 09 69 66 28 21 70 | 29 20 72 65 74 75 72 6e |.X.if(!p|) return|
|00002510| 20 2d 31 3b 0a 58 0a 58 | 09 64 65 6c 74 61 20 3d | -1;.X.X|.delta =|
|00002520| 20 66 77 72 69 74 65 28 | 70 2c 20 31 2c 20 64 65 | fwrite(|p, 1, de|
|00002530| 6c 74 61 2c 20 66 70 29 | 3b 0a 58 09 69 66 28 64 |lta, fp)|;.X.if(d|
|00002540| 65 6c 74 61 20 3c 20 30 | 29 20 7b 0a 58 09 09 65 |elta < 0|) {.X..e|
|00002550| 78 74 65 72 6e 20 69 6e | 74 20 65 72 72 6e 6f 3b |xtern in|t errno;|
|00002560| 0a 58 09 09 65 78 74 65 | 72 6e 20 63 68 61 72 20 |.X..exte|rn char |
|00002570| 2a 73 79 73 5f 65 72 72 | 6c 69 73 74 5b 5d 3b 0a |*sys_err|list[];.|
|00002580| 58 0a 58 09 09 62 75 66 | 66 65 72 5f 65 72 72 6f |X.X..buf|fer_erro|
|00002590| 72 20 3d 20 73 79 73 5f | 65 72 72 6c 69 73 74 5b |r = sys_|errlist[|
|000025a0| 65 72 72 6e 6f 5d 3b 0a | 58 09 09 72 65 74 75 72 |errno];.|X..retur|
|000025b0| 6e 20 2d 31 3b 0a 58 09 | 7d 0a 58 0a 58 09 72 65 |n -1;.X.|}.X.X.re|
|000025c0| 74 75 72 6e 20 64 65 6c | 74 61 3b 0a 58 7d 0a 58 |turn del|ta;.X}.X|
|000025d0| 2e 66 69 0a 58 2e 52 45 | 0a 58 2e 50 50 0a 58 4e |.fi.X.RE|.X.PP.XN|
|000025e0| 6f 74 65 20 74 68 61 74 | 20 74 68 65 20 65 72 72 |ote that| the err|
|000025f0| 6f 72 20 70 61 74 68 20 | 74 68 72 6f 75 67 68 20 |or path |through |
|00002600| 5c 66 42 69 6e 73 65 72 | 74 5f 66 69 6c 65 5c 66 |\fBinser|t_file\f|
|00002610| 52 0a 58 63 61 6c 6c 73 | 20 5c 66 42 6f 70 65 6e |R.Xcalls| \fBopen|
|00002620| 5f 74 65 78 74 5c 66 52 | 20 62 75 74 20 6e 6f 74 |_text\fR| but not|
|00002630| 20 5c 66 42 63 6c 6f 73 | 65 5f 74 65 78 74 5c 66 | \fBclos|e_text\f|
|00002640| 52 2e 0a 58 2e 53 48 20 | 44 49 41 47 4e 4f 53 54 |R..X.SH |DIAGNOST|
|00002650| 49 43 53 0a 58 49 6e 20 | 61 6c 6c 20 63 61 73 65 |ICS.XIn |all case|
|00002660| 73 20 6f 66 20 65 72 72 | 6f 72 2c 20 74 68 65 20 |s of err|or, the |
|00002670| 76 61 6c 75 65 0a 58 2e | 42 20 42 55 46 46 45 52 |value.X.|B BUFFER|
|00002680| 5f 45 52 52 4f 52 0a 58 | 69 73 20 72 65 74 75 72 |_ERROR.X|is retur|
|00002690| 6e 65 64 2c 20 61 6e 64 | 20 74 68 65 20 65 78 74 |ned, and| the ext|
|000026a0| 65 72 6e 61 6c 20 76 61 | 72 69 61 62 6c 65 0a 58 |ernal va|riable.X|
|000026b0| 2e 42 20 62 75 66 66 65 | 72 5f 65 72 72 6f 72 0a |.B buffe|r_error.|
|000026c0| 58 63 6f 6e 74 61 69 6e | 73 20 74 68 65 20 6c 61 |Xcontain|s the la|
|000026d0| 73 74 20 65 72 72 6f 72 | 20 63 6f 6e 64 69 74 69 |st error| conditi|
|000026e0| 6f 6e 2e 0a 58 2e 53 48 | 20 41 55 54 48 4f 52 0a |on..X.SH| AUTHOR.|
|000026f0| 58 50 65 74 65 72 20 64 | 61 20 53 69 6c 76 61 0a |XPeter d|a Silva.|
|00002700| 45 4e 44 5f 4f 46 5f 46 | 49 4c 45 0a 69 66 20 74 |END_OF_F|ILE.if t|
|00002710| 65 73 74 20 38 31 35 30 | 20 2d 6e 65 20 60 77 63 |est 8150| -ne `wc|
|00002720| 20 2d 63 20 3c 27 62 75 | 66 66 65 72 2e 31 27 60 | -c <'bu|ffer.1'`|
|00002730| 3b 20 74 68 65 6e 0a 20 | 20 20 20 65 63 68 6f 20 |; then. | echo |
|00002740| 73 68 61 72 3a 20 5c 22 | 27 62 75 66 66 65 72 2e |shar: \"|'buffer.|
|00002750| 31 27 5c 22 20 75 6e 70 | 61 63 6b 65 64 20 77 69 |1'\" unp|acked wi|
|00002760| 74 68 20 77 72 6f 6e 67 | 20 73 69 7a 65 21 0a 66 |th wrong| size!.f|
|00002770| 69 0a 23 20 65 6e 64 20 | 6f 66 20 27 62 75 66 66 |i.# end |of 'buff|
|00002780| 65 72 2e 31 27 0a 66 69 | 0a 69 66 20 74 65 73 74 |er.1'.fi|.if test|
|00002790| 20 2d 66 20 27 4d 61 6b | 65 66 69 6c 65 27 20 2d | -f 'Mak|efile' -|
|000027a0| 61 20 22 24 7b 31 7d 22 | 20 21 3d 20 22 2d 63 22 |a "${1}"| != "-c"|
|000027b0| 20 3b 20 74 68 65 6e 20 | 0a 20 20 65 63 68 6f 20 | ; then |. echo |
|000027c0| 73 68 61 72 3a 20 57 69 | 6c 6c 20 6e 6f 74 20 63 |shar: Wi|ll not c|
|000027d0| 6c 6f 62 62 65 72 20 65 | 78 69 73 74 69 6e 67 20 |lobber e|xisting |
|000027e0| 66 69 6c 65 20 5c 22 27 | 4d 61 6b 65 66 69 6c 65 |file \"'|Makefile|
|000027f0| 27 5c 22 0a 65 6c 73 65 | 0a 65 63 68 6f 20 73 68 |'\".else|.echo sh|
|00002800| 61 72 3a 20 45 78 74 72 | 61 63 74 69 6e 67 20 5c |ar: Extr|acting \|
|00002810| 22 27 4d 61 6b 65 66 69 | 6c 65 27 5c 22 20 5c 28 |"'Makefi|le'\" \(|
|00002820| 34 37 31 20 63 68 61 72 | 61 63 74 65 72 73 5c 29 |471 char|acters\)|
|00002830| 0a 73 65 64 20 22 73 2f | 5e 58 2f 2f 22 20 3e 27 |.sed "s/|^X//" >'|
|00002840| 4d 61 6b 65 66 69 6c 65 | 27 20 3c 3c 27 45 4e 44 |Makefile|' <<'END|
|00002850| 5f 4f 46 5f 46 49 4c 45 | 27 0a 58 53 48 45 4c 4c |_OF_FILE|'.XSHELL|
|00002860| 3d 2f 62 69 6e 2f 73 68 | 0a 58 23 58 4e 58 23 20 |=/bin/sh|.X#XNX# |
|00002870| 43 46 4c 41 47 53 3d 2d | 4d 6c 20 2d 4f 20 20 2d |CFLAGS=-|Ml -O -|
|00002880| 44 54 45 53 54 0a 58 43 | 46 4c 41 47 53 3d 2d 67 |DTEST.XC|FLAGS=-g|
|00002890| 20 2d 4f 20 2d 44 54 45 | 53 54 0a 58 54 46 49 4c | -O -DTE|ST.XTFIL|
|000028a0| 45 53 3d 62 75 66 66 65 | 72 2e 31 20 4d 61 6b 65 |ES=buffe|r.1 Make|
|000028b0| 66 69 6c 65 0a 58 43 46 | 49 4c 45 53 3d 62 75 66 |file.XCF|ILES=buf|
|000028c0| 66 65 72 2e 63 20 62 74 | 2e 63 20 62 6f 79 65 72 |fer.c bt|.c boyer|
|000028d0| 6d 6f 6f 2e 63 0a 58 48 | 46 49 4c 45 53 3d 62 75 |moo.c.XH|FILES=bu|
|000028e0| 66 66 65 72 2e 68 0a 58 | 4f 46 49 4c 45 53 3d 62 |ffer.h.X|OFILES=b|
|000028f0| 75 66 66 65 72 2e 6f 20 | 62 6f 79 65 72 6d 6f 6f |uffer.o |boyermoo|
|00002900| 2e 6f 0a 58 53 46 49 4c | 45 53 3d 24 28 48 46 49 |.o.XSFIL|ES=$(HFI|
|00002910| 4c 45 53 29 20 24 28 43 | 46 49 4c 45 53 29 0a 58 |LES) $(C|FILES).X|
|00002920| 50 46 49 4c 45 53 3d 4d | 61 6b 65 66 69 6c 65 0a |PFILES=M|akefile.|
|00002930| 58 4e 46 49 4c 45 53 3d | 62 75 66 66 65 72 2e 31 |XNFILES=|buffer.1|
|00002940| 0a 58 0a 58 62 74 3a 20 | 62 74 2e 6f 20 24 28 4f |.X.Xbt: |bt.o $(O|
|00002950| 46 49 4c 45 53 29 0a 58 | 09 24 28 43 43 29 20 24 |FILES).X|.$(CC) $|
|00002960| 28 43 46 4c 41 47 53 29 | 20 62 74 2e 6f 20 24 28 |(CFLAGS)| bt.o $(|
|00002970| 4f 46 49 4c 45 53 29 20 | 2d 6f 20 62 74 0a 58 0a |OFILES) |-o bt.X.|
|00002980| 58 62 74 2e 6f 75 74 3a | 20 62 74 0a 58 09 62 74 |Xbt.out:| bt.X.bt|
|00002990| 20 3e 20 62 74 2e 6f 75 | 74 20 32 3e 26 31 0a 58 | > bt.ou|t 2>&1.X|
|000029a0| 0a 58 74 65 73 74 70 72 | 69 6e 74 3a 20 62 74 2e |.Xtestpr|int: bt.|
|000029b0| 6f 75 74 0a 58 09 28 63 | 70 72 20 2d 72 30 20 24 |out.X.(c|pr -r0 $|
|000029c0| 28 54 46 49 4c 45 53 29 | 20 24 28 53 46 49 4c 45 |(TFILES)| $(SFILE|
|000029d0| 53 29 3b 20 70 72 20 62 | 74 2e 6f 75 74 3b 20 6e |S); pr b|t.out; n|
|000029e0| 72 6f 66 66 20 2d 6d 61 | 6e 20 62 75 66 66 65 72 |roff -ma|n buffer|
|000029f0| 2e 31 29 20 7c 20 6e 70 | 72 0a 58 0a 58 62 75 66 |.1) | np|r.X.Xbuf|
|00002a00| 66 65 72 2e 73 68 61 72 | 3a 20 24 28 54 46 49 4c |fer.shar|: $(TFIL|
|00002a10| 45 53 29 20 24 28 53 46 | 49 4c 45 53 29 0a 58 09 |ES) $(SF|ILES).X.|
|00002a20| 73 68 61 72 20 24 28 54 | 46 49 4c 45 53 29 20 24 |shar $(T|FILES) $|
|00002a30| 28 53 46 49 4c 45 53 29 | 20 3e 20 62 75 66 66 65 |(SFILES)| > buffe|
|00002a40| 72 2e 73 68 61 72 0a 45 | 4e 44 5f 4f 46 5f 46 49 |r.shar.E|ND_OF_FI|
|00002a50| 4c 45 0a 69 66 20 74 65 | 73 74 20 34 37 31 20 2d |LE.if te|st 471 -|
|00002a60| 6e 65 20 60 77 63 20 2d | 63 20 3c 27 4d 61 6b 65 |ne `wc -|c <'Make|
|00002a70| 66 69 6c 65 27 60 3b 20 | 74 68 65 6e 0a 20 20 20 |file'`; |then. |
|00002a80| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 5c 22 27 4d | echo sh|ar: \"'M|
|00002a90| 61 6b 65 66 69 6c 65 27 | 5c 22 20 75 6e 70 61 63 |akefile'|\" unpac|
|00002aa0| 6b 65 64 20 77 69 74 68 | 20 77 72 6f 6e 67 20 73 |ked with| wrong s|
|00002ab0| 69 7a 65 21 0a 66 69 0a | 23 20 65 6e 64 20 6f 66 |ize!.fi.|# end of|
|00002ac0| 20 27 4d 61 6b 65 66 69 | 6c 65 27 0a 66 69 0a 69 | 'Makefi|le'.fi.i|
|00002ad0| 66 20 74 65 73 74 20 2d | 66 20 27 62 75 66 66 65 |f test -|f 'buffe|
|00002ae0| 72 2e 68 27 20 2d 61 20 | 22 24 7b 31 7d 22 20 21 |r.h' -a |"${1}" !|
|00002af0| 3d 20 22 2d 63 22 20 3b | 20 74 68 65 6e 20 0a 20 |= "-c" ;| then . |
|00002b00| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 57 69 6c 6c | echo sh|ar: Will|
|00002b10| 20 6e 6f 74 20 63 6c 6f | 62 62 65 72 20 65 78 69 | not clo|bber exi|
|00002b20| 73 74 69 6e 67 20 66 69 | 6c 65 20 5c 22 27 62 75 |sting fi|le \"'bu|
|00002b30| 66 66 65 72 2e 68 27 5c | 22 0a 65 6c 73 65 0a 65 |ffer.h'\|".else.e|
|00002b40| 63 68 6f 20 73 68 61 72 | 3a 20 45 78 74 72 61 63 |cho shar|: Extrac|
|00002b50| 74 69 6e 67 20 5c 22 27 | 62 75 66 66 65 72 2e 68 |ting \"'|buffer.h|
|00002b60| 27 5c 22 20 5c 28 35 36 | 35 20 63 68 61 72 61 63 |'\" \(56|5 charac|
|00002b70| 74 65 72 73 5c 29 0a 73 | 65 64 20 22 73 2f 5e 58 |ters\).s|ed "s/^X|
|00002b80| 2f 2f 22 20 3e 27 62 75 | 66 66 65 72 2e 68 27 20 |//" >'bu|ffer.h' |
|00002b90| 3c 3c 27 45 4e 44 5f 4f | 46 5f 46 49 4c 45 27 0a |<<'END_O|F_FILE'.|
|00002ba0| 58 2f 2a 20 0a 58 20 2a | 20 43 6f 70 79 72 69 67 |X/* .X *| Copyrig|
|00002bb0| 68 74 20 31 39 39 32 20 | 50 65 74 65 72 20 64 61 |ht 1992 |Peter da|
|00002bc0| 20 53 69 6c 76 61 0a 58 | 20 2a 0a 58 20 2a 20 50 | Silva.X| *.X * P|
|00002bd0| 65 72 6d 69 73 73 69 6f | 6e 20 74 6f 20 75 73 65 |ermissio|n to use|
|00002be0| 2c 20 63 6f 70 79 2c 20 | 6d 6f 64 69 66 79 2c 20 |, copy, |modify, |
|00002bf0| 61 6e 64 20 64 69 73 74 | 72 69 62 75 74 65 20 74 |and dist|ribute t|
|00002c00| 68 69 73 0a 58 20 2a 20 | 73 6f 66 74 77 61 72 65 |his.X * |software|
|00002c10| 20 61 6e 64 20 69 74 73 | 20 64 6f 63 75 6d 65 6e | and its| documen|
|00002c20| 74 61 74 69 6f 6e 20 66 | 6f 72 20 61 6e 79 20 70 |tation f|or any p|
|00002c30| 75 72 70 6f 73 65 20 61 | 6e 64 20 77 69 74 68 6f |urpose a|nd witho|
|00002c40| 75 74 0a 58 20 2a 20 66 | 65 65 20 69 73 20 68 65 |ut.X * f|ee is he|
|00002c50| 72 65 62 79 20 67 72 61 | 6e 74 65 64 2c 20 70 72 |reby gra|nted, pr|
|00002c60| 6f 76 69 64 65 64 20 74 | 68 61 74 20 74 68 65 20 |ovided t|hat the |
|00002c70| 61 62 6f 76 65 20 63 6f | 70 79 72 69 67 68 74 0a |above co|pyright.|
|00002c80| 58 20 2a 20 6e 6f 74 69 | 63 65 20 61 70 70 65 61 |X * noti|ce appea|
|00002c90| 72 20 69 6e 20 61 6c 6c | 20 63 6f 70 69 65 73 2e |r in all| copies.|
|00002ca0| 20 20 54 68 65 20 61 75 | 74 68 6f 72 5b 73 5d 20 | The au|thor[s] |
|00002cb0| 6d 61 6b 65 20 6e 6f 20 | 72 65 70 72 65 73 65 6e |make no |represen|
|00002cc0| 74 61 74 69 6f 6e 73 0a | 58 20 2a 20 61 62 6f 75 |tations.|X * abou|
|00002cd0| 74 20 74 68 65 20 73 75 | 69 74 61 62 69 6c 69 74 |t the su|itabilit|
|00002ce0| 79 20 6f 66 20 74 68 69 | 73 20 73 6f 66 74 77 61 |y of thi|s softwa|
|00002cf0| 72 65 20 66 6f 72 20 61 | 6e 79 20 70 75 72 70 6f |re for a|ny purpo|
|00002d00| 73 65 2e 0a 58 20 2a 20 | 49 74 20 69 73 20 70 72 |se..X * |It is pr|
|00002d10| 6f 76 69 64 65 64 20 22 | 61 73 20 69 73 22 20 77 |ovided "|as is" w|
|00002d20| 69 74 68 6f 75 74 20 65 | 78 70 72 65 73 73 20 6f |ithout e|xpress o|
|00002d30| 72 20 69 6d 70 6c 69 65 | 64 20 77 61 72 72 61 6e |r implie|d warran|
|00002d40| 74 79 2e 0a 58 20 2a 2f | 0a 58 23 64 65 66 69 6e |ty..X */|.X#defin|
|00002d50| 65 20 42 55 46 46 45 52 | 20 69 6e 74 0a 58 23 64 |e BUFFER| int.X#d|
|00002d60| 65 66 69 6e 65 20 4d 41 | 52 4b 20 69 6e 74 0a 58 |efine MA|RK int.X|
|00002d70| 23 64 65 66 69 6e 65 20 | 52 41 4e 47 45 20 6c 6f |#define |RANGE lo|
|00002d80| 6e 67 0a 58 0a 58 23 64 | 65 66 69 6e 65 20 4d 41 |ng.X.X#d|efine MA|
|00002d90| 52 4b 5f 42 45 47 49 4e | 20 30 0a 58 23 64 65 66 |RK_BEGIN| 0.X#def|
|00002da0| 69 6e 65 20 4d 41 52 4b | 5f 45 4e 44 20 2d 31 0a |ine MARK|_END -1.|
|00002db0| 58 0a 58 23 64 65 66 69 | 6e 65 20 42 55 46 46 45 |X.X#defi|ne BUFFE|
|00002dc0| 52 5f 45 52 52 4f 52 20 | 2d 31 0a 58 0a 58 65 78 |R_ERROR |-1.X.Xex|
|00002dd0| 74 65 72 6e 20 63 68 61 | 72 20 2a 62 75 66 66 65 |tern cha|r *buffe|
|00002de0| 72 5f 65 72 72 6f 72 3b | 0a 45 4e 44 5f 4f 46 5f |r_error;|.END_OF_|
|00002df0| 46 49 4c 45 0a 69 66 20 | 74 65 73 74 20 35 36 35 |FILE.if |test 565|
|00002e00| 20 2d 6e 65 20 60 77 63 | 20 2d 63 20 3c 27 62 75 | -ne `wc| -c <'bu|
|00002e10| 66 66 65 72 2e 68 27 60 | 3b 20 74 68 65 6e 0a 20 |ffer.h'`|; then. |
|00002e20| 20 20 20 65 63 68 6f 20 | 73 68 61 72 3a 20 5c 22 | echo |shar: \"|
|00002e30| 27 62 75 66 66 65 72 2e | 68 27 5c 22 20 75 6e 70 |'buffer.|h'\" unp|
|00002e40| 61 63 6b 65 64 20 77 69 | 74 68 20 77 72 6f 6e 67 |acked wi|th wrong|
|00002e50| 20 73 69 7a 65 21 0a 66 | 69 0a 23 20 65 6e 64 20 | size!.f|i.# end |
|00002e60| 6f 66 20 27 62 75 66 66 | 65 72 2e 68 27 0a 66 69 |of 'buff|er.h'.fi|
|00002e70| 0a 69 66 20 74 65 73 74 | 20 2d 66 20 27 62 75 66 |.if test| -f 'buf|
|00002e80| 66 65 72 2e 63 27 20 2d | 61 20 22 24 7b 31 7d 22 |fer.c' -|a "${1}"|
|00002e90| 20 21 3d 20 22 2d 63 22 | 20 3b 20 74 68 65 6e 20 | != "-c"| ; then |
|00002ea0| 0a 20 20 65 63 68 6f 20 | 73 68 61 72 3a 20 57 69 |. echo |shar: Wi|
|00002eb0| 6c 6c 20 6e 6f 74 20 63 | 6c 6f 62 62 65 72 20 65 |ll not c|lobber e|
|00002ec0| 78 69 73 74 69 6e 67 20 | 66 69 6c 65 20 5c 22 27 |xisting |file \"'|
|00002ed0| 62 75 66 66 65 72 2e 63 | 27 5c 22 0a 65 6c 73 65 |buffer.c|'\".else|
|00002ee0| 0a 65 63 68 6f 20 73 68 | 61 72 3a 20 45 78 74 72 |.echo sh|ar: Extr|
|00002ef0| 61 63 74 69 6e 67 20 5c | 22 27 62 75 66 66 65 72 |acting \|"'buffer|
|00002f00| 2e 63 27 5c 22 20 5c 28 | 31 32 35 31 33 20 63 68 |.c'\" \(|12513 ch|
|00002f10| 61 72 61 63 74 65 72 73 | 5c 29 0a 73 65 64 20 22 |aracters|\).sed "|
|00002f20| 73 2f 5e 58 2f 2f 22 20 | 3e 27 62 75 66 66 65 72 |s/^X//" |>'buffer|
|00002f30| 2e 63 27 20 3c 3c 27 45 | 4e 44 5f 4f 46 5f 46 49 |.c' <<'E|ND_OF_FI|
|00002f40| 4c 45 27 0a 58 2f 2a 20 | 0a 58 20 2a 20 43 6f 70 |LE'.X/* |.X * Cop|
|00002f50| 79 72 69 67 68 74 20 31 | 39 39 32 20 50 65 74 65 |yright 1|992 Pete|
|00002f60| 72 20 64 61 20 53 69 6c | 76 61 0a 58 20 2a 0a 58 |r da Sil|va.X *.X|
|00002f70| 20 2a 20 50 65 72 6d 69 | 73 73 69 6f 6e 20 74 6f | * Permi|ssion to|
|00002f80| 20 75 73 65 2c 20 63 6f | 70 79 2c 20 6d 6f 64 69 | use, co|py, modi|
|00002f90| 66 79 2c 20 61 6e 64 20 | 64 69 73 74 72 69 62 75 |fy, and |distribu|
|00002fa0| 74 65 20 74 68 69 73 0a | 58 20 2a 20 73 6f 66 74 |te this.|X * soft|
|00002fb0| 77 61 72 65 20 61 6e 64 | 20 69 74 73 20 64 6f 63 |ware and| its doc|
|00002fc0| 75 6d 65 6e 74 61 74 69 | 6f 6e 20 66 6f 72 20 61 |umentati|on for a|
|00002fd0| 6e 79 20 70 75 72 70 6f | 73 65 20 61 6e 64 20 77 |ny purpo|se and w|
|00002fe0| 69 74 68 6f 75 74 0a 58 | 20 2a 20 66 65 65 20 69 |ithout.X| * fee i|
|00002ff0| 73 20 68 65 72 65 62 79 | 20 67 72 61 6e 74 65 64 |s hereby| granted|
|00003000| 2c 20 70 72 6f 76 69 64 | 65 64 20 74 68 61 74 20 |, provid|ed that |
|00003010| 74 68 65 20 61 62 6f 76 | 65 20 63 6f 70 79 72 69 |the abov|e copyri|
|00003020| 67 68 74 0a 58 20 2a 20 | 6e 6f 74 69 63 65 20 61 |ght.X * |notice a|
|00003030| 70 70 65 61 72 20 69 6e | 20 61 6c 6c 20 63 6f 70 |ppear in| all cop|
|00003040| 69 65 73 2e 20 20 54 68 | 65 20 61 75 74 68 6f 72 |ies. Th|e author|
|00003050| 5b 73 5d 20 6d 61 6b 65 | 20 6e 6f 20 72 65 70 72 |[s] make| no repr|
|00003060| 65 73 65 6e 74 61 74 69 | 6f 6e 73 0a 58 20 2a 20 |esentati|ons.X * |
|00003070| 61 62 6f 75 74 20 74 68 | 65 20 73 75 69 74 61 62 |about th|e suitab|
|00003080| 69 6c 69 74 79 20 6f 66 | 20 74 68 69 73 20 73 6f |ility of| this so|
|00003090| 66 74 77 61 72 65 20 66 | 6f 72 20 61 6e 79 20 70 |ftware f|or any p|
|000030a0| 75 72 70 6f 73 65 2e 0a | 58 20 2a 20 49 74 20 69 |urpose..|X * It i|
|000030b0| 73 20 70 72 6f 76 69 64 | 65 64 20 22 61 73 20 69 |s provid|ed "as i|
|000030c0| 73 22 20 77 69 74 68 6f | 75 74 20 65 78 70 72 65 |s" witho|ut expre|
|000030d0| 73 73 20 6f 72 20 69 6d | 70 6c 69 65 64 20 77 61 |ss or im|plied wa|
|000030e0| 72 72 61 6e 74 79 2e 0a | 58 20 2a 2f 0a 58 0a 58 |rranty..|X */.X.X|
|000030f0| 2f 2a 20 43 6f 64 65 20 | 74 6f 20 68 61 6e 64 6c |/* Code |to handl|
|00003100| 65 20 61 6e 20 65 64 69 | 74 6f 72 20 62 75 66 66 |e an edi|tor buff|
|00003110| 65 72 20 2a 2f 0a 58 23 | 69 6e 63 6c 75 64 65 20 |er */.X#|include |
|00003120| 3c 73 74 64 69 6f 2e 68 | 3e 0a 58 0a 58 63 68 61 |<stdio.h|>.X.Xcha|
|00003130| 72 20 2a 6d 61 6c 6c 6f | 63 28 29 3b 0a 58 0a 58 |r *mallo|c();.X.X|
|00003140| 23 64 65 66 69 6e 65 20 | 6e 65 77 28 74 2c 6e 29 |#define |new(t,n)|
|00003150| 20 28 28 74 20 2a 29 6d | 61 6c 6c 6f 63 28 6e 20 | ((t *)m|alloc(n |
|00003160| 2a 20 73 69 7a 65 6f 66 | 20 28 74 29 29 29 0a 58 |* sizeof| (t))).X|
|00003170| 0a 58 23 64 65 66 69 6e | 65 20 4d 41 58 42 55 46 |.X#defin|e MAXBUF|
|00003180| 53 20 33 32 0a 58 23 64 | 65 66 69 6e 65 20 4d 41 |S 32.X#d|efine MA|
|00003190| 58 4d 41 52 4b 53 20 33 | 32 0a 58 0a 58 74 79 70 |XMARKS 3|2.X.Xtyp|
|000031a0| 65 64 65 66 20 73 74 72 | 75 63 74 20 7b 0a 58 09 |edef str|uct {.X.|
|000031b0| 69 6e 74 20 62 6f 64 79 | 5f 6c 65 6e 67 74 68 3b |int body|_length;|
|000031c0| 09 2f 2a 20 6e 75 6d 62 | 65 72 20 6f 66 20 62 79 |./* numb|er of by|
|000031d0| 74 65 73 20 6f 66 20 74 | 65 78 74 20 69 6e 20 62 |tes of t|ext in b|
|000031e0| 6f 64 79 20 2a 2f 0a 58 | 09 69 6e 74 20 74 65 78 |ody */.X|.int tex|
|000031f0| 74 5f 6c 65 6e 67 74 68 | 3b 09 2f 2a 20 6e 75 6d |t_length|;./* num|
|00003200| 62 65 72 20 6f 66 20 62 | 79 74 65 73 20 6f 66 20 |ber of b|ytes of |
|00003210| 74 65 78 74 20 69 6e 20 | 62 6f 64 79 20 2a 2f 0a |text in |body */.|
|00003220| 58 09 69 6e 74 20 67 61 | 70 3b 09 09 2f 2a 20 73 |X.int ga|p;../* s|
|00003230| 74 61 72 74 20 6f 66 20 | 67 61 70 20 2a 2f 0a 58 |tart of |gap */.X|
|00003240| 09 69 6e 74 20 67 61 70 | 73 69 7a 65 3b 09 09 2f |.int gap|size;../|
|00003250| 2a 20 6c 65 6e 67 74 68 | 20 6f 66 20 67 61 70 20 |* length| of gap |
|00003260| 2a 2f 0a 58 09 69 6e 74 | 20 6d 61 72 6b 5b 4d 41 |*/.X.int| mark[MA|
|00003270| 58 4d 41 52 4b 53 5d 3b | 0a 58 09 69 6e 74 20 68 |XMARKS];|.X.int h|
|00003280| 69 6d 61 72 6b 3b 0a 58 | 09 63 68 61 72 20 2a 62 |imark;.X|.char *b|
|00003290| 6f 64 79 3b 0a 58 7d 20 | 62 75 66 66 65 72 3b 0a |ody;.X} |buffer;.|
|000032a0| 58 0a 58 73 74 61 74 69 | 63 20 62 75 66 66 65 72 |X.Xstati|c buffer|
|000032b0| 20 2a 62 75 66 74 61 62 | 5b 4d 41 58 42 55 46 53 | *buftab|[MAXBUFS|
|000032c0| 5d 3b 0a 58 73 74 61 74 | 69 63 20 69 6e 74 20 68 |];.Xstat|ic int h|
|000032d0| 69 62 75 66 66 65 72 3b | 0a 58 0a 58 73 74 61 74 |ibuffer;|.X.Xstat|
|000032e0| 69 63 20 63 68 61 72 20 | 2a 6c 61 73 74 72 6f 75 |ic char |*lastrou|
|000032f0| 74 69 6e 65 20 3d 20 22 | 4e 4f 4e 45 22 3b 0a 58 |tine = "|NONE";.X|
|00003300| 0a 58 23 64 65 66 69 6e | 65 20 6d 61 72 6b 32 69 |.X#defin|e mark2i|
|00003310| 6e 64 65 78 28 6d 29 20 | 28 28 6d 29 2d 31 29 0a |ndex(m) |((m)-1).|
|00003320| 58 23 64 65 66 69 6e 65 | 20 69 6e 64 65 78 32 6d |X#define| index2m|
|00003330| 61 72 6b 28 69 29 20 28 | 28 69 29 2b 31 29 0a 58 |ark(i) (|(i)+1).X|
|00003340| 0a 58 2f 2a 20 63 68 65 | 63 6b 62 75 66 28 62 75 |.X/* che|ckbuf(bu|
|00003350| 66 70 74 72 2c 20 62 75 | 66 66 65 72 2c 20 6e 61 |fptr, bu|ffer, na|
|00003360| 6d 65 29 0a 58 20 2a 0a | 58 20 2a 20 43 68 65 63 |me).X *.|X * Chec|
|00003370| 6b 73 20 74 68 65 20 69 | 6e 74 65 67 72 69 74 79 |ks the i|ntegrity|
|00003380| 20 6f 66 20 61 20 62 75 | 66 66 65 72 20 73 74 72 | of a bu|ffer str|
|00003390| 75 63 74 75 72 65 2e 20 | 43 61 6c 6c 65 64 20 66 |ucture. |Called f|
|000033a0| 72 6f 6d 20 65 61 63 68 | 20 72 6f 75 74 69 6e 65 |rom each| routine|
|000033b0| 0a 58 20 2a 20 74 68 61 | 74 20 72 65 73 6f 6c 76 |.X * tha|t resolv|
|000033c0| 65 73 20 61 20 62 75 66 | 66 65 72 20 69 6e 74 6f |es a buf|fer into|
|000033d0| 20 61 20 70 6f 69 6e 74 | 65 72 20 74 6f 20 6d 61 | a point|er to ma|
|000033e0| 6b 65 20 73 75 72 65 20 | 74 68 65 20 70 6f 69 6e |ke sure |the poin|
|000033f0| 74 65 72 20 69 73 20 76 | 61 6c 69 64 0a 58 20 2a |ter is v|alid.X *|
|00003400| 20 61 6e 64 20 74 68 65 | 20 62 75 66 66 65 72 20 | and the| buffer |
|00003410| 68 61 73 6e 27 74 20 62 | 65 65 6e 20 73 74 65 70 |hasn't b|een step|
|00003420| 70 65 64 20 6f 6e 2e 0a | 58 20 2a 2f 0a 58 63 68 |ped on..|X */.Xch|
|00003430| 65 63 6b 62 75 66 28 62 | 2c 69 2c 6e 29 0a 58 62 |eckbuf(b|,i,n).Xb|
|00003440| 75 66 66 65 72 20 2a 62 | 3b 0a 58 63 68 61 72 20 |uffer *b|;.Xchar |
|00003450| 2a 6e 3b 0a 58 7b 0a 58 | 09 69 66 28 62 2d 3e 62 |*n;.X{.X|.if(b->b|
|00003460| 6f 64 79 5f 6c 65 6e 67 | 74 68 20 21 3d 20 62 2d |ody_leng|th != b-|
|00003470| 3e 74 65 78 74 5f 6c 65 | 6e 67 74 68 2b 62 2d 3e |>text_le|ngth+b->|
|00003480| 67 61 70 73 69 7a 65 29 | 20 7b 0a 58 09 09 66 70 |gapsize)| {.X..fp|
|00003490| 72 69 6e 74 66 28 73 74 | 64 65 72 72 2c 20 22 62 |rintf(st|derr, "b|
|000034a0| 75 66 66 65 72 28 25 64 | 29 3a 20 49 6e 63 6f 6e |uffer(%d|): Incon|
|000034b0| 73 69 73 74 65 6e 74 20 | 73 69 7a 65 73 20 25 64 |sistent |sizes %d|
|000034c0| 21 3d 25 64 2b 25 64 5c | 6e 22 2c 0a 58 09 09 09 |!=%d+%d\|n",.X...|
|000034d0| 69 2c 20 62 2d 3e 62 6f | 64 79 5f 6c 65 6e 67 74 |i, b->bo|dy_lengt|
|000034e0| 68 2c 20 62 2d 3e 74 65 | 78 74 5f 6c 65 6e 67 74 |h, b->te|xt_lengt|
|000034f0| 68 2c 20 62 2d 3e 67 61 | 70 73 69 7a 65 29 3b 0a |h, b->ga|psize);.|
|00003500| 58 09 7d 20 65 6c 73 65 | 20 69 66 28 62 2d 3e 67 |X.} else| if(b->g|
|00003510| 61 70 20 3c 20 30 20 7c | 7c 20 62 2d 3e 67 61 70 |ap < 0 ||| b->gap|
|00003520| 20 3e 20 62 2d 3e 74 65 | 78 74 5f 6c 65 6e 67 74 | > b->te|xt_lengt|
|00003530| 68 29 20 7b 0a 58 09 09 | 66 70 72 69 6e 74 66 28 |h) {.X..|fprintf(|
|00003540| 73 74 64 65 72 72 2c 20 | 22 62 75 66 66 65 72 28 |stderr, |"buffer(|
|00003550| 25 64 29 3a 20 47 61 70 | 20 6f 75 74 20 6f 66 20 |%d): Gap| out of |
|00003560| 72 61 6e 67 65 20 25 64 | 5c 6e 22 2c 0a 58 09 09 |range %d|\n",.X..|
|00003570| 09 69 2c 20 62 2d 3e 67 | 61 70 29 3b 0a 58 09 7d |.i, b->g|ap);.X.}|
|00003580| 20 65 6c 73 65 20 69 66 | 28 62 2d 3e 68 69 6d 61 | else if|(b->hima|
|00003590| 72 6b 20 3c 20 30 20 7c | 7c 20 62 2d 3e 68 69 6d |rk < 0 ||| b->him|
|000035a0| 61 72 6b 20 3e 20 4d 41 | 58 4d 41 52 4b 53 29 20 |ark > MA|XMARKS) |
|000035b0| 7b 0a 58 09 09 66 70 72 | 69 6e 74 66 28 73 74 64 |{.X..fpr|intf(std|
|000035c0| 65 72 72 2c 20 22 62 75 | 66 66 65 72 28 25 64 29 |err, "bu|ffer(%d)|
|000035d0| 3a 20 4d 61 72 6b 20 63 | 6f 75 6e 74 20 6f 75 74 |: Mark c|ount out|
|000035e0| 20 6f 66 20 72 61 6e 67 | 65 20 25 64 5c 6e 22 2c | of rang|e %d\n",|
|000035f0| 0a 58 09 09 09 69 2c 20 | 62 2d 3e 68 69 6d 61 72 |.X...i, |b->himar|
|00003600| 6b 29 3b 0a 58 09 7d 20 | 65 6c 73 65 20 7b 0a 58 |k);.X.} |else {.X|
|00003610| 23 69 66 64 65 66 20 54 | 45 53 54 0a 58 09 09 69 |#ifdef T|EST.X..i|
|00003620| 6e 74 20 69 6e 64 65 78 | 3b 0a 58 0a 58 09 09 66 |nt index|;.X.X..f|
|00003630| 6f 72 28 69 6e 64 65 78 | 20 3d 20 30 3b 20 69 6e |or(index| = 0; in|
|00003640| 64 65 78 20 3c 20 62 2d | 3e 68 69 6d 61 72 6b 3b |dex < b-|>himark;|
|00003650| 20 69 6e 64 65 78 2b 2b | 29 20 7b 0a 58 09 09 09 | index++|) {.X...|
|00003660| 69 66 28 62 2d 3e 6d 61 | 72 6b 5b 69 6e 64 65 78 |if(b->ma|rk[index|
|00003670| 5d 20 3c 20 2d 31 0a 58 | 09 09 09 7c 7c 20 62 2d |] < -1.X|...|| b-|
|00003680| 3e 6d 61 72 6b 5b 69 6e | 64 65 78 5d 20 3e 20 62 |>mark[in|dex] > b|
|00003690| 2d 3e 74 65 78 74 5f 6c | 65 6e 67 74 68 29 20 7b |->text_l|ength) {|
|000036a0| 0a 58 09 09 09 09 66 70 | 72 69 6e 74 66 28 73 74 |.X....fp|rintf(st|
|000036b0| 64 65 72 72 2c 0a 58 09 | 09 09 09 20 20 20 20 22 |derr,.X.|... "|
|000036c0| 62 75 66 66 65 72 28 25 | 64 29 3a 20 6d 61 72 6b |buffer(%|d): mark|
|000036d0| 28 25 64 29 20 6f 75 74 | 20 6f 66 20 72 61 6e 67 |(%d) out| of rang|
|000036e0| 65 20 25 64 5c 6e 22 2c | 0a 58 09 09 09 09 09 69 |e %d\n",|.X.....i|
|000036f0| 2c 20 69 6e 64 65 78 32 | 6d 61 72 6b 28 69 6e 64 |, index2|mark(ind|
|00003700| 65 78 29 2c 20 62 2d 3e | 6d 61 72 6b 5b 69 6e 64 |ex), b->|mark[ind|
|00003710| 65 78 5d 29 3b 0a 58 09 | 09 09 09 62 72 65 61 6b |ex]);.X.|...break|
|00003720| 3b 0a 58 09 09 09 7d 0a | 58 09 09 7d 0a 58 09 09 |;.X...}.|X..}.X..|
|00003730| 69 66 28 69 6e 64 65 78 | 20 3d 3d 20 62 2d 3e 68 |if(index| == b->h|
|00003740| 69 6d 61 72 6b 29 20 7b | 0a 58 09 09 09 6c 61 73 |imark) {|.X...las|
|00003750| 74 72 6f 75 74 69 6e 65 | 20 3d 20 6e 3b 0a 58 09 |troutine| = n;.X.|
|00003760| 09 09 72 65 74 75 72 6e | 3b 0a 58 09 09 7d 0a 58 |..return|;.X..}.X|
|00003770| 23 65 6c 73 65 0a 58 09 | 09 6c 61 73 74 72 6f 75 |#else.X.|.lastrou|
|00003780| 74 69 6e 65 20 3d 20 6e | 3b 0a 58 09 09 72 65 74 |tine = n|;.X..ret|
|00003790| 75 72 6e 3b 0a 58 23 65 | 6e 64 69 66 0a 58 09 7d |urn;.X#e|ndif.X.}|
|000037a0| 0a 58 09 66 70 72 69 6e | 74 66 28 73 74 64 65 72 |.X.fprin|tf(stder|
|000037b0| 72 2c 20 22 45 72 72 6f | 72 20 64 65 74 65 63 74 |r, "Erro|r detect|
|000037c0| 65 64 20 69 6e 20 25 73 | 20 63 61 6c 6c 65 64 20 |ed in %s| called |
|000037d0| 61 66 74 65 72 20 25 73 | 5c 6e 22 2c 0a 58 09 09 |after %s|\n",.X..|
|000037e0| 6e 2c 20 6c 61 73 74 72 | 6f 75 74 69 6e 65 29 3b |n, lastr|outine);|
|000037f0| 0a 58 09 65 78 69 74 28 | 2d 31 29 3b 0a 58 7d 0a |.X.exit(|-1);.X}.|
|00003800| 58 0a 58 23 64 65 66 69 | 6e 65 20 43 48 45 43 4b |X.X#defi|ne CHECK|
|00003810| 28 62 2c 69 2c 6e 2c 66 | 29 20 5c 0a 58 09 62 75 |(b,i,n,f|) \.X.bu|
|00003820| 66 66 65 72 5f 65 72 72 | 6f 72 20 3d 20 69 6e 76 |ffer_err|or = inv|
|00003830| 61 6c 69 64 5f 62 75 66 | 66 65 72 3b 20 5c 0a 58 |alid_buf|fer; \.X|
|00003840| 09 69 66 28 69 20 3e 3d | 20 30 20 26 26 20 69 20 |.if(i >=| 0 && i |
|00003850| 3c 20 68 69 62 75 66 66 | 65 72 29 20 7b 20 5c 0a |< hibuff|er) { \.|
|00003860| 58 09 09 62 20 3d 20 62 | 75 66 74 61 62 5b 69 5d |X..b = b|uftab[i]|
|00003870| 3b 20 5c 0a 58 09 09 69 | 66 28 21 62 29 20 72 65 |; \.X..i|f(!b) re|
|00003880| 74 75 72 6e 20 66 3b 20 | 5c 0a 58 09 7d 20 65 6c |turn f; |\.X.} el|
|00003890| 73 65 20 72 65 74 75 72 | 6e 20 66 3b 20 5c 0a 58 |se retur|n f; \.X|
|000038a0| 09 63 68 65 63 6b 62 75 | 66 28 62 2c 69 2c 6e 29 |.checkbu|f(b,i,n)|
|000038b0| 0a 58 0a 58 23 64 65 66 | 69 6e 65 20 43 48 45 43 |.X.X#def|ine CHEC|
|000038c0| 4b 4d 41 52 4b 28 62 2c | 6a 2c 76 29 20 5c 0a 58 |KMARK(b,|j,v) \.X|
|000038d0| 09 69 66 28 6a 20 3c 20 | 2d 31 20 7c 7c 20 6a 20 |.if(j < |-1 || j |
|000038e0| 3e 20 62 2d 3e 68 69 6d | 61 72 6b 29 20 7b 20 5c |> b->him|ark) { \|
|000038f0| 0a 58 09 09 62 75 66 66 | 65 72 5f 65 72 72 6f 72 |.X..buff|er_error|
|00003900| 20 3d 20 6d 61 72 6b 5f | 72 61 6e 67 65 3b 20 5c | = mark_|range; \|
|00003910| 0a 58 09 09 72 65 74 75 | 72 6e 20 76 3b 20 5c 0a |.X..retu|rn v; \.|
|00003920| 58 09 7d 20 65 6c 73 65 | 20 69 66 28 6a 20 3e 20 |X.} else| if(j > |
|00003930| 30 20 26 26 20 62 2d 3e | 6d 61 72 6b 5b 6d 61 72 |0 && b->|mark[mar|
|00003940| 6b 32 69 6e 64 65 78 28 | 6a 29 5d 20 3d 3d 20 2d |k2index(|j)] == -|
|00003950| 31 29 20 7b 20 5c 0a 58 | 09 09 62 75 66 66 65 72 |1) { \.X|..buffer|
|00003960| 5f 65 72 72 6f 72 20 3d | 20 6d 61 72 6b 5f 75 6e |_error =| mark_un|
|00003970| 73 65 74 3b 20 5c 0a 58 | 09 09 72 65 74 75 72 6e |set; \.X|..return|
|00003980| 20 76 3b 20 5c 0a 58 09 | 7d 0a 58 0a 58 73 74 61 | v; \.X.|}.X.Xsta|
|00003990| 74 69 63 20 63 68 61 72 | 20 2a 69 6e 76 61 6c 69 |tic char| *invali|
|000039a0| 64 5f 62 75 66 66 65 72 | 20 3d 20 22 49 6e 76 61 |d_buffer| = "Inva|
|000039b0| 6c 69 64 20 62 75 66 66 | 65 72 20 49 44 22 3b 0a |lid buff|er ID";.|
|000039c0| 58 73 74 61 74 69 63 20 | 63 68 61 72 20 2a 66 6f |Xstatic |char *fo|
|000039d0| 75 6e 64 5f 65 6f 66 20 | 3d 20 22 42 65 79 6f 6e |und_eof |= "Beyon|
|000039e0| 64 20 65 6e 64 20 6f 66 | 20 62 75 66 66 65 72 22 |d end of| buffer"|
|000039f0| 3b 0a 58 73 74 61 74 69 | 63 20 63 68 61 72 20 2a |;.Xstati|c char *|
|00003a00| 66 6f 75 6e 64 5f 62 6f | 66 20 3d 20 22 42 65 79 |found_bo|f = "Bey|
|00003a10| 6f 6e 64 20 62 65 67 69 | 6e 6e 69 6e 67 20 6f 66 |ond begi|nning of|
|00003a20| 20 62 75 66 66 65 72 22 | 3b 0a 58 73 74 61 74 69 | buffer"|;.Xstati|
|00003a30| 63 20 63 68 61 72 20 2a | 6d 61 72 6b 5f 72 61 6e |c char *|mark_ran|
|00003a40| 67 65 20 3d 20 22 4d 61 | 72 6b 20 6f 75 74 20 6f |ge = "Ma|rk out o|
|00003a50| 66 20 72 61 6e 67 65 22 | 3b 0a 58 73 74 61 74 69 |f range"|;.Xstati|
|00003a60| 63 20 63 68 61 72 20 2a | 6d 61 72 6b 5f 75 6e 73 |c char *|mark_uns|
|00003a70| 65 74 20 3d 20 22 4d 61 | 72 6b 20 6e 6f 74 20 73 |et = "Ma|rk not s|
|00003a80| 65 74 22 3b 0a 58 0a 58 | 63 68 61 72 20 2a 62 75 |et";.X.X|char *bu|
|00003a90| 66 66 65 72 5f 65 72 72 | 6f 72 3b 0a 58 0a 58 69 |ffer_err|or;.X.Xi|
|00003aa0| 6e 74 20 6e 65 77 5f 62 | 75 66 66 65 72 28 29 0a |nt new_b|uffer().|
|00003ab0| 58 7b 0a 58 09 69 6e 74 | 20 69 2c 20 69 6e 64 65 |X{.X.int| i, inde|
|00003ac0| 78 3b 0a 58 0a 58 09 66 | 6f 72 28 69 20 3d 20 30 |x;.X.X.f|or(i = 0|
|00003ad0| 3b 20 69 20 3c 20 68 69 | 62 75 66 66 65 72 3b 20 |; i < hi|buffer; |
|00003ae0| 69 2b 2b 29 0a 58 09 09 | 69 66 28 21 62 75 66 74 |i++).X..|if(!buft|
|00003af0| 61 62 5b 69 5d 29 0a 58 | 09 09 09 62 72 65 61 6b |ab[i]).X|...break|
|00003b00| 3b 0a 58 09 69 66 28 69 | 20 3d 3d 20 68 69 62 75 |;.X.if(i| == hibu|
|00003b10| 66 66 65 72 29 20 7b 0a | 58 09 09 69 66 28 68 69 |ffer) {.|X..if(hi|
|00003b20| 62 75 66 66 65 72 20 3d | 3d 20 4d 41 58 42 55 46 |buffer =|= MAXBUF|
|00003b30| 53 29 20 7b 0a 58 09 09 | 09 62 75 66 66 65 72 5f |S) {.X..|.buffer_|
|00003b40| 65 72 72 6f 72 20 3d 20 | 22 4e 6f 20 6d 6f 72 65 |error = |"No more|
|00003b50| 20 62 75 66 66 65 72 73 | 22 3b 0a 58 09 09 09 72 | buffers|";.X...r|
|00003b60| 65 74 75 72 6e 20 2d 31 | 3b 0a 58 09 09 7d 0a 58 |eturn -1|;.X..}.X|
|00003b70| 09 09 68 69 62 75 66 66 | 65 72 2b 2b 3b 0a 58 09 |..hibuff|er++;.X.|
|00003b80| 7d 0a 58 09 62 75 66 74 | 61 62 5b 69 5d 20 3d 20 |}.X.buft|ab[i] = |
|00003b90| 6e 65 77 28 62 75 66 66 | 65 72 2c 20 31 29 3b 0a |new(buff|er, 1);.|
|00003ba0| 58 09 69 66 28 21 62 75 | 66 74 61 62 5b 69 5d 29 |X.if(!bu|ftab[i])|
|00003bb0| 20 7b 0a 58 09 09 62 75 | 66 66 65 72 5f 65 72 72 | {.X..bu|ffer_err|
|00003bc0| 6f 72 20 3d 20 22 4d 65 | 6d 6f 72 79 20 61 6c 6c |or = "Me|mory all|
|00003bd0| 6f 63 61 74 69 6f 6e 20 | 66 61 69 6c 75 72 65 22 |ocation |failure"|
|00003be0| 3b 0a 58 09 09 72 65 74 | 75 72 6e 20 2d 31 3b 0a |;.X..ret|urn -1;.|
|00003bf0| 58 09 7d 0a 58 09 62 75 | 66 74 61 62 5b 69 5d 20 |X.}.X.bu|ftab[i] |
|00003c00| 2d 3e 20 62 6f 64 79 5f | 6c 65 6e 67 74 68 20 3d |-> body_|length =|
|00003c10| 20 30 3b 0a 58 09 62 75 | 66 74 61 62 5b 69 5d 20 | 0;.X.bu|ftab[i] |
|00003c20| 2d 3e 20 74 65 78 74 5f | 6c 65 6e 67 74 68 20 3d |-> text_|length =|
|00003c30| 20 30 3b 0a 58 09 62 75 | 66 74 61 62 5b 69 5d 20 | 0;.X.bu|ftab[i] |
|00003c40| 2d 3e 20 67 61 70 73 69 | 7a 65 20 3d 20 30 3b 0a |-> gapsi|ze = 0;.|
|00003c50| 58 09 62 75 66 74 61 62 | 5b 69 5d 20 2d 3e 20 67 |X.buftab|[i] -> g|
|00003c60| 61 70 20 3d 20 30 3b 0a | 58 09 66 6f 72 28 69 6e |ap = 0;.|X.for(in|
|00003c70| 64 65 78 20 3d 20 30 3b | 20 69 6e 64 65 78 20 3c |dex = 0;| index <|
|00003c80| 20 4d 41 58 4d 41 52 4b | 53 3b 20 69 6e 64 65 78 | MAXMARK|S; index|
|00003c90| 2b 2b 29 0a 58 09 09 62 | 75 66 74 61 62 5b 69 5d |++).X..b|uftab[i]|
|00003ca0| 20 2d 3e 20 6d 61 72 6b | 5b 69 6e 64 65 78 5d 20 | -> mark|[index] |
|00003cb0| 3d 20 2d 31 3b 0a 58 09 | 62 75 66 74 61 62 5b 69 |= -1;.X.|buftab[i|
|00003cc0| 5d 20 2d 3e 20 68 69 6d | 61 72 6b 20 3d 20 30 3b |] -> him|ark = 0;|
|00003cd0| 0a 58 09 62 75 66 74 61 | 62 5b 69 5d 20 2d 3e 20 |.X.bufta|b[i] -> |
|00003ce0| 62 6f 64 79 20 3d 20 28 | 63 68 61 72 20 2a 29 30 |body = (|char *)0|
|00003cf0| 3b 0a 58 0a 58 09 72 65 | 74 75 72 6e 20 69 3b 0a |;.X.X.re|turn i;.|
|00003d00| 58 7d 0a 58 0a 58 64 65 | 6c 65 74 65 5f 62 75 66 |X}.X.Xde|lete_buf|
|00003d10| 66 65 72 28 69 29 0a 58 | 69 6e 74 20 69 3b 0a 58 |fer(i).X|int i;.X|
|00003d20| 7b 0a 58 09 62 75 66 66 | 65 72 20 2a 62 3b 0a 58 |{.X.buff|er *b;.X|
|00003d30| 0a 58 09 43 48 45 43 4b | 28 62 2c 69 2c 22 64 65 |.X.CHECK|(b,i,"de|
|00003d40| 6c 65 74 65 5f 62 75 66 | 66 65 72 22 2c 2d 31 29 |lete_buf|fer",-1)|
|00003d50| 3b 0a 58 0a 58 09 69 66 | 28 62 2d 3e 62 6f 64 79 |;.X.X.if|(b->body|
|00003d60| 29 20 66 72 65 65 28 62 | 2d 3e 62 6f 64 79 29 3b |) free(b|->body);|
|00003d70| 0a 58 0a 58 09 66 72 65 | 65 28 62 29 3b 0a 58 0a |.X.X.fre|e(b);.X.|
|00003d80| 58 09 62 75 66 74 61 62 | 5b 69 5d 20 3d 20 30 3b |X.buftab|[i] = 0;|
|00003d90| 0a 58 0a 58 09 72 65 74 | 75 72 6e 20 30 3b 0a 58 |.X.X.ret|urn 0;.X|
|00003da0| 7d 0a 58 0a 58 69 6e 74 | 20 6e 65 77 5f 6d 61 72 |}.X.Xint| new_mar|
|00003db0| 6b 28 69 2c 20 6f 66 66 | 29 0a 58 69 6e 74 20 69 |k(i, off|).Xint i|
|00003dc0| 2c 20 6f 66 66 3b 0a 58 | 7b 0a 58 09 69 6e 74 20 |, off;.X|{.X.int |
|00003dd0| 69 6e 64 65 78 3b 0a 58 | 09 62 75 66 66 65 72 20 |index;.X|.buffer |
|00003de0| 2a 62 3b 0a 58 0a 58 09 | 43 48 45 43 4b 28 62 2c |*b;.X.X.|CHECK(b,|
|00003df0| 69 2c 22 6e 65 77 5f 6d | 61 72 6b 22 2c 2d 31 29 |i,"new_m|ark",-1)|
|00003e00| 3b 0a 58 0a 58 09 69 66 | 28 6f 66 66 20 3c 20 30 |;.X.X.if|(off < 0|
|00003e10| 20 7c 7c 20 6f 66 66 20 | 3e 20 62 2d 3e 74 65 78 | || off |> b->tex|
|00003e20| 74 5f 6c 65 6e 67 74 68 | 29 20 7b 0a 58 09 09 62 |t_length|) {.X..b|
|00003e30| 75 66 66 65 72 5f 65 72 | 72 6f 72 20 3d 20 6d 61 |uffer_er|ror = ma|
|00003e40| 72 6b 5f 72 61 6e 67 65 | 3b 0a 58 09 09 72 65 74 |rk_range|;.X..ret|
|00003e50| 75 72 6e 20 2d 31 3b 0a | 58 09 7d 0a 58 0a 58 09 |urn -1;.|X.}.X.X.|
|00003e60| 66 6f 72 28 69 6e 64 65 | 78 20 3d 20 30 3b 20 69 |for(inde|x = 0; i|
|00003e70| 6e 64 65 78 20 3c 20 62 | 2d 3e 68 69 6d 61 72 6b |ndex < b|->himark|
|00003e80| 3b 20 69 6e 64 65 78 2b | 2b 29 0a 58 09 09 69 66 |; index+|+).X..if|
|00003e90| 28 62 2d 3e 6d 61 72 6b | 5b 69 6e 64 65 78 5d 20 |(b->mark|[index] |
|00003ea0| 3d 3d 20 2d 31 29 0a 58 | 09 09 09 62 72 65 61 6b |== -1).X|...break|
|00003eb0| 3b 0a 58 09 69 66 28 69 | 6e 64 65 78 20 3d 3d 20 |;.X.if(i|ndex == |
|00003ec0| 62 2d 3e 68 69 6d 61 72 | 6b 29 20 7b 0a 58 09 09 |b->himar|k) {.X..|
|00003ed0| 69 66 28 62 2d 3e 68 69 | 6d 61 72 6b 20 3d 3d 20 |if(b->hi|mark == |
|00003ee0| 4d 41 58 42 55 46 53 29 | 20 7b 0a 58 09 09 09 62 |MAXBUFS)| {.X...b|
|00003ef0| 75 66 66 65 72 5f 65 72 | 72 6f 72 20 3d 20 22 4e |uffer_er|ror = "N|
|00003f00| 6f 20 6d 6f 72 65 20 6d | 61 72 6b 73 22 3b 0a 58 |o more m|arks";.X|
|00003f10| 09 09 09 72 65 74 75 72 | 6e 20 2d 31 3b 0a 58 09 |...retur|n -1;.X.|
|00003f20| 09 7d 0a 58 09 09 62 2d | 3e 68 69 6d 61 72 6b 2b |.}.X..b-|>himark+|
|00003f30| 2b 3b 0a 58 09 7d 0a 58 | 09 62 2d 3e 6d 61 72 6b |+;.X.}.X|.b->mark|
|00003f40| 5b 69 6e 64 65 78 5d 20 | 3d 20 6f 66 66 3b 0a 58 |[index] |= off;.X|
|00003f50| 0a 58 09 72 65 74 75 72 | 6e 20 69 6e 64 65 78 32 |.X.retur|n index2|
|00003f60| 6d 61 72 6b 28 69 6e 64 | 65 78 29 3b 0a 58 7d 0a |mark(ind|ex);.X}.|
|00003f70| 58 0a 58 69 6e 74 20 63 | 6f 70 79 5f 6d 61 72 6b |X.Xint c|opy_mark|
|00003f80| 28 69 2c 20 6a 29 0a 58 | 69 6e 74 20 69 2c 20 6a |(i, j).X|int i, j|
|00003f90| 3b 0a 58 7b 0a 58 09 69 | 6e 74 20 6f 66 66 3b 0a |;.X{.X.i|nt off;.|
|00003fa0| 58 0a 58 09 6f 66 66 20 | 3d 20 6c 6f 63 61 74 65 |X.X.off |= locate|
|00003fb0| 5f 6d 61 72 6b 28 69 2c | 20 6a 29 3b 0a 58 0a 58 |_mark(i,| j);.X.X|
|00003fc0| 09 69 66 28 6f 66 66 20 | 3d 3d 20 2d 31 29 0a 58 |.if(off |== -1).X|
|00003fd0| 09 09 72 65 74 75 72 6e | 20 2d 31 3b 0a 58 09 65 |..return| -1;.X.e|
|00003fe0| 6c 73 65 0a 58 09 09 72 | 65 74 75 72 6e 20 6e 65 |lse.X..r|eturn ne|
|00003ff0| 77 5f 6d 61 72 6b 28 69 | 2c 20 6f 66 66 29 3b 0a |w_mark(i|, off);.|
|00004000| 58 7d 0a 58 0a 58 64 65 | 6c 65 74 65 5f 6d 61 72 |X}.X.Xde|lete_mar|
|00004010| 6b 28 69 2c 20 6a 29 0a | 58 69 6e 74 20 69 3b 0a |k(i, j).|Xint i;.|
|00004020| 58 69 6e 74 20 6a 3b 0a | 58 7b 0a 58 09 62 75 66 |Xint j;.|X{.X.buf|
|00004030| 66 65 72 20 2a 62 3b 0a | 58 0a 58 09 43 48 45 43 |fer *b;.|X.X.CHEC|
|00004040| 4b 28 62 2c 69 2c 22 64 | 65 6c 65 74 65 5f 6d 61 |K(b,i,"d|elete_ma|
|00004050| 72 6b 22 2c 2d 31 29 3b | 0a 58 09 43 48 45 43 4b |rk",-1);|.X.CHECK|
|00004060| 4d 41 52 4b 28 62 2c 6a | 2c 2d 31 29 3b 0a 58 0a |MARK(b,j|,-1);.X.|
|00004070| 58 09 69 66 28 6a 20 3c | 3d 20 30 29 20 7b 0a 58 |X.if(j <|= 0) {.X|
|00004080| 09 09 62 75 66 66 65 72 | 5f 65 72 72 6f 72 20 3d |..buffer|_error =|
|00004090| 20 22 44 65 6c 65 74 69 | 6e 67 20 66 69 78 65 64 | "Deleti|ng fixed|
|000040a0| 20 6d 61 72 6b 22 3b 0a | 58 09 09 72 65 74 75 72 | mark";.|X..retur|
|000040b0| 6e 20 2d 31 3b 0a 58 09 | 7d 0a 58 0a 58 09 62 2d |n -1;.X.|}.X.X.b-|
|000040c0| 3e 6d 61 72 6b 5b 6d 61 | 72 6b 32 69 6e 64 65 78 |>mark[ma|rk2index|
|000040d0| 28 6a 29 5d 20 3d 20 2d | 31 3b 0a 58 0a 58 09 72 |(j)] = -|1;.X.X.r|
|000040e0| 65 74 75 72 6e 20 30 3b | 0a 58 7d 0a 58 0a 58 6d |eturn 0;|.X}.X.Xm|
|000040f0| 6f 76 65 5f 6d 61 72 6b | 28 69 2c 20 6a 2c 20 6f |ove_mark|(i, j, o|
|00004100| 66 66 29 0a 58 69 6e 74 | 20 69 3b 0a 58 69 6e 74 |ff).Xint| i;.Xint|
|00004110| 20 6a 3b 0a 58 7b 0a 58 | 09 62 75 66 66 65 72 20 | j;.X{.X|.buffer |
|00004120| 2a 62 3b 0a 58 0a 58 09 | 43 48 45 43 4b 28 62 2c |*b;.X.X.|CHECK(b,|
|00004130| 69 2c 22 6d 6f 76 65 5f | 6d 61 72 6b 22 2c 2d 31 |i,"move_|mark",-1|
|00004140| 29 3b 0a 58 09 43 48 45 | 43 4b 4d 41 52 4b 28 62 |);.X.CHE|CKMARK(b|
|00004150| 2c 6a 2c 2d 31 29 3b 0a | 58 0a 58 09 69 66 28 6a |,j,-1);.|X.X.if(j|
|00004160| 20 3c 3d 20 30 29 20 7b | 0a 58 09 09 62 75 66 66 | <= 0) {|.X..buff|
|00004170| 65 72 5f 65 72 72 6f 72 | 20 3d 20 22 4d 6f 76 69 |er_error| = "Movi|
|00004180| 6e 67 20 66 69 78 65 64 | 20 6d 61 72 6b 22 3b 0a |ng fixed| mark";.|
|00004190| 58 09 09 72 65 74 75 72 | 6e 20 2d 31 3b 0a 58 09 |X..retur|n -1;.X.|
|000041a0| 7d 0a 58 0a 58 09 6f 66 | 66 20 2b 3d 20 62 2d 3e |}.X.X.of|f += b->|
|000041b0| 6d 61 72 6b 5b 6d 61 72 | 6b 32 69 6e 64 65 78 28 |mark[mar|k2index(|
|000041c0| 6a 29 5d 3b 0a 58 0a 58 | 09 69 66 28 6f 66 66 20 |j)];.X.X|.if(off |
|000041d0| 3e 20 62 2d 3e 74 65 78 | 74 5f 6c 65 6e 67 74 68 |> b->tex|t_length|
|000041e0| 29 20 7b 0a 58 09 09 62 | 75 66 66 65 72 5f 65 72 |) {.X..b|uffer_er|
|000041f0| 72 6f 72 20 3d 20 66 6f | 75 6e 64 5f 65 6f 66 3b |ror = fo|und_eof;|
|00004200| 0a 58 09 09 72 65 74 75 | 72 6e 20 2d 31 3b 0a 58 |.X..retu|rn -1;.X|
|00004210| 09 7d 0a 58 0a 58 09 69 | 66 28 6f 66 66 20 3c 20 |.}.X.X.i|f(off < |
|00004220| 30 29 20 7b 0a 58 09 09 | 62 75 66 66 65 72 5f 65 |0) {.X..|buffer_e|
|00004230| 72 72 6f 72 20 3d 20 66 | 6f 75 6e 64 5f 62 6f 66 |rror = f|ound_bof|
|00004240| 3b 0a 58 09 09 72 65 74 | 75 72 6e 20 2d 31 3b 0a |;.X..ret|urn -1;.|
|00004250| 58 09 7d 0a 58 0a 58 09 | 62 2d 3e 6d 61 72 6b 5b |X.}.X.X.|b->mark[|
|00004260| 6d 61 72 6b 32 69 6e 64 | 65 78 28 6a 29 5d 20 3d |mark2ind|ex(j)] =|
|00004270| 20 6f 66 66 3b 0a 58 0a | 58 09 72 65 74 75 72 6e | off;.X.|X.return|
|00004280| 20 6f 66 66 3b 0a 58 7d | 0a 58 0a 58 6c 6f 63 61 | off;.X}|.X.Xloca|
|00004290| 74 65 5f 6d 61 72 6b 28 | 69 2c 20 6a 29 0a 58 69 |te_mark(|i, j).Xi|
|000042a0| 6e 74 20 69 3b 0a 58 69 | 6e 74 20 6a 3b 0a 58 7b |nt i;.Xi|nt j;.X{|
|000042b0| 0a 58 09 62 75 66 66 65 | 72 20 2a 62 3b 0a 58 0a |.X.buffe|r *b;.X.|
|000042c0| 58 09 43 48 45 43 4b 28 | 62 2c 69 2c 22 6c 6f 63 |X.CHECK(|b,i,"loc|
|000042d0| 61 74 65 5f 6d 61 72 6b | 22 2c 2d 31 29 3b 0a 58 |ate_mark|",-1);.X|
|000042e0| 09 43 48 45 43 4b 4d 41 | 52 4b 28 62 2c 6a 2c 2d |.CHECKMA|RK(b,j,-|
|000042f0| 31 29 3b 0a 58 0a 58 09 | 69 66 28 6a 20 3d 3d 20 |1);.X.X.|if(j == |
|00004300| 2d 31 29 0a 58 09 09 72 | 65 74 75 72 6e 20 62 2d |-1).X..r|eturn b-|
|00004310| 3e 74 65 78 74 5f 6c 65 | 6e 67 74 68 3b 0a 58 09 |>text_le|ngth;.X.|
|00004320| 65 6c 73 65 20 69 66 28 | 6a 20 3d 3d 20 30 29 0a |else if(|j == 0).|
|00004330| 58 09 09 72 65 74 75 72 | 6e 20 30 3b 0a 58 09 65 |X..retur|n 0;.X.e|
|00004340| 6c 73 65 20 7b 0a 58 09 | 09 69 6e 74 20 6f 66 66 |lse {.X.|.int off|
|00004350| 20 3d 20 62 2d 3e 6d 61 | 72 6b 5b 6d 61 72 6b 32 | = b->ma|rk[mark2|
|00004360| 69 6e 64 65 78 28 6a 29 | 5d 3b 0a 58 23 69 66 6e |index(j)|];.X#ifn|
|00004370| 64 65 66 20 54 45 53 54 | 0a 58 09 09 69 66 28 6f |def TEST|.X..if(o|
|00004380| 66 66 20 3d 3d 20 2d 31 | 29 0a 58 09 09 09 62 75 |ff == -1|).X...bu|
|00004390| 66 66 65 72 5f 65 72 72 | 6f 72 20 3d 20 22 4d 61 |ffer_err|or = "Ma|
|000043a0| 72 6b 20 6e 6f 74 20 73 | 65 74 22 3b 0a 58 09 09 |rk not s|et";.X..|
|000043b0| 65 6c 73 65 20 69 66 28 | 6f 66 66 20 3c 20 2d 31 |else if(|off < -1|
|000043c0| 20 7c 7c 20 6f 66 66 20 | 3e 20 62 2d 3e 74 65 78 | || off |> b->tex|
|000043d0| 74 5f 6c 65 6e 67 74 68 | 29 20 7b 0a 58 09 09 09 |t_length|) {.X...|
|000043e0| 62 75 66 66 65 72 5f 65 | 72 72 6f 72 20 3d 20 22 |buffer_e|rror = "|
|000043f0| 49 6e 74 65 72 6e 61 6c | 20 65 72 72 6f 72 3a 20 |Internal| error: |
|00004400| 42 61 64 20 6d 61 72 6b | 22 3b 0a 58 09 09 09 72 |Bad mark|";.X...r|
|00004410| 65 74 75 72 6e 20 2d 31 | 3b 0a 58 09 09 7d 0a 58 |eturn -1|;.X..}.X|
|00004420| 23 65 6e 64 69 66 0a 58 | 09 09 72 65 74 75 72 6e |#endif.X|..return|
|00004430| 20 6f 66 66 3b 0a 58 09 | 7d 0a 58 7d 0a 58 0a 58 | off;.X.|}.X}.X.X|
|00004440| 73 74 61 74 69 63 20 73 | 61 66 65 63 6f 70 79 28 |static s|afecopy(|
|00004450| 62 6f 64 79 2c 20 74 6f | 2c 20 66 72 6f 6d 2c 20 |body, to|, from, |
|00004460| 6c 65 6e 67 74 68 29 0a | 58 63 68 61 72 20 2a 62 |length).|Xchar *b|
|00004470| 6f 64 79 3b 0a 58 69 6e | 74 20 74 6f 2c 20 66 72 |ody;.Xin|t to, fr|
|00004480| 6f 6d 2c 20 6c 65 6e 67 | 74 68 3b 0a 58 7b 0a 58 |om, leng|th;.X{.X|
|00004490| 09 69 6e 74 20 69 3b 0a | 58 0a 58 09 69 66 28 74 |.int i;.|X.X.if(t|
|000044a0| 6f 3e 66 72 6f 6d 29 0a | 58 09 09 66 6f 72 28 69 |o>from).|X..for(i|
|000044b0| 20 3d 20 30 3b 20 69 20 | 3c 20 6c 65 6e 67 74 68 | = 0; i |< length|
|000044c0| 3b 20 69 2b 2b 29 0a 58 | 09 09 09 62 6f 64 79 5b |; i++).X|...body[|
|000044d0| 74 6f 2b 69 5d 20 3d 20 | 62 6f 64 79 5b 66 72 6f |to+i] = |body[fro|
|000044e0| 6d 2b 69 5d 3b 0a 58 09 | 65 6c 73 65 0a 58 09 09 |m+i];.X.|else.X..|
|000044f0| 66 6f 72 28 69 20 3d 20 | 6c 65 6e 67 74 68 2d 31 |for(i = |length-1|
|00004500| 3b 20 69 3e 3d 30 3b 20 | 69 2d 2d 29 0a 58 09 09 |; i>=0; |i--).X..|
|00004510| 09 62 6f 64 79 5b 74 6f | 2b 69 5d 20 3d 20 62 6f |.body[to|+i] = bo|
|00004520| 64 79 5b 66 72 6f 6d 2b | 69 5d 3b 0a 58 7d 0a 58 |dy[from+|i];.X}.X|
|00004530| 0a 58 2f 2a 20 6d 6f 76 | 65 5f 67 61 70 28 62 75 |.X/* mov|e_gap(bu|
|00004540| 66 66 65 72 2c 20 67 61 | 70 5f 70 6f 73 69 74 69 |ffer, ga|p_positi|
|00004550| 6f 6e 29 0a 58 20 2a 0a | 58 20 2a 20 4d 6f 76 65 |on).X *.|X * Move|
|00004560| 73 20 74 68 65 20 67 61 | 70 20 74 6f 20 74 68 65 |s the ga|p to the|
|00004570| 20 69 6e 64 69 63 61 74 | 65 64 20 70 6f 73 69 74 | indicat|ed posit|
|00004580| 69 6f 6e 20 69 6e 20 74 | 68 65 20 62 75 66 66 65 |ion in t|he buffe|
|00004590| 72 2e 20 54 68 69 73 20 | 64 6f 65 73 20 6e 6f 74 |r. This |does not|
|000045a0| 20 63 68 61 6e 67 65 0a | 58 20 2a 20 74 68 65 20 | change.|X * the |
|000045b0| 6c 6f 67 69 63 61 6c 20 | 73 74 72 75 63 74 75 72 |logical |structur|
|000045c0| 65 20 6f 66 20 74 68 65 | 20 62 75 66 66 65 72 2e |e of the| buffer.|
|000045d0| 20 49 74 20 69 73 20 6d | 6f 73 74 20 6f 66 74 65 | It is m|ost ofte|
|000045e0| 6e 20 75 73 65 64 20 74 | 6f 20 6d 6f 76 65 20 74 |n used t|o move t|
|000045f0| 68 65 20 67 61 70 0a 58 | 20 2a 20 74 6f 20 61 20 |he gap.X| * to a |
|00004600| 6d 61 72 6b 20 66 6f 72 | 20 64 65 6c 65 74 69 6f |mark for| deletio|
|00004610| 6e 20 6f 72 20 28 69 66 | 20 73 70 61 63 65 20 61 |n or (if| space a|
|00004620| 6c 6c 6f 77 73 29 20 69 | 6e 73 65 72 74 69 6f 6e |llows) i|nsertion|
|00004630| 2e 20 49 74 27 73 20 61 | 6c 73 6f 20 75 73 65 64 |. It's a|lso used|
|00004640| 20 74 6f 0a 58 20 2a 20 | 6d 6f 76 65 20 74 68 65 | to.X * |move the|
|00004650| 20 67 61 70 20 6f 75 74 | 20 6f 66 20 72 61 6e 67 | gap out| of rang|
|00004660| 65 20 6f 66 20 61 20 73 | 65 74 20 6f 66 20 6d 61 |e of a s|et of ma|
|00004670| 72 6b 73 2e 0a 58 20 2a | 2f 0a 58 73 74 61 74 69 |rks..X *|/.Xstati|
|00004680| 63 20 6d 6f 76 65 5f 67 | 61 70 28 69 2c 20 6e 65 |c move_g|ap(i, ne|
|00004690| 77 67 61 70 29 0a 58 69 | 6e 74 20 69 3b 0a 58 69 |wgap).Xi|nt i;.Xi|
|000046a0| 6e 74 20 6e 65 77 67 61 | 70 3b 0a 58 7b 0a 58 09 |nt newga|p;.X{.X.|
|000046b0| 62 75 66 66 65 72 20 2a | 62 3b 0a 58 0a 58 09 43 |buffer *|b;.X.X.C|
|000046c0| 48 45 43 4b 28 62 2c 69 | 2c 22 6d 6f 76 65 5f 67 |HECK(b,i|,"move_g|
|000046d0| 61 70 22 2c 2d 31 29 3b | 0a 58 0a 58 09 69 66 28 |ap",-1);|.X.X.if(|
|000046e0| 6e 65 77 67 61 70 20 3e | 20 62 2d 3e 67 61 70 29 |newgap >| b->gap)|
|000046f0| 20 7b 0a 58 09 09 73 61 | 66 65 63 6f 70 79 28 62 | {.X..sa|fecopy(b|
|00004700| 2d 3e 62 6f 64 79 2c 0a | 58 09 09 09 20 62 2d 3e |->body,.|X... b->|
|00004710| 67 61 70 2c 09 2f 2a 20 | 6d 6f 76 65 20 74 6f 20 |gap,./* |move to |
|00004720| 62 65 67 69 6e 6e 69 6e | 67 20 6f 66 20 6f 6c 64 |beginnin|g of old|
|00004730| 20 67 61 70 20 2a 2f 0a | 58 09 09 09 20 62 2d 3e | gap */.|X... b->|
|00004740| 67 61 70 2b 62 2d 3e 67 | 61 70 73 69 7a 65 2c 09 |gap+b->g|apsize,.|
|00004750| 2f 2a 20 66 72 6f 6d 20 | 65 6e 64 20 6f 66 20 6f |/* from |end of o|
|00004760| 6c 64 20 67 61 70 20 2a | 2f 0a 58 09 09 09 20 6e |ld gap *|/.X... n|
|00004770| 65 77 67 61 70 2d 62 2d | 3e 67 61 70 29 3b 0a 58 |ewgap-b-|>gap);.X|
|00004780| 09 7d 20 65 6c 73 65 20 | 7b 0a 58 09 09 73 61 66 |.} else |{.X..saf|
|00004790| 65 63 6f 70 79 28 62 2d | 3e 62 6f 64 79 2c 0a 58 |ecopy(b-|>body,.X|
|000047a0| 09 09 09 20 6e 65 77 67 | 61 70 2b 62 2d 3e 67 61 |... newg|ap+b->ga|
|000047b0| 70 73 69 7a 65 2c 09 2f | 2a 20 6d 6f 76 65 20 74 |psize,./|* move t|
|000047c0| 6f 20 65 6e 64 20 6f 66 | 20 6e 65 77 20 67 61 70 |o end of| new gap|
|000047d0| 20 2a 2f 0a 58 09 09 09 | 20 6e 65 77 67 61 70 2c | */.X...| newgap,|
|000047e0| 09 2f 2a 20 66 72 6f 6d | 20 62 65 67 69 6e 6e 69 |./* from| beginni|
|000047f0| 6e 67 20 6f 66 20 6e 65 | 77 20 67 61 70 20 2a 2f |ng of ne|w gap */|
|00004800| 0a 58 09 09 09 20 62 2d | 3e 67 61 70 2d 6e 65 77 |.X... b-|>gap-new|
|00004810| 67 61 70 29 3b 0a 58 09 | 7d 0a 58 09 62 2d 3e 67 |gap);.X.|}.X.b->g|
|00004820| 61 70 20 3d 20 6e 65 77 | 67 61 70 3b 0a 58 0a 58 |ap = new|gap;.X.X|
|00004830| 09 72 65 74 75 72 6e 20 | 30 3b 0a 58 7d 0a 58 0a |.return |0;.X}.X.|
|00004840| 58 2f 2a 20 65 78 70 61 | 6e 64 5f 67 61 70 28 62 |X/* expa|nd_gap(b|
|00004850| 75 66 66 65 72 2c 20 73 | 70 61 63 65 5f 6e 65 65 |uffer, s|pace_nee|
|00004860| 64 65 64 2c 20 67 61 70 | 5f 70 6f 73 69 74 69 6f |ded, gap|_positio|
|00004870| 6e 29 0a 58 20 2a 0a 58 | 20 2a 20 42 65 63 61 75 |n).X *.X| * Becau|
|00004880| 73 65 20 74 68 65 20 67 | 61 70 20 75 73 75 61 6c |se the g|ap usual|
|00004890| 6c 79 20 6e 65 65 64 73 | 20 74 6f 20 62 65 20 6d |ly needs| to be m|
|000048a0| 6f 76 65 64 20 77 68 65 | 6e 20 69 74 27 73 20 65 |oved whe|n it's e|
|000048b0| 78 70 61 6e 64 65 64 2c | 20 49 20 63 6f 6d 62 69 |xpanded,| I combi|
|000048c0| 6e 65 20 74 68 65 0a 58 | 20 2a 20 74 77 6f 20 61 |ne the.X| * two a|
|000048d0| 63 74 69 6f 6e 73 20 69 | 6e 74 6f 20 61 20 73 69 |ctions i|nto a si|
|000048e0| 6e 67 6c 65 20 65 78 70 | 61 6e 64 5f 67 61 70 2e |ngle exp|and_gap.|
|000048f0| 20 54 68 69 73 20 69 73 | 20 6d 6f 72 65 20 65 66 | This is| more ef|
|00004900| 66 69 63 69 65 6e 74 20 | 66 6f 72 20 74 68 65 20 |ficient |for the |
|00004910| 63 6f 6d 6d 6f 6e 0a 58 | 20 2a 20 63 61 73 65 2c |common.X| * case,|
|00004920| 20 74 68 6f 75 67 68 20 | 69 74 20 6d 61 6b 65 73 | though |it makes|
|00004930| 20 74 68 65 20 63 6f 64 | 65 20 61 20 6c 69 74 74 | the cod|e a litt|
|00004940| 6c 65 20 68 61 72 64 20 | 74 6f 20 66 6f 6c 6c 6f |le hard |to follo|
|00004950| 77 2e 0a 58 20 2a 0a 58 | 20 2a 20 59 6f 75 20 61 |w..X *.X| * You a|
|00004960| 72 65 20 6e 6f 74 20 65 | 78 70 65 63 74 65 64 20 |re not e|xpected |
|00004970| 74 6f 20 75 6e 64 65 72 | 73 74 61 6e 64 20 74 68 |to under|stand th|
|00004980| 69 73 2e 0a 58 20 2a 0a | 58 20 2a 20 49 27 76 65 |is..X *.|X * I've|
|00004990| 20 61 6c 77 61 79 73 20 | 77 61 6e 74 65 64 20 74 | always |wanted t|
|000049a0| 6f 20 73 61 79 20 74 68 | 61 74 2e 20 3a 2d 3e 0a |o say th|at. :->.|
|000049b0| 58 20 2a 0a 58 20 2a 20 | 49 20 70 72 6f 62 61 62 |X *.X * |I probab|
|000049c0| 6c 79 20 6e 65 65 64 20 | 74 6f 20 70 75 74 20 63 |ly need |to put c|
|000049d0| 6f 6e 64 69 74 69 6f 6e | 73 20 6f 6e 20 73 6f 6d |ondition|s on som|
|000049e0| 65 20 6d 6f 72 65 20 6f | 66 20 74 68 65 20 63 61 |e more o|f the ca|
|000049f0| 6c 6c 73 20 74 6f 20 6d | 65 6d 63 70 79 20 74 6f |lls to m|emcpy to|
|00004a00| 0a 58 20 2a 20 68 61 6e | 64 6c 65 20 74 68 65 20 |.X * han|dle the |
|00004a10| 63 61 73 65 20 6f 66 20 | 74 68 65 20 67 61 70 20 |case of |the gap |
|00004a20| 62 65 69 6e 67 20 61 74 | 20 74 68 65 20 62 65 67 |being at| the beg|
|00004a30| 69 6e 6e 69 6e 67 20 6f | 72 20 65 6e 64 20 6f 66 |inning o|r end of|
|00004a40| 20 74 68 65 20 62 75 66 | 66 65 72 2e 0a 58 20 2a | the buf|fer..X *|
|00004a50| 20 54 68 61 74 27 73 20 | 6a 75 73 74 20 61 6e 20 | That's |just an |
|00004a60| 6f 70 74 69 6d 69 7a 61 | 74 69 6f 6e 2c 20 62 75 |optimiza|tion, bu|
|00004a70| 74 20 77 68 61 74 20 74 | 68 65 20 68 65 63 6b 2e |t what t|he heck.|
|00004a80| 0a 58 20 2a 2f 0a 58 73 | 74 61 74 69 63 20 65 78 |.X */.Xs|tatic ex|
|00004a90| 70 61 6e 64 5f 67 61 70 | 28 69 2c 20 6e 65 77 73 |pand_gap|(i, news|
|00004aa0| 69 7a 65 2c 20 6e 65 77 | 67 61 70 29 0a 58 69 6e |ize, new|gap).Xin|
|00004ab0| 74 20 69 3b 0a 58 69 6e | 74 20 6e 65 77 73 69 7a |t i;.Xin|t newsiz|
|00004ac0| 65 3b 0a 58 69 6e 74 20 | 6e 65 77 67 61 70 3b 0a |e;.Xint |newgap;.|
|00004ad0| 58 7b 0a 58 09 62 75 66 | 66 65 72 20 2a 62 3b 0a |X{.X.buf|fer *b;.|
|00004ae0| 58 09 63 68 61 72 20 2a | 6e 65 77 62 6f 64 79 3b |X.char *|newbody;|
|00004af0| 0a 58 09 69 6e 74 20 6e | 65 77 6c 65 6e 67 74 68 |.X.int n|ewlength|
|00004b00| 3b 0a 58 0a 58 09 43 48 | 45 43 4b 28 62 2c 69 2c |;.X.X.CH|ECK(b,i,|
|00004b10| 22 65 78 70 61 6e 64 5f | 67 61 70 22 2c 2d 31 29 |"expand_|gap",-1)|
|00004b20| 3b 0a 58 0a 58 09 6e 65 | 77 6c 65 6e 67 74 68 20 |;.X.X.ne|wlength |
|00004b30| 3d 20 62 2d 3e 62 6f 64 | 79 5f 6c 65 6e 67 74 68 |= b->bod|y_length|
|00004b40| 20 2b 20 6e 65 77 73 69 | 7a 65 3b 0a 58 09 6e 65 | + newsi|ze;.X.ne|
|00004b50| 77 62 6f 64 79 20 3d 20 | 6d 61 6c 6c 6f 63 28 6e |wbody = |malloc(n|
|00004b60| 65 77 6c 65 6e 67 74 68 | 29 3b 0a 58 09 69 66 28 |ewlength|);.X.if(|
|00004b70| 6e 65 77 62 6f 64 79 29 | 0a 58 09 09 6e 65 77 73 |newbody)|.X..news|
|00004b80| 69 7a 65 20 2b 3d 20 62 | 2d 3e 67 61 70 73 69 7a |ize += b|->gapsiz|
|00004b90| 65 3b 0a 58 09 65 6c 73 | 65 20 7b 0a 58 09 09 6e |e;.X.els|e {.X..n|
|00004ba0| 65 77 6c 65 6e 67 74 68 | 20 3d 20 62 2d 3e 74 65 |ewlength| = b->te|
|00004bb0| 78 74 5f 6c 65 6e 67 74 | 68 20 2b 20 6e 65 77 73 |xt_lengt|h + news|
|00004bc0| 69 7a 65 3b 0a 58 09 09 | 6e 65 77 62 6f 64 79 20 |ize;.X..|newbody |
|00004bd0| 3d 20 6d 61 6c 6c 6f 63 | 28 6e 65 77 6c 65 6e 67 |= malloc|(newleng|
|00004be0| 74 68 29 3b 0a 58 09 7d | 0a 58 0a 58 09 69 66 28 |th);.X.}|.X.X.if(|
|00004bf0| 21 6e 65 77 62 6f 64 79 | 29 20 7b 0a 58 09 09 62 |!newbody|) {.X..b|
|00004c00| 75 66 66 65 72 5f 65 72 | 72 6f 72 20 3d 20 22 4d |uffer_er|ror = "M|
|00004c10| 65 6d 6f 72 79 20 61 6c | 6c 6f 63 61 74 69 6f 6e |emory al|location|
|00004c20| 20 66 61 69 6c 75 72 65 | 22 3b 0a 58 09 09 72 65 | failure|";.X..re|
|00004c30| 74 75 72 6e 20 2d 31 3b | 0a 58 09 7d 0a 58 0a 58 |turn -1;|.X.}.X.X|
|00004c40| 09 2f 2a 20 48 65 72 65 | 20 74 68 65 72 65 20 62 |./* Here| there b|
|00004c50| 65 20 74 79 67 65 72 73 | 2e 20 49 66 20 79 6f 75 |e tygers|. If you|
|00004c60| 20 63 68 61 6e 67 65 20 | 74 68 69 73 20 63 6f 64 | change |this cod|
|00004c70| 65 2c 20 73 69 74 20 64 | 6f 77 6e 20 61 68 65 61 |e, sit d|own ahea|
|00004c80| 64 20 6f 66 0a 58 09 20 | 2a 20 74 69 6d 65 20 61 |d of.X. |* time a|
|00004c90| 6e 64 20 66 69 67 75 72 | 65 20 6f 75 74 20 45 58 |nd figur|e out EX|
|00004ca0| 41 43 54 4c 59 20 77 68 | 61 74 20 74 68 65 20 69 |ACTLY wh|at the i|
|00004cb0| 6e 64 69 76 69 64 75 61 | 6c 20 6d 6f 76 65 73 20 |ndividua|l moves |
|00004cc0| 64 6f 2e 0a 58 09 20 2a | 2f 0a 58 09 69 66 28 62 |do..X. *|/.X.if(b|
|00004cd0| 2d 3e 62 6f 64 79 29 20 | 7b 0a 58 09 09 69 66 28 |->body) |{.X..if(|
|00004ce0| 6e 65 77 67 61 70 20 3c | 20 62 2d 3e 67 61 70 29 |newgap <| b->gap)|
|00004cf0| 20 7b 0a 58 09 09 09 6d | 65 6d 63 70 79 28 6e 65 | {.X...m|emcpy(ne|
|00004d00| 77 62 6f 64 79 2c 20 62 | 2d 3e 62 6f 64 79 2c 20 |wbody, b|->body, |
|00004d10| 6e 65 77 67 61 70 29 3b | 0a 58 09 09 09 6d 65 6d |newgap);|.X...mem|
|00004d20| 63 70 79 28 6e 65 77 62 | 6f 64 79 2b 6e 65 77 67 |cpy(newb|ody+newg|
|00004d30| 61 70 2b 6e 65 77 73 69 | 7a 65 2c 20 62 2d 3e 62 |ap+newsi|ze, b->b|
|00004d40| 6f 64 79 2b 6e 65 77 67 | 61 70 2c 0a 58 09 09 09 |ody+newg|ap,.X...|
|00004d50| 09 62 2d 3e 67 61 70 2d | 6e 65 77 67 61 70 29 3b |.b->gap-|newgap);|
|00004d60| 0a 58 09 09 09 6d 65 6d | 63 70 79 28 6e 65 77 62 |.X...mem|cpy(newb|
|00004d70| 6f 64 79 2b 6e 65 77 73 | 69 7a 65 2b 62 2d 3e 67 |ody+news|ize+b->g|
|00004d80| 61 70 2c 0a 58 09 09 09 | 09 62 2d 3e 62 6f 64 79 |ap,.X...|.b->body|
|00004d90| 2b 62 2d 3e 67 61 70 2b | 62 2d 3e 67 61 70 73 69 |+b->gap+|b->gapsi|
|00004da0| 7a 65 2c 0a 58 09 09 09 | 09 62 2d 3e 74 65 78 74 |ze,.X...|.b->text|
|00004db0| 5f 6c 65 6e 67 74 68 2d | 62 2d 3e 67 61 70 29 3b |_length-|b->gap);|
|00004dc0| 0a 58 09 09 7d 20 65 6c | 73 65 20 7b 0a 58 09 09 |.X..} el|se {.X..|
|00004dd0| 09 6d 65 6d 63 70 79 28 | 6e 65 77 62 6f 64 79 2c |.memcpy(|newbody,|
|00004de0| 20 62 2d 3e 62 6f 64 79 | 2c 20 62 2d 3e 67 61 70 | b->body|, b->gap|
|00004df0| 29 3b 0a 58 09 09 09 69 | 66 28 6e 65 77 67 61 70 |);.X...i|f(newgap|
|00004e00| 20 3e 20 62 2d 3e 67 61 | 70 29 20 7b 0a 58 09 09 | > b->ga|p) {.X..|
|00004e10| 09 09 6d 65 6d 63 70 79 | 28 6e 65 77 62 6f 64 79 |..memcpy|(newbody|
|00004e20| 2b 62 2d 3e 67 61 70 2c | 0a 58 09 09 09 09 09 62 |+b->gap,|.X.....b|
|00004e30| 2d 3e 62 6f 64 79 2b 62 | 2d 3e 67 61 70 2b 62 2d |->body+b|->gap+b-|
|00004e40| 3e 67 61 70 73 69 7a 65 | 2c 0a 58 09 09 09 09 09 |>gapsize|,.X.....|
|00004e50| 6e 65 77 67 61 70 2d 62 | 2d 3e 67 61 70 29 3b 0a |newgap-b|->gap);.|
|00004e60| 58 09 09 09 7d 0a 58 09 | 09 09 6d 65 6d 63 70 79 |X...}.X.|..memcpy|
|00004e70| 28 6e 65 77 62 6f 64 79 | 2b 6e 65 77 67 61 70 2b |(newbody|+newgap+|
|00004e80| 6e 65 77 73 69 7a 65 2c | 0a 58 09 09 09 09 62 2d |newsize,|.X....b-|
|00004e90| 3e 62 6f 64 79 2b 62 2d | 3e 67 61 70 73 69 7a 65 |>body+b-|>gapsize|
|00004ea0| 2b 6e 65 77 67 61 70 2c | 0a 58 09 09 09 09 62 2d |+newgap,|.X....b-|
|00004eb0| 3e 74 65 78 74 5f 6c 65 | 6e 67 74 68 2d 6e 65 77 |>text_le|ngth-new|
|00004ec0| 67 61 70 29 3b 0a 58 09 | 09 7d 0a 58 0a 58 09 09 |gap);.X.|.}.X.X..|
|00004ed0| 66 72 65 65 28 62 2d 3e | 62 6f 64 79 29 3b 0a 58 |free(b->|body);.X|
|00004ee0| 09 7d 0a 58 0a 58 09 62 | 2d 3e 62 6f 64 79 20 3d |.}.X.X.b|->body =|
|00004ef0| 20 6e 65 77 62 6f 64 79 | 3b 0a 58 09 62 2d 3e 67 | newbody|;.X.b->g|
|00004f00| 61 70 20 3d 20 6e 65 77 | 67 61 70 3b 0a 58 09 62 |ap = new|gap;.X.b|
|00004f10| 2d 3e 67 61 70 73 69 7a | 65 20 3d 20 6e 65 77 73 |->gapsiz|e = news|
|00004f20| 69 7a 65 3b 0a 58 09 62 | 2d 3e 62 6f 64 79 5f 6c |ize;.X.b|->body_l|
|00004f30| 65 6e 67 74 68 20 3d 20 | 6e 65 77 6c 65 6e 67 74 |ength = |newlengt|
|00004f40| 68 3b 0a 58 09 62 2d 3e | 74 65 78 74 5f 6c 65 6e |h;.X.b->|text_len|
|00004f50| 67 74 68 20 3d 20 6e 65 | 77 6c 65 6e 67 74 68 2d |gth = ne|wlength-|
|00004f60| 6e 65 77 73 69 7a 65 3b | 0a 58 0a 58 09 72 65 74 |newsize;|.X.X.ret|
|00004f70| 75 72 6e 20 62 2d 3e 67 | 61 70 73 69 7a 65 3b 0a |urn b->g|apsize;.|
|00004f80| 58 7d 0a 58 0a 58 63 68 | 61 72 20 2a 74 65 78 74 |X}.X.Xch|ar *text|
|00004f90| 28 69 2c 20 6d 31 2c 20 | 6d 32 2c 20 6c 65 6e 67 |(i, m1, |m2, leng|
|00004fa0| 74 68 29 0a 58 69 6e 74 | 20 69 3b 0a 58 69 6e 74 |th).Xint| i;.Xint|
|00004fb0| 20 6d 31 2c 20 6d 32 3b | 0a 58 69 6e 74 20 2a 6c | m1, m2;|.Xint *l|
|00004fc0| 65 6e 67 74 68 3b 0a 58 | 7b 0a 58 09 62 75 66 66 |ength;.X|{.X.buff|
|00004fd0| 65 72 20 2a 62 3b 0a 58 | 09 63 68 61 72 20 2a 70 |er *b;.X|.char *p|
|00004fe0| 3b 0a 58 09 69 6e 74 20 | 6f 31 2c 20 6f 32 3b 0a |;.X.int |o1, o2;.|
|00004ff0| 58 09 69 6e 74 20 73 74 | 61 72 74 3b 0a 58 0a 58 |X.int st|art;.X.X|
|00005000| 09 43 48 45 43 4b 28 62 | 2c 69 2c 22 74 65 78 74 |.CHECK(b|,i,"text|
|00005010| 22 2c 30 29 3b 0a 58 0a | 58 09 69 66 20 28 28 6f |",0);.X.|X.if ((o|
|00005020| 31 20 3d 20 6c 6f 63 61 | 74 65 5f 6d 61 72 6b 28 |1 = loca|te_mark(|
|00005030| 69 2c 20 6d 31 29 29 20 | 3d 3d 20 2d 31 0a 58 09 |i, m1)) |== -1.X.|
|00005040| 20 7c 7c 20 28 6f 32 20 | 3d 20 6c 6f 63 61 74 65 | || (o2 |= locate|
|00005050| 5f 6d 61 72 6b 28 69 2c | 20 6d 32 29 29 20 3d 3d |_mark(i,| m2)) ==|
|00005060| 20 2d 31 29 0a 58 09 09 | 72 65 74 75 72 6e 20 30 | -1).X..|return 0|
|00005070| 3b 0a 58 0a 58 09 69 66 | 28 6f 32 20 3c 20 6f 31 |;.X.X.if|(o2 < o1|
|00005080| 29 20 7b 0a 58 09 09 69 | 6e 74 20 74 6d 70 20 3d |) {.X..i|nt tmp =|
|00005090| 20 6f 32 3b 0a 58 09 09 | 6f 32 20 3d 20 6f 31 3b | o2;.X..|o2 = o1;|
|000050a0| 0a 58 09 09 6f 31 20 3d | 20 74 6d 70 3b 0a 58 09 |.X..o1 =| tmp;.X.|
|000050b0| 7d 0a 58 0a 58 09 2a 6c | 65 6e 67 74 68 20 3d 20 |}.X.X.*l|ength = |
|000050c0| 6f 32 20 2d 20 6f 31 3b | 0a 58 0a 58 09 69 66 28 |o2 - o1;|.X.X.if(|
|000050d0| 6f 31 20 3c 20 62 2d 3e | 67 61 70 20 26 26 20 6f |o1 < b->|gap && o|
|000050e0| 32 20 3e 20 62 2d 3e 67 | 61 70 29 0a 58 09 09 6d |2 > b->g|ap).X..m|
|000050f0| 6f 76 65 5f 67 61 70 28 | 69 2c 20 6f 32 29 3b 0a |ove_gap(|i, o2);.|
|00005100| 58 0a 58 09 73 74 61 72 | 74 20 3d 20 6f 31 3b 0a |X.X.star|t = o1;.|
|00005110| 58 0a 58 09 69 66 28 73 | 74 61 72 74 20 3e 20 62 |X.X.if(s|tart > b|
|00005120| 2d 3e 67 61 70 29 0a 58 | 09 09 73 74 61 72 74 20 |->gap).X|..start |
|00005130| 2b 3d 20 62 2d 3e 67 61 | 70 73 69 7a 65 3b 0a 58 |+= b->ga|psize;.X|
|00005140| 0a 58 09 72 65 74 75 72 | 6e 20 62 2d 3e 62 6f 64 |.X.retur|n b->bod|
|00005150| 79 20 2b 20 73 74 61 72 | 74 3b 0a 58 7d 0a 58 0a |y + star|t;.X}.X.|
|00005160| 58 63 68 61 72 20 2a 6f | 70 65 6e 5f 74 65 78 74 |Xchar *o|pen_text|
|00005170| 28 69 2c 20 6d 61 72 6b | 2c 20 6c 65 6e 67 74 68 |(i, mark|, length|
|00005180| 29 0a 58 69 6e 74 20 69 | 3b 0a 58 69 6e 74 20 6d |).Xint i|;.Xint m|
|00005190| 61 72 6b 3b 0a 58 69 6e | 74 20 6c 65 6e 67 74 68 |ark;.Xin|t length|
|000051a0| 3b 0a 58 7b 0a 58 09 62 | 75 66 66 65 72 20 2a 62 |;.X{.X.b|uffer *b|
|000051b0| 3b 0a 58 09 63 68 61 72 | 20 2a 70 3b 0a 58 09 69 |;.X.char| *p;.X.i|
|000051c0| 6e 74 20 6f 66 66 3b 0a | 58 0a 58 09 43 48 45 43 |nt off;.|X.X.CHEC|
|000051d0| 4b 28 62 2c 69 2c 22 6f | 70 65 6e 5f 74 65 78 74 |K(b,i,"o|pen_text|
|000051e0| 22 2c 30 29 3b 0a 58 0a | 58 09 69 66 20 28 28 6f |",0);.X.|X.if ((o|
|000051f0| 66 66 20 3d 20 6c 6f 63 | 61 74 65 5f 6d 61 72 6b |ff = loc|ate_mark|
|00005200| 28 69 2c 20 6d 61 72 6b | 29 29 20 3d 3d 20 2d 31 |(i, mark|)) == -1|
|00005210| 29 0a 58 09 09 72 65 74 | 75 72 6e 20 30 3b 0a 58 |).X..ret|urn 0;.X|
|00005220| 0a 58 09 69 66 28 62 2d | 3e 67 61 70 73 69 7a 65 |.X.if(b-|>gapsize|
|00005230| 20 3c 20 6c 65 6e 67 74 | 68 29 20 7b 0a 58 09 09 | < lengt|h) {.X..|
|00005240| 69 66 28 65 78 70 61 6e | 64 5f 67 61 70 28 69 2c |if(expan|d_gap(i,|
|00005250| 20 6c 65 6e 67 74 68 2c | 20 6f 66 66 29 20 3c 20 | length,| off) < |
|00005260| 30 29 0a 58 09 09 09 72 | 65 74 75 72 6e 20 30 3b |0).X...r|eturn 0;|
|00005270| 0a 58 09 7d 0a 58 09 65 | 6c 73 65 20 69 66 28 6f |.X.}.X.e|lse if(o|
|00005280| 66 66 20 21 3d 20 62 2d | 3e 67 61 70 29 0a 58 09 |ff != b-|>gap).X.|
|00005290| 09 6d 6f 76 65 5f 67 61 | 70 28 69 2c 20 6f 66 66 |.move_ga|p(i, off|
|000052a0| 29 3b 0a 58 0a 58 09 72 | 65 74 75 72 6e 20 62 2d |);.X.X.r|eturn b-|
|000052b0| 3e 62 6f 64 79 20 2b 20 | 62 2d 3e 67 61 70 3b 0a |>body + |b->gap;.|
|000052c0| 58 7d 0a 58 0a 58 63 6c | 6f 73 65 5f 74 65 78 74 |X}.X.Xcl|ose_text|
|000052d0| 28 69 2c 20 6c 65 6e 67 | 74 68 29 0a 58 69 6e 74 |(i, leng|th).Xint|
|000052e0| 20 69 3b 0a 58 69 6e 74 | 20 6c 65 6e 67 74 68 3b | i;.Xint| length;|
|000052f0| 0a 58 7b 0a 58 09 62 75 | 66 66 65 72 20 2a 62 3b |.X{.X.bu|ffer *b;|
|00005300| 0a 58 0a 58 09 43 48 45 | 43 4b 28 62 2c 69 2c 22 |.X.X.CHE|CK(b,i,"|
|00005310| 63 6c 6f 73 65 5f 74 65 | 78 74 22 2c 2d 31 29 3b |close_te|xt",-1);|
|00005320| 0a 58 0a 58 09 66 69 78 | 5f 6d 61 72 6b 73 28 69 |.X.X.fix|_marks(i|
|00005330| 2c 20 6c 65 6e 67 74 68 | 29 3b 0a 58 0a 58 09 62 |, length|);.X.X.b|
|00005340| 2d 3e 67 61 70 20 2b 3d | 20 6c 65 6e 67 74 68 3b |->gap +=| length;|
|00005350| 0a 58 09 62 2d 3e 67 61 | 70 73 69 7a 65 20 2d 3d |.X.b->ga|psize -=|
|00005360| 20 6c 65 6e 67 74 68 3b | 0a 58 09 62 2d 3e 74 65 | length;|.X.b->te|
|00005370| 78 74 5f 6c 65 6e 67 74 | 68 20 2b 3d 20 6c 65 6e |xt_lengt|h += len|
|00005380| 67 74 68 3b 0a 58 09 72 | 65 74 75 72 6e 20 6c 65 |gth;.X.r|eturn le|
|00005390| 6e 67 74 68 3b 0a 58 7d | 0a 58 0a 58 63 6f 70 79 |ngth;.X}|.X.Xcopy|
|000053a0| 5f 74 65 78 74 28 69 2c | 20 6d 31 2c 20 6d 32 2c |_text(i,| m1, m2,|
|000053b0| 20 6f 75 74 62 75 66 2c | 20 6c 65 6e 67 74 68 29 | outbuf,| length)|
|000053c0| 0a 58 69 6e 74 20 69 3b | 0a 58 69 6e 74 20 6d 31 |.Xint i;|.Xint m1|
|000053d0| 2c 20 6d 32 3b 0a 58 63 | 68 61 72 20 2a 6f 75 74 |, m2;.Xc|har *out|
|000053e0| 62 75 66 3b 0a 58 69 6e | 74 20 6c 65 6e 67 74 68 |buf;.Xin|t length|
|000053f0| 3b 0a 58 7b 0a 58 09 63 | 68 61 72 20 2a 70 3b 0a |;.X{.X.c|har *p;.|
|00005400| 58 09 69 6e 74 20 64 65 | 6c 74 61 3b 0a 58 0a 58 |X.int de|lta;.X.X|
|00005410| 09 70 20 3d 20 74 65 78 | 74 28 69 2c 20 6d 31 2c |.p = tex|t(i, m1,|
|00005420| 20 6d 32 2c 20 26 64 65 | 6c 74 61 29 3b 0a 58 0a | m2, &de|lta);.X.|
|00005430| 58 09 69 66 28 21 70 29 | 20 72 65 74 75 72 6e 20 |X.if(!p)| return |
|00005440| 2d 31 3b 0a 58 0a 58 09 | 69 66 28 64 65 6c 74 61 |-1;.X.X.|if(delta|
|00005450| 20 3e 20 6c 65 6e 67 74 | 68 29 20 7b 0a 58 09 09 | > lengt|h) {.X..|
|00005460| 62 75 66 66 65 72 5f 65 | 72 72 6f 72 20 3d 20 22 |buffer_e|rror = "|
|00005470| 4f 75 74 70 75 74 20 73 | 74 72 69 6e 67 20 74 6f |Output s|tring to|
|00005480| 6f 20 73 68 6f 72 74 22 | 3b 0a 58 09 09 72 65 74 |o short"|;.X..ret|
|00005490| 75 72 6e 20 2d 31 3b 0a | 58 09 7d 0a 58 0a 58 09 |urn -1;.|X.}.X.X.|
|000054a0| 6d 65 6d 63 70 79 28 6f | 75 74 62 75 66 2c 20 70 |memcpy(o|utbuf, p|
|000054b0| 2c 20 64 65 6c 74 61 29 | 3b 0a 58 0a 58 09 72 65 |, delta)|;.X.X.re|
|000054c0| 74 75 72 6e 20 64 65 6c | 74 61 3b 0a 58 7d 0a 58 |turn del|ta;.X}.X|
|000054d0| 0a 58 63 75 74 5f 74 65 | 78 74 28 69 2c 20 6d 31 |.Xcut_te|xt(i, m1|
|000054e0| 2c 20 6d 32 2c 20 6f 75 | 74 62 75 66 2c 20 6c 65 |, m2, ou|tbuf, le|
|000054f0| 6e 67 74 68 29 0a 58 69 | 6e 74 20 69 3b 0a 58 69 |ngth).Xi|nt i;.Xi|
|00005500| 6e 74 20 6d 31 2c 20 6d | 32 3b 0a 58 63 68 61 72 |nt m1, m|2;.Xchar|
|00005510| 20 2a 6f 75 74 62 75 66 | 3b 0a 58 69 6e 74 20 6c | *outbuf|;.Xint l|
|00005520| 65 6e 67 74 68 3b 0a 58 | 7b 0a 58 09 69 66 20 28 |ength;.X|{.X.if (|
|00005530| 63 6f 70 79 5f 74 65 78 | 74 28 69 2c 20 6d 31 2c |copy_tex|t(i, m1,|
|00005540| 20 6d 32 2c 20 6f 75 74 | 62 75 66 2c 20 6c 65 6e | m2, out|buf, len|
|00005550| 67 74 68 29 20 3e 3d 20 | 30 29 0a 58 09 09 72 65 |gth) >= |0).X..re|
|00005560| 74 75 72 6e 20 64 65 6c | 65 74 65 5f 74 65 78 74 |turn del|ete_text|
|00005570| 28 69 2c 20 6d 31 2c 20 | 6d 32 29 3b 0a 58 0a 58 |(i, m1, |m2);.X.X|
|00005580| 09 72 65 74 75 72 6e 20 | 2d 31 3b 0a 58 7d 0a 58 |.return |-1;.X}.X|
|00005590| 0a 58 2f 2a 20 66 69 78 | 5f 6d 61 72 6b 73 28 62 |.X/* fix|_marks(b|
|000055a0| 75 66 66 65 72 2c 20 6c | 65 6e 67 74 68 29 0a 58 |uffer, l|ength).X|
|000055b0| 20 2a 0a 58 20 2a 20 54 | 68 69 73 20 72 6f 75 74 | *.X * T|his rout|
|000055c0| 69 6e 65 20 72 65 61 64 | 6a 75 73 74 73 20 74 68 |ine read|justs th|
|000055d0| 65 20 6d 61 72 6b 73 20 | 61 66 74 65 72 20 74 68 |e marks |after th|
|000055e0| 65 20 67 61 70 20 77 68 | 65 6e 20 74 65 78 74 20 |e gap wh|en text |
|000055f0| 68 61 73 20 62 65 65 6e | 20 61 64 64 65 64 0a 58 |has been| added.X|
|00005600| 20 2a 20 6f 72 20 72 65 | 6d 6f 76 65 64 2e 20 4d | * or re|moved. M|
|00005610| 61 72 6b 73 20 61 72 65 | 20 63 6f 6e 73 69 64 65 |arks are| conside|
|00005620| 72 65 64 20 74 6f 20 62 | 65 20 61 74 74 61 63 68 |red to b|e attach|
|00005630| 65 64 20 74 6f 20 74 65 | 78 74 20 74 68 61 74 20 |ed to te|xt that |
|00005640| 66 6f 6c 6c 6f 77 73 2c | 20 73 6f 0a 58 20 2a 20 |follows,| so.X * |
|00005650| 6d 61 72 6b 73 20 72 69 | 67 68 74 20 6f 6e 20 74 |marks ri|ght on t|
|00005660| 68 65 20 67 61 70 20 61 | 72 65 20 6d 6f 76 65 64 |he gap a|re moved|
|00005670| 2e 20 49 6e 20 74 68 65 | 20 63 61 73 65 20 6f 66 |. In the| case of|
|00005680| 20 61 20 64 65 6c 65 74 | 69 6f 6e 20 74 68 65 73 | a delet|ion thes|
|00005690| 65 20 6d 61 72 6b 73 0a | 58 20 2a 20 28 61 6e 64 |e marks.|X * (and|
|000056a0| 20 61 6e 79 20 6f 74 68 | 65 72 73 20 69 6e 20 74 | any oth|ers in t|
|000056b0| 68 65 20 70 6f 72 74 69 | 6f 6e 20 6f 66 20 74 65 |he porti|on of te|
|000056c0| 78 74 20 74 68 61 74 20 | 68 61 73 20 62 65 65 6e |xt that |has been|
|000056d0| 20 64 65 6c 65 74 65 64 | 29 20 61 72 65 20 72 65 | deleted|) are re|
|000056e0| 6d 6f 76 65 64 2e 0a 58 | 20 2a 2f 0a 58 73 74 61 |moved..X| */.Xsta|
|000056f0| 74 69 63 20 66 69 78 5f | 6d 61 72 6b 73 28 69 2c |tic fix_|marks(i,|
|00005700| 6c 65 6e 67 74 68 29 0a | 58 69 6e 74 20 69 3b 0a |length).|Xint i;.|
|00005710| 58 69 6e 74 20 6c 65 6e | 67 74 68 3b 0a 58 7b 0a |Xint len|gth;.X{.|
|00005720| 58 09 62 75 66 66 65 72 | 20 2a 62 3b 0a 58 09 69 |X.buffer| *b;.X.i|
|00005730| 6e 74 20 69 6e 64 65 78 | 3b 0a 58 0a 58 09 43 48 |nt index|;.X.X.CH|
|00005740| 45 43 4b 28 62 2c 69 2c | 22 66 69 78 5f 6d 61 72 |ECK(b,i,|"fix_mar|
|00005750| 6b 73 22 2c 2d 31 29 3b | 0a 58 0a 58 09 66 6f 72 |ks",-1);|.X.X.for|
|00005760| 28 69 6e 64 65 78 20 3d | 20 30 3b 20 69 6e 64 65 |(index =| 0; inde|
|00005770| 78 20 3c 20 62 2d 3e 68 | 69 6d 61 72 6b 3b 20 69 |x < b->h|imark; i|
|00005780| 6e 64 65 78 2b 2b 29 20 | 7b 0a 58 09 09 69 66 28 |ndex++) |{.X..if(|
|00005790| 62 2d 3e 6d 61 72 6b 5b | 69 6e 64 65 78 5d 20 3e |b->mark[|index] >|
|000057a0| 3d 20 62 2d 3e 67 61 70 | 29 20 7b 0a 58 09 09 09 |= b->gap|) {.X...|
|000057b0| 62 2d 3e 6d 61 72 6b 5b | 69 6e 64 65 78 5d 20 2b |b->mark[|index] +|
|000057c0| 3d 20 6c 65 6e 67 74 68 | 3b 0a 58 09 09 09 69 66 |= length|;.X...if|
|000057d0| 28 62 2d 3e 6d 61 72 6b | 5b 69 6e 64 65 78 5d 20 |(b->mark|[index] |
|000057e0| 3c 20 62 2d 3e 67 61 70 | 29 20 7b 0a 58 09 09 09 |< b->gap|) {.X...|
|000057f0| 09 62 2d 3e 6d 61 72 6b | 5b 69 6e 64 65 78 5d 20 |.b->mark|[index] |
|00005800| 3d 20 2d 31 3b 0a 58 09 | 09 09 7d 0a 58 09 09 7d |= -1;.X.|..}.X..}|
|00005810| 0a 58 09 7d 0a 58 7d 0a | 58 0a 58 69 6e 73 65 72 |.X.}.X}.|X.Xinser|
|00005820| 74 5f 74 65 78 74 28 69 | 2c 20 6d 61 72 6b 2c 20 |t_text(i|, mark, |
|00005830| 74 65 78 74 2c 20 6c 65 | 6e 67 74 68 29 0a 58 69 |text, le|ngth).Xi|
|00005840| 6e 74 20 69 3b 0a 58 69 | 6e 74 20 6d 61 72 6b 3b |nt i;.Xi|nt mark;|
|00005850| 0a 58 63 68 61 72 20 2a | 74 65 78 74 3b 0a 58 69 |.Xchar *|text;.Xi|
|00005860| 6e 74 20 6c 65 6e 67 74 | 68 3b 0a 58 7b 0a 58 09 |nt lengt|h;.X{.X.|
|00005870| 63 68 61 72 20 2a 70 3b | 0a 58 0a 58 09 70 20 3d |char *p;|.X.X.p =|
|00005880| 20 6f 70 65 6e 5f 74 65 | 78 74 28 69 2c 20 6d 61 | open_te|xt(i, ma|
|00005890| 72 6b 2c 20 6c 65 6e 67 | 74 68 29 3b 0a 58 09 69 |rk, leng|th);.X.i|
|000058a0| 66 28 21 70 29 20 72 65 | 74 75 72 6e 20 2d 31 3b |f(!p) re|turn -1;|
|000058b0| 0a 58 0a 58 09 6d 65 6d | 63 70 79 28 70 2c 20 74 |.X.X.mem|cpy(p, t|
|000058c0| 65 78 74 2c 20 6c 65 6e | 67 74 68 29 3b 0a 58 0a |ext, len|gth);.X.|
|000058d0| 58 09 63 6c 6f 73 65 5f | 74 65 78 74 28 69 2c 20 |X.close_|text(i, |
|000058e0| 6c 65 6e 67 74 68 29 3b | 0a 58 0a 58 09 72 65 74 |length);|.X.X.ret|
|000058f0| 75 72 6e 20 6c 65 6e 67 | 74 68 3b 0a 58 7d 0a 58 |urn leng|th;.X}.X|
|00005900| 0a 58 64 65 6c 65 74 65 | 5f 74 65 78 74 28 69 2c |.Xdelete|_text(i,|
|00005910| 20 6d 31 2c 20 6d 32 29 | 0a 58 69 6e 74 20 69 3b | m1, m2)|.Xint i;|
|00005920| 0a 58 69 6e 74 20 6d 31 | 2c 20 6d 32 3b 0a 58 7b |.Xint m1|, m2;.X{|
|00005930| 0a 58 09 62 75 66 66 65 | 72 20 2a 62 3b 0a 58 09 |.X.buffe|r *b;.X.|
|00005940| 69 6e 74 20 6f 31 2c 20 | 6f 32 3b 0a 58 09 69 6e |int o1, |o2;.X.in|
|00005950| 74 20 6c 65 6e 67 74 68 | 3b 0a 58 0a 58 09 43 48 |t length|;.X.X.CH|
|00005960| 45 43 4b 28 62 2c 69 2c | 22 64 65 6c 65 74 65 5f |ECK(b,i,|"delete_|
|00005970| 74 65 78 74 22 2c 2d 31 | 29 3b 0a 58 0a 58 09 69 |text",-1|);.X.X.i|
|00005980| 66 20 28 28 6f 31 20 3d | 20 6c 6f 63 61 74 65 5f |f ((o1 =| locate_|
|00005990| 6d 61 72 6b 28 69 2c 20 | 6d 31 29 29 20 3d 3d 20 |mark(i, |m1)) == |
|000059a0| 2d 31 0a 58 09 20 7c 7c | 20 28 6f 32 20 3d 20 6c |-1.X. ||| (o2 = l|
|000059b0| 6f 63 61 74 65 5f 6d 61 | 72 6b 28 69 2c 20 6d 32 |ocate_ma|rk(i, m2|
|000059c0| 29 29 20 3d 3d 20 2d 31 | 29 0a 58 09 09 72 65 74 |)) == -1|).X..ret|
|000059d0| 75 72 6e 20 2d 31 3b 0a | 58 0a 58 09 69 66 28 6f |urn -1;.|X.X.if(o|
|000059e0| 32 20 3c 20 6f 31 29 20 | 7b 0a 58 09 09 69 6e 74 |2 < o1) |{.X..int|
|000059f0| 20 74 6d 70 20 3d 20 6f | 32 3b 0a 58 09 09 6f 32 | tmp = o|2;.X..o2|
|00005a00| 20 3d 20 6f 31 3b 0a 58 | 09 09 6f 31 20 3d 20 74 | = o1;.X|..o1 = t|
|00005a10| 6d 70 3b 0a 58 09 09 74 | 6d 70 20 3d 20 6d 32 3b |mp;.X..t|mp = m2;|
|00005a20| 0a 58 09 09 6d 32 20 3d | 20 6d 31 3b 0a 58 09 09 |.X..m2 =| m1;.X..|
|00005a30| 6d 31 20 3d 20 74 6d 70 | 3b 0a 58 09 7d 0a 58 0a |m1 = tmp|;.X.}.X.|
|00005a40| 58 09 69 66 28 6f 32 20 | 3d 3d 20 6f 31 29 0a 58 |X.if(o2 |== o1).X|
|00005a50| 09 09 72 65 74 75 72 6e | 20 30 3b 0a 58 0a 58 09 |..return| 0;.X.X.|
|00005a60| 6c 65 6e 67 74 68 20 3d | 20 6f 32 20 2d 20 6f 31 |length =| o2 - o1|
|00005a70| 3b 0a 58 0a 58 09 69 66 | 28 6f 31 20 21 3d 20 62 |;.X.X.if|(o1 != b|
|00005a80| 2d 3e 67 61 70 29 20 7b | 0a 58 09 09 6d 6f 76 65 |->gap) {|.X..move|
|00005a90| 5f 67 61 70 28 69 2c 20 | 6f 31 29 3b 0a 58 09 7d |_gap(i, |o1);.X.}|
|00005aa0| 0a 58 0a 58 09 66 69 78 | 5f 6d 61 72 6b 73 28 69 |.X.X.fix|_marks(i|
|00005ab0| 2c 20 2d 6c 65 6e 67 74 | 68 29 3b 0a 58 0a 58 09 |, -lengt|h);.X.X.|
|00005ac0| 62 2d 3e 67 61 70 73 69 | 7a 65 20 2b 3d 20 6c 65 |b->gapsi|ze += le|
|00005ad0| 6e 67 74 68 3b 0a 58 09 | 62 2d 3e 74 65 78 74 5f |ngth;.X.|b->text_|
|00005ae0| 6c 65 6e 67 74 68 20 2d | 3d 20 6c 65 6e 67 74 68 |length -|= length|
|00005af0| 3b 0a 58 0a 58 09 72 65 | 74 75 72 6e 20 6c 65 6e |;.X.X.re|turn len|
|00005b00| 67 74 68 3b 0a 58 7d 0a | 58 0a 58 69 6e 74 20 63 |gth;.X}.|X.Xint c|
|00005b10| 6f 75 6e 74 5f 63 68 61 | 72 73 28 69 2c 20 6d 31 |ount_cha|rs(i, m1|
|00005b20| 2c 20 6d 32 2c 20 63 29 | 0a 58 69 6e 74 20 69 3b |, m2, c)|.Xint i;|
|00005b30| 0a 58 69 6e 74 20 6d 31 | 2c 20 6d 32 3b 0a 58 63 |.Xint m1|, m2;.Xc|
|00005b40| 68 61 72 20 63 3b 0a 58 | 7b 0a 58 09 69 6e 74 20 |har c;.X|{.X.int |
|00005b50| 6c 65 6e 67 74 68 2c 20 | 63 6f 75 6e 74 3b 0a 58 |length, |count;.X|
|00005b60| 09 63 68 61 72 20 2a 70 | 3b 0a 58 0a 58 09 70 20 |.char *p|;.X.X.p |
|00005b70| 3d 20 74 65 78 74 28 69 | 2c 20 6d 31 2c 20 6d 32 |= text(i|, m1, m2|
|00005b80| 2c 20 26 6c 65 6e 67 74 | 68 29 3b 0a 58 0a 58 09 |, &lengt|h);.X.X.|
|00005b90| 63 6f 75 6e 74 20 3d 20 | 30 3b 0a 58 09 77 68 69 |count = |0;.X.whi|
|00005ba0| 6c 65 28 6c 65 6e 67 74 | 68 2d 2d 20 3e 20 20 30 |le(lengt|h-- > 0|
|00005bb0| 29 0a 58 09 09 69 66 28 | 2a 70 2b 2b 20 3d 3d 20 |).X..if(|*p++ == |
|00005bc0| 63 29 0a 58 09 09 09 63 | 6f 75 6e 74 2b 2b 3b 0a |c).X...c|ount++;.|
|00005bd0| 58 0a 58 09 72 65 74 75 | 72 6e 20 63 6f 75 6e 74 |X.X.retu|rn count|
|00005be0| 3b 0a 58 7d 0a 58 0a 58 | 23 69 66 64 65 66 20 54 |;.X}.X.X|#ifdef T|
|00005bf0| 45 53 54 0a 58 73 74 61 | 74 69 63 20 64 70 75 74 |EST.Xsta|tic dput|
|00005c00| 73 28 73 2c 20 6c 29 0a | 58 63 68 61 72 20 2a 73 |s(s, l).|Xchar *s|
|00005c10| 3b 0a 58 69 6e 74 20 6c | 3b 0a 58 7b 0a 58 09 77 |;.Xint l|;.X{.X.w|
|00005c20| 68 69 6c 65 28 6c 3e 30 | 29 20 7b 0a 58 09 09 63 |hile(l>0|) {.X..c|
|00005c30| 68 61 72 20 63 20 3d 20 | 2a 73 2b 2b 3b 0a 58 0a |har c = |*s++;.X.|
|00005c40| 58 09 09 69 66 28 63 20 | 26 20 30 78 38 30 29 20 |X..if(c |& 0x80) |
|00005c50| 7b 0a 58 09 09 09 70 72 | 69 6e 74 66 28 22 25 22 |{.X...pr|intf("%"|
|00005c60| 29 3b 0a 58 09 09 09 63 | 20 26 3d 20 30 78 37 46 |);.X...c| &= 0x7F|
|00005c70| 3b 0a 58 09 09 7d 0a 58 | 09 09 69 66 28 28 63 20 |;.X..}.X|..if((c |
|00005c80| 3c 20 27 20 27 20 7c 7c | 20 63 20 3e 20 31 32 37 |< ' ' ||| c > 127|
|00005c90| 29 20 26 26 20 63 20 21 | 3d 20 27 5c 6e 27 29 20 |) && c !|= '\n') |
|00005ca0| 7b 0a 58 09 09 09 70 75 | 74 63 68 61 72 28 27 7e |{.X...pu|tchar('~|
|00005cb0| 27 29 3b 0a 58 09 09 09 | 63 20 5e 3d 20 27 40 27 |');.X...|c ^= '@'|
|00005cc0| 3b 0a 58 09 09 7d 0a 58 | 09 09 69 66 28 63 20 3d |;.X..}.X|..if(c =|
|00005cd0| 3d 20 27 7e 27 20 7c 7c | 20 63 20 3d 3d 20 27 25 |= '~' ||| c == '%|
|00005ce0| 27 29 0a 58 09 09 09 70 | 75 74 63 68 61 72 28 63 |').X...p|utchar(c|
|00005cf0| 29 3b 0a 58 09 09 70 75 | 74 63 68 61 72 28 63 29 |);.X..pu|tchar(c)|
|00005d00| 3b 0a 58 09 09 6c 2d 2d | 3b 0a 58 09 7d 0a 58 7d |;.X..l--|;.X.}.X}|
|00005d10| 0a 58 23 65 6e 64 69 66 | 0a 58 0a 58 62 75 66 66 |.X#endif|.X.Xbuff|
|00005d20| 65 72 5f 64 65 62 75 67 | 28 69 29 0a 58 69 6e 74 |er_debug|(i).Xint|
|00005d30| 20 69 3b 0a 58 7b 0a 58 | 09 62 75 66 66 65 72 20 | i;.X{.X|.buffer |
|00005d40| 2a 62 3b 0a 58 09 69 6e | 74 20 69 6e 64 65 78 3b |*b;.X.in|t index;|
|00005d50| 0a 58 0a 58 09 43 48 45 | 43 4b 28 62 2c 69 2c 22 |.X.X.CHE|CK(b,i,"|
|00005d60| 62 75 66 66 65 72 5f 64 | 65 62 75 67 22 2c 2d 31 |buffer_d|ebug",-1|
|00005d70| 29 3b 0a 58 0a 58 09 70 | 72 69 6e 74 66 28 22 62 |);.X.X.p|rintf("b|
|00005d80| 75 66 66 65 72 28 25 64 | 29 20 6c 65 6e 67 74 68 |uffer(%d|) length|
|00005d90| 3d 25 64 2f 25 64 20 67 | 61 70 3d 25 64 20 67 61 |=%d/%d g|ap=%d ga|
|00005da0| 70 73 69 7a 65 3d 25 64 | 20 68 69 6d 61 72 6b 3d |psize=%d| himark=|
|00005db0| 25 64 5c 6e 22 2c 0a 58 | 09 09 69 2c 20 62 2d 3e |%d\n",.X|..i, b->|
|00005dc0| 62 6f 64 79 5f 6c 65 6e | 67 74 68 2c 20 62 2d 3e |body_len|gth, b->|
|00005dd0| 74 65 78 74 5f 6c 65 6e | 67 74 68 2c 0a 58 09 09 |text_len|gth,.X..|
|00005de0| 20 20 20 62 2d 3e 67 61 | 70 2c 20 62 2d 3e 67 61 | b->ga|p, b->ga|
|00005df0| 70 73 69 7a 65 2c 20 62 | 2d 3e 68 69 6d 61 72 6b |psize, b|->himark|
|00005e00| 29 3b 0a 58 09 66 6f 72 | 28 69 6e 64 65 78 20 3d |);.X.for|(index =|
|00005e10| 20 30 3b 20 69 6e 64 65 | 78 20 3c 20 62 2d 3e 68 | 0; inde|x < b->h|
|00005e20| 69 6d 61 72 6b 3b 20 69 | 6e 64 65 78 2b 2b 29 0a |imark; i|ndex++).|
|00005e30| 58 09 09 70 72 69 6e 74 | 66 28 22 5c 74 6d 61 72 |X..print|f("\tmar|
|00005e40| 6b 28 25 64 29 20 3d 20 | 25 64 5c 6e 22 2c 20 69 |k(%d) = |%d\n", i|
|00005e50| 6e 64 65 78 32 6d 61 72 | 6b 28 69 6e 64 65 78 29 |ndex2mar|k(index)|
|00005e60| 2c 20 62 2d 3e 6d 61 72 | 6b 5b 69 6e 64 65 78 5d |, b->mar|k[index]|
|00005e70| 29 3b 0a 58 23 69 66 64 | 65 66 20 54 45 53 54 0a |);.X#ifd|ef TEST.|
|00005e80| 58 09 69 66 28 62 2d 3e | 62 6f 64 79 29 20 7b 0a |X.if(b->|body) {.|
|00005e90| 58 09 09 70 72 69 6e 74 | 66 28 22 62 6f 64 79 20 |X..print|f("body |
|00005ea0| 3d 20 7b 22 29 3b 0a 58 | 09 09 64 70 75 74 73 28 |= {");.X|..dputs(|
|00005eb0| 62 2d 3e 62 6f 64 79 2c | 20 62 2d 3e 67 61 70 29 |b->body,| b->gap)|
|00005ec0| 3b 0a 58 09 09 70 72 69 | 6e 74 66 28 22 7d 20 47 |;.X..pri|ntf("} G|
|00005ed0| 41 50 20 7b 22 29 3b 0a | 58 09 09 64 70 75 74 73 |AP {");.|X..dputs|
|00005ee0| 28 62 2d 3e 62 6f 64 79 | 2b 62 2d 3e 67 61 70 2b |(b->body|+b->gap+|
|00005ef0| 62 2d 3e 67 61 70 73 69 | 7a 65 2c 20 62 2d 3e 74 |b->gapsi|ze, b->t|
|00005f00| 65 78 74 5f 6c 65 6e 67 | 74 68 2d 62 2d 3e 67 61 |ext_leng|th-b->ga|
|00005f10| 70 29 3b 0a 58 09 09 70 | 72 69 6e 74 66 28 22 7d |p);.X..p|rintf("}|
|00005f20| 3b 5c 6e 22 29 3b 0a 58 | 09 7d 0a 58 23 65 6e 64 |;\n");.X|.}.X#end|
|00005f30| 69 66 0a 58 09 66 66 6c | 75 73 68 28 73 74 64 6f |if.X.ffl|ush(stdo|
|00005f40| 75 74 29 3b 0a 58 7d 0a | 58 0a 58 69 6e 74 20 73 |ut);.X}.|X.Xint s|
|00005f50| 65 61 72 63 68 28 69 2c | 20 6d 31 2c 20 6d 32 2c |earch(i,| m1, m2,|
|00005f60| 20 70 61 74 29 0a 58 69 | 6e 74 20 69 2c 20 6d 31 | pat).Xi|nt i, m1|
|00005f70| 2c 20 6d 32 3b 0a 58 63 | 68 61 72 20 2a 70 61 74 |, m2;.Xc|har *pat|
|00005f80| 3b 0a 58 7b 0a 58 09 63 | 68 61 72 20 2a 62 6f 79 |;.X{.X.c|har *boy|
|00005f90| 65 72 5f 6d 6f 6f 72 65 | 5f 73 65 61 72 63 68 5f |er_moore|_search_|
|00005fa0| 63 6f 6d 70 69 6c 65 28 | 29 3b 0a 58 09 63 68 61 |compile(|);.X.cha|
|00005fb0| 72 20 2a 62 6f 79 65 72 | 5f 6d 6f 6f 72 65 5f 73 |r *boyer|_moore_s|
|00005fc0| 65 61 72 63 68 5f 65 78 | 65 63 75 74 65 28 29 3b |earch_ex|ecute();|
|00005fd0| 0a 58 09 69 6e 74 20 70 | 61 74 6c 65 6e 3b 0a 58 |.X.int p|atlen;.X|
|00005fe0| 09 69 6e 74 20 77 6f 72 | 6b 6c 65 6e 3b 0a 58 09 |.int wor|klen;.X.|
|00005ff0| 69 6e 74 20 6e 65 77 5f | 6d 61 72 6b 3b 0a 58 09 |int new_|mark;.X.|
|00006000| 63 68 61 72 20 2a 63 6f | 6d 70 69 6c 65 64 3b 0a |char *co|mpiled;.|
|00006010| 58 09 63 68 61 72 20 2a | 77 6f 72 6b 3b 0a 58 09 |X.char *|work;.X.|
|00006020| 69 6e 74 20 64 75 6d 6d | 79 3b 0a 58 09 63 68 61 |int dumm|y;.X.cha|
|00006030| 72 20 2a 66 6f 75 6e 64 | 3b 0a 58 0a 58 09 70 61 |r *found|;.X.X.pa|
|00006040| 74 6c 65 6e 20 3d 20 73 | 74 72 6c 65 6e 28 70 61 |tlen = s|trlen(pa|
|00006050| 74 29 3b 0a 58 0a 58 09 | 77 6f 72 6b 20 3d 20 74 |t);.X.X.|work = t|
|00006060| 65 78 74 28 69 2c 20 6d | 31 2c 20 6d 32 2c 20 26 |ext(i, m|1, m2, &|
|00006070| 77 6f 72 6b 6c 65 6e 29 | 3b 0a 58 09 69 66 28 21 |worklen)|;.X.if(!|
|00006080| 77 6f 72 6b 29 0a 58 09 | 09 72 65 74 75 72 6e 20 |work).X.|.return |
|00006090| 2d 31 3b 0a 58 0a 58 09 | 69 66 28 6c 6f 63 61 74 |-1;.X.X.|if(locat|
|000060a0| 65 5f 6d 61 72 6b 28 69 | 2c 20 6d 31 29 20 3c 20 |e_mark(i|, m1) < |
|000060b0| 6c 6f 63 61 74 65 5f 6d | 61 72 6b 28 69 2c 20 6d |locate_m|ark(i, m|
|000060c0| 32 29 29 0a 58 09 09 6e | 65 77 5f 6d 61 72 6b 20 |2)).X..n|ew_mark |
|000060d0| 3d 20 63 6f 70 79 5f 6d | 61 72 6b 28 69 2c 20 6d |= copy_m|ark(i, m|
|000060e0| 31 29 3b 0a 58 09 65 6c | 73 65 0a 58 09 09 6e 65 |1);.X.el|se.X..ne|
|000060f0| 77 5f 6d 61 72 6b 20 3d | 20 63 6f 70 79 5f 6d 61 |w_mark =| copy_ma|
|00006100| 72 6b 28 69 2c 20 6d 32 | 29 3b 0a 58 0a 58 09 69 |rk(i, m2|);.X.X.i|
|00006110| 66 28 6e 65 77 5f 6d 61 | 72 6b 20 3c 3d 20 30 29 |f(new_ma|rk <= 0)|
|00006120| 0a 58 09 09 72 65 74 75 | 72 6e 20 2d 31 3b 0a 58 |.X..retu|rn -1;.X|
|00006130| 0a 58 09 63 6f 6d 70 69 | 6c 65 64 20 3d 20 62 6f |.X.compi|led = bo|
|00006140| 79 65 72 5f 6d 6f 6f 72 | 65 5f 73 65 61 72 63 68 |yer_moor|e_search|
|00006150| 5f 63 6f 6d 70 69 6c 65 | 28 70 61 74 2c 20 70 61 |_compile|(pat, pa|
|00006160| 74 6c 65 6e 29 3b 0a 58 | 09 69 66 28 21 63 6f 6d |tlen);.X|.if(!com|
|00006170| 70 69 6c 65 64 29 20 7b | 0a 58 09 09 64 65 6c 65 |piled) {|.X..dele|
|00006180| 74 65 5f 6d 61 72 6b 28 | 69 2c 20 6e 65 77 5f 6d |te_mark(|i, new_m|
|00006190| 61 72 6b 29 3b 0a 58 09 | 09 62 75 66 66 65 72 5f |ark);.X.|.buffer_|
|000061a0| 65 72 72 6f 72 20 3d 20 | 22 53 65 61 72 63 68 20 |error = |"Search |
|000061b0| 73 74 72 69 6e 67 20 63 | 6f 6d 70 69 6c 65 20 66 |string c|ompile f|
|000061c0| 61 69 6c 65 64 22 3b 0a | 58 09 09 72 65 74 75 72 |ailed";.|X..retur|
|000061d0| 6e 20 2d 31 3b 0a 58 09 | 7d 0a 58 0a 58 09 66 6f |n -1;.X.|}.X.X.fo|
|000061e0| 75 6e 64 20 3d 20 62 6f | 79 65 72 5f 6d 6f 6f 72 |und = bo|yer_moor|
|000061f0| 65 5f 73 65 61 72 63 68 | 5f 65 78 65 63 75 74 65 |e_search|_execute|
|00006200| 28 77 6f 72 6b 2c 20 77 | 6f 72 6b 6c 65 6e 2c 20 |(work, w|orklen, |
|00006210| 63 6f 6d 70 69 6c 65 64 | 2c 20 26 64 75 6d 6d 79 |compiled|, &dummy|
|00006220| 29 3b 0a 58 0a 58 09 66 | 72 65 65 28 63 6f 6d 70 |);.X.X.f|ree(comp|
|00006230| 69 6c 65 64 29 3b 0a 58 | 0a 58 09 69 66 28 21 66 |iled);.X|.X.if(!f|
|00006240| 6f 75 6e 64 29 20 7b 0a | 58 09 09 64 65 6c 65 74 |ound) {.|X..delet|
|00006250| 65 5f 6d 61 72 6b 28 69 | 2c 20 6e 65 77 5f 6d 61 |e_mark(i|, new_ma|
|00006260| 72 6b 29 3b 0a 58 09 09 | 62 75 66 66 65 72 5f 65 |rk);.X..|buffer_e|
|00006270| 72 72 6f 72 20 3d 20 22 | 53 65 61 72 63 68 20 73 |rror = "|Search s|
|00006280| 74 72 69 6e 67 20 6e 6f | 74 20 66 6f 75 6e 64 22 |tring no|t found"|
|00006290| 3b 0a 58 09 09 72 65 74 | 75 72 6e 20 30 3b 0a 58 |;.X..ret|urn 0;.X|
|000062a0| 09 7d 0a 58 0a 58 09 6d | 6f 76 65 5f 6d 61 72 6b |.}.X.X.m|ove_mark|
|000062b0| 28 69 2c 20 6e 65 77 5f | 6d 61 72 6b 2c 20 66 6f |(i, new_|mark, fo|
|000062c0| 75 6e 64 20 2d 20 77 6f | 72 6b 29 3b 0a 58 0a 58 |und - wo|rk);.X.X|
|000062d0| 09 72 65 74 75 72 6e 20 | 6e 65 77 5f 6d 61 72 6b |.return |new_mark|
|000062e0| 3b 0a 58 7d 0a 45 4e 44 | 5f 4f 46 5f 46 49 4c 45 |;.X}.END|_OF_FILE|
|000062f0| 0a 69 66 20 74 65 73 74 | 20 31 32 35 31 33 20 2d |.if test| 12513 -|
|00006300| 6e 65 20 60 77 63 20 2d | 63 20 3c 27 62 75 66 66 |ne `wc -|c <'buff|
|00006310| 65 72 2e 63 27 60 3b 20 | 74 68 65 6e 0a 20 20 20 |er.c'`; |then. |
|00006320| 20 65 63 68 6f 20 73 68 | 61 72 3a 20 5c 22 27 62 | echo sh|ar: \"'b|
|00006330| 75 66 66 65 72 2e 63 27 | 5c 22 20 75 6e 70 61 63 |uffer.c'|\" unpac|
|00006340| 6b 65 64 20 77 69 74 68 | 20 77 72 6f 6e 67 20 73 |ked with| wrong s|
|00006350| 69 7a 65 21 0a 66 69 0a | 23 20 65 6e 64 20 6f 66 |ize!.fi.|# end of|
|00006360| 20 27 62 75 66 66 65 72 | 2e 63 27 0a 66 69 0a 69 | 'buffer|.c'.fi.i|
|00006370| 66 20 74 65 73 74 20 2d | 66 20 27 62 74 2e 63 27 |f test -|f 'bt.c'|
|00006380| 20 2d 61 20 22 24 7b 31 | 7d 22 20 21 3d 20 22 2d | -a "${1|}" != "-|
|00006390| 63 22 20 3b 20 74 68 65 | 6e 20 0a 20 20 65 63 68 |c" ; the|n . ech|
|000063a0| 6f 20 73 68 61 72 3a 20 | 57 69 6c 6c 20 6e 6f 74 |o shar: |Will not|
|000063b0| 20 63 6c 6f 62 62 65 72 | 20 65 78 69 73 74 69 6e | clobber| existin|
|000063c0| 67 20 66 69 6c 65 20 5c | 22 27 62 74 2e 63 27 5c |g file \|"'bt.c'\|
|000063d0| 22 0a 65 6c 73 65 0a 65 | 63 68 6f 20 73 68 61 72 |".else.e|cho shar|
|000063e0| 3a 20 45 78 74 72 61 63 | 74 69 6e 67 20 5c 22 27 |: Extrac|ting \"'|
|000063f0| 62 74 2e 63 27 5c 22 20 | 5c 28 31 30 36 30 20 63 |bt.c'\" |\(1060 c|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.