home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / sources / unix / volume11 / templates / part04 < prev    next >
SHell self-extracting ARchive  |  1987-10-04  |  50.0 KB

view JSON data     |     view as text     |     open on a Mac     |     open on a PC

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

You can browse this item here: part04

ConfidenceProgramDetectionMatch TypeSupport
100% dexvert Newsgroup Content (archive/news) magic Supported
100% dexvert SHell self-extracting ARchive (archive/shar) magic Supported
100% dexvert Internet Message Format (text/imf) magic Supported
1% dexvert Texas Instruments Calculator Program (executable/tiCalcProgram) magic Unsupported
1% dexvert Text File (text/txt) fallback Supported
100% file news or mail text default
99% file Lisp/Scheme program text default
98% file Lisp/Scheme program, ASCII text default
100% checkBytes Printable ASCII default
100% perlTextCheck Likely Text (Perl) default
100% siegfried fmt/329 Shell Archive Format default
100% detectItEasy Format: plain text[LF] default (weak)
100% xdgMime message/rfc822 default



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 53 75 62 6a 65 63 74 3a | 20 20 76 31 31 69 30 39 |Subject:| v11i09|
|00000010| 34 3a 20 20 54 65 6d 70 | 6c 61 74 65 20 6d 6f 64 |4: Temp|late mod|
|00000020| 65 20 66 6f 72 20 47 4e | 55 20 45 6d 61 63 73 2c |e for GN|U Emacs,|
|00000030| 20 50 61 72 74 30 34 2f | 30 36 0a 4e 65 77 73 67 | Part04/|06.Newsg|
|00000040| 72 6f 75 70 73 3a 20 63 | 6f 6d 70 2e 73 6f 75 72 |roups: c|omp.sour|
|00000050| 63 65 73 2e 75 6e 69 78 | 0a 53 65 6e 64 65 72 3a |ces.unix|.Sender:|
|00000060| 20 73 6f 75 72 63 65 73 | 0a 41 70 70 72 6f 76 65 | sources|.Approve|
|00000070| 64 3a 20 72 73 40 75 75 | 6e 65 74 2e 55 55 2e 4e |d: rs@uu|net.UU.N|
|00000080| 45 54 0a 0a 53 75 62 6d | 69 74 74 65 64 2d 62 79 |ET..Subm|itted-by|
|00000090| 3a 20 22 4d 61 72 6b 20 | 41 2e 20 41 72 64 69 73 |: "Mark |A. Ardis|
|000000a0| 22 20 3c 6d 61 61 40 73 | 65 69 2e 63 6d 75 2e 65 |" <maa@s|ei.cmu.e|
|000000b0| 64 75 3e 0a 50 6f 73 74 | 69 6e 67 2d 6e 75 6d 62 |du>.Post|ing-numb|
|000000c0| 65 72 3a 20 56 6f 6c 75 | 6d 65 20 31 31 2c 20 49 |er: Volu|me 11, I|
|000000d0| 73 73 75 65 20 39 34 0a | 41 72 63 68 69 76 65 2d |ssue 94.|Archive-|
|000000e0| 6e 61 6d 65 3a 20 74 65 | 6d 70 6c 61 74 65 73 2f |name: te|mplates/|
|000000f0| 70 61 72 74 30 34 0a 0a | 23 21 20 2f 62 69 6e 2f |part04..|#! /bin/|
|00000100| 73 68 0a 23 20 54 68 69 | 73 20 69 73 20 61 20 73 |sh.# Thi|s is a s|
|00000110| 68 65 6c 6c 20 61 72 63 | 68 69 76 65 2c 20 6d 65 |hell arc|hive, me|
|00000120| 61 6e 69 6e 67 3a 0a 23 | 20 31 2e 20 52 65 6d 6f |aning:.#| 1. Remo|
|00000130| 76 65 20 65 76 65 72 79 | 74 68 69 6e 67 20 61 62 |ve every|thing ab|
|00000140| 6f 76 65 20 74 68 65 20 | 23 21 20 2f 62 69 6e 2f |ove the |#! /bin/|
|00000150| 73 68 20 6c 69 6e 65 2e | 0a 23 20 32 2e 20 53 61 |sh line.|.# 2. Sa|
|00000160| 76 65 20 74 68 65 20 72 | 65 73 75 6c 74 69 6e 67 |ve the r|esulting|
|00000170| 20 74 65 78 74 20 69 6e | 20 61 20 66 69 6c 65 2e | text in| a file.|
|00000180| 0a 23 20 33 2e 20 45 78 | 65 63 75 74 65 20 74 68 |.# 3. Ex|ecute th|
|00000190| 65 20 66 69 6c 65 20 77 | 69 74 68 20 2f 62 69 6e |e file w|ith /bin|
|000001a0| 2f 73 68 20 28 6e 6f 74 | 20 63 73 68 29 20 74 6f |/sh (not| csh) to|
|000001b0| 20 63 72 65 61 74 65 3a | 0a 23 09 74 70 6c 70 61 | create:|.#.tplpa|
|000001c0| 72 73 65 2e 65 6c 0a 23 | 09 74 70 6c 73 63 61 6e |rse.el.#|.tplscan|
|000001d0| 2e 65 6c 0a 65 78 70 6f | 72 74 20 50 41 54 48 3b |.el.expo|rt PATH;|
|000001e0| 20 50 41 54 48 3d 2f 62 | 69 6e 3a 2f 75 73 72 2f | PATH=/b|in:/usr/|
|000001f0| 62 69 6e 3a 24 50 41 54 | 48 0a 65 63 68 6f 20 73 |bin:$PAT|H.echo s|
|00000200| 68 61 72 3a 20 22 65 78 | 74 72 61 63 74 69 6e 67 |har: "ex|tracting|
|00000210| 20 27 74 70 6c 70 61 72 | 73 65 2e 65 6c 27 22 20 | 'tplpar|se.el'" |
|00000220| 27 28 33 35 38 32 37 20 | 63 68 61 72 61 63 74 65 |'(35827 |characte|
|00000230| 72 73 29 27 0a 69 66 20 | 74 65 73 74 20 2d 66 20 |rs)'.if |test -f |
|00000240| 27 74 70 6c 70 61 72 73 | 65 2e 65 6c 27 0a 74 68 |'tplpars|e.el'.th|
|00000250| 65 6e 0a 09 65 63 68 6f | 20 73 68 61 72 3a 20 22 |en..echo| shar: "|
|00000260| 77 69 6c 6c 20 6e 6f 74 | 20 6f 76 65 72 2d 77 72 |will not| over-wr|
|00000270| 69 74 65 20 65 78 69 73 | 74 69 6e 67 20 66 69 6c |ite exis|ting fil|
|00000280| 65 20 27 74 70 6c 70 61 | 72 73 65 2e 65 6c 27 22 |e 'tplpa|rse.el'"|
|00000290| 0a 65 6c 73 65 0a 73 65 | 64 20 27 73 2f 5e 58 2f |.else.se|d 's/^X/|
|000002a0| 2f 27 20 3c 3c 20 5c 53 | 48 41 52 5f 45 4f 46 20 |/' << \S|HAR_EOF |
|000002b0| 3e 20 27 74 70 6c 70 61 | 72 73 65 2e 65 6c 27 0a |> 'tplpa|rse.el'.|
|000002c0| 58 3b 3b 3b 20 74 70 6c | 70 61 72 73 65 2e 65 6c |X;;; tpl|parse.el|
|000002d0| 20 2d 2d 20 50 61 72 73 | 69 6e 67 20 72 6f 75 74 | -- Pars|ing rout|
|000002e0| 69 6e 65 73 20 66 6f 72 | 20 74 65 6d 70 6c 61 74 |ines for| templat|
|000002f0| 65 20 70 61 63 6b 61 67 | 65 0a 58 3b 3b 3b 20 43 |e packag|e.X;;; C|
|00000300| 6f 70 79 72 69 67 68 74 | 20 28 43 29 20 31 39 38 |opyright| (C) 198|
|00000310| 37 20 4d 61 72 6b 20 41 | 2e 20 41 72 64 69 73 2e |7 Mark A|. Ardis.|
|00000320| 0a 58 0a 58 28 72 65 71 | 75 69 72 65 20 27 74 70 |.X.X(req|uire 'tp|
|00000330| 6c 76 61 72 73 29 0a 58 | 28 72 65 71 75 69 72 65 |lvars).X|(require|
|00000340| 20 27 74 70 6c 68 65 6c | 70 65 72 29 0a 58 0a 58 | 'tplhel|per).X.X|
|00000350| 28 70 72 6f 76 69 64 65 | 20 27 74 70 6c 70 61 72 |(provide| 'tplpar|
|00000360| 73 65 29 0a 58 0a 58 3b | 3b 3b 2b 2b 2b 2b 2b 2b |se).X.X;|;;++++++|
|00000370| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000380| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000390| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000003a0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 0a 58 3b 3b 3b |++++++++|+++.X;;;|
|000003b0| 20 41 6c 6c 20 67 6c 6f | 62 61 6c 20 76 61 72 69 | All glo|bal vari|
|000003c0| 61 62 6c 65 73 20 61 72 | 65 20 69 6e 20 22 74 70 |ables ar|e in "tp|
|000003d0| 6c 76 61 72 73 22 0a 58 | 0a 58 3b 3b 3b 2b 2b 2b |lvars".X|.X;;;+++|
|000003e0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000003f0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000400| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000410| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 0a 58 |++++++++|++++++.X|
|00000420| 0a 58 28 64 65 66 75 6e | 20 6c 6f 6f 6b 69 6e 67 |.X(defun| looking|
|00000430| 2d 61 74 2d 74 70 6c 20 | 28 29 0a 58 20 20 22 74 |-at-tpl |().X "t|
|00000440| 20 69 66 20 74 65 78 74 | 20 61 66 74 65 72 20 70 | if text| after p|
|00000450| 6f 69 6e 74 20 6d 61 74 | 63 68 65 73 20 73 70 65 |oint mat|ches spe|
|00000460| 63 69 66 69 65 64 20 74 | 65 6d 70 6c 61 74 65 2e |cified t|emplate.|
|00000470| 22 0a 58 20 20 28 69 6e | 74 65 72 61 63 74 69 76 |".X (in|teractiv|
|00000480| 65 29 0a 58 09 09 09 09 | 09 3b 20 4c 6f 63 61 6c |e).X....|.; Local|
|00000490| 20 56 61 72 69 61 62 6c | 65 73 0a 58 20 20 28 6c | Variabl|es.X (l|
|000004a0| 65 74 20 28 6e 61 6d 65 | 2d 6c 69 73 74 20 74 70 |et (name|-list tp|
|000004b0| 6c 2d 6e 61 6d 65 29 0a | 58 09 09 09 09 09 3b 20 |l-name).|X.....; |
|000004c0| 42 6f 64 79 0a 58 20 20 | 20 20 28 73 65 74 71 20 |Body.X | (setq |
|000004d0| 6e 61 6d 65 2d 6c 69 73 | 74 20 28 74 70 6c 2d 6d |name-lis|t (tpl-m|
|000004e0| 61 6b 65 2d 63 6f 6d 70 | 6c 65 74 69 6f 6e 2d 6c |ake-comp|letion-l|
|000004f0| 69 73 74 29 29 0a 58 20 | 20 20 20 28 73 65 74 71 |ist)).X | (setq|
|00000500| 20 74 70 6c 2d 6e 61 6d | 65 20 28 63 6f 6d 70 6c | tpl-nam|e (compl|
|00000510| 65 74 69 6e 67 2d 72 65 | 61 64 20 22 6c 6f 6f 6b |eting-re|ad "look|
|00000520| 69 6e 67 2d 61 74 2d 74 | 70 6c 3a 20 54 65 6d 70 |ing-at-t|pl: Temp|
|00000530| 6c 61 74 65 20 6e 61 6d | 65 3f 20 22 0a 58 09 09 |late nam|e? ".X..|
|00000540| 09 09 20 20 20 20 6e 61 | 6d 65 2d 6c 69 73 74 20 |.. na|me-list |
|00000550| 6e 69 6c 20 74 20 6e 69 | 6c 29 29 0a 58 20 20 20 |nil t ni|l)).X |
|00000560| 20 28 74 70 6c 2d 6c 6f | 6f 6b 69 6e 67 2d 61 74 | (tpl-lo|oking-at|
|00000570| 20 74 70 6c 2d 6e 61 6d | 65 29 0a 58 20 20 29 20 | tpl-nam|e).X ) |
|00000580| 3b 20 6c 65 74 0a 58 29 | 20 3b 20 64 65 66 75 6e |; let.X)| ; defun|
|00000590| 20 6c 6f 6f 6b 69 6e 67 | 2d 61 74 2d 74 70 6c 0a | looking|-at-tpl.|
|000005a0| 58 0a 58 3b 3b 3b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |X.X;;;++|++++++++|
|000005b0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000005c0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000005d0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000005e0| 2b 2b 2b 2b 2b 2b 2b 0a | 58 0a 58 28 64 65 66 75 |+++++++.|X.X(defu|
|000005f0| 6e 20 71 75 65 72 79 2d | 72 65 70 6c 61 63 65 2d |n query-|replace-|
|00000600| 74 70 6c 20 28 29 0a 58 | 20 20 22 52 65 70 6c 61 |tpl ().X| "Repla|
|00000610| 63 65 20 73 6f 6d 65 20 | 69 6e 73 74 61 6e 63 65 |ce some |instance|
|00000620| 73 20 6f 66 20 61 20 74 | 65 6d 70 6c 61 74 65 20 |s of a t|emplate |
|00000630| 77 69 74 68 20 63 6f 72 | 72 65 73 70 6f 6e 64 69 |with cor|respondi|
|00000640| 6e 67 20 69 6e 73 74 61 | 6e 63 65 73 0a 58 20 20 |ng insta|nces.X |
|00000650| 20 6f 66 20 61 6e 6f 74 | 68 65 72 2e 22 0a 58 20 | of anot|her.".X |
|00000660| 20 28 69 6e 74 65 72 61 | 63 74 69 76 65 29 0a 58 | (intera|ctive).X|
|00000670| 09 09 09 09 09 3b 20 4c | 6f 63 61 6c 20 56 61 72 |.....; L|ocal Var|
|00000680| 69 61 62 6c 65 73 0a 58 | 20 20 28 6c 65 74 20 28 |iables.X| (let (|
|00000690| 6e 61 6d 65 2d 6c 69 73 | 74 20 66 72 6f 6d 20 74 |name-lis|t from t|
|000006a0| 6f 29 0a 58 09 09 09 09 | 09 3b 20 42 6f 64 79 0a |o).X....|.; Body.|
|000006b0| 58 20 20 20 20 28 73 65 | 74 71 20 6e 61 6d 65 2d |X (se|tq name-|
|000006c0| 6c 69 73 74 20 28 74 70 | 6c 2d 6d 61 6b 65 2d 63 |list (tp|l-make-c|
|000006d0| 6f 6d 70 6c 65 74 69 6f | 6e 2d 6c 69 73 74 29 29 |ompletio|n-list))|
|000006e0| 0a 58 20 20 20 20 28 73 | 65 74 71 20 66 72 6f 6d |.X (s|etq from|
|000006f0| 20 28 63 6f 6d 70 6c 65 | 74 69 6e 67 2d 72 65 61 | (comple|ting-rea|
|00000700| 64 20 22 71 75 65 72 79 | 2d 72 65 70 6c 61 63 65 |d "query|-replace|
|00000710| 2d 74 70 6c 3a 20 46 72 | 6f 6d 3f 20 22 0a 58 09 |-tpl: Fr|om? ".X.|
|00000720| 09 09 09 20 20 20 20 6e | 61 6d 65 2d 6c 69 73 74 |... n|ame-list|
|00000730| 20 6e 69 6c 20 74 20 6e | 69 6c 29 29 0a 58 20 20 | nil t n|il)).X |
|00000740| 20 20 28 73 65 74 71 20 | 74 6f 20 28 63 6f 6d 70 | (setq |to (comp|
|00000750| 6c 65 74 69 6e 67 2d 72 | 65 61 64 20 28 63 6f 6e |leting-r|ead (con|
|00000760| 63 61 74 20 22 71 75 65 | 72 79 2d 72 65 70 6c 61 |cat "que|ry-repla|
|00000770| 63 65 2d 74 70 6c 3a 20 | 46 72 6f 6d 20 22 20 66 |ce-tpl: |From " f|
|00000780| 72 6f 6d 20 22 20 54 6f | 3f 20 22 29 0a 58 09 09 |rom " To|? ").X..|
|00000790| 09 09 20 20 20 20 6e 61 | 6d 65 2d 6c 69 73 74 20 |.. na|me-list |
|000007a0| 6e 69 6c 20 74 20 6e 69 | 6c 29 29 0a 58 20 20 20 |nil t ni|l)).X |
|000007b0| 20 28 74 70 6c 2d 71 75 | 65 72 79 2d 72 65 70 6c | (tpl-qu|ery-repl|
|000007c0| 61 63 65 20 66 72 6f 6d | 20 74 6f 29 0a 58 20 20 |ace from| to).X |
|000007d0| 29 20 3b 20 6c 65 74 0a | 58 29 20 3b 20 64 65 66 |) ; let.|X) ; def|
|000007e0| 75 6e 20 71 75 65 72 79 | 2d 72 65 70 6c 61 63 65 |un query|-replace|
|000007f0| 2d 74 70 6c 0a 58 0a 58 | 3b 3b 3b 2b 2b 2b 2b 2b |-tpl.X.X|;;;+++++|
|00000800| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000810| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000820| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000830| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 0a 58 0a 58 |++++++++|++++.X.X|
|00000840| 28 64 65 66 75 6e 20 72 | 65 70 6c 61 63 65 2d 74 |(defun r|eplace-t|
|00000850| 70 6c 20 28 29 0a 58 20 | 20 22 52 65 70 6c 61 63 |pl ().X | "Replac|
|00000860| 65 20 61 6e 20 69 6e 73 | 74 61 6e 63 65 20 6f 66 |e an ins|tance of|
|00000870| 20 61 20 74 65 6d 70 6c | 61 74 65 20 77 69 74 68 | a templ|ate with|
|00000880| 20 61 20 63 6f 72 72 65 | 73 70 6f 6e 64 69 6e 67 | a corre|sponding|
|00000890| 20 69 6e 73 74 61 6e 63 | 65 0a 58 20 20 20 6f 66 | instanc|e.X of|
|000008a0| 20 61 6e 6f 74 68 65 72 | 20 74 65 6d 70 6c 61 74 | another| templat|
|000008b0| 65 2e 22 0a 58 20 20 28 | 69 6e 74 65 72 61 63 74 |e.".X (|interact|
|000008c0| 69 76 65 29 0a 58 09 09 | 09 09 09 3b 20 4c 6f 63 |ive).X..|...; Loc|
|000008d0| 61 6c 20 56 61 72 69 61 | 62 6c 65 73 0a 58 20 20 |al Varia|bles.X |
|000008e0| 28 6c 65 74 20 28 6e 61 | 6d 65 2d 6c 69 73 74 20 |(let (na|me-list |
|000008f0| 66 72 6f 6d 20 74 6f 29 | 0a 58 09 09 09 09 09 3b |from to)|.X.....;|
|00000900| 20 42 6f 64 79 0a 58 20 | 20 20 20 28 73 65 74 71 | Body.X | (setq|
|00000910| 20 6e 61 6d 65 2d 6c 69 | 73 74 20 28 74 70 6c 2d | name-li|st (tpl-|
|00000920| 6d 61 6b 65 2d 63 6f 6d | 70 6c 65 74 69 6f 6e 2d |make-com|pletion-|
|00000930| 6c 69 73 74 29 29 0a 58 | 20 20 20 20 28 73 65 74 |list)).X| (set|
|00000940| 71 20 66 72 6f 6d 20 28 | 63 6f 6d 70 6c 65 74 69 |q from (|completi|
|00000950| 6e 67 2d 72 65 61 64 20 | 22 72 65 70 6c 61 63 65 |ng-read |"replace|
|00000960| 2d 74 70 6c 3a 20 46 72 | 6f 6d 3f 20 22 0a 58 09 |-tpl: Fr|om? ".X.|
|00000970| 09 09 09 20 20 20 20 6e | 61 6d 65 2d 6c 69 73 74 |... n|ame-list|
|00000980| 20 6e 69 6c 20 74 20 6e | 69 6c 29 29 0a 58 20 20 | nil t n|il)).X |
|00000990| 20 20 28 73 65 74 71 20 | 74 6f 20 28 63 6f 6d 70 | (setq |to (comp|
|000009a0| 6c 65 74 69 6e 67 2d 72 | 65 61 64 20 28 63 6f 6e |leting-r|ead (con|
|000009b0| 63 61 74 20 22 72 65 70 | 6c 61 63 65 2d 74 70 6c |cat "rep|lace-tpl|
|000009c0| 3a 20 46 72 6f 6d 20 22 | 20 66 72 6f 6d 20 22 20 |: From "| from " |
|000009d0| 54 6f 3f 20 22 29 0a 58 | 09 09 09 09 20 20 20 20 |To? ").X|.... |
|000009e0| 6e 61 6d 65 2d 6c 69 73 | 74 20 6e 69 6c 20 74 20 |name-lis|t nil t |
|000009f0| 6e 69 6c 29 29 0a 58 20 | 20 20 20 28 77 68 69 6c |nil)).X | (whil|
|00000a00| 65 20 28 74 70 6c 2d 73 | 65 61 72 63 68 2d 66 6f |e (tpl-s|earch-fo|
|00000a10| 72 77 61 72 64 20 66 72 | 6f 6d 20 28 70 6f 69 6e |rward fr|om (poin|
|00000a20| 74 2d 6d 61 78 29 20 74 | 29 0a 58 20 20 20 20 20 |t-max) t|).X |
|00000a30| 20 28 65 78 63 68 61 6e | 67 65 2d 70 6f 69 6e 74 | (exchan|ge-point|
|00000a40| 2d 61 6e 64 2d 6d 61 72 | 6b 29 0a 58 20 20 20 20 |-and-mar|k).X |
|00000a50| 20 20 28 74 70 6c 2d 72 | 65 70 6c 61 63 65 20 66 | (tpl-r|eplace f|
|00000a60| 72 6f 6d 20 74 6f 29 0a | 58 20 20 20 20 20 20 29 |rom to).|X )|
|00000a70| 20 3b 20 77 68 69 6c 65 | 0a 58 20 20 29 20 3b 20 | ; while|.X ) ; |
|00000a80| 6c 65 74 0a 58 29 20 3b | 20 64 65 66 75 6e 20 72 |let.X) ;| defun r|
|00000a90| 65 70 6c 61 63 65 2d 74 | 70 6c 0a 58 0a 58 3b 3b |eplace-t|pl.X.X;;|
|00000aa0| 3b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |;+++++++|++++++++|
|00000ab0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000ac0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000ad0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000ae0| 2b 2b 0a 58 0a 58 28 64 | 65 66 75 6e 20 73 65 61 |++.X.X(d|efun sea|
|00000af0| 72 63 68 2d 66 6f 72 77 | 61 72 64 2d 74 70 6c 20 |rch-forw|ard-tpl |
|00000b00| 28 29 0a 58 20 20 22 53 | 65 61 72 63 68 20 66 6f |().X "S|earch fo|
|00000b10| 72 77 61 72 64 20 66 72 | 6f 6d 20 70 6f 69 6e 74 |rward fr|om point|
|00000b20| 20 66 6f 72 20 61 20 74 | 65 6d 70 6c 61 74 65 2e | for a t|emplate.|
|00000b30| 22 0a 58 20 20 28 69 6e | 74 65 72 61 63 74 69 76 |".X (in|teractiv|
|00000b40| 65 29 0a 58 09 09 09 09 | 09 3b 20 4c 6f 63 61 6c |e).X....|.; Local|
|00000b50| 20 56 61 72 69 61 62 6c | 65 73 0a 58 20 20 28 6c | Variabl|es.X (l|
|00000b60| 65 74 20 28 6e 61 6d 65 | 2d 6c 69 73 74 20 74 70 |et (name|-list tp|
|00000b70| 6c 2d 6e 61 6d 65 29 0a | 58 09 09 09 09 09 3b 20 |l-name).|X.....; |
|00000b80| 42 6f 64 79 0a 58 20 20 | 20 20 28 73 65 74 71 20 |Body.X | (setq |
|00000b90| 6e 61 6d 65 2d 6c 69 73 | 74 20 28 74 70 6c 2d 6d |name-lis|t (tpl-m|
|00000ba0| 61 6b 65 2d 63 6f 6d 70 | 6c 65 74 69 6f 6e 2d 6c |ake-comp|letion-l|
|00000bb0| 69 73 74 29 29 0a 58 20 | 20 20 20 28 73 65 74 71 |ist)).X | (setq|
|00000bc0| 20 74 70 6c 2d 6e 61 6d | 65 20 28 63 6f 6d 70 6c | tpl-nam|e (compl|
|00000bd0| 65 74 69 6e 67 2d 72 65 | 61 64 20 22 73 65 61 72 |eting-re|ad "sear|
|00000be0| 63 68 2d 66 6f 72 77 61 | 72 64 2d 74 70 6c 3a 20 |ch-forwa|rd-tpl: |
|00000bf0| 4e 61 6d 65 20 6f 66 20 | 74 65 6d 70 6c 61 74 65 |Name of |template|
|00000c00| 3f 20 22 0a 58 09 09 09 | 09 20 20 20 20 6e 61 6d |? ".X...|. nam|
|00000c10| 65 2d 6c 69 73 74 20 6e | 69 6c 20 74 20 6e 69 6c |e-list n|il t nil|
|00000c20| 29 29 0a 58 20 20 20 20 | 28 74 70 6c 2d 73 65 61 |)).X |(tpl-sea|
|00000c30| 72 63 68 2d 66 6f 72 77 | 61 72 64 20 74 70 6c 2d |rch-forw|ard tpl-|
|00000c40| 6e 61 6d 65 29 0a 58 20 | 20 29 20 3b 20 6c 65 74 |name).X | ) ; let|
|00000c50| 0a 58 29 20 3b 20 64 65 | 66 75 6e 20 73 65 61 72 |.X) ; de|fun sear|
|00000c60| 63 68 2d 66 6f 72 77 61 | 72 64 2d 74 70 6c 0a 58 |ch-forwa|rd-tpl.X|
|00000c70| 0a 58 3b 3b 3b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |.X;;;+++|++++++++|
|00000c80| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000c90| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000ca0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000cb0| 2b 2b 2b 2b 2b 2b 0a 58 | 0a 58 28 64 65 66 75 6e |++++++.X|.X(defun|
|00000cc0| 20 74 70 6c 2d 64 65 6c | 65 74 65 2d 6c 65 61 64 | tpl-del|ete-lead|
|00000cd0| 69 6e 67 2d 77 68 69 74 | 65 73 70 61 63 65 20 28 |ing-whit|espace (|
|00000ce0| 74 65 78 74 2d 6c 69 73 | 74 29 0a 58 20 20 22 52 |text-lis|t).X "R|
|00000cf0| 65 6d 6f 76 65 20 6c 65 | 61 64 69 6e 67 20 77 68 |emove le|ading wh|
|00000d00| 69 74 65 73 70 61 63 65 | 20 74 6f 6b 65 6e 73 20 |itespace| tokens |
|00000d10| 66 72 6f 6d 20 54 45 58 | 54 2d 4c 49 53 54 20 61 |from TEX|T-LIST a|
|00000d20| 6e 64 20 72 65 74 75 72 | 6e 20 72 65 6d 61 69 6e |nd retur|n remain|
|00000d30| 69 6e 67 20 6c 69 73 74 | 2e 22 0a 58 09 09 09 09 |ing list|.".X....|
|00000d40| 09 3b 20 4c 6f 63 61 6c | 20 56 61 72 69 61 62 6c |.; Local| Variabl|
|00000d50| 65 73 0a 58 20 20 28 6c | 65 74 20 28 29 0a 58 09 |es.X (l|et ().X.|
|00000d60| 09 09 09 09 3b 20 42 6f | 64 79 0a 58 20 20 20 20 |....; Bo|dy.X |
|00000d70| 28 77 68 69 6c 65 20 28 | 61 6e 64 20 74 65 78 74 |(while (|and text|
|00000d80| 2d 6c 69 73 74 20 28 65 | 71 75 61 6c 20 74 70 6c |-list (e|qual tpl|
|00000d90| 2d 77 68 69 74 65 73 70 | 61 63 65 2d 74 79 70 65 |-whitesp|ace-type|
|00000da0| 0a 58 09 09 09 09 20 28 | 74 70 6c 2d 74 6f 6b 65 |.X.... (|tpl-toke|
|00000db0| 6e 2d 6e 61 6d 65 20 28 | 63 61 72 20 74 65 78 74 |n-name (|car text|
|00000dc0| 2d 6c 69 73 74 29 29 29 | 29 0a 58 20 20 20 20 20 |-list)))|).X |
|00000dd0| 20 28 73 65 74 71 20 74 | 65 78 74 2d 6c 69 73 74 | (setq t|ext-list|
|00000de0| 20 28 63 64 72 20 74 65 | 78 74 2d 6c 69 73 74 29 | (cdr te|xt-list)|
|00000df0| 29 0a 58 20 20 20 20 20 | 20 29 20 3b 20 77 68 69 |).X | ) ; whi|
|00000e00| 6c 65 0a 58 20 20 20 20 | 3b 20 72 65 74 75 72 6e |le.X |; return|
|00000e10| 0a 58 20 20 20 20 74 65 | 78 74 2d 6c 69 73 74 0a |.X te|xt-list.|
|00000e20| 58 20 20 20 20 29 20 3b | 20 6c 65 74 0a 58 20 20 |X ) ;| let.X |
|00000e30| 29 20 3b 20 64 65 66 75 | 6e 20 74 70 6c 2d 64 65 |) ; defu|n tpl-de|
|00000e40| 6c 65 74 65 2d 6c 65 61 | 64 69 6e 67 2d 77 68 69 |lete-lea|ding-whi|
|00000e50| 74 65 73 70 61 63 65 0a | 58 0a 58 3b 3b 3b 2b 2b |tespace.|X.X;;;++|
|00000e60| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000e70| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000e80| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00000e90| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 0a |++++++++|+++++++.|
|00000ea0| 58 0a 58 28 64 65 66 75 | 6e 20 74 70 6c 2d 66 69 |X.X(defu|n tpl-fi|
|00000eb0| 78 2d 6d 61 74 63 68 20 | 28 74 72 65 65 20 6f 6c |x-match |(tree ol|
|00000ec0| 64 20 6e 65 77 29 0a 58 | 20 20 22 41 64 6a 75 73 |d new).X| "Adjus|
|00000ed0| 74 20 69 6e 64 65 6e 74 | 61 74 69 6f 6e 20 69 6e |t indent|ation in|
|00000ee0| 20 54 52 45 45 20 66 72 | 6f 6d 20 4f 4c 44 20 74 | TREE fr|om OLD t|
|00000ef0| 6f 20 4e 45 57 2e 22 0a | 58 09 09 09 09 09 3b 20 |o NEW.".|X.....; |
|00000f00| 4c 6f 63 61 6c 20 56 61 | 72 69 61 62 6c 65 73 0a |Local Va|riables.|
|00000f10| 58 20 20 28 6c 65 74 20 | 28 72 65 73 75 6c 74 20 |X (let |(result |
|00000f20| 74 6f 6b 65 6e 2d 6c 69 | 73 74 20 74 6f 6b 65 6e |token-li|st token|
|00000f30| 29 0a 58 09 09 09 09 09 | 3b 20 42 6f 64 79 0a 58 |).X.....|; Body.X|
|00000f40| 20 20 20 20 28 69 66 20 | 28 6e 6f 74 20 6e 65 77 | (if |(not new|
|00000f50| 29 0a 58 09 28 73 65 74 | 71 20 6e 65 77 20 6f 6c |).X.(set|q new ol|
|00000f60| 64 29 0a 58 20 20 20 20 | 20 20 29 20 3b 20 69 66 |d).X | ) ; if|
|00000f70| 0a 58 20 20 20 20 28 73 | 65 74 71 20 72 65 73 75 |.X (s|etq resu|
|00000f80| 6c 74 20 6e 69 6c 29 0a | 58 20 20 20 20 28 73 65 |lt nil).|X (se|
|00000f90| 74 71 20 74 6f 6b 65 6e | 2d 6c 69 73 74 20 28 74 |tq token|-list (t|
|00000fa0| 70 6c 2d 74 6f 6b 65 6e | 2d 76 61 6c 75 65 20 74 |pl-token|-value t|
|00000fb0| 72 65 65 29 29 0a 58 20 | 20 20 20 28 77 68 69 6c |ree)).X | (whil|
|00000fc0| 65 20 74 6f 6b 65 6e 2d | 6c 69 73 74 0a 58 20 20 |e token-|list.X |
|00000fd0| 20 20 20 20 28 73 65 74 | 71 20 74 6f 6b 65 6e 20 | (set|q token |
|00000fe0| 28 63 61 72 20 74 6f 6b | 65 6e 2d 6c 69 73 74 29 |(car tok|en-list)|
|00000ff0| 29 0a 58 20 20 20 20 20 | 20 28 73 65 74 71 20 74 |).X | (setq t|
|00001000| 6f 6b 65 6e 2d 6c 69 73 | 74 20 28 63 64 72 20 74 |oken-lis|t (cdr t|
|00001010| 6f 6b 65 6e 2d 6c 69 73 | 74 29 29 0a 58 20 20 20 |oken-lis|t)).X |
|00001020| 20 20 20 3b 28 64 65 62 | 75 67 20 6e 69 6c 20 22 | ;(deb|ug nil "|
|00001030| 74 6f 6b 65 6e 22 20 74 | 6f 6b 65 6e 29 0a 58 20 |token" t|oken).X |
|00001040| 20 20 20 20 20 28 69 66 | 20 28 61 6e 64 20 28 65 | (if| (and (e|
|00001050| 71 75 61 6c 20 74 70 6c | 2d 69 6e 64 65 6e 74 61 |qual tpl|-indenta|
|00001060| 74 69 6f 6e 2d 74 79 70 | 65 20 28 74 70 6c 2d 74 |tion-typ|e (tpl-t|
|00001070| 6f 6b 65 6e 2d 6e 61 6d | 65 20 74 6f 6b 65 6e 29 |oken-nam|e token)|
|00001080| 29 0a 58 09 20 20 20 20 | 20 20 20 28 2f 3d 20 74 |).X. | (/= t|
|00001090| 70 6c 2d 63 6f 6d 6d 65 | 6e 74 2d 6c 65 76 65 6c |pl-comme|nt-level|
|000010a0| 20 28 74 70 6c 2d 74 6f | 6b 65 6e 2d 76 61 6c 75 | (tpl-to|ken-valu|
|000010b0| 65 20 74 6f 6b 65 6e 29 | 29 29 0a 58 09 20 20 28 |e token)|)).X. (|
|000010c0| 73 65 74 71 20 74 6f 6b | 65 6e 20 28 74 70 6c 2d |setq tok|en (tpl-|
|000010d0| 6d 61 6b 65 2d 74 6f 6b | 65 6e 20 28 74 70 6c 2d |make-tok|en (tpl-|
|000010e0| 74 6f 6b 65 6e 2d 74 79 | 70 65 20 74 6f 6b 65 6e |token-ty|pe token|
|000010f0| 29 0a 58 09 09 09 09 20 | 20 20 20 20 20 28 74 70 |).X.... | (tp|
|00001100| 6c 2d 74 6f 6b 65 6e 2d | 6e 61 6d 65 20 74 6f 6b |l-token-|name tok|
|00001110| 65 6e 29 0a 58 09 09 09 | 09 20 20 20 20 20 20 28 |en).X...|. (|
|00001120| 2b 20 28 2d 20 6e 65 77 | 20 6f 6c 64 29 20 28 74 |+ (- new| old) (t|
|00001130| 70 6c 2d 74 6f 6b 65 6e | 2d 76 61 6c 75 65 20 74 |pl-token|-value t|
|00001140| 6f 6b 65 6e 29 29 29 29 | 0a 58 09 29 20 3b 20 69 |oken))))|.X.) ; i|
|00001150| 66 0a 58 20 20 20 20 20 | 20 28 73 65 74 71 20 72 |f.X | (setq r|
|00001160| 65 73 75 6c 74 20 28 61 | 70 70 65 6e 64 20 72 65 |esult (a|ppend re|
|00001170| 73 75 6c 74 20 28 6c 69 | 73 74 20 74 6f 6b 65 6e |sult (li|st token|
|00001180| 29 29 29 0a 58 20 20 20 | 20 20 20 29 20 3b 20 77 |))).X | ) ; w|
|00001190| 68 69 6c 65 20 74 6f 6b | 65 6e 2d 6c 69 73 74 0a |hile tok|en-list.|
|000011a0| 58 20 20 20 20 3b 20 72 | 65 74 75 72 6e 0a 58 20 |X ; r|eturn.X |
|000011b0| 20 20 20 72 65 73 75 6c | 74 0a 58 20 20 20 20 29 | resul|t.X )|
|000011c0| 20 3b 20 6c 65 74 0a 58 | 20 20 29 20 3b 20 64 65 | ; let.X| ) ; de|
|000011d0| 66 75 6e 20 74 70 6c 2d | 66 69 78 2d 6d 61 74 63 |fun tpl-|fix-matc|
|000011e0| 68 0a 58 0a 58 3b 3b 3b | 2b 2b 2b 2b 2b 2b 2b 2b |h.X.X;;;|++++++++|
|000011f0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00001200| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00001210| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00001220| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 0a 58 0a 58 28 64 65 |++++++++|+.X.X(de|
|00001230| 66 75 6e 20 74 70 6c 2d | 67 65 74 2d 6d 61 74 63 |fun tpl-|get-matc|
|00001240| 68 20 28 70 6c 61 63 65 | 68 6f 6c 64 65 72 20 74 |h (place|holder t|
|00001250| 72 65 65 20 69 6e 64 65 | 6e 74 29 0a 58 20 20 22 |ree inde|nt).X "|
|00001260| 46 69 6e 64 20 6d 61 74 | 63 68 20 66 6f 72 20 50 |Find mat|ch for P|
|00001270| 4c 41 43 45 48 4f 4c 44 | 45 52 20 69 6e 20 54 52 |LACEHOLD|ER in TR|
|00001280| 45 45 2e 20 20 41 64 6a | 75 73 74 20 6d 61 74 63 |EE. Adj|ust matc|
|00001290| 68 65 64 20 76 61 6c 75 | 65 20 77 69 74 68 20 49 |hed valu|e with I|
|000012a0| 4e 44 45 4e 54 2e 22 0a | 58 09 09 09 09 09 3b 20 |NDENT.".|X.....; |
|000012b0| 4c 6f 63 61 6c 20 56 61 | 72 69 61 62 6c 65 73 0a |Local Va|riables.|
|000012c0| 58 20 20 28 6c 65 74 20 | 28 6e 61 6d 65 20 6d 61 |X (let |(name ma|
|000012d0| 74 63 68 20 74 6f 6b 65 | 6e 20 74 6f 6b 65 6e 2d |tch toke|n token-|
|000012e0| 74 79 70 65 20 63 75 72 | 72 65 6e 74 2d 69 6e 64 |type cur|rent-ind|
|000012f0| 65 6e 74 29 0a 58 09 09 | 09 09 09 3b 20 42 6f 64 |ent).X..|...; Bod|
|00001300| 79 0a 58 20 20 20 20 28 | 73 65 74 71 20 6e 61 6d |y.X (|setq nam|
|00001310| 65 20 28 74 70 6c 2d 74 | 6f 6b 65 6e 2d 6e 61 6d |e (tpl-t|oken-nam|
|00001320| 65 20 28 74 70 6c 2d 70 | 61 72 73 65 2d 70 6c 61 |e (tpl-p|arse-pla|
|00001330| 63 65 68 6f 6c 64 65 72 | 20 28 74 70 6c 2d 74 6f |ceholder| (tpl-to|
|00001340| 6b 65 6e 2d 76 61 6c 75 | 65 20 70 6c 61 63 65 68 |ken-valu|e placeh|
|00001350| 6f 6c 64 65 72 29 29 29 | 29 0a 58 20 20 20 20 28 |older)))|).X (|
|00001360| 73 65 74 71 20 6d 61 74 | 63 68 20 6e 69 6c 29 0a |setq mat|ch nil).|
|00001370| 58 20 20 20 20 28 77 68 | 69 6c 65 20 28 61 6e 64 |X (wh|ile (and|
|00001380| 20 74 72 65 65 20 28 6e | 6f 74 20 6d 61 74 63 68 | tree (n|ot match|
|00001390| 29 29 0a 58 20 20 20 20 | 20 20 28 73 65 74 71 20 |)).X | (setq |
|000013a0| 74 6f 6b 65 6e 20 28 63 | 61 72 20 74 72 65 65 29 |token (c|ar tree)|
|000013b0| 29 0a 58 20 20 20 20 20 | 20 28 73 65 74 71 20 74 |).X | (setq t|
|000013c0| 72 65 65 20 28 63 64 72 | 20 74 72 65 65 29 29 0a |ree (cdr| tree)).|
|000013d0| 58 20 20 20 20 20 20 28 | 73 65 74 71 20 74 6f 6b |X (|setq tok|
|000013e0| 65 6e 2d 74 79 70 65 20 | 28 74 70 6c 2d 74 6f 6b |en-type |(tpl-tok|
|000013f0| 65 6e 2d 74 79 70 65 20 | 74 6f 6b 65 6e 29 29 0a |en-type |token)).|
|00001400| 58 20 20 20 20 20 20 3b | 28 64 65 62 75 67 20 6e |X ;|(debug n|
|00001410| 69 6c 20 22 74 6f 6b 65 | 6e 2d 74 79 70 65 22 20 |il "toke|n-type" |
|00001420| 74 6f 6b 65 6e 2d 74 79 | 70 65 29 0a 58 20 20 20 |token-ty|pe).X |
|00001430| 20 20 20 28 69 66 20 28 | 65 71 75 61 6c 20 74 70 | (if (|equal tp|
|00001440| 6c 2d 74 65 72 6d 69 6e | 61 6c 2d 74 79 70 65 20 |l-termin|al-type |
|00001450| 74 6f 6b 65 6e 2d 74 79 | 70 65 29 0a 58 09 20 20 |token-ty|pe).X. |
|00001460| 28 69 66 20 28 65 71 75 | 61 6c 20 74 70 6c 2d 69 |(if (equ|al tpl-i|
|00001470| 6e 64 65 6e 74 61 74 69 | 6f 6e 2d 74 79 70 65 20 |ndentati|on-type |
|00001480| 28 74 70 6c 2d 74 6f 6b | 65 6e 2d 6e 61 6d 65 20 |(tpl-tok|en-name |
|00001490| 74 6f 6b 65 6e 29 29 0a | 58 09 20 20 20 20 20 20 |token)).|X. |
|000014a0| 28 73 65 74 71 20 63 75 | 72 72 65 6e 74 2d 69 6e |(setq cu|rrent-in|
|000014b0| 64 65 6e 74 20 28 74 70 | 6c 2d 74 6f 6b 65 6e 2d |dent (tp|l-token-|
|000014c0| 76 61 6c 75 65 20 74 6f | 6b 65 6e 29 29 0a 58 09 |value to|ken)).X.|
|000014d0| 20 20 20 20 29 20 3b 20 | 69 66 20 28 65 71 75 61 | ) ; |if (equa|
|000014e0| 6c 20 74 70 6c 2d 69 6e | 64 65 6e 74 61 74 69 6f |l tpl-in|dentatio|
|000014f0| 6e 2d 74 79 70 65 20 28 | 74 70 6c 2d 74 6f 6b 65 |n-type (|tpl-toke|
|00001500| 6e 2d 6e 61 6d 65 20 74 | 6f 6b 65 6e 29 29 0a 58 |n-name t|oken)).X|
|00001510| 09 3b 20 65 6c 73 65 0a | 58 09 28 69 66 20 28 65 |.; else.|X.(if (e|
|00001520| 71 75 61 6c 20 6e 61 6d | 65 0a 58 09 09 20 20 20 |qual nam|e.X.. |
|00001530| 28 74 70 6c 2d 74 6f 6b | 65 6e 2d 6e 61 6d 65 0a |(tpl-tok|en-name.|
|00001540| 58 09 09 20 20 20 20 28 | 74 70 6c 2d 70 61 72 73 |X.. (|tpl-pars|
|00001550| 65 2d 70 6c 61 63 65 68 | 6f 6c 64 65 72 20 28 74 |e-placeh|older (t|
|00001560| 70 6c 2d 74 6f 6b 65 6e | 2d 6e 61 6d 65 20 74 6f |pl-token|-name to|
|00001570| 6b 65 6e 29 29 29 29 0a | 58 09 20 20 20 20 28 73 |ken)))).|X. (s|
|00001580| 65 74 71 20 6d 61 74 63 | 68 20 28 74 70 6c 2d 66 |etq matc|h (tpl-f|
|00001590| 69 78 2d 6d 61 74 63 68 | 20 74 6f 6b 65 6e 20 69 |ix-match| token i|
|000015a0| 6e 64 65 6e 74 20 63 75 | 72 72 65 6e 74 2d 69 6e |ndent cu|rrent-in|
|000015b0| 64 65 6e 74 29 29 0a 58 | 09 20 20 29 20 3b 20 69 |dent)).X|. ) ; i|
|000015c0| 66 20 28 65 71 75 61 6c | 20 6e 61 6d 65 2e 2e 2e |f (equal| name...|
|000015d0| 29 0a 58 09 29 20 3b 20 | 69 66 20 28 65 71 75 61 |).X.) ; |if (equa|
|000015e0| 6c 20 74 70 6c 2d 74 65 | 72 6d 69 6e 61 6c 2d 74 |l tpl-te|rminal-t|
|000015f0| 79 70 65 20 74 6f 6b 65 | 6e 2d 74 79 70 65 29 0a |ype toke|n-type).|
|00001600| 58 20 20 20 20 20 20 29 | 20 3b 20 77 68 69 6c 65 |X )| ; while|
|00001610| 20 28 61 6e 64 20 74 72 | 65 65 20 28 6e 6f 74 20 | (and tr|ee (not |
|00001620| 6d 61 74 63 68 29 29 0a | 58 20 20 20 20 3b 20 72 |match)).|X ; r|
|00001630| 65 74 75 72 6e 0a 58 20 | 20 20 20 6d 61 74 63 68 |eturn.X | match|
|00001640| 0a 58 20 20 20 20 29 20 | 3b 20 6c 65 74 0a 58 20 |.X ) |; let.X |
|00001650| 20 29 20 3b 20 64 65 66 | 75 6e 20 74 70 6c 2d 67 | ) ; def|un tpl-g|
|00001660| 65 74 2d 6d 61 74 63 68 | 0a 58 0a 58 3b 3b 3b 2b |et-match|.X.X;;;+|
|00001670| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00001680| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00001690| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000016a0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000016b0| 0a 58 0a 58 28 64 65 66 | 75 6e 20 74 70 6c 2d 67 |.X.X(def|un tpl-g|
|000016c0| 65 74 2d 70 6c 61 63 65 | 68 6f 6c 64 65 72 2d 65 |et-place|holder-e|
|000016d0| 6e 64 20 28 70 6c 61 63 | 65 68 6f 6c 64 65 72 20 |nd (plac|eholder |
|000016e0| 74 70 6c 2d 6e 61 6d 65 | 20 26 6f 70 74 69 6f 6e |tpl-name| &option|
|000016f0| 61 6c 20 6f 63 63 75 72 | 72 65 6e 63 65 29 0a 58 |al occur|rence).X|
|00001700| 20 20 22 50 72 6f 6d 70 | 74 20 75 73 65 72 20 66 | "Promp|t user f|
|00001710| 6f 72 20 65 6e 64 20 6f | 66 20 50 4c 41 43 45 48 |or end o|f PLACEH|
|00001720| 4f 4c 44 45 52 20 69 6e | 20 54 50 4c 2d 4e 41 4d |OLDER in| TPL-NAM|
|00001730| 45 2e 0a 58 20 20 20 4f | 70 74 69 6f 6e 61 6c 20 |E..X O|ptional |
|00001740| 74 68 69 72 64 20 61 72 | 67 75 6d 65 6e 74 20 4f |third ar|gument O|
|00001750| 43 43 55 52 52 45 4e 43 | 45 20 73 70 65 63 69 66 |CCURRENC|E specif|
|00001760| 69 65 73 20 77 68 69 63 | 68 0a 58 20 20 20 6f 63 |ies whic|h.X oc|
|00001770| 63 75 72 72 65 6e 63 65 | 20 6f 66 20 70 6c 61 63 |currence| of plac|
|00001780| 65 68 6f 6c 64 65 72 20 | 74 6f 20 66 69 6e 64 2e |eholder |to find.|
|00001790| 22 0a 58 09 09 09 09 09 | 3b 20 4c 6f 63 61 6c 20 |".X.....|; Local |
|000017a0| 56 61 72 69 61 62 6c 65 | 73 0a 58 20 20 28 6c 65 |Variable|s.X (le|
|000017b0| 74 20 28 74 65 6d 70 6c | 61 74 65 20 6d 73 67 20 |t (templ|ate msg |
|000017c0| 72 65 74 75 72 6e 20 73 | 74 6f 70 20 73 69 7a 65 |return s|top size|
|000017d0| 29 0a 58 09 09 09 09 09 | 3b 20 42 6f 64 79 0a 58 |).X.....|; Body.X|
|000017e0| 20 20 20 20 28 69 66 20 | 28 6e 6f 74 20 6f 63 63 | (if |(not occ|
|000017f0| 75 72 72 65 6e 63 65 29 | 0a 58 09 28 73 65 74 71 |urrence)|.X.(setq|
|00001800| 20 6f 63 63 75 72 72 65 | 6e 63 65 20 31 29 0a 58 | occurre|nce 1).X|
|00001810| 20 20 20 20 20 20 29 20 | 3b 20 69 66 0a 58 09 09 | ) |; if.X..|
|00001820| 09 09 09 3b 20 47 65 74 | 20 76 61 6c 75 65 20 62 |...; Get| value b|
|00001830| 65 66 6f 72 65 20 63 68 | 61 6e 67 69 6e 67 20 62 |efore ch|anging b|
|00001840| 75 66 66 65 72 0a 58 20 | 20 20 20 28 73 65 74 71 |uffer.X | (setq|
|00001850| 20 74 65 6d 70 6c 61 74 | 65 20 28 74 70 6c 2d 66 | templat|e (tpl-f|
|00001860| 69 6e 64 2d 74 65 6d 70 | 6c 61 74 65 20 74 70 6c |ind-temp|late tpl|
|00001870| 2d 6e 61 6d 65 29 29 0a | 58 20 20 20 20 28 73 61 |-name)).|X (sa|
|00001880| 76 65 2d 77 69 6e 64 6f | 77 2d 65 78 63 75 72 73 |ve-windo|w-excurs|
|00001890| 69 6f 6e 0a 58 20 20 20 | 20 20 20 28 64 65 6c 65 |ion.X | (dele|
|000018a0| 74 65 2d 6f 74 68 65 72 | 2d 77 69 6e 64 6f 77 73 |te-other|-windows|
|000018b0| 29 0a 58 20 20 20 20 20 | 20 28 70 6f 70 2d 74 6f |).X | (pop-to|
|000018c0| 2d 62 75 66 66 65 72 20 | 28 67 65 74 2d 62 75 66 |-buffer |(get-buf|
|000018d0| 66 65 72 2d 63 72 65 61 | 74 65 20 22 2a 54 65 6d |fer-crea|te "*Tem|
|000018e0| 70 6c 61 74 65 2a 22 29 | 29 0a 58 20 20 20 20 20 |plate*")|).X |
|000018f0| 20 28 65 72 61 73 65 2d | 62 75 66 66 65 72 29 0a | (erase-|buffer).|
|00001900| 58 20 20 20 20 20 20 28 | 74 70 6c 2d 75 6e 73 63 |X (|tpl-unsc|
|00001910| 61 6e 20 74 65 6d 70 6c | 61 74 65 29 0a 58 09 09 |an templ|ate).X..|
|00001920| 09 09 09 3b 20 53 69 7a | 65 20 74 68 65 20 77 69 |...; Siz|e the wi|
|00001930| 6e 64 6f 77 0a 58 20 20 | 20 20 20 20 28 73 65 74 |ndow.X | (set|
|00001940| 71 20 73 74 6f 70 20 28 | 70 6f 69 6e 74 2d 6d 61 |q stop (|point-ma|
|00001950| 78 29 29 0a 58 20 20 20 | 20 20 20 28 67 6f 74 6f |x)).X | (goto|
|00001960| 2d 63 68 61 72 20 28 70 | 6f 69 6e 74 2d 6d 69 6e |-char (p|oint-min|
|00001970| 29 29 0a 58 20 20 20 20 | 20 20 28 73 65 74 71 20 |)).X | (setq |
|00001980| 73 69 7a 65 20 28 31 2b | 20 28 63 6f 75 6e 74 2d |size (1+| (count-|
|00001990| 6c 69 6e 65 73 20 28 70 | 6f 69 6e 74 29 20 73 74 |lines (p|oint) st|
|000019a0| 6f 70 29 29 29 0a 58 20 | 20 20 20 20 20 28 73 65 |op))).X | (se|
|000019b0| 74 71 20 73 69 7a 65 20 | 28 6d 61 78 20 73 69 7a |tq size |(max siz|
|000019c0| 65 20 77 69 6e 64 6f 77 | 2d 6d 69 6e 2d 68 65 69 |e window|-min-hei|
|000019d0| 67 68 74 29 29 0a 58 20 | 20 20 20 20 20 28 69 66 |ght)).X | (if|
|000019e0| 20 28 3c 20 73 69 7a 65 | 20 28 77 69 6e 64 6f 77 | (< size| (window|
|000019f0| 2d 68 65 69 67 68 74 29 | 29 0a 58 09 20 20 28 73 |-height)|).X. (s|
|00001a00| 68 72 69 6e 6b 2d 77 69 | 6e 64 6f 77 20 28 2d 20 |hrink-wi|ndow (- |
|00001a10| 28 77 69 6e 64 6f 77 2d | 68 65 69 67 68 74 29 20 |(window-|height) |
|00001a20| 73 69 7a 65 29 29 0a 58 | 09 29 20 3b 20 69 66 0a |size)).X|.) ; if.|
|00001a30| 58 09 09 09 09 09 3b 20 | 46 69 6e 64 20 74 68 65 |X.....; |Find the|
|00001a40| 20 70 6c 61 63 65 68 6f | 6c 64 65 72 0a 58 20 20 | placeho|lder.X |
|00001a50| 20 20 20 20 28 73 65 61 | 72 63 68 2d 66 6f 72 77 | (sea|rch-forw|
|00001a60| 61 72 64 20 70 6c 61 63 | 65 68 6f 6c 64 65 72 20 |ard plac|eholder |
|00001a70| 28 70 6f 69 6e 74 2d 6d | 61 78 29 20 74 20 6f 63 |(point-m|ax) t oc|
|00001a80| 63 75 72 72 65 6e 63 65 | 29 0a 58 20 20 20 20 20 |currence|).X |
|00001a90| 20 28 6f 74 68 65 72 2d | 77 69 6e 64 6f 77 20 31 | (other-|window 1|
|00001aa0| 29 0a 58 20 20 20 20 20 | 20 28 73 65 74 71 20 6d |).X | (setq m|
|00001ab0| 73 67 20 28 63 6f 6e 63 | 61 74 20 22 49 6e 20 5c |sg (conc|at "In \|
|00001ac0| 22 22 20 74 70 6c 2d 6e | 61 6d 65 20 22 5c 22 20 |"" tpl-n|ame "\" |
|00001ad0| 6c 6f 6f 6b 69 6e 67 20 | 66 6f 72 20 65 6e 64 20 |looking |for end |
|00001ae0| 6f 66 20 5c 22 22 0a 58 | 09 09 09 70 6c 61 63 65 |of \"".X|...place|
|00001af0| 68 6f 6c 64 65 72 20 22 | 5c 22 22 29 29 0a 58 20 |holder "|\"")).X |
|00001b00| 20 20 20 20 20 28 73 65 | 74 71 20 72 65 74 75 72 | (se|tq retur|
|00001b10| 6e 20 28 74 70 6c 2d 67 | 65 74 2d 70 6f 73 69 74 |n (tpl-g|et-posit|
|00001b20| 69 6f 6e 20 28 70 6f 69 | 6e 74 29 20 28 70 6f 69 |ion (poi|nt) (poi|
|00001b30| 6e 74 2d 6d 61 78 29 20 | 6d 73 67 29 29 0a 58 20 |nt-max) |msg)).X |
|00001b40| 20 20 20 20 20 29 20 3b | 20 73 61 76 65 2d 77 69 | ) ;| save-wi|
|00001b50| 6e 64 6f 77 2d 65 78 63 | 75 72 73 69 6f 6e 0a 58 |ndow-exc|ursion.X|
|00001b60| 20 20 20 20 28 62 75 72 | 79 2d 62 75 66 66 65 72 | (bur|y-buffer|
|00001b70| 20 22 2a 54 65 6d 70 6c | 61 74 65 2a 22 29 0a 58 | "*Templ|ate*").X|
|00001b80| 20 20 20 20 72 65 74 75 | 72 6e 0a 58 20 20 29 20 | retu|rn.X ) |
|00001b90| 3b 20 6c 65 74 0a 58 29 | 20 3b 20 64 65 66 75 6e |; let.X)| ; defun|
|00001ba0| 20 74 70 6c 2d 67 65 74 | 2d 70 6c 61 63 65 68 6f | tpl-get|-placeho|
|00001bb0| 6c 64 65 72 2d 65 6e 64 | 0a 58 0a 58 3b 3b 3b 2b |lder-end|.X.X;;;+|
|00001bc0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00001bd0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00001be0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00001bf0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00001c00| 0a 58 0a 58 28 64 65 66 | 75 6e 20 74 70 6c 2d 67 |.X.X(def|un tpl-g|
|00001c10| 65 74 2d 70 6f 73 69 74 | 69 6f 6e 20 28 73 74 61 |et-posit|ion (sta|
|00001c20| 72 74 20 73 74 6f 70 20 | 6d 73 67 20 26 6f 70 74 |rt stop |msg &opt|
|00001c30| 69 6f 6e 61 6c 20 73 74 | 61 72 74 2d 70 6f 73 20 |ional st|art-pos |
|00001c40| 6e 61 72 72 6f 77 29 0a | 58 20 20 22 50 72 6f 6d |narrow).|X "Prom|
|00001c50| 70 74 20 75 73 65 72 20 | 66 6f 72 20 61 20 6c 6f |pt user |for a lo|
|00001c60| 63 61 74 69 6f 6e 20 62 | 65 74 77 65 65 6e 20 53 |cation b|etween S|
|00001c70| 54 41 52 54 20 61 6e 64 | 20 53 54 4f 50 20 77 69 |TART and| STOP wi|
|00001c80| 74 68 20 4d 53 47 2e 0a | 58 20 20 20 4f 70 74 69 |th MSG..|X Opti|
|00001c90| 6f 6e 61 6c 20 66 6f 75 | 72 74 68 20 61 72 67 75 |onal fou|rth argu|
|00001ca0| 6d 65 6e 74 20 53 54 41 | 52 54 2d 50 4f 53 20 6d |ment STA|RT-POS m|
|00001cb0| 61 79 20 62 65 20 75 73 | 65 64 20 66 6f 72 20 69 |ay be us|ed for i|
|00001cc0| 6e 69 74 69 61 6c 0a 58 | 20 20 20 70 6c 61 63 65 |nitial.X| place|
|00001cd0| 6d 65 6e 74 20 6f 66 20 | 70 6f 69 6e 74 2e 20 20 |ment of |point. |
|00001ce0| 46 69 66 74 68 20 61 72 | 67 75 6d 65 6e 74 20 4e |Fifth ar|gument N|
|00001cf0| 41 52 52 4f 57 2c 20 69 | 66 20 6e 6f 6e 2d 6e 69 |ARROW, i|f non-ni|
|00001d00| 6c 2c 0a 58 20 20 20 6e | 61 72 72 6f 77 73 20 74 |l,.X n|arrows t|
|00001d10| 68 65 20 72 65 67 69 6f | 6e 2e 22 0a 58 09 09 09 |he regio|n.".X...|
|00001d20| 09 09 3b 20 4c 6f 63 61 | 6c 20 56 61 72 69 61 62 |..; Loca|l Variab|
|00001d30| 6c 65 73 0a 58 20 20 28 | 6c 65 74 20 28 6c 6f 6f |les.X (|let (loo|
|00001d40| 6b 69 6e 67 20 77 61 73 | 2d 6d 6f 64 69 66 69 61 |king was|-modifia|
|00001d50| 62 6c 65 29 0a 58 09 09 | 09 09 09 3b 20 42 6f 64 |ble).X..|...; Bod|
|00001d60| 79 0a 58 09 09 09 09 09 | 3b 20 43 68 65 63 6b 20 |y.X.....|; Check |
|00001d70| 66 6f 72 20 76 61 6c 69 | 64 20 72 65 67 69 6f 6e |for vali|d region|
|00001d80| 0a 58 20 20 20 20 28 69 | 66 20 28 3c 20 73 74 6f |.X (i|f (< sto|
|00001d90| 70 20 73 74 61 72 74 29 | 0a 58 09 28 65 72 72 6f |p start)|.X.(erro|
|00001da0| 72 20 22 74 70 6c 2d 67 | 65 74 2d 70 6f 73 69 74 |r "tpl-g|et-posit|
|00001db0| 69 6f 6e 3a 20 49 6e 76 | 61 6c 69 64 20 72 65 67 |ion: Inv|alid reg|
|00001dc0| 69 6f 6e 20 73 70 65 63 | 69 66 69 63 61 74 69 6f |ion spec|ificatio|
|00001dd0| 6e 2e 22 29 0a 58 20 20 | 20 20 20 20 29 20 3b 20 |n.").X | ) ; |
|00001de0| 69 66 0a 58 09 09 09 09 | 09 3b 20 53 61 76 65 20 |if.X....|.; Save |
|00001df0| 63 75 72 72 65 6e 74 20 | 73 74 61 74 75 73 0a 58 |current |status.X|
|00001e00| 20 20 20 20 28 69 66 20 | 28 6e 6f 74 20 73 74 61 | (if |(not sta|
|00001e10| 72 74 2d 70 6f 73 29 0a | 58 09 28 73 65 74 71 20 |rt-pos).|X.(setq |
|00001e20| 73 74 61 72 74 2d 70 6f | 73 20 73 74 61 72 74 29 |start-po|s start)|
|00001e30| 0a 58 20 20 20 20 20 20 | 29 20 3b 20 69 66 0a 58 |.X |) ; if.X|
|00001e40| 20 20 20 20 28 73 61 76 | 65 2d 72 65 73 74 72 69 | (sav|e-restri|
|00001e50| 63 74 69 6f 6e 0a 58 20 | 20 20 20 20 20 28 69 66 |ction.X | (if|
|00001e60| 20 6e 61 72 72 6f 77 0a | 58 09 20 20 28 6e 61 72 | narrow.|X. (nar|
|00001e70| 72 6f 77 2d 74 6f 2d 72 | 65 67 69 6f 6e 20 73 74 |row-to-r|egion st|
|00001e80| 61 72 74 20 73 74 6f 70 | 29 0a 58 09 29 20 3b 20 |art stop|).X.) ; |
|00001e90| 69 66 0a 58 20 20 20 20 | 20 20 28 73 65 74 71 20 |if.X | (setq |
|00001ea0| 77 61 73 2d 6d 6f 64 69 | 66 69 61 62 6c 65 20 28 |was-modi|fiable (|
|00001eb0| 6e 6f 74 20 62 75 66 66 | 65 72 2d 72 65 61 64 2d |not buff|er-read-|
|00001ec0| 6f 6e 6c 79 29 29 0a 58 | 20 20 20 20 20 20 28 69 |only)).X| (i|
|00001ed0| 66 20 77 61 73 2d 6d 6f | 64 69 66 69 61 62 6c 65 |f was-mo|difiable|
|00001ee0| 0a 58 09 20 20 28 74 6f | 67 67 6c 65 2d 72 65 61 |.X. (to|ggle-rea|
|00001ef0| 64 2d 6f 6e 6c 79 29 0a | 58 09 29 20 3b 20 69 66 |d-only).|X.) ; if|
|00001f00| 20 77 61 73 2d 6d 6f 64 | 69 66 69 61 62 6c 65 0a | was-mod|ifiable.|
|00001f10| 58 20 20 20 20 20 20 28 | 73 65 74 71 20 6f 72 69 |X (|setq ori|
|00001f20| 67 2d 62 75 66 66 65 72 | 20 28 63 75 72 72 65 6e |g-buffer| (curren|
|00001f30| 74 2d 62 75 66 66 65 72 | 29 29 0a 58 09 09 09 09 |t-buffer|)).X....|
|00001f40| 09 3b 20 4c 6f 6f 70 20 | 75 6e 74 69 6c 20 61 63 |.; Loop |until ac|
|00001f50| 63 65 70 74 61 62 6c 65 | 20 61 6e 73 77 65 72 0a |ceptable| answer.|
|00001f60| 58 20 20 20 20 20 20 28 | 73 65 74 71 20 6c 6f 6f |X (|setq loo|
|00001f70| 6b 69 6e 67 20 74 29 0a | 58 20 20 20 20 20 20 28 |king t).|X (|
|00001f80| 77 68 69 6c 65 20 6c 6f | 6f 6b 69 6e 67 0a 58 09 |while lo|oking.X.|
|00001f90| 28 67 6f 74 6f 2d 63 68 | 61 72 20 73 74 61 72 74 |(goto-ch|ar start|
|00001fa0| 2d 70 6f 73 29 0a 58 09 | 28 6d 65 73 73 61 67 65 |-pos).X.|(message|
|00001fb0| 20 6d 73 67 29 0a 58 09 | 09 09 09 09 3b 20 57 61 | msg).X.|....; Wa|
|00001fc0| 69 74 20 66 6f 72 20 75 | 73 65 72 20 73 65 6c 65 |it for u|ser sele|
|00001fd0| 63 74 69 6f 6e 0a 58 09 | 28 72 65 63 75 72 73 69 |ction.X.|(recursi|
|00001fe0| 76 65 2d 65 64 69 74 29 | 0a 58 09 09 09 09 09 3b |ve-edit)|.X.....;|
|00001ff0| 20 43 68 65 63 6b 20 76 | 61 6c 69 64 69 74 79 0a | Check v|alidity.|
|00002000| 58 09 28 69 66 20 28 6f | 72 20 28 6e 6f 74 20 28 |X.(if (o|r (not (|
|00002010| 65 71 75 61 6c 20 6f 72 | 69 67 2d 62 75 66 66 65 |equal or|ig-buffe|
|00002020| 72 20 28 63 75 72 72 65 | 6e 74 2d 62 75 66 66 65 |r (curre|nt-buffe|
|00002030| 72 29 29 29 0a 58 09 09 | 28 3c 20 28 70 6f 69 6e |r))).X..|(< (poin|
|00002040| 74 29 20 73 74 61 72 74 | 29 0a 58 09 09 28 3e 20 |t) start|).X..(> |
|00002050| 28 70 6f 69 6e 74 29 20 | 73 74 6f 70 29 29 0a 58 |(point) |stop)).X|
|00002060| 09 20 20 20 20 28 70 72 | 6f 67 6e 0a 58 09 20 20 |. (pr|ogn.X. |
|00002070| 20 20 20 20 28 64 69 6e | 67 29 0a 58 09 20 20 20 | (din|g).X. |
|00002080| 20 20 20 28 6d 65 73 73 | 61 67 65 20 22 53 65 6c | (mess|age "Sel|
|00002090| 65 63 74 65 64 20 70 6f | 73 69 74 69 6f 6e 20 6f |ected po|sition o|
|000020a0| 75 74 20 6f 66 20 62 6f | 75 6e 64 73 2e 22 29 0a |ut of bo|unds.").|
|000020b0| 58 09 20 20 20 20 20 20 | 28 73 69 74 2d 66 6f 72 |X. |(sit-for|
|000020c0| 20 32 29 0a 58 09 20 20 | 20 20 20 20 28 70 6f 70 | 2).X. | (pop|
|000020d0| 2d 74 6f 2d 62 75 66 66 | 65 72 20 6f 72 69 67 2d |-to-buff|er orig-|
|000020e0| 62 75 66 66 65 72 29 0a | 58 09 20 20 20 20 20 20 |buffer).|X. |
|000020f0| 28 67 6f 74 6f 2d 63 68 | 61 72 20 73 74 61 72 74 |(goto-ch|ar start|
|00002100| 2d 70 6f 73 29 0a 58 09 | 20 20 20 20 20 20 29 20 |-pos).X.| ) |
|00002110| 3b 20 70 72 6f 67 6e 0a | 58 09 20 20 3b 20 65 6c |; progn.|X. ; el|
|00002120| 73 65 0a 58 09 20 20 28 | 73 65 74 71 20 6c 6f 6f |se.X. (|setq loo|
|00002130| 6b 69 6e 67 20 6e 69 6c | 29 0a 58 09 20 20 29 20 |king nil|).X. ) |
|00002140| 3b 20 69 66 0a 58 09 29 | 20 3b 20 77 68 69 6c 65 |; if.X.)| ; while|
|00002150| 20 6c 6f 6f 6b 69 6e 67 | 0a 58 09 09 09 09 09 3b | looking|.X.....;|
|00002160| 20 52 65 73 74 6f 72 65 | 20 6f 72 69 67 69 6e 61 | Restore| origina|
|00002170| 6c 20 73 74 61 74 75 73 | 0a 58 20 20 20 20 20 20 |l status|.X |
|00002180| 28 69 66 20 77 61 73 2d | 6d 6f 64 69 66 69 61 62 |(if was-|modifiab|
|00002190| 6c 65 0a 58 09 20 20 28 | 74 6f 67 67 6c 65 2d 72 |le.X. (|toggle-r|
|000021a0| 65 61 64 2d 6f 6e 6c 79 | 29 0a 58 09 29 20 3b 20 |ead-only|).X.) ; |
|000021b0| 69 66 20 77 61 73 2d 6d | 6f 64 69 66 69 61 62 6c |if was-m|odifiabl|
|000021c0| 65 0a 58 20 20 20 20 20 | 20 28 69 66 20 6e 61 72 |e.X | (if nar|
|000021d0| 72 6f 77 0a 58 09 20 20 | 28 77 69 64 65 6e 29 0a |row.X. |(widen).|
|000021e0| 58 09 29 20 3b 20 69 66 | 20 6e 61 72 72 6f 77 0a |X.) ; if| narrow.|
|000021f0| 58 20 20 20 20 20 20 29 | 20 3b 20 73 61 76 65 2d |X )| ; save-|
|00002200| 72 65 73 74 72 69 63 74 | 69 6f 6e 0a 58 20 20 20 |restrict|ion.X |
|00002210| 20 28 70 6f 69 6e 74 29 | 09 09 09 09 3b 20 72 65 | (point)|....; re|
|00002220| 74 75 72 6e 0a 58 20 20 | 29 20 3b 20 6c 65 74 0a |turn.X |) ; let.|
|00002230| 58 29 20 3b 20 64 65 66 | 75 6e 20 74 70 6c 2d 67 |X) ; def|un tpl-g|
|00002240| 65 74 2d 70 6f 73 69 74 | 69 6f 6e 0a 58 0a 58 3b |et-posit|ion.X.X;|
|00002250| 3b 3b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |;;++++++|++++++++|
|00002260| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002270| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002280| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002290| 2b 2b 2b 0a 58 0a 58 28 | 64 65 66 75 6e 20 74 70 |+++.X.X(|defun tp|
|000022a0| 6c 2d 6c 65 61 64 69 6e | 67 2d 74 65 78 74 20 28 |l-leadin|g-text (|
|000022b0| 74 65 6d 70 6c 61 74 65 | 29 0a 58 20 20 22 52 65 |template|).X "Re|
|000022c0| 74 75 72 6e 20 6c 69 74 | 65 72 61 6c 20 74 65 78 |turn lit|eral tex|
|000022d0| 74 20 73 74 72 69 6e 67 | 20 61 74 20 73 74 61 72 |t string| at star|
|000022e0| 74 20 6f 66 20 54 45 4d | 50 4c 41 54 45 20 28 61 |t of TEM|PLATE (a|
|000022f0| 20 6e 61 6d 65 29 2e 22 | 0a 58 09 09 09 09 09 3b | name)."|.X.....;|
|00002300| 20 4c 6f 63 61 6c 20 56 | 61 72 69 61 62 6c 65 73 | Local V|ariables|
|00002310| 0a 58 20 20 28 6c 65 74 | 20 28 62 6f 64 79 20 73 |.X (let| (body s|
|00002320| 74 61 72 74 20 73 74 6f | 70 20 72 65 73 75 6c 74 |tart sto|p result|
|00002330| 29 0a 58 09 09 09 09 09 | 3b 20 42 6f 64 79 0a 58 |).X.....|; Body.X|
|00002340| 20 20 20 20 28 73 65 74 | 71 20 62 6f 64 79 20 28 | (set|q body (|
|00002350| 74 70 6c 2d 66 69 6e 64 | 2d 74 65 6d 70 6c 61 74 |tpl-find|-templat|
|00002360| 65 20 74 65 6d 70 6c 61 | 74 65 29 29 0a 58 20 20 |e templa|te)).X |
|00002370| 20 20 28 69 66 20 28 6e | 6f 74 20 62 6f 64 79 29 | (if (n|ot body)|
|00002380| 0a 58 09 28 65 72 72 6f | 72 20 22 43 61 6e 6e 6f |.X.(erro|r "Canno|
|00002390| 74 20 66 69 6e 64 20 74 | 65 6d 70 6c 61 74 65 2e |t find t|emplate.|
|000023a0| 22 29 0a 58 20 20 20 20 | 20 20 29 20 3b 20 69 66 |").X | ) ; if|
|000023b0| 20 28 6e 6f 74 20 62 6f | 64 79 29 0a 58 20 20 20 | (not bo|dy).X |
|000023c0| 20 28 67 65 74 2d 62 75 | 66 66 65 72 2d 63 72 65 | (get-bu|ffer-cre|
|000023d0| 61 74 65 20 22 2a 57 6f | 72 6b 2a 22 29 0a 58 20 |ate "*Wo|rk*").X |
|000023e0| 20 20 20 28 73 61 76 65 | 2d 77 69 6e 64 6f 77 2d | (save|-window-|
|000023f0| 65 78 63 75 72 73 69 6f | 6e 0a 58 20 20 20 20 20 |excursio|n.X |
|00002400| 20 28 73 65 74 2d 62 75 | 66 66 65 72 20 22 2a 57 | (set-bu|ffer "*W|
|00002410| 6f 72 6b 2a 22 29 0a 58 | 20 20 20 20 20 20 28 65 |ork*").X| (e|
|00002420| 72 61 73 65 2d 62 75 66 | 66 65 72 29 0a 58 20 20 |rase-buf|fer).X |
|00002430| 20 20 20 20 28 74 70 6c | 2d 75 6e 73 63 61 6e 20 | (tpl|-unscan |
|00002440| 62 6f 64 79 29 0a 58 20 | 20 20 20 20 20 28 67 6f |body).X | (go|
|00002450| 74 6f 2d 63 68 61 72 20 | 28 70 6f 69 6e 74 2d 6d |to-char |(point-m|
|00002460| 69 6e 29 29 0a 58 20 20 | 20 20 20 20 28 73 65 74 |in)).X | (set|
|00002470| 71 20 73 74 61 72 74 20 | 28 70 6f 69 6e 74 29 29 |q start |(point))|
|00002480| 0a 58 20 20 20 20 20 20 | 28 65 6e 64 2d 6f 66 2d |.X |(end-of-|
|00002490| 6c 69 6e 65 20 6e 69 6c | 29 0a 58 20 20 20 20 20 |line nil|).X |
|000024a0| 20 28 73 65 74 71 20 73 | 74 6f 70 20 28 70 6f 69 | (setq s|top (poi|
|000024b0| 6e 74 29 29 0a 58 20 20 | 20 20 20 20 28 67 6f 74 |nt)).X | (got|
|000024c0| 6f 2d 63 68 61 72 20 73 | 74 61 72 74 29 0a 58 20 |o-char s|tart).X |
|000024d0| 20 20 20 20 20 28 69 66 | 20 28 72 65 2d 73 65 61 | (if| (re-sea|
|000024e0| 72 63 68 2d 66 6f 72 77 | 61 72 64 20 74 70 6c 2d |rch-forw|ard tpl-|
|000024f0| 62 65 67 69 6e 2d 70 6c | 61 63 65 68 6f 6c 64 65 |begin-pl|aceholde|
|00002500| 72 20 73 74 6f 70 20 73 | 74 61 72 74 29 0a 58 09 |r stop s|tart).X.|
|00002510| 20 20 28 72 65 2d 73 65 | 61 72 63 68 2d 62 61 63 | (re-se|arch-bac|
|00002520| 6b 77 61 72 64 20 74 70 | 6c 2d 62 65 67 69 6e 2d |kward tp|l-begin-|
|00002530| 70 6c 61 63 65 68 6f 6c | 64 65 72 29 0a 58 09 29 |placehol|der).X.)|
|00002540| 20 3b 20 69 66 0a 58 20 | 20 20 20 20 20 28 73 65 | ; if.X | (se|
|00002550| 74 71 20 72 65 73 75 6c | 74 20 28 62 75 66 66 65 |tq resul|t (buffe|
|00002560| 72 2d 73 75 62 73 74 72 | 69 6e 67 20 73 74 61 72 |r-substr|ing star|
|00002570| 74 20 28 70 6f 69 6e 74 | 29 29 29 0a 58 20 20 20 |t (point|))).X |
|00002580| 20 20 20 29 20 3b 20 73 | 61 76 65 2d 77 69 6e 64 | ) ; s|ave-wind|
|00002590| 6f 77 2d 65 78 63 75 72 | 73 69 6f 6e 0a 58 20 20 |ow-excur|sion.X |
|000025a0| 20 20 3b 20 72 65 74 75 | 72 6e 0a 58 20 20 20 20 | ; retu|rn.X |
|000025b0| 72 65 73 75 6c 74 0a 58 | 20 20 20 20 29 20 3b 20 |result.X| ) ; |
|000025c0| 6c 65 74 0a 58 20 20 29 | 20 3b 20 64 65 66 75 6e |let.X )| ; defun|
|000025d0| 20 74 70 6c 2d 6c 65 61 | 64 69 6e 67 2d 74 65 78 | tpl-lea|ding-tex|
|000025e0| 74 0a 58 0a 58 3b 3b 3b | 2b 2b 2b 2b 2b 2b 2b 2b |t.X.X;;;|++++++++|
|000025f0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002600| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002610| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002620| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 0a 58 0a 58 28 64 65 |++++++++|+.X.X(de|
|00002630| 66 75 6e 20 74 70 6c 2d | 6c 69 6e 65 2d 74 6f 2d |fun tpl-|line-to-|
|00002640| 74 6f 6b 65 6e 20 28 74 | 72 65 65 29 0a 58 20 20 |token (t|ree).X |
|00002650| 22 43 6f 6e 76 65 72 74 | 20 54 52 45 45 20 66 72 |"Convert| TREE fr|
|00002660| 6f 6d 20 6c 69 6e 65 2d | 66 6f 72 6d 61 74 20 74 |om line-|format t|
|00002670| 6f 20 74 6f 6b 65 6e 2d | 66 6f 72 6d 61 74 2e 22 |o token-|format."|
|00002680| 0a 58 09 09 09 09 09 3b | 20 4c 6f 63 61 6c 20 56 |.X.....;| Local V|
|00002690| 61 72 69 61 62 6c 65 73 | 0a 58 20 20 28 6c 65 74 |ariables|.X (let|
|000026a0| 20 28 6c 69 6e 65 2d 6c | 69 73 74 20 6c 69 6e 65 | (line-l|ist line|
|000026b0| 20 74 6f 6b 65 6e 20 72 | 65 73 75 6c 74 20 74 79 | token r|esult ty|
|000026c0| 70 65 20 6e 61 6d 65 29 | 0a 58 09 09 09 09 09 3b |pe name)|.X.....;|
|000026d0| 20 42 6f 64 79 0a 58 20 | 20 20 20 28 73 65 74 71 | Body.X | (setq|
|000026e0| 20 72 65 73 75 6c 74 20 | 6e 69 6c 29 0a 58 20 20 | result |nil).X |
|000026f0| 20 20 28 73 65 74 71 20 | 74 79 70 65 20 28 74 70 | (setq |type (tp|
|00002700| 6c 2d 74 6f 6b 65 6e 2d | 74 79 70 65 20 74 72 65 |l-token-|type tre|
|00002710| 65 29 29 0a 58 20 20 20 | 20 28 73 65 74 71 20 6e |e)).X | (setq n|
|00002720| 61 6d 65 20 28 74 70 6c | 2d 74 6f 6b 65 6e 2d 6e |ame (tpl|-token-n|
|00002730| 61 6d 65 20 74 72 65 65 | 29 29 0a 58 20 20 20 20 |ame tree|)).X |
|00002740| 28 73 65 74 71 20 6c 69 | 6e 65 2d 6c 69 73 74 20 |(setq li|ne-list |
|00002750| 28 74 70 6c 2d 74 6f 6b | 65 6e 2d 76 61 6c 75 65 |(tpl-tok|en-value|
|00002760| 20 74 72 65 65 29 29 0a | 58 20 20 20 20 28 77 68 | tree)).|X (wh|
|00002770| 69 6c 65 20 6c 69 6e 65 | 2d 6c 69 73 74 0a 58 20 |ile line|-list.X |
|00002780| 20 20 20 20 20 28 73 65 | 74 71 20 6c 69 6e 65 20 | (se|tq line |
|00002790| 28 63 61 72 20 6c 69 6e | 65 2d 6c 69 73 74 29 29 |(car lin|e-list))|
|000027a0| 0a 58 20 20 20 20 20 20 | 28 73 65 74 71 20 6c 69 |.X |(setq li|
|000027b0| 6e 65 2d 6c 69 73 74 20 | 28 63 64 72 20 6c 69 6e |ne-list |(cdr lin|
|000027c0| 65 2d 6c 69 73 74 29 29 | 0a 58 20 20 20 20 20 20 |e-list))|.X |
|000027d0| 28 73 65 74 71 20 72 65 | 73 75 6c 74 0a 58 09 20 |(setq re|sult.X. |
|000027e0| 20 20 20 28 61 70 70 65 | 6e 64 20 72 65 73 75 6c | (appe|nd resul|
|000027f0| 74 0a 58 09 09 20 20 20 | 20 28 6c 69 73 74 20 28 |t.X.. | (list (|
|00002800| 74 70 6c 2d 6d 61 6b 65 | 2d 74 6f 6b 65 6e 20 74 |tpl-make|-token t|
|00002810| 70 6c 2d 74 65 72 6d 69 | 6e 61 6c 2d 74 79 70 65 |pl-termi|nal-type|
|00002820| 0a 58 09 09 09 09 09 20 | 20 74 70 6c 2d 69 6e 64 |.X..... | tpl-ind|
|00002830| 65 6e 74 61 74 69 6f 6e | 2d 74 79 70 65 0a 58 09 |entation|-type.X.|
|00002840| 09 09 09 09 20 20 28 74 | 70 6c 2d 6c 69 6e 65 2d |.... (t|pl-line-|
|00002850| 69 6e 64 65 6e 74 20 6c | 69 6e 65 29 29 29 29 29 |indent l|ine)))))|
|00002860| 0a 58 20 20 20 20 20 20 | 28 73 65 74 71 20 72 65 |.X |(setq re|
|00002870| 73 75 6c 74 20 28 61 70 | 70 65 6e 64 20 72 65 73 |sult (ap|pend res|
|00002880| 75 6c 74 20 28 74 70 6c | 2d 6c 69 6e 65 2d 74 6f |ult (tpl|-line-to|
|00002890| 6b 65 6e 73 20 6c 69 6e | 65 29 29 29 0a 58 20 20 |kens lin|e))).X |
|000028a0| 20 20 20 20 28 69 66 20 | 6c 69 6e 65 2d 6c 69 73 | (if |line-lis|
|000028b0| 74 0a 58 09 20 20 28 73 | 65 74 71 20 72 65 73 75 |t.X. (s|etq resu|
|000028c0| 6c 74 20 28 61 70 70 65 | 6e 64 20 72 65 73 75 6c |lt (appe|nd resul|
|000028d0| 74 20 28 6c 69 73 74 20 | 74 70 6c 2d 6e 65 77 6c |t (list |tpl-newl|
|000028e0| 69 6e 65 2d 74 6f 6b 65 | 6e 29 29 29 0a 58 09 29 |ine-toke|n))).X.)|
|000028f0| 20 3b 20 69 66 20 6c 69 | 6e 65 2d 6c 69 73 74 0a | ; if li|ne-list.|
|00002900| 58 20 20 20 20 20 20 29 | 20 3b 20 77 68 69 6c 65 |X )| ; while|
|00002910| 20 6c 69 6e 65 2d 6c 69 | 73 74 0a 58 20 20 20 20 | line-li|st.X |
|00002920| 28 73 65 74 71 20 72 65 | 73 75 6c 74 20 28 74 70 |(setq re|sult (tp|
|00002930| 6c 2d 6d 61 6b 65 2d 74 | 6f 6b 65 6e 20 74 79 70 |l-make-t|oken typ|
|00002940| 65 20 6e 61 6d 65 20 72 | 65 73 75 6c 74 29 29 0a |e name r|esult)).|
|00002950| 58 20 20 20 20 3b 20 72 | 65 74 75 72 6e 0a 58 20 |X ; r|eturn.X |
|00002960| 20 20 20 72 65 73 75 6c | 74 0a 58 20 20 20 20 29 | resul|t.X )|
|00002970| 20 3b 20 6c 65 74 0a 58 | 20 20 29 20 3b 20 64 65 | ; let.X| ) ; de|
|00002980| 66 75 6e 20 74 70 6c 2d | 6c 69 6e 65 2d 74 6f 2d |fun tpl-|line-to-|
|00002990| 74 6f 6b 65 6e 0a 58 0a | 58 3b 3b 3b 2b 2b 2b 2b |token.X.|X;;;++++|
|000029a0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000029b0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000029c0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000029d0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 0a 58 0a |++++++++|+++++.X.|
|000029e0| 58 28 64 65 66 75 6e 20 | 74 70 6c 2d 6c 6f 6f 6b |X(defun |tpl-look|
|000029f0| 69 6e 67 2d 61 74 20 28 | 6e 61 6d 65 29 0a 58 20 |ing-at (|name).X |
|00002a00| 20 22 74 20 69 66 20 74 | 65 78 74 20 61 66 74 65 | "t if t|ext afte|
|00002a10| 72 20 70 6f 69 6e 74 20 | 6d 61 74 63 68 65 73 20 |r point |matches |
|00002a20| 74 65 6d 70 6c 61 74 65 | 20 4e 41 4d 45 22 0a 58 |template| NAME".X|
|00002a30| 09 09 09 09 09 3b 20 4c | 6f 63 61 6c 20 56 61 72 |.....; L|ocal Var|
|00002a40| 69 61 62 6c 65 73 0a 58 | 20 20 28 6c 65 74 20 28 |iables.X| (let (|
|00002a50| 72 65 73 75 6c 74 29 0a | 58 09 09 09 09 09 3b 20 |result).|X.....; |
|00002a60| 42 6f 64 79 0a 58 20 20 | 20 20 28 73 65 74 71 20 |Body.X | (setq |
|00002a70| 72 65 73 75 6c 74 20 28 | 74 70 6c 2d 6d 61 74 63 |result (|tpl-matc|
|00002a80| 68 2d 74 65 6d 70 6c 61 | 74 65 20 6e 61 6d 65 29 |h-templa|te name)|
|00002a90| 29 0a 58 20 20 20 20 28 | 69 66 20 72 65 73 75 6c |).X (|if resul|
|00002aa0| 74 0a 58 09 74 0a 58 20 | 20 20 20 20 20 6e 69 6c |t.X.t.X | nil|
|00002ab0| 0a 58 20 20 20 20 20 20 | 29 20 3b 20 69 66 0a 58 |.X |) ; if.X|
|00002ac0| 20 20 20 20 29 20 3b 20 | 6c 65 74 0a 58 20 20 29 | ) ; |let.X )|
|00002ad0| 20 3b 20 64 65 66 75 6e | 20 74 70 6c 2d 6c 6f 6f | ; defun| tpl-loo|
|00002ae0| 6b 69 6e 67 2d 61 74 0a | 58 0a 58 3b 3b 3b 2b 2b |king-at.|X.X;;;++|
|00002af0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002b00| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002b10| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002b20| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 0a |++++++++|+++++++.|
|00002b30| 58 0a 58 28 64 65 66 75 | 6e 20 74 70 6c 2d 6d 61 |X.X(defu|n tpl-ma|
|00002b40| 74 63 68 2d 66 75 6e 63 | 74 69 6f 6e 2d 74 65 6d |tch-func|tion-tem|
|00002b50| 70 6c 61 74 65 20 28 74 | 65 6d 70 6c 61 74 65 29 |plate (t|emplate)|
|00002b60| 0a 58 20 20 22 4d 61 74 | 63 68 20 54 45 4d 50 4c |.X "Mat|ch TEMPL|
|00002b70| 41 54 45 20 61 6e 64 20 | 72 65 74 75 72 6e 20 74 |ATE and |return t|
|00002b80| 20 6f 72 20 6e 69 6c 2e | 22 0a 58 09 09 09 09 09 | or nil.|".X.....|
|00002b90| 3b 20 4c 6f 63 61 6c 20 | 56 61 72 69 61 62 6c 65 |; Local |Variable|
|00002ba0| 73 0a 58 20 20 28 6c 65 | 74 20 28 29 0a 58 09 09 |s.X (le|t ().X..|
|00002bb0| 09 09 09 3b 20 42 6f 64 | 79 0a 58 20 20 20 20 28 |...; Bod|y.X (|
|00002bc0| 65 72 72 6f 72 20 22 74 | 70 6c 2d 6d 61 74 63 68 |error "t|pl-match|
|00002bd0| 2d 66 75 6e 63 74 69 6f | 6e 2d 74 79 70 65 3a 20 |-functio|n-type: |
|00002be0| 43 61 6e 6e 6f 74 20 6d | 61 74 63 68 20 66 75 6e |Cannot m|atch fun|
|00002bf0| 63 74 69 6f 6e 2d 74 79 | 70 65 20 74 65 6d 70 6c |ction-ty|pe templ|
|00002c00| 61 74 65 73 2e 22 29 0a | 58 20 20 20 20 29 20 3b |ates.").|X ) ;|
|00002c10| 20 6c 65 74 0a 58 20 20 | 29 20 3b 20 64 65 66 75 | let.X |) ; defu|
|00002c20| 6e 20 74 70 6c 2d 6d 61 | 74 63 68 2d 66 75 6e 63 |n tpl-ma|tch-func|
|00002c30| 74 69 6f 6e 2d 74 65 6d | 70 6c 61 74 65 0a 58 0a |tion-tem|plate.X.|
|00002c40| 58 3b 3b 3b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |X;;;++++|++++++++|
|00002c50| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002c60| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002c70| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002c80| 2b 2b 2b 2b 2b 0a 58 0a | 58 28 64 65 66 75 6e 20 |+++++.X.|X(defun |
|00002c90| 74 70 6c 2d 6d 61 74 63 | 68 2d 6c 65 78 69 63 61 |tpl-matc|h-lexica|
|00002ca0| 6c 2d 74 65 6d 70 6c 61 | 74 65 20 28 74 65 6d 70 |l-templa|te (temp|
|00002cb0| 6c 61 74 65 29 0a 58 20 | 20 22 4d 61 74 63 68 20 |late).X | "Match |
|00002cc0| 54 45 4d 50 4c 41 54 45 | 20 61 6e 64 20 72 65 74 |TEMPLATE| and ret|
|00002cd0| 75 72 6e 20 74 20 6f 72 | 20 6e 69 6c 2e 22 0a 58 |urn t or| nil.".X|
|00002ce0| 09 09 09 09 09 3b 20 4c | 6f 63 61 6c 20 56 61 72 |.....; L|ocal Var|
|00002cf0| 69 61 62 6c 65 73 0a 58 | 20 20 28 6c 65 74 20 28 |iables.X| (let (|
|00002d00| 29 0a 58 09 09 09 09 09 | 3b 20 42 6f 64 79 0a 58 |).X.....|; Body.X|
|00002d10| 20 20 20 20 28 6c 6f 6f | 6b 69 6e 67 2d 61 74 20 | (loo|king-at |
|00002d20| 28 74 70 6c 2d 74 6f 6b | 65 6e 2d 76 61 6c 75 65 |(tpl-tok|en-value|
|00002d30| 20 74 65 6d 70 6c 61 74 | 65 29 29 0a 58 20 20 20 | templat|e)).X |
|00002d40| 20 29 20 3b 20 6c 65 74 | 0a 58 20 20 29 20 3b 20 | ) ; let|.X ) ; |
|00002d50| 64 65 66 75 6e 20 74 70 | 6c 2d 6d 61 74 63 68 2d |defun tp|l-match-|
|00002d60| 6c 65 78 69 63 61 6c 2d | 74 65 6d 70 6c 61 74 65 |lexical-|template|
|00002d70| 0a 58 0a 58 3b 3b 3b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |.X.X;;;+|++++++++|
|00002d80| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002d90| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002da0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00002db0| 2b 2b 2b 2b 2b 2b 2b 2b | 0a 58 0a 58 28 64 65 66 |++++++++|.X.X(def|
|00002dc0| 75 6e 20 74 70 6c 2d 6d | 61 74 63 68 2d 6c 69 6e |un tpl-m|atch-lin|
|00002dd0| 65 20 28 70 61 74 74 65 | 72 6e 20 74 65 78 74 29 |e (patte|rn text)|
|00002de0| 0a 58 20 20 22 41 74 74 | 65 6d 70 74 20 74 6f 20 |.X "Att|empt to |
|00002df0| 6d 61 74 63 68 20 74 68 | 65 20 6c 69 6e 65 20 64 |match th|e line d|
|00002e00| 65 73 63 72 69 62 65 64 | 20 62 79 20 50 41 54 54 |escribed| by PATT|
|00002e10| 45 52 4e 20 77 69 74 68 | 20 54 45 58 54 2e 20 52 |ERN with| TEXT. R|
|00002e20| 65 74 75 72 6e 20 74 20 | 6f 72 20 6e 69 6c 2e 22 |eturn t |or nil."|
|00002e30| 0a 58 09 09 09 09 09 3b | 20 4c 6f 63 61 6c 20 56 |.X.....;| Local V|
|00002e40| 61 72 69 61 62 6c 65 73 | 0a 58 20 20 28 6c 65 74 |ariables|.X (let|
|00002e50| 20 28 70 61 74 74 65 72 | 6e 2d 6c 69 73 74 20 74 | (patter|n-list t|
|00002e60| 65 78 74 2d 6c 69 73 74 | 20 6e 65 78 74 2d 70 61 |ext-list| next-pa|
|00002e70| 74 74 65 72 6e 20 72 65 | 73 75 6c 74 20 73 75 63 |ttern re|sult suc|
|00002e80| 63 65 73 73 29 0a 58 09 | 09 09 09 09 3b 20 42 6f |cess).X.|....; Bo|
|00002e90| 64 79 0a 58 20 20 20 20 | 28 69 66 20 28 61 6e 64 |dy.X |(if (and|
|00002ea0| 20 74 65 78 74 0a 58 09 | 20 20 20 20 20 28 3d 20 | text.X.| (= |
|00002eb0| 28 74 70 6c 2d 6c 69 6e | 65 2d 69 6e 64 65 6e 74 |(tpl-lin|e-indent|
|00002ec0| 20 70 61 74 74 65 72 6e | 29 20 28 74 70 6c 2d 6c | pattern|) (tpl-l|
|00002ed0| 69 6e 65 2d 69 6e 64 65 | 6e 74 20 74 65 78 74 29 |ine-inde|nt text)|
|00002ee0| 29 29 0a 58 09 28 70 72 | 6f 67 6e 0a 58 09 20 20 |)).X.(pr|ogn.X. |
|00002ef0| 28 73 65 74 71 20 73 75 | 63 63 65 73 73 20 74 29 |(setq su|ccess t)|
|00002f00| 0a 58 09 20 20 28 73 65 | 74 71 20 70 61 74 74 65 |.X. (se|tq patte|
|00002f10| 72 6e 2d 6c 69 73 74 20 | 28 74 70 6c 2d 6c 69 6e |rn-list |(tpl-lin|
|00002f20| 65 2d 74 6f 6b 65 6e 73 | 20 70 61 74 74 65 72 6e |e-tokens| pattern|
|00002f30| 29 29 0a 58 09 20 20 28 | 73 65 74 71 20 74 65 78 |)).X. (|setq tex|
|00002f40| 74 2d 6c 69 73 74 20 28 | 74 70 6c 2d 6c 69 6e 65 |t-list (|tpl-line|
|00002f50| 2d 74 6f 6b 65 6e 73 20 | 74 65 78 74 29 29 0a 58 |-tokens |text)).X|
|00002f60| 09 20 20 28 77 68 69 6c | 65 20 28 61 6e 64 20 70 |. (whil|e (and p|
|00002f70| 61 74 74 65 72 6e 2d 6c | 69 73 74 20 73 75 63 63 |attern-l|ist succ|
|00002f80| 65 73 73 20 74 65 78 74 | 2d 6c 69 73 74 29 0a 58 |ess text|-list).X|
|00002f90| 09 20 20 20 20 28 73 65 | 74 71 20 6e 65 78 74 2d |. (se|tq next-|
|00002fa0| 70 61 74 74 65 72 6e 20 | 28 63 61 72 20 70 61 74 |pattern |(car pat|
|00002fb0| 74 65 72 6e 2d 6c 69 73 | 74 29 29 0a 58 09 20 20 |tern-lis|t)).X. |
|00002fc0| 20 20 28 73 65 74 71 20 | 70 61 74 74 65 72 6e 2d | (setq |pattern-|
|00002fd0| 6c 69 73 74 20 28 63 64 | 72 20 70 61 74 74 65 72 |list (cd|r patter|
|00002fe0| 6e 2d 6c 69 73 74 29 29 | 0a 58 09 20 20 20 20 28 |n-list))|.X. (|
|00002ff0| 73 65 74 71 20 72 65 73 | 75 6c 74 20 28 74 70 6c |setq res|ult (tpl|
|00003000| 2d 6d 61 74 63 68 2d 74 | 6f 6b 65 6e 20 6e 65 78 |-match-t|oken nex|
|00003010| 74 2d 70 61 74 74 65 72 | 6e 20 74 65 78 74 2d 6c |t-patter|n text-l|
|00003020| 69 73 74 29 29 0a 58 09 | 20 20 20 20 28 69 66 20 |ist)).X.| (if |
|00003030| 72 65 73 75 6c 74 0a 58 | 09 09 28 73 65 74 71 20 |result.X|..(setq |
|00003040| 74 65 78 74 2d 6c 69 73 | 74 20 28 63 64 72 20 72 |text-lis|t (cdr r|
|00003050| 65 73 75 6c 74 29 29 0a | 58 09 20 20 20 20 20 20 |esult)).|X. |
|00003060| 3b 20 65 6c 73 65 0a 58 | 09 20 20 20 20 20 20 28 |; else.X|. (|
|00003070| 73 65 74 71 20 73 75 63 | 63 65 73 73 20 6e 69 6c |setq suc|cess nil|
|00003080| 29 0a 58 09 20 20 20 20 | 20 20 29 20 3b 20 69 66 |).X. | ) ; if|
|00003090| 20 72 65 73 75 6c 74 0a | 58 09 20 20 20 20 29 20 | result.|X. ) |
|000030a0| 3b 20 77 68 69 6c 65 20 | 70 61 74 74 65 72 6e 2d |; while |pattern-|
|000030b0| 6c 69 73 74 0a 58 09 20 | 20 29 20 3b 20 70 72 6f |list.X. | ) ; pro|
|000030c0| 67 6e 0a 58 20 20 20 20 | 20 20 3b 20 65 6c 73 65 |gn.X | ; else|
|000030d0| 0a 58 20 20 20 20 20 20 | 28 73 65 74 71 20 73 75 |.X |(setq su|
|000030e0| 63 63 65 73 73 20 6e 69 | 6c 29 0a 58 20 20 20 20 |ccess ni|l).X |
|000030f0| 20 20 29 20 3b 20 69 66 | 20 28 3d 20 28 74 70 6c | ) ; if| (= (tpl|
|00003100| 2d 6c 69 6e 65 2d 69 6e | 64 65 6e 74 20 70 61 74 |-line-in|dent pat|
|00003110| 74 65 72 6e 29 20 28 74 | 70 6c 2d 6c 69 6e 65 2d |tern) (t|pl-line-|
|00003120| 69 6e 64 65 6e 74 20 74 | 65 78 74 29 29 0a 58 20 |indent t|ext)).X |
|00003130| 20 20 20 3b 20 72 65 74 | 75 72 6e 0a 58 20 20 20 | ; ret|urn.X |
|00003140| 20 73 75 63 63 65 73 73 | 0a 58 20 20 20 20 29 20 | success|.X ) |
|00003150| 3b 20 6c 65 74 0a 58 20 | 20 29 20 3b 20 64 65 66 |; let.X | ) ; def|
|00003160| 75 6e 20 74 70 6c 2d 6d | 61 74 63 68 2d 6c 69 6e |un tpl-m|atch-lin|
|00003170| 65 0a 58 0a 58 3b 3b 3b | 2b 2b 2b 2b 2b 2b 2b 2b |e.X.X;;;|++++++++|
|00003180| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00003190| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000031a0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000031b0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 0a 58 0a 58 28 64 65 |++++++++|+.X.X(de|
|000031c0| 66 75 6e 20 74 70 6c 2d | 6d 61 74 63 68 2d 70 61 |fun tpl-|match-pa|
|000031d0| 74 74 65 72 6e 20 28 70 | 61 74 74 65 72 6e 2d 6c |ttern (p|attern-l|
|000031e0| 69 73 74 20 73 63 61 6e | 6e 65 72 2d 70 61 74 74 |ist scan|ner-patt|
|000031f0| 65 72 6e 73 29 0a 58 20 | 20 22 41 74 74 65 6d 70 |erns).X | "Attemp|
|00003200| 74 20 74 6f 20 6d 61 74 | 63 68 20 65 61 63 68 20 |t to mat|ch each |
|00003210| 6c 69 6e 65 20 69 6e 20 | 50 41 54 54 45 52 4e 2d |line in |PATTERN-|
|00003220| 4c 49 53 54 20 77 69 74 | 68 20 74 65 78 74 20 61 |LIST wit|h text a|
|00003230| 66 74 65 72 20 70 6f 69 | 6e 74 2e 0a 58 20 20 20 |fter poi|nt..X |
|00003240| 20 52 65 74 75 72 6e 20 | 61 20 6c 69 73 74 20 6f | Return |a list o|
|00003250| 66 20 6d 61 74 63 68 65 | 73 2e 20 20 53 65 63 6f |f matche|s. Seco|
|00003260| 6e 64 20 61 72 67 75 6d | 65 6e 74 20 53 43 41 4e |nd argum|ent SCAN|
|00003270| 4e 45 52 2d 50 41 54 54 | 45 52 4e 53 0a 58 20 20 |NER-PATT|ERNS.X |
|00003280| 20 20 73 70 65 63 69 66 | 69 65 73 20 77 68 61 74 | specif|ies what|
|00003290| 20 74 79 70 65 20 6f 66 | 20 6c 65 78 69 63 61 6c | type of| lexical|
|000032a0| 20 70 61 74 74 65 72 6e | 73 20 74 6f 20 75 73 65 | pattern|s to use|
|000032b0| 20 77 68 65 6e 20 73 63 | 61 6e 6e 69 6e 67 2e 22 | when sc|anning."|
|000032c0| 0a 58 09 09 09 09 09 3b | 20 4c 6f 63 61 6c 20 56 |.X.....;| Local V|
|000032d0| 61 72 69 61 62 6c 65 73 | 0a 58 20 20 28 6c 65 74 |ariables|.X (let|
|000032e0| 20 28 73 75 63 63 65 73 | 73 20 74 72 65 65 20 74 | (succes|s tree t|
|000032f0| 68 69 73 2d 70 61 74 74 | 65 72 6e 20 6e 65 78 74 |his-patt|ern next|
|00003300| 2d 70 61 74 74 65 72 6e | 20 74 68 69 73 2d 6d 61 |-pattern| this-ma|
|00003310| 74 63 68 20 66 69 72 73 | 74 2d 74 65 78 74 20 6e |tch firs|t-text n|
|00003320| 65 78 74 2d 74 65 78 74 | 0a 58 09 09 73 74 61 72 |ext-text|.X..star|
|00003330| 74 2d 72 65 67 69 6f 6e | 20 73 74 61 72 74 2d 63 |t-region| start-c|
|00003340| 6f 6c 0a 58 09 09 74 68 | 69 73 2d 69 6e 64 65 6e |ol.X..th|is-inden|
|00003350| 74 20 6e 65 78 74 2d 69 | 6e 64 65 6e 74 29 0a 58 |t next-i|ndent).X|
|00003360| 09 09 09 09 09 3b 20 42 | 6f 64 79 0a 58 20 20 20 |.....; B|ody.X |
|00003370| 20 28 73 65 74 71 20 73 | 75 63 63 65 73 73 20 74 | (setq s|uccess t|
|00003380| 29 0a 58 20 20 20 20 28 | 73 65 74 71 20 74 72 65 |).X (|setq tre|
|00003390| 65 20 6e 69 6c 29 0a 58 | 09 09 09 09 09 3b 20 49 |e nil).X|.....; I|
|000033a0| 6e 69 74 69 61 6c 69 7a | 65 20 73 63 61 6e 6e 65 |nitializ|e scanne|
|000033b0| 72 0a 58 20 20 20 20 28 | 73 65 74 71 20 73 74 61 |r.X (|setq sta|
|000033c0| 72 74 2d 72 65 67 69 6f | 6e 20 28 70 6f 69 6e 74 |rt-regio|n (point|
|000033d0| 29 29 0a 58 20 20 20 20 | 28 73 65 74 71 20 73 74 |)).X |(setq st|
|000033e0| 61 72 74 2d 63 6f 6c 20 | 28 63 75 72 72 65 6e 74 |art-col |(current|
|000033f0| 2d 63 6f 6c 75 6d 6e 29 | 29 0a 58 20 20 20 20 28 |-column)|).X (|
|00003400| 73 65 74 71 20 74 68 69 | 73 2d 69 6e 64 65 6e 74 |setq thi|s-indent|
|00003410| 20 30 29 0a 58 09 09 09 | 09 09 3b 20 47 65 74 20 | 0).X...|..; Get |
|00003420| 66 69 72 73 74 20 22 6e | 65 78 74 20 74 65 78 74 |first "n|ext text|
|00003430| 20 6c 69 6e 65 22 0a 58 | 20 20 20 20 28 62 61 63 | line".X| (bac|
|00003440| 6b 2d 74 6f 2d 69 6e 64 | 65 6e 74 61 74 69 6f 6e |k-to-ind|entation|
|00003450| 29 0a 58 20 20 20 20 28 | 73 65 74 71 20 6e 65 78 |).X (|setq nex|
|00003460| 74 2d 74 65 78 74 20 28 | 74 70 6c 2d 73 63 61 6e |t-text (|tpl-scan|
|00003470| 2d 6c 69 6e 65 20 73 74 | 61 72 74 2d 63 6f 6c 20 |-line st|art-col |
|00003480| 73 63 61 6e 6e 65 72 2d | 70 61 74 74 65 72 6e 73 |scanner-|patterns|
|00003490| 29 29 0a 58 20 20 20 20 | 28 73 65 74 71 20 74 68 |)).X |(setq th|
|000034a0| 69 73 2d 69 6e 64 65 6e | 74 20 28 74 70 6c 2d 6c |is-inden|t (tpl-l|
|000034b0| 69 6e 65 2d 69 6e 64 65 | 6e 74 20 6e 65 78 74 2d |ine-inde|nt next-|
|000034c0| 74 65 78 74 29 29 0a 58 | 20 20 20 20 28 69 66 20 |text)).X| (if |
|000034d0| 28 6e 6f 74 20 28 65 6f | 62 70 29 29 0a 58 09 28 |(not (eo|bp)).X.(|
|000034e0| 66 6f 72 77 61 72 64 2d | 63 68 61 72 29 0a 58 20 |forward-|char).X |
|000034f0| 20 20 20 20 20 29 20 3b | 20 69 66 0a 58 09 09 09 | ) ;| if.X...|
|00003500| 09 09 3b 20 46 6f 72 20 | 65 61 63 68 20 6c 69 6e |..; For |each lin|
|00003510| 65 20 69 6e 20 70 61 74 | 74 65 72 6e 0a 58 20 20 |e in pat|tern.X |
|00003520| 20 20 28 77 68 69 6c 65 | 20 28 61 6e 64 20 70 61 | (while| (and pa|
|00003530| 74 74 65 72 6e 2d 6c 69 | 73 74 20 73 75 63 63 65 |ttern-li|st succe|
|00003540| 73 73 29 0a 58 20 20 20 | 20 20 20 3b 28 64 65 62 |ss).X | ;(deb|
|00003550| 75 67 20 6e 69 6c 20 22 | 74 6f 70 20 6f 66 20 70 |ug nil "|top of p|
|00003560| 61 74 74 65 72 6e 20 6c | 6f 6f 70 22 29 0a 58 09 |attern l|oop").X.|
|00003570| 09 09 09 09 3b 20 47 65 | 74 20 6e 65 78 74 20 70 |....; Ge|t next p|
|00003580| 61 74 74 65 72 6e 20 6c | 69 6e 65 0a 58 20 20 20 |attern l|ine.X |
|00003590| 20 20 20 28 73 65 74 71 | 20 74 68 69 73 2d 70 61 | (setq| this-pa|
|000035a0| 74 74 65 72 6e 20 28 63 | 61 72 20 70 61 74 74 65 |ttern (c|ar patte|
|000035b0| 72 6e 2d 6c 69 73 74 29 | 29 0a 58 20 20 20 20 20 |rn-list)|).X |
|000035c0| 20 28 73 65 74 71 20 70 | 61 74 74 65 72 6e 2d 6c | (setq p|attern-l|
|000035d0| 69 73 74 20 28 63 64 72 | 20 70 61 74 74 65 72 6e |ist (cdr| pattern|
|000035e0| 2d 6c 69 73 74 29 29 0a | 58 20 20 20 20 20 20 28 |-list)).|X (|
|000035f0| 69 66 20 70 61 74 74 65 | 72 6e 2d 6c 69 73 74 0a |if patte|rn-list.|
|00003600| 58 09 20 20 28 73 65 74 | 71 20 6e 65 78 74 2d 70 |X. (set|q next-p|
|00003610| 61 74 74 65 72 6e 20 28 | 63 61 72 20 70 61 74 74 |attern (|car patt|
|00003620| 65 72 6e 2d 6c 69 73 74 | 29 29 0a 58 09 3b 20 65 |ern-list|)).X.; e|
|00003630| 6c 73 65 0a 58 09 28 73 | 65 74 71 20 6e 65 78 74 |lse.X.(s|etq next|
|00003640| 2d 70 61 74 74 65 72 6e | 20 6e 69 6c 29 0a 58 09 |-pattern| nil).X.|
|00003650| 29 20 3b 20 69 66 20 70 | 61 74 74 65 72 6e 2d 6c |) ; if p|attern-l|
|00003660| 69 73 74 0a 58 20 20 20 | 20 20 20 28 73 65 74 71 |ist.X | (setq|
|00003670| 20 74 68 69 73 2d 6d 61 | 74 63 68 20 6e 69 6c 29 | this-ma|tch nil)|
|00003680| 0a 58 09 09 09 09 09 3b | 20 47 65 74 20 66 69 72 |.X.....;| Get fir|
|00003690| 73 74 20 74 65 78 74 20 | 6c 69 6e 65 0a 58 20 20 |st text |line.X |
|000036a0| 20 20 20 20 28 73 65 74 | 71 20 66 69 72 73 74 2d | (set|q first-|
|000036b0| 74 65 78 74 20 6e 65 78 | 74 2d 74 65 78 74 29 0a |text nex|t-text).|
|000036c0| 58 09 09 09 09 09 3b 20 | 54 72 79 20 74 6f 20 6d |X.....; |Try to m|
|000036d0| 61 74 63 68 20 6c 69 6e | 65 73 0a 58 20 20 20 20 |atch lin|es.X |
|000036e0| 20 20 28 69 66 20 28 74 | 70 6c 2d 6d 61 74 63 68 | (if (t|pl-match|
|000036f0| 2d 6c 69 6e 65 20 74 68 | 69 73 2d 70 61 74 74 65 |-line th|is-patte|
|00003700| 72 6e 20 66 69 72 73 74 | 2d 74 65 78 74 29 0a 58 |rn first|-text).X|
|00003710| 09 20 20 28 70 72 6f 67 | 6e 0a 58 09 20 20 20 20 |. (prog|n.X. |
|00003720| 28 73 65 74 71 20 74 68 | 69 73 2d 6d 61 74 63 68 |(setq th|is-match|
|00003730| 20 28 6c 69 73 74 20 66 | 69 72 73 74 2d 74 65 78 | (list f|irst-tex|
|00003740| 74 29 29 0a 58 09 20 20 | 20 20 28 69 66 20 6e 65 |t)).X. | (if ne|
|00003750| 78 74 2d 70 61 74 74 65 | 72 6e 0a 58 09 09 28 70 |xt-patte|rn.X..(p|
|00003760| 72 6f 67 6e 0a 58 09 09 | 20 20 28 73 65 74 71 20 |rogn.X..| (setq |
|00003770| 6e 65 78 74 2d 69 6e 64 | 65 6e 74 20 28 74 70 6c |next-ind|ent (tpl|
|00003780| 2d 6c 69 6e 65 2d 69 6e | 64 65 6e 74 20 6e 65 78 |-line-in|dent nex|
|00003790| 74 2d 70 61 74 74 65 72 | 6e 29 29 0a 58 09 09 09 |t-patter|n)).X...|
|000037a0| 09 09 3b 20 47 65 74 20 | 6e 65 78 74 20 74 65 78 |..; Get |next tex|
|000037b0| 74 20 6c 69 6e 65 0a 58 | 09 09 20 20 28 62 61 63 |t line.X|.. (bac|
|000037c0| 6b 2d 74 6f 2d 69 6e 64 | 65 6e 74 61 74 69 6f 6e |k-to-ind|entation|
|000037d0| 29 0a 58 09 09 20 20 28 | 73 65 74 71 20 6e 65 78 |).X.. (|setq nex|
|000037e0| 74 2d 74 65 78 74 20 28 | 74 70 6c 2d 73 63 61 6e |t-text (|tpl-scan|
|000037f0| 2d 6c 69 6e 65 20 73 74 | 61 72 74 2d 63 6f 6c 20 |-line st|art-col |
|00003800| 73 63 61 6e 6e 65 72 2d | 70 61 74 74 65 72 6e 73 |scanner-|patterns|
|00003810| 29 29 0a 58 09 09 20 20 | 28 73 65 74 71 20 74 68 |)).X.. |(setq th|
|00003820| 69 73 2d 69 6e 64 65 6e | 74 20 28 74 70 6c 2d 6c |is-inden|t (tpl-l|
|00003830| 69 6e 65 2d 69 6e 64 65 | 6e 74 20 6e 65 78 74 2d |ine-inde|nt next-|
|00003840| 74 65 78 74 29 29 0a 58 | 09 09 20 20 28 69 66 20 |text)).X|.. (if |
|00003850| 28 6e 6f 74 20 28 65 6f | 62 70 29 29 0a 58 09 09 |(not (eo|bp)).X..|
|00003860| 20 20 20 20 20 20 28 66 | 6f 72 77 61 72 64 2d 63 | (f|orward-c|
|00003870| 68 61 72 29 0a 58 09 09 | 20 20 20 20 29 20 3b 20 |har).X..| ) ; |
|00003880| 69 66 0a 58 09 09 09 09 | 09 3b 20 41 70 70 65 6e |if.X....|.; Appen|
|00003890| 64 20 75 6e 74 69 6c 20 | 6e 65 78 74 20 6d 61 74 |d until |next mat|
|000038a0| 63 68 0a 58 09 09 20 20 | 28 77 68 69 6c 65 20 28 |ch.X.. |(while (|
|000038b0| 61 6e 64 20 28 6e 6f 74 | 20 28 65 6f 62 70 29 29 |and (not| (eobp))|
|000038c0| 0a 58 09 09 09 20 20 20 | 20 20 20 28 6f 72 20 28 |.X... | (or (|
|000038d0| 3e 20 74 68 69 73 2d 69 | 6e 64 65 6e 74 20 6e 65 |> this-i|ndent ne|
|000038e0| 78 74 2d 69 6e 64 65 6e | 74 29 0a 58 09 09 09 09 |xt-inden|t).X....|
|000038f0| 20 20 28 65 71 75 61 6c | 20 28 74 70 6c 2d 6c 69 | (equal| (tpl-li|
|00003900| 6e 65 2d 74 6f 6b 65 6e | 73 20 6e 65 78 74 2d 74 |ne-token|s next-t|
|00003910| 65 78 74 29 20 6e 69 6c | 29 29 29 0a 58 09 09 20 |ext) nil|))).X.. |
|00003920| 20 20 20 3b 28 64 65 62 | 75 67 20 6e 69 6c 20 22 | ;(deb|ug nil "|
|00003930| 61 70 70 65 6e 64 69 6e | 67 20 69 6e 20 6d 69 64 |appendin|g in mid|
|00003940| 64 6c 65 2e 2e 2e 22 29 | 0a 58 09 09 20 20 20 20 |dle...")|.X.. |
|00003950| 28 73 65 74 71 20 74 68 | 69 73 2d 6d 61 74 63 68 |(setq th|is-match|
|00003960| 20 28 61 70 70 65 6e 64 | 20 74 68 69 73 2d 6d 61 | (append| this-ma|
|00003970| 74 63 68 20 28 6c 69 73 | 74 20 6e 65 78 74 2d 74 |tch (lis|t next-t|
|00003980| 65 78 74 29 29 29 0a 58 | 09 09 09 09 09 3b 20 47 |ext))).X|.....; G|
|00003990| 65 74 20 6e 65 78 74 20 | 74 65 78 74 20 6c 69 6e |et next |text lin|
|000039a0| 65 0a 58 09 09 20 20 20 | 20 28 62 61 63 6b 2d 74 |e.X.. | (back-t|
|000039b0| 6f 2d 69 6e 64 65 6e 74 | 61 74 69 6f 6e 29 0a 58 |o-indent|ation).X|
|000039c0| 09 09 20 20 20 20 28 73 | 65 74 71 20 6e 65 78 74 |.. (s|etq next|
|000039d0| 2d 74 65 78 74 20 28 74 | 70 6c 2d 73 63 61 6e 2d |-text (t|pl-scan-|
|000039e0| 6c 69 6e 65 20 73 74 61 | 72 74 2d 63 6f 6c 20 73 |line sta|rt-col s|
|000039f0| 63 61 6e 6e 65 72 2d 70 | 61 74 74 65 72 6e 73 29 |canner-p|atterns)|
|00003a00| 29 0a 58 09 09 20 20 20 | 20 28 73 65 74 71 20 74 |).X.. | (setq t|
|00003a10| 68 69 73 2d 69 6e 64 65 | 6e 74 20 28 74 70 6c 2d |his-inde|nt (tpl-|
|00003a20| 6c 69 6e 65 2d 69 6e 64 | 65 6e 74 20 6e 65 78 74 |line-ind|ent next|
|00003a30| 2d 74 65 78 74 29 29 0a | 58 09 09 20 20 20 20 28 |-text)).|X.. (|
|00003a40| 69 66 20 28 6e 6f 74 20 | 28 65 6f 62 70 29 29 0a |if (not |(eobp)).|
|00003a50| 58 09 09 09 28 66 6f 72 | 77 61 72 64 2d 63 68 61 |X...(for|ward-cha|
|00003a60| 72 29 0a 58 09 09 20 20 | 20 20 20 20 29 20 3b 20 |r).X.. | ) ; |
|00003a70| 69 66 0a 58 09 09 20 20 | 20 20 29 20 3b 20 77 68 |if.X.. | ) ; wh|
|00003a80| 69 6c 65 0a 58 09 09 20 | 20 29 20 3b 20 70 72 6f |ile.X.. | ) ; pro|
|00003a90| 67 6e 0a 58 09 20 20 20 | 20 20 20 3b 20 65 6c 73 |gn.X. | ; els|
|00003aa0| 65 0a 58 09 09 09 09 09 | 3b 20 41 70 70 65 6e 64 |e.X.....|; Append|
|00003ab0| 20 75 6e 74 69 6c 20 6e | 6f 20 6d 6f 72 65 20 69 | until n|o more i|
|00003ac0| 6e 64 65 6e 74 61 74 69 | 6f 6e 0a 58 09 20 20 20 |ndentati|on.X. |
|00003ad0| 20 20 20 28 70 72 6f 67 | 6e 0a 58 09 09 28 77 68 | (prog|n.X..(wh|
|00003ae0| 69 6c 65 20 28 61 6e 64 | 20 28 6e 6f 74 20 28 65 |ile (and| (not (e|
|00003af0| 6f 62 70 29 29 0a 58 09 | 09 09 20 20 20 20 28 6f |obp)).X.|.. (o|
|00003b00| 72 20 28 3e 20 74 68 69 | 73 2d 69 6e 64 65 6e 74 |r (> thi|s-indent|
|00003b10| 20 30 29 0a 58 09 09 09 | 09 28 65 71 75 61 6c 20 | 0).X...|.(equal |
|00003b20| 28 74 70 6c 2d 6c 69 6e | 65 2d 74 6f 6b 65 6e 73 |(tpl-lin|e-tokens|
|00003b30| 20 6e 65 78 74 2d 74 65 | 78 74 29 20 6e 69 6c 29 | next-te|xt) nil)|
|00003b40| 29 29 0a 58 09 09 20 20 | 3b 28 64 65 62 75 67 20 |)).X.. |;(debug |
|00003b50| 6e 69 6c 20 22 61 70 70 | 65 6e 64 69 6e 67 20 61 |nil "app|ending a|
|00003b60| 74 20 65 6e 64 2e 2e 2e | 22 29 0a 58 09 09 20 20 |t end...|").X.. |
|00003b70| 28 73 65 74 71 20 74 68 | 69 73 2d 6d 61 74 63 68 |(setq th|is-match|
|00003b80| 20 28 61 70 70 65 6e 64 | 20 74 68 69 73 2d 6d 61 | (append| this-ma|
|00003b90| 74 63 68 20 28 6c 69 73 | 74 20 6e 65 78 74 2d 74 |tch (lis|t next-t|
|00003ba0| 65 78 74 29 29 29 0a 58 | 09 09 09 09 09 3b 20 47 |ext))).X|.....; G|
|00003bb0| 65 74 20 6e 65 78 74 20 | 74 65 78 74 20 6c 69 6e |et next |text lin|
|00003bc0| 65 0a 58 09 09 20 20 28 | 62 61 63 6b 2d 74 6f 2d |e.X.. (|back-to-|
|00003bd0| 69 6e 64 65 6e 74 61 74 | 69 6f 6e 29 0a 58 09 09 |indentat|ion).X..|
|00003be0| 20 20 28 73 65 74 71 20 | 74 68 69 73 2d 63 6f 6c | (setq |this-col|
|00003bf0| 20 28 63 75 72 72 65 6e | 74 2d 63 6f 6c 75 6d 6e | (curren|t-column|
|00003c00| 29 29 0a 58 09 09 20 20 | 28 73 65 74 71 20 6e 65 |)).X.. |(setq ne|
|00003c10| 78 74 2d 74 65 78 74 20 | 28 74 70 6c 2d 73 63 61 |xt-text |(tpl-sca|
|00003c20| 6e 2d 6c 69 6e 65 20 73 | 74 61 72 74 2d 63 6f 6c |n-line s|tart-col|
|00003c30| 20 73 63 61 6e 6e 65 72 | 2d 70 61 74 74 65 72 6e | scanner|-pattern|
|00003c40| 73 29 29 0a 58 09 09 20 | 20 28 73 65 74 71 20 74 |s)).X.. | (setq t|
|00003c50| 68 69 73 2d 69 6e 64 65 | 6e 74 20 28 74 70 6c 2d |his-inde|nt (tpl-|
|00003c60| 6c 69 6e 65 2d 69 6e 64 | 65 6e 74 20 6e 65 78 74 |line-ind|ent next|
|00003c70| 2d 74 65 78 74 29 29 0a | 58 09 09 20 20 28 69 66 |-text)).|X.. (if|
|00003c80| 20 28 6e 6f 74 20 28 65 | 6f 62 70 29 29 0a 58 09 | (not (e|obp)).X.|
|00003c90| 09 20 20 20 20 20 20 28 | 66 6f 72 77 61 72 64 2d |. (|forward-|
|00003ca0| 63 68 61 72 29 0a 58 09 | 09 20 20 20 20 29 20 3b |char).X.|. ) ;|
|00003cb0| 20 69 66 0a 58 09 09 20 | 20 29 20 3b 20 77 68 69 | if.X.. | ) ; whi|
|00003cc0| 6c 65 0a 58 09 09 28 69 | 66 20 28 3e 20 74 68 69 |le.X..(i|f (> thi|
|00003cd0| 73 2d 69 6e 64 65 6e 74 | 20 30 29 0a 58 09 09 20 |s-indent| 0).X.. |
|00003ce0| 20 20 20 28 73 65 74 71 | 20 74 68 69 73 2d 6d 61 | (setq| this-ma|
|00003cf0| 74 63 68 20 28 61 70 70 | 65 6e 64 20 74 68 69 73 |tch (app|end this|
|00003d00| 2d 6d 61 74 63 68 20 28 | 6c 69 73 74 20 6e 65 78 |-match (|list nex|
|00003d10| 74 2d 74 65 78 74 29 29 | 29 0a 58 09 09 20 20 28 |t-text))|).X.. (|
|00003d20| 66 6f 72 77 61 72 64 2d | 6c 69 6e 65 20 2d 31 29 |forward-|line -1)|
|00003d30| 0a 58 09 09 20 20 29 20 | 3b 20 69 66 0a 58 09 09 |.X.. ) |; if.X..|
|00003d40| 29 20 3b 20 70 72 6f 67 | 6e 0a 58 09 20 20 20 20 |) ; prog|n.X. |
|00003d50| 20 20 29 20 3b 20 69 66 | 20 6e 65 78 74 2d 70 61 | ) ; if| next-pa|
|00003d60| 74 74 65 72 6e 0a 58 09 | 20 20 20 20 28 73 65 74 |ttern.X.| (set|
|00003d70| 71 20 74 72 65 65 20 28 | 61 70 70 65 6e 64 20 74 |q tree (|append t|
|00003d80| 72 65 65 20 28 6c 69 73 | 74 20 28 6c 69 73 74 20 |ree (lis|t (list |
|00003d90| 74 68 69 73 2d 70 61 74 | 74 65 72 6e 20 74 68 69 |this-pat|tern thi|
|00003da0| 73 2d 6d 61 74 63 68 29 | 29 29 29 0a 58 09 20 20 |s-match)|))).X. |
|00003db0| 20 20 29 20 3b 20 70 72 | 6f 67 6e 0a 58 09 3b 20 | ) ; pr|ogn.X.; |
|00003dc0| 65 6c 73 65 0a 58 09 28 | 73 65 74 71 20 73 75 63 |else.X.(|setq suc|
|00003dd0| 63 65 73 73 20 6e 69 6c | 29 0a 58 09 29 20 3b 20 |cess nil|).X.) ; |
|00003de0| 69 66 20 28 74 70 6c 2d | 6d 61 74 63 68 2d 6c 69 |if (tpl-|match-li|
|00003df0| 6e 65 20 74 68 69 73 2d | 70 61 74 74 65 72 6e 20 |ne this-|pattern |
|00003e00| 66 69 72 73 74 2d 74 65 | 78 74 29 0a 58 20 20 20 |first-te|xt).X |
|00003e10| 20 20 20 29 20 3b 20 77 | 68 69 6c 65 20 70 61 74 | ) ; w|hile pat|
|00003e20| 74 65 72 6e 2d 6c 69 73 | 74 0a 58 20 20 20 20 3b |tern-lis|t.X ;|
|00003e30| 20 53 65 74 20 70 6f 69 | 6e 74 20 61 6e 64 20 6d | Set poi|nt and m|
|00003e40| 61 72 6b 0a 58 20 20 20 | 20 28 69 66 20 73 75 63 |ark.X | (if suc|
|00003e50| 63 65 73 73 0a 58 09 28 | 70 72 6f 67 6e 0a 58 09 |cess.X.(|progn.X.|
|00003e60| 20 20 28 73 65 74 71 20 | 73 75 63 63 65 73 73 20 | (setq |success |
|00003e70| 74 72 65 65 29 0a 58 09 | 20 20 28 73 65 74 2d 6d |tree).X.| (set-m|
|00003e80| 61 72 6b 20 73 74 61 72 | 74 2d 72 65 67 69 6f 6e |ark star|t-region|
|00003e90| 29 0a 58 09 20 20 28 69 | 66 20 28 65 6f 62 70 29 |).X. (i|f (eobp)|
|00003ea0| 0a 58 09 20 20 20 20 20 | 20 28 65 6e 64 2d 6f 66 |.X. | (end-of|
|00003eb0| 2d 6c 69 6e 65 29 0a 58 | 09 20 20 20 20 3b 20 65 |-line).X|. ; e|
|00003ec0| 6c 73 65 0a 58 09 20 20 | 20 20 28 65 6e 64 2d 6f |lse.X. | (end-o|
|00003ed0| 66 2d 6c 69 6e 65 20 30 | 29 0a 58 09 20 20 20 20 |f-line 0|).X. |
|00003ee0| 29 20 3b 20 69 66 0a 58 | 09 20 20 29 20 3b 20 70 |) ; if.X|. ) ; p|
|00003ef0| 72 6f 67 6e 0a 58 20 20 | 20 20 20 20 3b 20 65 6c |rogn.X | ; el|
|00003f00| 73 65 0a 58 20 20 20 20 | 20 20 28 67 6f 74 6f 2d |se.X | (goto-|
|00003f10| 63 68 61 72 20 73 74 61 | 72 74 2d 72 65 67 69 6f |char sta|rt-regio|
|00003f20| 6e 29 0a 58 20 20 20 20 | 20 20 29 20 3b 20 69 66 |n).X | ) ; if|
|00003f30| 20 73 75 63 63 65 73 73 | 0a 58 20 20 20 20 3b 20 | success|.X ; |
|00003f40| 72 65 74 75 72 6e 0a 58 | 20 20 20 20 73 75 63 63 |return.X| succ|
|00003f50| 65 73 73 0a 58 20 20 20 | 20 29 20 3b 20 6c 65 74 |ess.X | ) ; let|
|00003f60| 0a 58 20 20 29 20 3b 20 | 64 65 66 75 6e 20 74 70 |.X ) ; |defun tp|
|00003f70| 6c 2d 6d 61 74 63 68 2d | 70 61 74 74 65 72 6e 0a |l-match-|pattern.|
|00003f80| 58 0a 58 3b 3b 3b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |X.X;;;++|++++++++|
|00003f90| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00003fa0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00003fb0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00003fc0| 2b 2b 2b 2b 2b 2b 2b 0a | 58 0a 58 28 64 65 66 75 |+++++++.|X.X(defu|
|00003fd0| 6e 20 74 70 6c 2d 6d 61 | 74 63 68 2d 72 65 70 65 |n tpl-ma|tch-repe|
|00003fe0| 74 69 74 69 6f 6e 2d 74 | 65 6d 70 6c 61 74 65 20 |tition-t|emplate |
|00003ff0| 28 74 65 6d 70 6c 61 74 | 65 29 0a 58 20 20 22 4d |(templat|e).X "M|
|00004000| 61 74 63 68 20 54 45 4d | 50 4c 41 54 45 20 61 6e |atch TEM|PLATE an|
|00004010| 64 20 72 65 74 75 72 6e | 20 74 20 6f 72 20 6e 69 |d return| t or ni|
|00004020| 6c 2e 22 0a 58 09 09 09 | 09 09 3b 20 4c 6f 63 61 |l.".X...|..; Loca|
|00004030| 6c 20 56 61 72 69 61 62 | 6c 65 73 0a 58 20 20 28 |l Variab|les.X (|
|00004040| 6c 65 74 20 28 29 0a 58 | 09 09 09 09 09 3b 20 42 |let ().X|.....; B|
|00004050| 6f 64 79 0a 58 20 20 20 | 20 28 65 72 72 6f 72 0a |ody.X | (error.|
|00004060| 58 20 20 20 20 20 22 74 | 70 6c 2d 6d 61 74 63 68 |X "t|pl-match|
|00004070| 2d 72 65 70 65 74 69 74 | 69 6f 6e 2d 74 65 6d 70 |-repetit|ion-temp|
|00004080| 6c 61 74 65 3a 20 43 61 | 6e 6e 6f 74 20 6d 61 74 |late: Ca|nnot mat|
|00004090| 63 68 20 72 65 70 65 74 | 69 74 69 6f 6e 2d 74 79 |ch repet|ition-ty|
|000040a0| 70 65 20 74 65 6d 70 6c | 61 74 65 2e 22 29 0a 58 |pe templ|ate.").X|
|000040b0| 20 20 20 20 29 20 3b 20 | 6c 65 74 0a 58 20 20 29 | ) ; |let.X )|
|000040c0| 20 3b 20 64 65 66 75 6e | 20 74 70 6c 2d 6d 61 74 | ; defun| tpl-mat|
|000040d0| 63 68 2d 72 65 70 65 74 | 69 74 69 6f 6e 2d 74 65 |ch-repet|ition-te|
|000040e0| 6d 70 6c 61 74 65 0a 58 | 0a 58 3b 3b 3b 2b 2b 2b |mplate.X|.X;;;+++|
|000040f0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004100| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004110| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004120| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 0a 58 |++++++++|++++++.X|
|00004130| 0a 58 28 64 65 66 75 6e | 20 74 70 6c 2d 6d 61 74 |.X(defun| tpl-mat|
|00004140| 63 68 2d 73 65 6c 65 63 | 74 69 6f 6e 2d 74 65 6d |ch-selec|tion-tem|
|00004150| 70 6c 61 74 65 20 28 74 | 65 6d 70 6c 61 74 65 29 |plate (t|emplate)|
|00004160| 0a 58 20 20 22 4d 61 74 | 63 68 20 54 45 4d 50 4c |.X "Mat|ch TEMPL|
|00004170| 41 54 45 20 61 6e 64 20 | 72 65 74 75 72 6e 20 74 |ATE and |return t|
|00004180| 72 65 65 20 6f 72 20 6e | 69 6c 2e 22 0a 58 09 09 |ree or n|il.".X..|
|00004190| 09 09 09 3b 20 4c 6f 63 | 61 6c 20 56 61 72 69 61 |...; Loc|al Varia|
|000041a0| 62 6c 65 73 0a 58 20 20 | 28 6c 65 74 20 28 72 65 |bles.X |(let (re|
|000041b0| 73 75 6c 74 20 73 65 6c | 65 63 74 69 6f 6e 2d 6c |sult sel|ection-l|
|000041c0| 69 73 74 20 73 65 6c 65 | 63 74 69 6f 6e 29 0a 58 |ist sele|ction).X|
|000041d0| 09 09 09 09 09 3b 20 42 | 6f 64 79 0a 58 20 20 20 |.....; B|ody.X |
|000041e0| 20 28 73 65 74 71 20 72 | 65 73 75 6c 74 20 6e 69 | (setq r|esult ni|
|000041f0| 6c 29 0a 58 20 20 20 20 | 28 73 65 74 71 20 73 65 |l).X |(setq se|
|00004200| 6c 65 63 74 69 6f 6e 2d | 6c 69 73 74 20 28 74 70 |lection-|list (tp|
|00004210| 6c 2d 74 6f 6b 65 6e 2d | 76 61 6c 75 65 20 74 65 |l-token-|value te|
|00004220| 6d 70 6c 61 74 65 29 29 | 0a 58 20 20 20 20 28 77 |mplate))|.X (w|
|00004230| 68 69 6c 65 20 28 61 6e | 64 20 73 65 6c 65 63 74 |hile (an|d select|
|00004240| 69 6f 6e 2d 6c 69 73 74 | 20 28 6e 6f 74 20 72 65 |ion-list| (not re|
|00004250| 73 75 6c 74 29 29 0a 58 | 20 20 20 20 20 20 28 73 |sult)).X| (s|
|00004260| 65 74 71 20 73 65 6c 65 | 63 74 69 6f 6e 20 28 63 |etq sele|ction (c|
|00004270| 61 72 20 73 65 6c 65 63 | 74 69 6f 6e 2d 6c 69 73 |ar selec|tion-lis|
|00004280| 74 29 29 0a 58 20 20 20 | 20 20 20 28 73 65 74 71 |t)).X | (setq|
|00004290| 20 73 65 6c 65 63 74 69 | 6f 6e 2d 6c 69 73 74 20 | selecti|on-list |
|000042a0| 28 63 64 72 20 73 65 6c | 65 63 74 69 6f 6e 2d 6c |(cdr sel|ection-l|
|000042b0| 69 73 74 29 29 0a 58 20 | 20 20 20 20 20 28 73 65 |ist)).X | (se|
|000042c0| 74 71 20 73 65 6c 65 63 | 74 69 6f 6e 20 28 74 70 |tq selec|tion (tp|
|000042d0| 6c 2d 74 6f 6b 65 6e 2d | 76 61 6c 75 65 20 28 63 |l-token-|value (c|
|000042e0| 61 72 20 28 74 70 6c 2d | 6c 69 6e 65 2d 74 6f 6b |ar (tpl-|line-tok|
|000042f0| 65 6e 73 20 73 65 6c 65 | 63 74 69 6f 6e 29 29 29 |ens sele|ction)))|
|00004300| 29 0a 58 20 20 20 20 20 | 20 28 73 65 74 71 20 72 |).X | (setq r|
|00004310| 65 73 75 6c 74 20 28 74 | 70 6c 2d 6d 61 74 63 68 |esult (t|pl-match|
|00004320| 2d 74 65 6d 70 6c 61 74 | 65 20 73 65 6c 65 63 74 |-templat|e select|
|00004330| 69 6f 6e 29 29 0a 58 20 | 20 20 20 20 20 29 20 3b |ion)).X | ) ;|
|00004340| 20 77 68 69 6c 65 20 73 | 65 6c 65 63 74 69 6f 6e | while s|election|
|00004350| 2d 6c 69 73 74 0a 58 20 | 20 20 20 3b 20 72 65 74 |-list.X | ; ret|
|00004360| 75 72 6e 0a 58 20 20 20 | 20 72 65 73 75 6c 74 0a |urn.X | result.|
|00004370| 58 20 20 20 20 29 20 3b | 20 6c 65 74 0a 58 20 20 |X ) ;| let.X |
|00004380| 29 20 3b 20 64 65 66 75 | 6e 20 74 70 6c 2d 6d 61 |) ; defu|n tpl-ma|
|00004390| 74 63 68 2d 73 65 6c 65 | 63 74 69 6f 6e 2d 74 65 |tch-sele|ction-te|
|000043a0| 6d 70 6c 61 74 65 0a 58 | 0a 58 3b 3b 3b 2b 2b 2b |mplate.X|.X;;;+++|
|000043b0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000043c0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000043d0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000043e0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 0a 58 |++++++++|++++++.X|
|000043f0| 0a 58 28 64 65 66 75 6e | 20 74 70 6c 2d 6d 61 74 |.X(defun| tpl-mat|
|00004400| 63 68 2d 73 65 71 75 65 | 6e 63 65 2d 74 65 6d 70 |ch-seque|nce-temp|
|00004410| 6c 61 74 65 20 28 74 65 | 6d 70 6c 61 74 65 29 0a |late (te|mplate).|
|00004420| 58 20 20 22 4d 61 74 63 | 68 20 54 45 4d 50 4c 41 |X "Matc|h TEMPLA|
|00004430| 54 45 20 61 6e 64 20 72 | 65 74 75 72 6e 20 74 72 |TE and r|eturn tr|
|00004440| 65 65 20 6f 72 20 6e 69 | 6c 2e 22 0a 58 09 09 09 |ee or ni|l.".X...|
|00004450| 09 09 3b 20 4c 6f 63 61 | 6c 20 56 61 72 69 61 62 |..; Loca|l Variab|
|00004460| 6c 65 73 0a 58 20 20 28 | 6c 65 74 20 28 70 61 74 |les.X (|let (pat|
|00004470| 74 65 72 6e 2d 6c 69 73 | 74 20 72 65 73 75 6c 74 |tern-lis|t result|
|00004480| 29 0a 58 09 09 09 09 09 | 3b 20 42 6f 64 79 0a 58 |).X.....|; Body.X|
|00004490| 20 20 20 20 28 73 65 74 | 71 20 70 61 74 74 65 72 | (set|q patter|
|000044a0| 6e 2d 6c 69 73 74 20 28 | 74 70 6c 2d 74 6f 6b 65 |n-list (|tpl-toke|
|000044b0| 6e 2d 76 61 6c 75 65 20 | 74 65 6d 70 6c 61 74 65 |n-value |template|
|000044c0| 29 29 0a 58 20 20 20 20 | 28 73 65 74 71 20 72 65 |)).X |(setq re|
|000044d0| 73 75 6c 74 20 28 74 70 | 6c 2d 6d 61 74 63 68 2d |sult (tp|l-match-|
|000044e0| 70 61 74 74 65 72 6e 20 | 70 61 74 74 65 72 6e 2d |pattern |pattern-|
|000044f0| 6c 69 73 74 20 6c 65 78 | 2d 70 61 74 74 65 72 6e |list lex|-pattern|
|00004500| 73 29 29 0a 58 20 20 20 | 20 28 69 66 20 72 65 73 |s)).X | (if res|
|00004510| 75 6c 74 0a 58 09 28 73 | 65 74 71 20 72 65 73 75 |ult.X.(s|etq resu|
|00004520| 6c 74 20 28 74 70 6c 2d | 6d 61 6b 65 2d 74 6f 6b |lt (tpl-|make-tok|
|00004530| 65 6e 0a 58 09 09 20 20 | 20 20 20 20 74 70 6c 2d |en.X.. | tpl-|
|00004540| 73 65 71 75 65 6e 63 65 | 2d 74 79 70 65 20 28 74 |sequence|-type (t|
|00004550| 70 6c 2d 74 6f 6b 65 6e | 2d 6e 61 6d 65 20 74 65 |pl-token|-name te|
|00004560| 6d 70 6c 61 74 65 29 20 | 72 65 73 75 6c 74 29 29 |mplate) |result))|
|00004570| 0a 58 20 20 20 20 20 20 | 29 20 3b 20 69 66 20 72 |.X |) ; if r|
|00004580| 65 73 75 6c 74 0a 58 20 | 20 20 20 3b 20 72 65 74 |esult.X | ; ret|
|00004590| 75 72 6e 0a 58 20 20 20 | 20 72 65 73 75 6c 74 0a |urn.X | result.|
|000045a0| 58 20 20 20 20 29 20 3b | 20 6c 65 74 0a 58 20 20 |X ) ;| let.X |
|000045b0| 29 20 3b 20 64 65 66 75 | 6e 20 74 70 6c 2d 6d 61 |) ; defu|n tpl-ma|
|000045c0| 74 63 68 2d 73 65 71 75 | 65 6e 63 65 2d 74 65 6d |tch-sequ|ence-tem|
|000045d0| 70 6c 61 74 65 0a 58 0a | 58 3b 3b 3b 2b 2b 2b 2b |plate.X.|X;;;++++|
|000045e0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000045f0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004600| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004610| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 0a 58 0a |++++++++|+++++.X.|
|00004620| 58 28 64 65 66 75 6e 20 | 74 70 6c 2d 6d 61 74 63 |X(defun |tpl-matc|
|00004630| 68 2d 73 74 72 69 6e 67 | 2d 74 65 6d 70 6c 61 74 |h-string|-templat|
|00004640| 65 20 28 74 65 6d 70 6c | 61 74 65 29 0a 58 20 20 |e (templ|ate).X |
|00004650| 22 4d 61 74 63 68 20 54 | 45 4d 50 4c 41 54 45 20 |"Match T|EMPLATE |
|00004660| 61 6e 64 20 72 65 74 75 | 72 6e 20 74 72 65 65 20 |and retu|rn tree |
|00004670| 6f 72 20 6e 69 6c 2e 22 | 0a 58 09 09 09 09 09 3b |or nil."|.X.....;|
|00004680| 20 4c 6f 63 61 6c 20 56 | 61 72 69 61 62 6c 65 73 | Local V|ariables|
|00004690| 0a 58 20 20 28 6c 65 74 | 20 28 70 61 74 74 65 72 |.X (let| (patter|
|000046a0| 6e 2d 6c 69 73 74 20 72 | 65 73 75 6c 74 29 0a 58 |n-list r|esult).X|
|000046b0| 09 09 09 09 09 3b 20 42 | 6f 64 79 0a 58 20 20 20 |.....; B|ody.X |
|000046c0| 20 28 73 65 74 71 20 70 | 61 74 74 65 72 6e 2d 6c | (setq p|attern-l|
|000046d0| 69 73 74 20 28 74 70 6c | 2d 74 6f 6b 65 6e 2d 76 |ist (tpl|-token-v|
|000046e0| 61 6c 75 65 20 74 65 6d | 70 6c 61 74 65 29 29 0a |alue tem|plate)).|
|000046f0| 58 20 20 20 20 28 73 65 | 74 71 20 72 65 73 75 6c |X (se|tq resul|
|00004700| 74 20 28 74 70 6c 2d 6d | 61 74 63 68 2d 70 61 74 |t (tpl-m|atch-pat|
|00004710| 74 65 72 6e 20 70 61 74 | 74 65 72 6e 2d 6c 69 73 |tern pat|tern-lis|
|00004720| 74 20 73 74 72 69 6e 67 | 2d 70 61 74 74 65 72 6e |t string|-pattern|
|00004730| 73 29 29 0a 58 20 20 20 | 20 28 69 66 20 72 65 73 |s)).X | (if res|
|00004740| 75 6c 74 0a 58 09 28 73 | 65 74 71 20 72 65 73 75 |ult.X.(s|etq resu|
|00004750| 6c 74 20 28 74 70 6c 2d | 6d 61 6b 65 2d 74 6f 6b |lt (tpl-|make-tok|
|00004760| 65 6e 0a 58 09 09 20 20 | 20 20 20 20 74 70 6c 2d |en.X.. | tpl-|
|00004770| 73 65 71 75 65 6e 63 65 | 2d 74 79 70 65 20 28 74 |sequence|-type (t|
|00004780| 70 6c 2d 74 6f 6b 65 6e | 2d 6e 61 6d 65 20 74 65 |pl-token|-name te|
|00004790| 6d 70 6c 61 74 65 29 20 | 72 65 73 75 6c 74 29 29 |mplate) |result))|
|000047a0| 0a 58 20 20 20 20 20 20 | 29 20 3b 20 69 66 20 72 |.X |) ; if r|
|000047b0| 65 73 75 6c 74 0a 58 20 | 20 20 20 3b 20 72 65 74 |esult.X | ; ret|
|000047c0| 75 72 6e 0a 58 20 20 20 | 20 72 65 73 75 6c 74 0a |urn.X | result.|
|000047d0| 58 20 20 20 20 29 20 3b | 20 6c 65 74 0a 58 20 20 |X ) ;| let.X |
|000047e0| 29 20 3b 20 64 65 66 75 | 6e 20 74 70 6c 2d 6d 61 |) ; defu|n tpl-ma|
|000047f0| 74 63 68 2d 73 74 72 69 | 6e 67 2d 74 65 6d 70 6c |tch-stri|ng-templ|
|00004800| 61 74 65 0a 58 0a 58 3b | 3b 3b 2b 2b 2b 2b 2b 2b |ate.X.X;|;;++++++|
|00004810| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004820| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004830| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004840| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 0a 58 0a 58 28 |++++++++|+++.X.X(|
|00004850| 64 65 66 75 6e 20 74 70 | 6c 2d 6d 61 74 63 68 2d |defun tp|l-match-|
|00004860| 74 65 6d 70 6c 61 74 65 | 20 28 6e 61 6d 65 29 0a |template| (name).|
|00004870| 58 20 20 22 4d 61 74 63 | 68 20 74 65 6d 70 6c 61 |X "Matc|h templa|
|00004880| 74 65 20 4e 41 4d 45 20 | 61 6e 64 20 72 65 74 75 |te NAME |and retu|
|00004890| 72 6e 20 74 72 65 65 20 | 6f 72 20 6e 69 6c 2e 22 |rn tree |or nil."|
|000048a0| 0a 58 09 09 09 09 09 3b | 20 4c 6f 63 61 6c 20 56 |.X.....;| Local V|
|000048b0| 61 72 69 61 62 6c 65 73 | 0a 58 20 20 28 6c 65 74 |ariables|.X (let|
|000048c0| 20 28 74 65 6d 70 6c 61 | 74 65 20 74 65 6d 70 6c | (templa|te templ|
|000048d0| 61 74 65 2d 74 79 70 65 | 20 72 65 73 75 6c 74 29 |ate-type| result)|
|000048e0| 0a 58 09 09 09 09 09 3b | 20 42 6f 64 79 0a 58 20 |.X.....;| Body.X |
|000048f0| 20 20 20 28 73 65 74 71 | 20 74 65 6d 70 6c 61 74 | (setq| templat|
|00004900| 65 20 28 74 70 6c 2d 66 | 69 6e 64 2d 74 65 6d 70 |e (tpl-f|ind-temp|
|00004910| 6c 61 74 65 20 6e 61 6d | 65 29 29 0a 58 20 20 20 |late nam|e)).X |
|00004920| 20 28 73 65 74 71 20 74 | 65 6d 70 6c 61 74 65 2d | (setq t|emplate-|
|00004930| 74 79 70 65 20 28 74 70 | 6c 2d 74 6f 6b 65 6e 2d |type (tp|l-token-|
|00004940| 74 79 70 65 20 74 65 6d | 70 6c 61 74 65 29 29 0a |type tem|plate)).|
|00004950| 58 20 20 20 20 28 63 6f | 6e 64 0a 58 20 20 20 20 |X (co|nd.X |
|00004960| 20 28 28 65 71 75 61 6c | 20 74 65 6d 70 6c 61 74 | ((equal| templat|
|00004970| 65 2d 74 79 70 65 20 74 | 70 6c 2d 66 75 6e 63 74 |e-type t|pl-funct|
|00004980| 69 6f 6e 2d 74 79 70 65 | 29 0a 58 20 20 20 20 20 |ion-type|).X |
|00004990| 20 28 73 65 74 71 20 72 | 65 73 75 6c 74 20 28 74 | (setq r|esult (t|
|000049a0| 70 6c 2d 6d 61 74 63 68 | 2d 66 75 6e 63 74 69 6f |pl-match|-functio|
|000049b0| 6e 2d 74 65 6d 70 6c 61 | 74 65 20 74 65 6d 70 6c |n-templa|te templ|
|000049c0| 61 74 65 29 29 0a 58 20 | 20 20 20 20 20 29 20 3b |ate)).X | ) ;|
|000049d0| 20 28 65 71 75 61 6c 20 | 74 65 6d 70 6c 61 74 65 | (equal |template|
|000049e0| 2d 74 79 70 65 20 74 70 | 6c 2d 66 75 6e 63 74 69 |-type tp|l-functi|
|000049f0| 6f 6e 2d 74 79 70 65 29 | 0a 58 20 20 20 20 20 28 |on-type)|.X (|
|00004a00| 28 65 71 75 61 6c 20 74 | 65 6d 70 6c 61 74 65 2d |(equal t|emplate-|
|00004a10| 74 79 70 65 20 74 70 6c | 2d 6c 65 78 69 63 61 6c |type tpl|-lexical|
|00004a20| 2d 74 79 70 65 29 0a 58 | 20 20 20 20 20 20 28 73 |-type).X| (s|
|00004a30| 65 74 71 20 72 65 73 75 | 6c 74 20 28 74 70 6c 2d |etq resu|lt (tpl-|
|00004a40| 6d 61 74 63 68 2d 6c 65 | 78 69 63 61 6c 2d 74 65 |match-le|xical-te|
|00004a50| 6d 70 6c 61 74 65 20 74 | 65 6d 70 6c 61 74 65 29 |mplate t|emplate)|
|00004a60| 29 0a 58 20 20 20 20 20 | 20 29 20 3b 20 28 65 71 |).X | ) ; (eq|
|00004a70| 75 61 6c 20 74 65 6d 70 | 6c 61 74 65 2d 74 79 70 |ual temp|late-typ|
|00004a80| 65 20 74 70 6c 2d 6c 65 | 78 69 63 61 6c 2d 74 79 |e tpl-le|xical-ty|
|00004a90| 70 65 29 0a 58 20 20 20 | 20 20 28 28 65 71 75 61 |pe).X | ((equa|
|00004aa0| 6c 20 74 65 6d 70 6c 61 | 74 65 2d 74 79 70 65 20 |l templa|te-type |
|00004ab0| 74 70 6c 2d 72 65 70 65 | 74 69 74 69 6f 6e 2d 74 |tpl-repe|tition-t|
|00004ac0| 79 70 65 29 0a 58 20 20 | 20 20 20 20 28 73 65 74 |ype).X | (set|
|00004ad0| 71 20 72 65 73 75 6c 74 | 20 28 74 70 6c 2d 6d 61 |q result| (tpl-ma|
|00004ae0| 74 63 68 2d 72 65 70 65 | 74 69 74 69 6f 6e 2d 74 |tch-repe|tition-t|
|00004af0| 65 6d 70 6c 61 74 65 20 | 74 65 6d 70 6c 61 74 65 |emplate |template|
|00004b00| 29 29 0a 58 20 20 20 20 | 20 20 29 20 3b 20 28 65 |)).X | ) ; (e|
|00004b10| 71 75 61 6c 20 74 65 6d | 70 6c 61 74 65 2d 74 79 |qual tem|plate-ty|
|00004b20| 70 65 20 74 70 6c 2d 72 | 65 70 65 74 69 74 69 6f |pe tpl-r|epetitio|
|00004b30| 6e 2d 74 79 70 65 29 0a | 58 20 20 20 20 20 28 28 |n-type).|X ((|
|00004b40| 65 71 75 61 6c 20 74 65 | 6d 70 6c 61 74 65 2d 74 |equal te|mplate-t|
|00004b50| 79 70 65 20 74 70 6c 2d | 73 65 6c 65 63 74 69 6f |ype tpl-|selectio|
|00004b60| 6e 2d 74 79 70 65 29 0a | 58 20 20 20 20 20 20 28 |n-type).|X (|
|00004b70| 73 65 74 71 20 72 65 73 | 75 6c 74 20 28 74 70 6c |setq res|ult (tpl|
|00004b80| 2d 6d 61 74 63 68 2d 73 | 65 6c 65 63 74 69 6f 6e |-match-s|election|
|00004b90| 2d 74 65 6d 70 6c 61 74 | 65 20 74 65 6d 70 6c 61 |-templat|e templa|
|00004ba0| 74 65 29 29 0a 58 20 20 | 20 20 20 20 29 20 3b 20 |te)).X | ) ; |
|00004bb0| 28 65 71 75 61 6c 20 74 | 65 6d 70 6c 61 74 65 2d |(equal t|emplate-|
|00004bc0| 74 79 70 65 20 74 70 6c | 2d 73 65 6c 65 63 74 69 |type tpl|-selecti|
|00004bd0| 6f 6e 2d 74 79 70 65 29 | 0a 58 20 20 20 20 20 28 |on-type)|.X (|
|00004be0| 28 65 71 75 61 6c 20 74 | 65 6d 70 6c 61 74 65 2d |(equal t|emplate-|
|00004bf0| 74 79 70 65 20 74 70 6c | 2d 73 65 71 75 65 6e 63 |type tpl|-sequenc|
|00004c00| 65 2d 74 79 70 65 29 0a | 58 20 20 20 20 20 20 28 |e-type).|X (|
|00004c10| 73 65 74 71 20 72 65 73 | 75 6c 74 20 28 74 70 6c |setq res|ult (tpl|
|00004c20| 2d 6d 61 74 63 68 2d 73 | 65 71 75 65 6e 63 65 2d |-match-s|equence-|
|00004c30| 74 65 6d 70 6c 61 74 65 | 20 74 65 6d 70 6c 61 74 |template| templat|
|00004c40| 65 29 29 0a 58 20 20 20 | 20 20 20 29 20 3b 20 28 |e)).X | ) ; (|
|00004c50| 65 71 75 61 6c 20 74 65 | 6d 70 6c 61 74 65 2d 74 |equal te|mplate-t|
|00004c60| 79 70 65 20 74 70 6c 2d | 73 65 71 75 65 6e 63 65 |ype tpl-|sequence|
|00004c70| 2d 74 79 70 65 29 0a 58 | 20 20 20 20 20 28 28 65 |-type).X| ((e|
|00004c80| 71 75 61 6c 20 74 65 6d | 70 6c 61 74 65 2d 74 79 |qual tem|plate-ty|
|00004c90| 70 65 20 74 70 6c 2d 73 | 74 72 69 6e 67 2d 74 79 |pe tpl-s|tring-ty|
|00004ca0| 70 65 29 0a 58 20 20 20 | 20 20 20 28 73 65 74 71 |pe).X | (setq|
|00004cb0| 20 72 65 73 75 6c 74 20 | 28 74 70 6c 2d 6d 61 74 | result |(tpl-mat|
|00004cc0| 63 68 2d 73 74 72 69 6e | 67 2d 74 65 6d 70 6c 61 |ch-strin|g-templa|
|00004cd0| 74 65 20 74 65 6d 70 6c | 61 74 65 29 29 0a 58 20 |te templ|ate)).X |
|00004ce0| 20 20 20 20 20 29 20 3b | 20 28 65 71 75 61 6c 20 | ) ;| (equal |
|00004cf0| 74 65 6d 70 6c 61 74 65 | 2d 74 79 70 65 20 74 70 |template|-type tp|
|00004d00| 6c 2d 73 74 72 69 6e 67 | 2d 74 79 70 65 29 0a 58 |l-string|-type).X|
|00004d10| 20 20 20 20 20 29 20 3b | 20 63 6f 6e 64 0a 58 20 | ) ;| cond.X |
|00004d20| 20 20 20 3b 20 72 65 74 | 75 72 6e 0a 58 20 20 20 | ; ret|urn.X |
|00004d30| 20 72 65 73 75 6c 74 0a | 58 20 20 20 20 29 20 3b | result.|X ) ;|
|00004d40| 20 6c 65 74 0a 58 20 20 | 29 20 3b 20 64 65 66 75 | let.X |) ; defu|
|00004d50| 6e 20 74 70 6c 2d 6d 61 | 74 63 68 2d 74 65 6d 70 |n tpl-ma|tch-temp|
|00004d60| 6c 61 74 65 0a 58 0a 58 | 3b 3b 3b 2b 2b 2b 2b 2b |late.X.X|;;;+++++|
|00004d70| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004d80| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004d90| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00004da0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 0a 58 0a 58 |++++++++|++++.X.X|
|00004db0| 28 64 65 66 75 6e 20 74 | 70 6c 2d 6d 61 74 63 68 |(defun t|pl-match|
|00004dc0| 2d 74 6f 6b 65 6e 20 28 | 74 6f 6b 65 6e 20 74 65 |-token (|token te|
|00004dd0| 78 74 2d 6c 69 73 74 29 | 0a 58 20 20 22 41 74 74 |xt-list)|.X "Att|
|00004de0| 65 6d 70 74 20 74 6f 20 | 6d 61 74 63 68 20 54 4f |empt to |match TO|
|00004df0| 4b 45 4e 20 77 69 74 68 | 20 74 6f 6b 65 6e 73 20 |KEN with| tokens |
|00004e00| 69 6e 20 54 45 58 54 2d | 4c 49 53 54 2e 20 20 52 |in TEXT-|LIST. R|
|00004e10| 65 74 75 72 6e 20 74 68 | 65 0a 58 20 20 20 20 6c |eturn th|e.X l|
|00004e20| 69 73 74 20 28 74 20 72 | 65 6d 61 69 6e 64 65 72 |ist (t r|emainder|
|00004e30| 2d 6f 66 2d 54 45 58 54 | 2d 4c 49 53 54 29 20 6f |-of-TEXT|-LIST) o|
|00004e40| 72 20 6e 69 6c 2e 22 0a | 58 09 09 09 09 09 3b 20 |r nil.".|X.....; |
|00004e50| 4c 6f 63 61 6c 20 56 61 | 72 69 61 62 6c 65 73 0a |Local Va|riables.|
|00004e60| 58 20 20 28 6c 65 74 20 | 28 74 79 70 65 20 73 75 |X (let |(type su|
|00004e70| 63 63 65 73 73 29 0a 58 | 09 09 09 09 09 3b 20 42 |ccess).X|.....; B|
|00004e80| 6f 64 79 0a 58 20 20 20 | 20 28 73 65 74 71 20 74 |ody.X | (setq t|
|00004e90| 65 78 74 2d 6c 69 73 74 | 20 28 74 70 6c 2d 64 65 |ext-list| (tpl-de|
|00004ea0| 6c 65 74 65 2d 6c 65 61 | 64 69 6e 67 2d 77 68 69 |lete-lea|ding-whi|
|00004eb0| 74 65 73 70 61 63 65 20 | 74 65 78 74 2d 6c 69 73 |tespace |text-lis|
|00004ec0| 74 29 29 0a 58 20 20 20 | 20 28 73 65 74 71 20 74 |t)).X | (setq t|
|00004ed0| 79 70 65 20 28 74 70 6c | 2d 74 6f 6b 65 6e 2d 6e |ype (tpl|-token-n|
|00004ee0| 61 6d 65 20 74 6f 6b 65 | 6e 29 29 0a 58 20 20 20 |ame toke|n)).X |
|00004ef0| 20 28 63 6f 6e 64 0a 58 | 20 20 20 20 20 28 28 6f | (cond.X| ((o|
|00004f00| 72 20 28 65 71 75 61 6c | 20 74 79 70 65 20 74 70 |r (equal| type tp|
|00004f10| 6c 2d 6f 74 68 65 72 2d | 74 79 70 65 29 0a 58 09 |l-other-|type).X.|
|00004f20| 20 20 28 65 71 75 61 6c | 20 74 79 70 65 20 74 70 | (equal| type tp|
|00004f30| 6c 2d 70 75 6e 63 74 75 | 61 74 69 6f 6e 2d 74 79 |l-punctu|ation-ty|
|00004f40| 70 65 29 0a 58 09 20 20 | 28 65 71 75 61 6c 20 74 |pe).X. |(equal t|
|00004f50| 79 70 65 20 74 70 6c 2d | 73 74 72 69 6e 67 2d 74 |ype tpl-|string-t|
|00004f60| 79 70 65 29 29 0a 58 20 | 20 20 20 20 20 28 70 72 |ype)).X | (pr|
|00004f70| 6f 67 6e 0a 58 09 28 69 | 66 20 74 65 78 74 2d 6c |ogn.X.(i|f text-l|
|00004f80| 69 73 74 0a 58 09 20 20 | 20 20 28 70 72 6f 67 6e |ist.X. | (progn|
|00004f90| 0a 58 09 20 20 20 20 20 | 20 28 73 65 74 71 20 73 |.X. | (setq s|
|00004fa0| 75 63 63 65 73 73 20 28 | 65 71 75 61 6c 20 28 74 |uccess (|equal (t|
|00004fb0| 70 6c 2d 74 6f 6b 65 6e | 2d 76 61 6c 75 65 20 74 |pl-token|-value t|
|00004fc0| 6f 6b 65 6e 29 0a 58 09 | 09 09 09 20 20 20 28 74 |oken).X.|... (t|
|00004fd0| 70 6c 2d 74 6f 6b 65 6e | 2d 76 61 6c 75 65 20 28 |pl-token|-value (|
|00004fe0| 63 61 72 20 74 65 78 74 | 2d 6c 69 73 74 29 29 29 |car text|-list)))|
|00004ff0| 29 0a 58 09 20 20 20 20 | 20 20 28 73 65 74 71 20 |).X. | (setq |
|00005000| 74 65 78 74 2d 6c 69 73 | 74 20 28 63 64 72 20 74 |text-lis|t (cdr t|
|00005010| 65 78 74 2d 6c 69 73 74 | 29 29 0a 58 09 20 20 20 |ext-list|)).X. |
|00005020| 20 20 20 29 20 3b 20 70 | 72 6f 67 6e 0a 58 09 20 | ) ; p|rogn.X. |
|00005030| 20 3b 20 65 6c 73 65 0a | 58 09 20 20 28 73 65 74 | ; else.|X. (set|
|00005040| 71 20 73 75 63 63 65 73 | 73 20 6e 69 6c 29 0a 58 |q succes|s nil).X|
|00005050| 09 20 20 29 20 3b 20 69 | 66 20 74 65 78 74 2d 6c |. ) ; i|f text-l|
|00005060| 69 73 74 0a 58 09 29 20 | 3b 20 70 72 6f 67 6e 0a |ist.X.) |; progn.|
|00005070| 58 20 20 20 20 20 20 29 | 20 3b 20 28 6f 72 20 28 |X )| ; (or (|
|00005080| 65 71 75 61 6c 20 74 79 | 70 65 20 74 70 6c 2d 6f |equal ty|pe tpl-o|
|00005090| 74 68 65 72 2d 74 79 70 | 65 29 2e 2e 2e 29 0a 58 |ther-typ|e)...).X|
|000050a0| 20 20 20 20 20 28 28 65 | 71 75 61 6c 20 74 79 70 | ((e|qual typ|
|000050b0| 65 20 74 70 6c 2d 77 6f | 72 64 2d 74 79 70 65 29 |e tpl-wo|rd-type)|
|000050c0| 0a 58 20 20 20 20 20 20 | 28 70 72 6f 67 6e 0a 58 |.X |(progn.X|
|000050d0| 09 28 69 66 20 74 65 78 | 74 2d 6c 69 73 74 0a 58 |.(if tex|t-list.X|
|000050e0| 09 20 20 20 20 28 70 72 | 6f 67 6e 0a 58 09 20 20 |. (pr|ogn.X. |
|000050f0| 20 20 20 20 28 73 65 74 | 71 20 73 75 63 63 65 73 | (set|q succes|
|00005100| 73 20 28 65 71 75 61 6c | 20 28 75 70 63 61 73 65 |s (equal| (upcase|
|00005110| 20 28 74 70 6c 2d 74 6f | 6b 65 6e 2d 76 61 6c 75 | (tpl-to|ken-valu|
|00005120| 65 20 74 6f 6b 65 6e 29 | 29 0a 58 09 09 09 09 20 |e token)|).X.... |
|00005130| 20 20 28 75 70 63 61 73 | 65 20 28 74 70 6c 2d 74 | (upcas|e (tpl-t|
|00005140| 6f 6b 65 6e 2d 76 61 6c | 75 65 20 28 63 61 72 20 |oken-val|ue (car |
|00005150| 74 65 78 74 2d 6c 69 73 | 74 29 29 29 29 29 0a 58 |text-lis|t))))).X|
|00005160| 09 20 20 20 20 20 20 28 | 73 65 74 71 20 74 65 78 |. (|setq tex|
|00005170| 74 2d 6c 69 73 74 20 28 | 63 64 72 20 74 65 78 74 |t-list (|cdr text|
|00005180| 2d 6c 69 73 74 29 29 0a | 58 09 20 20 20 20 20 20 |-list)).|X. |
|00005190| 29 20 3b 20 70 72 6f 67 | 6e 0a 58 09 20 20 3b 20 |) ; prog|n.X. ; |
|000051a0| 65 6c 73 65 0a 58 09 20 | 20 28 73 65 74 71 20 73 |else.X. | (setq s|
|000051b0| 75 63 63 65 73 73 20 6e | 69 6c 29 0a 58 09 20 20 |uccess n|il).X. |
|000051c0| 29 20 3b 20 69 66 20 74 | 65 78 74 2d 6c 69 73 74 |) ; if t|ext-list|
|000051d0| 0a 58 09 29 20 3b 20 70 | 72 6f 67 6e 0a 58 20 20 |.X.) ; p|rogn.X |
|000051e0| 20 20 20 20 29 20 3b 20 | 28 65 71 75 61 6c 20 74 | ) ; |(equal t|
|000051f0| 79 70 65 20 74 70 6c 2d | 77 6f 72 64 2d 74 79 70 |ype tpl-|word-typ|
|00005200| 65 29 0a 58 20 20 20 20 | 20 28 28 65 71 75 61 6c |e).X | ((equal|
|00005210| 20 74 79 70 65 20 74 70 | 6c 2d 77 68 69 74 65 73 | type tp|l-whites|
|00005220| 70 61 63 65 2d 74 79 70 | 65 29 0a 58 20 20 20 20 |pace-typ|e).X |
|00005230| 20 20 28 70 72 6f 67 6e | 0a 58 09 28 69 66 20 28 | (progn|.X.(if (|
|00005240| 61 6e 64 20 74 65 78 74 | 2d 6c 69 73 74 0a 58 09 |and text|-list.X.|
|00005250| 09 20 28 65 71 75 61 6c | 20 74 70 6c 2d 77 68 69 |. (equal| tpl-whi|
|00005260| 74 65 73 70 61 63 65 2d | 74 79 70 65 20 28 74 70 |tespace-|type (tp|
|00005270| 6c 2d 74 6f 6b 65 6e 2d | 6e 61 6d 65 20 28 63 61 |l-token-|name (ca|
|00005280| 72 20 74 65 78 74 2d 6c | 69 73 74 29 29 29 29 0a |r text-l|ist)))).|
|00005290| 58 09 20 20 20 20 28 73 | 65 74 71 20 74 65 78 74 |X. (s|etq text|
|000052a0| 2d 6c 69 73 74 20 28 63 | 64 72 20 74 65 78 74 2d |-list (c|dr text-|
|000052b0| 6c 69 73 74 29 29 0a 58 | 09 20 20 29 20 3b 20 69 |list)).X|. ) ; i|
|000052c0| 66 0a 58 09 28 73 65 74 | 71 20 73 75 63 63 65 73 |f.X.(set|q succes|
|000052d0| 73 20 74 29 0a 58 09 29 | 20 3b 20 70 72 6f 67 6e |s t).X.)| ; progn|
|000052e0| 0a 58 20 20 20 20 20 20 | 29 20 3b 20 28 65 71 75 |.X |) ; (equ|
|000052f0| 61 6c 20 74 79 70 65 20 | 74 70 6c 2d 77 68 69 74 |al type |tpl-whit|
|00005300| 65 73 70 61 63 65 2d 74 | 79 70 65 29 0a 58 20 20 |espace-t|ype).X |
|00005310| 20 20 20 28 28 6f 72 20 | 28 65 71 75 61 6c 20 74 | ((or |(equal t|
|00005320| 79 70 65 20 74 70 6c 2d | 70 6c 61 63 65 68 6f 6c |ype tpl-|placehol|
|00005330| 64 65 72 2d 74 79 70 65 | 29 0a 58 09 20 20 28 65 |der-type|).X. (e|
|00005340| 71 75 61 6c 20 74 79 70 | 65 20 74 70 6c 2d 6f 70 |qual typ|e tpl-op|
|00005350| 74 69 6f 6e 61 6c 2d 74 | 79 70 65 29 29 0a 58 20 |tional-t|ype)).X |
|00005360| 20 20 20 20 20 28 70 72 | 6f 67 6e 0a 58 09 28 73 | (pr|ogn.X.(s|
|00005370| 65 74 71 20 74 65 78 74 | 2d 6c 69 73 74 20 6e 69 |etq text|-list ni|
|00005380| 6c 29 0a 58 09 28 73 65 | 74 71 20 73 75 63 63 65 |l).X.(se|tq succe|
|00005390| 73 73 20 74 29 0a 58 09 | 29 20 3b 20 70 72 6f 67 |ss t).X.|) ; prog|
|000053a0| 6e 0a 58 20 20 20 20 20 | 20 29 20 3b 20 28 65 71 |n.X | ) ; (eq|
|000053b0| 75 61 6c 20 74 79 70 65 | 20 74 70 6c 2d 70 6c 61 |ual type| tpl-pla|
|000053c0| 63 65 68 6f 6c 64 65 72 | 2d 74 79 70 65 29 0a 58 |ceholder|-type).X|
|000053d0| 20 20 20 20 20 29 20 3b | 20 63 6f 6e 64 0a 58 20 | ) ;| cond.X |
|000053e0| 20 20 20 28 69 66 20 73 | 75 63 63 65 73 73 0a 58 | (if s|uccess.X|
|000053f0| 09 28 73 65 74 71 20 73 | 75 63 63 65 73 73 20 28 |.(setq s|uccess (|
|00005400| 63 6f 6e 73 20 74 20 74 | 65 78 74 2d 6c 69 73 74 |cons t t|ext-list|
|00005410| 29 29 0a 58 20 20 20 20 | 20 20 29 20 3b 20 69 66 |)).X | ) ; if|
|00005420| 20 73 75 63 63 65 73 73 | 0a 58 20 20 20 20 3b 20 | success|.X ; |
|00005430| 72 65 74 75 72 6e 0a 58 | 20 20 20 20 73 75 63 63 |return.X| succ|
|00005440| 65 73 73 0a 58 20 20 20 | 20 29 20 3b 20 6c 65 74 |ess.X | ) ; let|
|00005450| 0a 58 20 20 29 20 3b 20 | 64 65 66 75 6e 20 74 70 |.X ) ; |defun tp|
|00005460| 6c 2d 6d 61 74 63 68 2d | 74 6f 6b 65 6e 0a 58 0a |l-match-|token.X.|
|00005470| 58 3b 3b 3b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |X;;;++++|++++++++|
|00005480| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005490| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000054a0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|000054b0| 2b 2b 2b 2b 2b 0a 58 0a | 58 28 64 65 66 75 6e 20 |+++++.X.|X(defun |
|000054c0| 74 70 6c 2d 70 61 72 73 | 65 2d 66 75 6e 63 74 69 |tpl-pars|e-functi|
|000054d0| 6f 6e 20 28 74 65 6d 70 | 6c 61 74 65 29 0a 58 20 |on (temp|late).X |
|000054e0| 20 22 54 72 79 20 74 6f | 20 70 61 72 73 65 20 74 | "Try to| parse t|
|000054f0| 65 78 74 20 61 74 20 70 | 6f 69 6e 74 20 61 73 20 |ext at p|oint as |
|00005500| 61 6e 20 69 6e 73 74 61 | 6e 63 65 20 6f 66 20 66 |an insta|nce of f|
|00005510| 75 6e 63 74 69 6f 6e 2d | 74 79 70 65 20 54 45 4d |unction-|type TEM|
|00005520| 50 4c 41 54 45 2e 0a 58 | 20 20 20 52 65 74 75 72 |PLATE..X| Retur|
|00005530| 6e 20 61 20 70 61 72 73 | 65 20 74 72 65 65 20 6f |n a pars|e tree o|
|00005540| 72 20 6e 69 6c 2e 22 0a | 58 09 09 09 09 09 3b 20 |r nil.".|X.....; |
|00005550| 4c 6f 63 61 6c 20 56 61 | 72 69 61 62 6c 65 73 0a |Local Va|riables.|
|00005560| 58 20 20 28 6c 65 74 20 | 28 29 0a 58 09 09 09 09 |X (let |().X....|
|00005570| 09 3b 20 42 6f 64 79 0a | 58 20 20 20 20 28 65 72 |.; Body.|X (er|
|00005580| 72 6f 72 20 22 74 70 6c | 2d 70 61 72 73 65 2d 66 |ror "tpl|-parse-f|
|00005590| 75 6e 63 74 69 6f 6e 3a | 20 43 61 6e 6e 6f 74 20 |unction:| Cannot |
|000055a0| 70 61 72 73 65 20 66 75 | 6e 63 74 69 6f 6e 2d 74 |parse fu|nction-t|
|000055b0| 79 70 65 20 74 65 6d 70 | 6c 61 74 65 73 2e 22 29 |ype temp|lates.")|
|000055c0| 0a 58 20 20 29 20 3b 20 | 6c 65 74 0a 58 29 20 3b |.X ) ; |let.X) ;|
|000055d0| 20 64 65 66 75 6e 20 74 | 70 6c 2d 70 61 72 73 65 | defun t|pl-parse|
|000055e0| 2d 66 75 6e 63 74 69 6f | 6e 0a 58 0a 58 3b 3b 3b |-functio|n.X.X;;;|
|000055f0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005600| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005610| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005620| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005630| 2b 0a 58 0a 58 28 64 65 | 66 75 6e 20 74 70 6c 2d |+.X.X(de|fun tpl-|
|00005640| 70 61 72 73 65 2d 69 6e | 73 74 61 6e 63 65 20 28 |parse-in|stance (|
|00005650| 74 70 6c 2d 6e 61 6d 65 | 29 0a 58 20 20 22 54 72 |tpl-name|).X "Tr|
|00005660| 79 20 74 6f 20 70 61 72 | 73 65 20 74 65 78 74 20 |y to par|se text |
|00005670| 61 74 20 70 6f 69 6e 74 | 20 61 73 20 61 6e 20 69 |at point| as an i|
|00005680| 6e 73 74 61 6e 63 65 20 | 6f 66 20 54 50 4c 2d 4e |nstance |of TPL-N|
|00005690| 41 4d 45 2e 0a 58 20 20 | 20 52 65 74 75 72 6e 20 |AME..X | Return |
|000056a0| 61 20 70 61 72 73 65 20 | 74 72 65 65 20 6f 72 20 |a parse |tree or |
|000056b0| 6e 69 6c 2e 22 0a 58 09 | 09 09 09 09 3b 20 4c 6f |nil.".X.|....; Lo|
|000056c0| 63 61 6c 20 56 61 72 69 | 61 62 6c 65 73 0a 58 20 |cal Vari|ables.X |
|000056d0| 20 28 6c 65 74 20 28 29 | 0a 58 09 09 09 09 09 3b | (let ()|.X.....;|
|000056e0| 20 42 6f 64 79 0a 58 20 | 20 20 20 28 73 65 74 71 | Body.X | (setq|
|000056f0| 20 74 65 6d 70 6c 61 74 | 65 20 28 74 70 6c 2d 66 | templat|e (tpl-f|
|00005700| 69 6e 64 2d 74 65 6d 70 | 6c 61 74 65 20 74 70 6c |ind-temp|late tpl|
|00005710| 2d 6e 61 6d 65 29 29 0a | 58 20 20 20 20 28 73 65 |-name)).|X (se|
|00005720| 74 71 20 74 65 6d 70 6c | 61 74 65 2d 74 79 70 65 |tq templ|ate-type|
|00005730| 20 28 74 70 6c 2d 74 6f | 6b 65 6e 2d 74 79 70 65 | (tpl-to|ken-type|
|00005740| 20 74 65 6d 70 6c 61 74 | 65 29 29 0a 58 20 20 20 | templat|e)).X |
|00005750| 20 28 63 6f 6e 64 0a 58 | 20 20 20 20 20 20 28 28 | (cond.X| ((|
|00005760| 65 71 75 61 6c 20 74 65 | 6d 70 6c 61 74 65 2d 74 |equal te|mplate-t|
|00005770| 79 70 65 20 74 70 6c 2d | 66 75 6e 63 74 69 6f 6e |ype tpl-|function|
|00005780| 2d 74 79 70 65 29 0a 58 | 09 28 73 65 74 71 20 72 |-type).X|.(setq r|
|00005790| 65 73 75 6c 74 20 28 74 | 70 6c 2d 70 61 72 73 65 |esult (t|pl-parse|
|000057a0| 2d 66 75 6e 63 74 69 6f | 6e 20 74 65 6d 70 6c 61 |-functio|n templa|
|000057b0| 74 65 29 29 0a 58 20 20 | 20 20 20 20 29 20 3b 20 |te)).X | ) ; |
|000057c0| 28 65 71 75 61 6c 20 74 | 65 6d 70 6c 61 74 65 2d |(equal t|emplate-|
|000057d0| 74 79 70 65 20 74 70 6c | 2d 66 75 6e 63 74 69 6f |type tpl|-functio|
|000057e0| 6e 2d 74 79 70 65 29 0a | 58 20 20 20 20 20 20 28 |n-type).|X (|
|000057f0| 28 65 71 75 61 6c 20 74 | 65 6d 70 6c 61 74 65 2d |(equal t|emplate-|
|00005800| 74 79 70 65 20 74 70 6c | 2d 6c 65 78 69 63 61 6c |type tpl|-lexical|
|00005810| 2d 74 79 70 65 29 0a 58 | 09 28 73 65 74 71 20 72 |-type).X|.(setq r|
|00005820| 65 73 75 6c 74 20 28 74 | 70 6c 2d 70 61 72 73 65 |esult (t|pl-parse|
|00005830| 2d 6c 65 78 69 63 61 6c | 20 74 65 6d 70 6c 61 74 |-lexical| templat|
|00005840| 65 29 29 0a 58 20 20 20 | 20 20 20 29 20 3b 20 28 |e)).X | ) ; (|
|00005850| 65 71 75 61 6c 20 74 65 | 6d 70 6c 61 74 65 2d 74 |equal te|mplate-t|
|00005860| 79 70 65 20 74 70 6c 2d | 6c 65 78 69 63 61 6c 2d |ype tpl-|lexical-|
|00005870| 74 79 70 65 29 0a 58 20 | 20 20 20 20 20 28 28 65 |type).X | ((e|
|00005880| 71 75 61 6c 20 74 65 6d | 70 6c 61 74 65 2d 74 79 |qual tem|plate-ty|
|00005890| 70 65 20 74 70 6c 2d 72 | 65 70 65 74 69 74 69 6f |pe tpl-r|epetitio|
|000058a0| 6e 2d 74 79 70 65 29 0a | 58 09 28 73 65 74 71 20 |n-type).|X.(setq |
|000058b0| 72 65 73 75 6c 74 20 28 | 74 70 6c 2d 70 61 72 73 |result (|tpl-pars|
|000058c0| 65 2d 72 65 70 65 74 69 | 74 69 6f 6e 20 74 65 6d |e-repeti|tion tem|
|000058d0| 70 6c 61 74 65 29 29 0a | 58 20 20 20 20 20 20 29 |plate)).|X )|
|000058e0| 20 3b 20 28 65 71 75 61 | 6c 20 74 65 6d 70 6c 61 | ; (equa|l templa|
|000058f0| 74 65 2d 74 79 70 65 20 | 74 70 6c 2d 72 65 70 65 |te-type |tpl-repe|
|00005900| 74 69 74 69 6f 6e 2d 74 | 79 70 65 29 0a 58 20 20 |tition-t|ype).X |
|00005910| 20 20 20 20 28 28 65 71 | 75 61 6c 20 74 65 6d 70 | ((eq|ual temp|
|00005920| 6c 61 74 65 2d 74 79 70 | 65 20 74 70 6c 2d 73 65 |late-typ|e tpl-se|
|00005930| 6c 65 63 74 69 6f 6e 2d | 74 79 70 65 29 0a 58 09 |lection-|type).X.|
|00005940| 28 73 65 74 71 20 72 65 | 73 75 6c 74 20 28 74 70 |(setq re|sult (tp|
|00005950| 6c 2d 70 61 72 73 65 2d | 73 65 6c 65 63 74 69 6f |l-parse-|selectio|
|00005960| 6e 20 74 65 6d 70 6c 61 | 74 65 29 29 0a 58 20 20 |n templa|te)).X |
|00005970| 20 20 20 20 29 20 3b 20 | 28 65 71 75 61 6c 20 74 | ) ; |(equal t|
|00005980| 65 6d 70 6c 61 74 65 2d | 74 79 70 65 20 74 70 6c |emplate-|type tpl|
|00005990| 2d 73 65 6c 65 63 74 69 | 6f 6e 2d 74 79 70 65 29 |-selecti|on-type)|
|000059a0| 0a 58 20 20 20 20 20 20 | 28 28 65 71 75 61 6c 20 |.X |((equal |
|000059b0| 74 65 6d 70 6c 61 74 65 | 2d 74 79 70 65 20 74 70 |template|-type tp|
|000059c0| 6c 2d 73 65 71 75 65 6e | 63 65 2d 74 79 70 65 29 |l-sequen|ce-type)|
|000059d0| 0a 58 09 28 73 65 74 71 | 20 72 65 73 75 6c 74 20 |.X.(setq| result |
|000059e0| 28 74 70 6c 2d 70 61 72 | 73 65 2d 73 65 71 75 65 |(tpl-par|se-seque|
|000059f0| 6e 63 65 20 74 65 6d 70 | 6c 61 74 65 29 29 0a 58 |nce temp|late)).X|
|00005a00| 20 20 20 20 20 20 29 20 | 3b 20 28 65 71 75 61 6c | ) |; (equal|
|00005a10| 20 74 65 6d 70 6c 61 74 | 65 2d 74 79 70 65 20 74 | templat|e-type t|
|00005a20| 70 6c 2d 73 65 71 75 65 | 6e 63 65 2d 74 79 70 65 |pl-seque|nce-type|
|00005a30| 29 0a 58 20 20 20 20 20 | 20 28 28 65 71 75 61 6c |).X | ((equal|
|00005a40| 20 74 65 6d 70 6c 61 74 | 65 2d 74 79 70 65 20 74 | templat|e-type t|
|00005a50| 70 6c 2d 73 74 72 69 6e | 67 2d 74 79 70 65 29 0a |pl-strin|g-type).|
|00005a60| 58 09 28 73 65 74 71 20 | 72 65 73 75 6c 74 20 28 |X.(setq |result (|
|00005a70| 74 70 6c 2d 70 61 72 73 | 65 2d 73 74 72 69 6e 67 |tpl-pars|e-string|
|00005a80| 20 74 65 6d 70 6c 61 74 | 65 29 29 0a 58 20 20 20 | templat|e)).X |
|00005a90| 20 20 20 29 20 3b 20 28 | 65 71 75 61 6c 20 74 65 | ) ; (|equal te|
|00005aa0| 6d 70 6c 61 74 65 2d 74 | 79 70 65 20 74 70 6c 2d |mplate-t|ype tpl-|
|00005ab0| 73 74 72 69 6e 67 2d 74 | 79 70 65 29 0a 58 20 20 |string-t|ype).X |
|00005ac0| 20 20 29 20 3b 20 63 6f | 6e 64 0a 58 20 20 20 20 | ) ; co|nd.X |
|00005ad0| 72 65 73 75 6c 74 09 09 | 09 09 3b 20 72 65 74 75 |result..|..; retu|
|00005ae0| 72 6e 0a 58 20 20 29 20 | 3b 20 6c 65 74 0a 58 29 |rn.X ) |; let.X)|
|00005af0| 20 3b 20 64 65 66 75 6e | 20 74 70 6c 2d 70 61 72 | ; defun| tpl-par|
|00005b00| 73 65 2d 69 6e 73 74 61 | 6e 63 65 0a 58 0a 58 3b |se-insta|nce.X.X;|
|00005b10| 3b 3b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |;;++++++|++++++++|
|00005b20| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005b30| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005b40| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005b50| 2b 2b 2b 0a 58 0a 58 28 | 64 65 66 75 6e 20 74 70 |+++.X.X(|defun tp|
|00005b60| 6c 2d 70 61 72 73 65 2d | 6c 65 78 69 63 61 6c 20 |l-parse-|lexical |
|00005b70| 28 74 65 6d 70 6c 61 74 | 65 29 0a 58 20 20 22 54 |(templat|e).X "T|
|00005b80| 72 79 20 74 6f 20 70 61 | 72 73 65 20 74 65 78 74 |ry to pa|rse text|
|00005b90| 20 61 74 20 70 6f 69 6e | 74 20 61 73 20 61 6e 20 | at poin|t as an |
|00005ba0| 69 6e 73 74 61 6e 63 65 | 20 6f 66 20 6c 65 78 69 |instance| of lexi|
|00005bb0| 63 61 6c 2d 74 79 70 65 | 20 54 45 4d 50 4c 41 54 |cal-type| TEMPLAT|
|00005bc0| 45 2e 0a 58 20 20 20 52 | 65 74 75 72 6e 20 61 20 |E..X R|eturn a |
|00005bd0| 70 61 72 73 65 20 74 72 | 65 65 20 6f 72 20 6e 69 |parse tr|ee or ni|
|00005be0| 6c 2e 22 0a 58 09 09 09 | 09 09 3b 20 4c 6f 63 61 |l.".X...|..; Loca|
|00005bf0| 6c 20 56 61 72 69 61 62 | 6c 65 73 0a 58 20 20 28 |l Variab|les.X (|
|00005c00| 6c 65 74 20 28 29 0a 58 | 09 09 09 09 09 3b 20 42 |let ().X|.....; B|
|00005c10| 6f 64 79 0a 58 20 20 20 | 20 28 65 72 72 6f 72 20 |ody.X | (error |
|00005c20| 22 74 70 6c 2d 70 61 72 | 73 65 2d 6c 65 78 69 63 |"tpl-par|se-lexic|
|00005c30| 61 6c 3a 20 43 61 6e 6e | 6f 74 20 70 61 72 73 65 |al: Cann|ot parse|
|00005c40| 20 6c 65 78 69 63 61 6c | 2d 74 79 70 65 20 74 65 | lexical|-type te|
|00005c50| 6d 70 6c 61 74 65 73 2e | 22 29 0a 58 20 20 29 20 |mplates.|").X ) |
|00005c60| 3b 20 6c 65 74 0a 58 29 | 20 3b 20 64 65 66 75 6e |; let.X)| ; defun|
|00005c70| 20 74 70 6c 2d 70 61 72 | 73 65 2d 6c 65 78 69 63 | tpl-par|se-lexic|
|00005c80| 61 6c 0a 58 0a 58 3b 3b | 3b 2b 2b 2b 2b 2b 2b 2b |al.X.X;;|;+++++++|
|00005c90| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005ca0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005cb0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 2b 2b 2b 2b 2b 2b |++++++++|++++++++|
|00005cc0| 2b 2b 2b 2b 2b 2b 2b 2b | 2b 2b 0a 58 0a 58 28 64 |++++++++|++.X.X(d|
|00005cd0| 65 66 75 6e 20 74 70 6c | 2d 70 61 72 73 65 2d 70 |efun tpl|-parse-p|
|00005ce0| 61 74 74 65 72 6e 20 28 | 70 61 74 74 65 72 6e 20 |attern (|pattern |
|00005cf0| 74 70 6c 2d 6e 61 6d 65 | 20 73 74 61 72 74 2d 63 |tpl-name| start-c|
|00005d00| 6f 6c 20 73 63 61 6e 6e | 65 72 2d 70 61 74 74 65 |ol scann|er-patte|
|00005d10| 72 6e 73 29 0a 58 20 20 | 22 54 72 79 20 74 6f 20 |rns).X |"Try to |
|00005d20| 70 61 72 73 65 20 74 65 | 78 74 20 61 74 20 70 6f |parse te|xt at po|
|00005d30| 69 6e 74 20 61 73 20 61 | 6e 20 69 6e 73 74 61 6e |int as a|n instan|
|00005d40| 63 65 20 6f 66 20 50 41 | 54 54 45 52 4e 20 77 69 |ce of PA|TTERN wi|
|00005d50| 74 68 69 6e 0a 58 20 20 | 20 74 65 6d 70 6c 61 74 |thin.X | templat|
|00005d60| 65 20 54 50 4c 2d 4e 41 | 4d 45 2e 20 20 53 54 41 |e TPL-NA|ME. STA|
|00005d70| 52 54 2d 43 4f 4c 20 73 | 70 65 63 69 66 69 65 73 |RT-COL s|pecifies|
|00005d80| 20 74 68 65 20 73 74 61 | 72 74 69 6e 67 20 63 6f | the sta|rting co|
|00005d90| 6c 75 6d 6e 20 6f 66 0a | 58 20 20 20 74 68 65 20 |lumn of.|X the |
|00005da0| 74 65 6d 70 6c 61 74 65 | 2e 20 20 53 43 41 4e 4e |template|. SCANN|
|00005db0| 45 52 2d 50 41 54 54 45 | 52 4e 53 20 73 70 65 63 |ER-PATTE|RNS spec|
|00005dc0| 69 66 69 65 73 20 77 68 | 69 63 68 20 6c 65 78 69 |ifies wh|ich lexi|
|00005dd0| 63 61 6c 20 70 61 74 74 | 65 72 6e 73 0a 58 20 20 |cal patt|erns.X |
|00005de0| 20 74 6f 20 75 73 65 20 | 77 68 65 6e 20 73 63 61 | to use |when sca|
|00005df0| 6e 6e 69 6e 67 2e 20 20 | 52 65 74 75 72 6e 20 61 |nning. |Return a|
|00005e00| 20 74 6f 6b 65 6e 20 6f | 72 20 6e 69 6c 2e 22 0a | token o|r nil.".|
|00005e10| 58 09 09 09 09 09 3b 20 | 4c 6f 63 61 6c 20 56 61 |X.....; |Local Va|
|00005e20| 72 69 61 62 6c 65 73 0a | 58 20 20 28 6c 65 74 20 |riables.|X (let |
|00005e30| 28 74 79 70 65 20 72 65 | 73 75 6c 74 20 73 74 61 |(type re|sult sta|
|00005e40| 72 74 20 73 74 6f 70 20 | 74 68 69 73 2d 63 6f 6c |rt stop |this-col|
|00005e50| 20 69 6e 64 65 6e 74 2d | 6c 65 76 65 6c 29 0a 58 | indent-|level).X|
|00005e60| 09 09 09 09 09 3b 20 42 | 6f 64 79 0a 58 20 20 20 |.....; B|ody.X |
|00005e70| 20 28 73 65 74 71 20 74 | 79 70 65 20 28 74 70 6c | (setq t|ype (tpl|
|00005e80| 2d 74 6f 6b 65 6e 2d 6e | 61 6d 65 20 70 61 74 74 |-token-n|ame patt|
|00005e90| 65 72 6e 29 29 0a 58 20 | 20 20 20 28 63 6f 6e 64 |ern)).X | (cond|
|00005ea0| 0a 58 20 20 20 20 20 20 | 28 28 65 71 75 61 6c 20 |.X |((equal |
|00005eb0| 74 79 70 65 20 74 70 6c | 2d 69 6e 64 65 6e 74 61 |type tpl|-indenta|
|00005ec0| 74 69 6f 6e 2d 74 79 70 | 65 29 0a 58 09 28 70 72 |tion-typ|e).X.(pr|
|00005ed0| 6f 67 6e 0a 58 09 20 20 | 28 73 65 74 71 20 72 65 |ogn.X. |(setq re|
|00005ee0| 73 75 6c 74 20 70 61 74 | 74 65 72 6e 29 0a 58 09 |sult pat|tern).X.|
|00005ef0| 20 20 29 20 3b 20 70 72 | 6f 67 6e 0a 58 20 20 20 | ) ; pr|ogn.X |
|00005f00| 20 20 20 29 20 3b 20 28 | 65 71 75 61 6c 20 74 79 | ) ; (|equal ty|
|00005f10| 70 65 20 74 70 6c 2d 69 | 6e 64 65 6e 74 61 74 69 |pe tpl-i|ndentati|
|00005f20| 6f 6e 2d 74 79 70 65 29 | 0a 58 20 20 20 20 20 20 |on-type)|.X |
|00005f30| 28 28 65 71 75 61 6c 20 | 74 79 70 65 20 74 70 6c |((equal |type tpl|
|00005f40| 2d 6e 65 77 6c 69 6e 65 | 2d 74 79 70 65 29 0a 58 |-newline|-type).X|
|00005f50| 09 28 70 72 6f 67 6e 0a | 58 09 20 20 28 73 65 74 |.(progn.|X. (set|
|00005f60| 71 20 72 65 73 75 6c 74 | 20 70 61 74 74 65 72 6e |q result| pattern|
|00005f70| 29 0a 58 09 20 20 29 20 | 3b 20 70 72 6f 67 6e 0a |).X. ) |; progn.|
|00005f80| 58 20 20 20 20 20 20 29 | 20 3b 20 28 65 71 75 61 |X )| ; (equa|
|00005f90| 6c 20 74 79 70 65 20 74 | 70 6c 2d 6e 65 77 6c 69 |l type t|pl-newli|
|00005fa0| 6e 65 2d 74 79 70 65 29 | 0a 58 20 20 20 20 20 20 |ne-type)|.X |
|00005fb0| 28 28 65 71 75 61 6c 20 | 74 79 70 65 20 74 70 6c |((equal |type tpl|
|00005fc0| 2d 6f 74 68 65 72 2d 74 | 79 70 65 29 0a 58 09 28 |-other-t|ype).X.(|
|00005fd0| 70 72 6f 67 6e 0a 58 09 | 20 20 28 74 70 6c 2d 73 |progn.X.| (tpl-s|
|00005fe0| 6b 69 70 2d 6f 76 65 72 | 2d 77 68 69 74 65 73 70 |kip-over|-whitesp|
|00005ff0| 61 63 65 29 0a 58 09 20 | 20 28 69 66 20 28 6c 6f |ace).X. | (if (lo|
|00006000| 6f 6b 69 6e 67 2d 61 74 | 20 28 74 70 6c 2d 74 6f |oking-at| (tpl-to|
|00006010| 6b 65 6e 2d 76 61 6c 75 | 65 20 70 61 74 74 65 72 |ken-valu|e patter|
|00006020| 6e 29 29 0a 58 09 20 20 | 20 20 20 20 28 73 65 74 |n)).X. | (set|
|00006030| 71 20 72 65 73 75 6c 74 | 20 28 74 70 6c 2d 73 63 |q result| (tpl-sc|
|00006040| 61 6e 2d 74 6f 6b 65 6e | 20 73 63 61 6e 6e 65 72 |an-token| scanner|
|00006050| 2d 70 61 74 74 65 72 6e | 73 29 29 0a 58 09 20 20 |-pattern|s)).X. |
|00006060| 20 20 28 73 65 74 71 20 | 72 65 73 75 6c 74 20 6e | (setq |result n|
|00006070| 69 6c 29 0a 58 09 20 20 | 20 20 29 20 3b 20 69 66 |il).X. | ) ; if|
|00006080| 0a 58 09 20 20 29 20 3b | 20 70 72 6f 67 6e 0a 58 |.X. ) ;| progn.X|
|00006090| 20 20 20 20 20 20 29 20 | 3b 20 28 65 71 75 61 6c | ) |; (equal|
|000060a0| 20 74 79 70 65 20 74 70 | 6c 2d 6f 74 68 65 72 2d | type tp|l-other-|
|000060b0| 74 79 70 65 29 0a 58 20 | 20 20 20 20 20 28 28 65 |type).X | ((e|
|000060c0| 71 75 61 6c 20 74 79 70 | 65 20 74 70 6c 2d 70 6c |qual typ|e tpl-pl|
|000060d0| 61 63 65 68 6f 6c 64 65 | 72 2d 74 79 70 65 29 0a |aceholde|r-type).|
|000060e0| 58 09 28 70 72 6f 67 6e | 0a 58 09 20 20 28 74 70 |X.(progn|.X. (tp|
|000060f0| 6c 2d 73 6b 69 70 2d 6f | 76 65 72 2d 77 68 69 74 |l-skip-o|ver-whit|
|00006100| 65 73 70 61 63 65 29 0a | 58 09 20 20 28 73 65 74 |espace).|X. (set|
|00006110| 71 20 73 74 61 72 74 20 | 28 70 6f 69 6e 74 29 29 |q start |(point))|
|00006120| 0a 58 09 20 20 28 73 65 | 74 71 20 73 74 6f 70 20 |.X. (se|tq stop |
|00006130| 28 74 70 6c 2d 67 65 74 | 2d 70 6c 61 63 65 68 6f |(tpl-get|-placeho|
|00006140| 6c 64 65 72 2d 65 6e 64 | 20 28 74 70 6c 2d 74 6f |lder-end| (tpl-to|
|00006150| 6b 65 6e 2d 76 61 6c 75 | 65 20 70 61 74 74 65 72 |ken-valu|e patter|
|00006160| 6e 29 0a 58 09 09 09 09 | 09 20 20 20 20 20 20 74 |n).X....|. t|
|00006170| 70 6c 2d 6e 61 6d 65 29 | 29 0a 58 09 20 20 28 73 |pl-name)|).X. (s|
|00006180| 65 74 71 20 72 65 73 75 | 6c 74 20 6e 69 6c 29 0a |etq resu|lt nil).|
|00006190| 58 09 20 20 28 67 6f 74 | 6f 2d 63 68 61 72 20 73 |X. (got|o-char s|
|000061a0| 74 61 72 74 29 0a 58 09 | 20 20 28 77 68 69 6c 65 |tart).X.| (while|
|000061b0| 20 28 3c 20 28 70 6f 69 | 6e 74 29 20 73 74 6f 70 | (< (poi|nt) stop|
|000061c0| 29 0a 58 09 20 20 20 20 | 28 69 66 20 28 65 6f 6c |).X. |(if (eol|
|000061d0| 70 29 0a 58 09 09 09 09 | 09 3b 20 54 68 69 73 20 |p).X....|.; This |
|000061e0| 63 6f 64 65 20 64 75 70 | 6c 69 63 61 74 65 73 20 |code dup|licates |
|000061f0| 73 6f 6d 65 20 6f 66 0a | 58 09 09 09 09 09 3b 20 |some of.|X.....; |
|00006200| 20 20 22 74 70 6c 2d 73 | 63 61 6e 2d 6c 69 6e 65 | "tpl-s|can-line|
|00006210| 22 0a 58 09 09 28 70 72 | 6f 67 6e 0a 58 09 09 20 |".X..(pr|ogn.X.. |
|00006220| 20 28 73 65 74 71 20 72 | 65 73 75 6c 74 0a 58 09 | (setq r|esult.X.|
|00006230| 09 09 28 61 70 70 65 6e | 64 20 72 65 73 75 6c 74 |..(appen|d result|
|00006240| 20 28 6c 69 73 74 20 74 | 70 6c 2d 6e 65 77 6c 69 | (list t|pl-newli|
|00006250| 6e 65 2d 74 6f 6b 65 6e | 29 29 29 0a 58 09 09 20 |ne-token|))).X.. |
|00006260| 20 28 66 6f 72 77 61 72 | 64 2d 6c 69 6e 65 20 31 | (forwar|d-line 1|
|00006270| 29 0a 58 09 09 20 20 28 | 62 61 63 6b 2d 74 6f 2d |).X.. (|back-to-|
|00006280| 69 6e 64 65 6e 74 61 74 | 69 6f 6e 29 0a 58 09 09 |indentat|ion).X..|
|00006290| 20 20 28 73 65 74 71 20 | 74 68 69 73 2d 63 6f 6c | (setq |this-col|
|000062a0| 20 28 63 75 72 72 65 6e | 74 2d 63 6f 6c 75 6d 6e | (curren|t-column|
|000062b0| 29 29 0a 58 09 09 20 20 | 28 63 6f 6e 64 0a 58 09 |)).X.. |(cond.X.|
|000062c0| 09 20 20 20 28 28 3e 3d | 20 74 68 69 73 2d 63 6f |. ((>=| this-co|
|000062d0| 6c 20 63 6f 6d 6d 65 6e | 74 2d 63 6f 6c 75 6d 6e |l commen|t-column|
|000062e0| 29 0a 58 09 09 20 20 20 | 20 28 70 72 6f 67 6e 0a |).X.. | (progn.|
|000062f0| 58 09 09 20 20 20 20 20 | 20 28 73 65 74 71 20 69 |X.. | (setq i|
|00006300| 6e 64 65 6e 74 2d 6c 65 | 76 65 6c 20 74 70 6c 2d |ndent-le|vel tpl-|
|00006310| 63 6f 6d 6d 65 6e 74 2d | 6c 65 76 65 6c 29 0a 58 |comment-|level).X|
|00006320| 09 09 20 20 20 20 20 20 | 29 20 3b 20 70 72 6f 67 |.. |) ; prog|
|00006330| 6e 0a 58 09 09 20 20 20 | 20 29 20 3b 20 63 6f 6d |n.X.. | ) ; com|
|00006340| 6d 65 6e 74 0a 58 09 09 | 20 20 20 28 28 3c 3d 20 |ment.X..| ((<= |
|00006350| 74 68 69 73 2d 63 6f 6c | 20 73 74 61 72 74 2d 63 |this-col| start-c|
|00006360| 6f 6c 29 0a 58 09 09 20 | 20 20 20 28 70 72 6f 67 |ol).X.. | (prog|
|00006370| 6e 0a 58 09 09 20 20 20 | 20 20 20 28 73 65 74 71 |n.X.. | (setq|
|00006380| 20 69 6e 64 65 6e 74 2d | 6c 65 76 65 6c 20 30 29 | indent-|level 0)|
|00006390| 0a 58 09 09 20 20 20 20 | 20 20 29 20 3b 20 70 72 |.X.. | ) ; pr|
|000063a0| 6f 67 6e 0a 58 09 09 20 | 20 20 20 29 20 3b 20 74 |ogn.X.. | ) ; t|
|000063b0| 6f 6f 20 73 6d 61 6c 6c | 0a 58 09 09 20 20 20 28 |oo small|.X.. (|
|000063c0| 74 0a 58 09 09 20 20 20 | 20 28 70 72 6f 67 6e 0a |t.X.. | (progn.|
|000063d0| 58 09 09 20 20 20 20 20 | 20 28 73 65 74 71 20 69 |X.. | (setq i|
|000063e0| 6e 64 65 6e 74 2d 6c 65 | 76 65 6c 20 28 2d 20 74 |ndent-le|vel (- t|
|000063f0| 68 69 73 2d 63 6f 6c 20 | 73 74 61 72 74 2d 63 6f |his-col |start-co|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.