annotate miscellany/less-177/brac.c @ 0:bce86c4163a3

Initial revision
author kono
date Mon, 18 Apr 2005 23:46:02 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
1 /*
bce86c4163a3 Initial revision
kono
parents:
diff changeset
2 * Routines to perform bracket matching functions.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
3 */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
4
bce86c4163a3 Initial revision
kono
parents:
diff changeset
5 #include "less.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
6 #include "position.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
7
bce86c4163a3 Initial revision
kono
parents:
diff changeset
8 /*
bce86c4163a3 Initial revision
kono
parents:
diff changeset
9 * Try to match the n-th open bracket
bce86c4163a3 Initial revision
kono
parents:
diff changeset
10 * which appears in the top displayed line (forwdir),
bce86c4163a3 Initial revision
kono
parents:
diff changeset
11 * or the n-th close bracket
bce86c4163a3 Initial revision
kono
parents:
diff changeset
12 * which appears in the bottom displayed line (!forwdir).
bce86c4163a3 Initial revision
kono
parents:
diff changeset
13 * The characters which serve as "open bracket" and
bce86c4163a3 Initial revision
kono
parents:
diff changeset
14 * "close bracket" are given.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
15 */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
16 public void
bce86c4163a3 Initial revision
kono
parents:
diff changeset
17 match_brac(obrac, cbrac, forwdir, n)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
18 register int obrac;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
19 register int cbrac;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
20 int forwdir;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
21 int n;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
22 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
23 register int c;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
24 register int nest;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
25 POSITION pos;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
26 int (*chget)();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
27
bce86c4163a3 Initial revision
kono
parents:
diff changeset
28 extern int ch_forw_get(), ch_back_get();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
29
bce86c4163a3 Initial revision
kono
parents:
diff changeset
30 /*
bce86c4163a3 Initial revision
kono
parents:
diff changeset
31 * Seek to the line containing the open bracket.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
32 * This is either the top or bottom line on the screen,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
33 * depending on the type of bracket.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
34 */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
35 pos = position((forwdir) ? TOP : BOTTOM);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
36 if (pos == NULL_POSITION || ch_seek(pos))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
37 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
38 if (forwdir)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
39 error("Nothing in top line", NULL_PARG);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
40 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
41 error("Nothing in bottom line", NULL_PARG);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
42 return;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
43 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
44
bce86c4163a3 Initial revision
kono
parents:
diff changeset
45 /*
bce86c4163a3 Initial revision
kono
parents:
diff changeset
46 * Look thru the line to find the open bracket to match.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
47 */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
48 do
bce86c4163a3 Initial revision
kono
parents:
diff changeset
49 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
50 if ((c = ch_forw_get()) == '\n' || c == EOI)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
51 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
52 if (forwdir)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
53 error("No bracket in top line", NULL_PARG);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
54 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
55 error("No bracket in bottom line", NULL_PARG);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
56 return;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
57 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
58 } while (c != obrac || --n > 0);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
59
bce86c4163a3 Initial revision
kono
parents:
diff changeset
60 /*
bce86c4163a3 Initial revision
kono
parents:
diff changeset
61 * Position the file just "after" the open bracket
bce86c4163a3 Initial revision
kono
parents:
diff changeset
62 * (in the direction in which we will be searching).
bce86c4163a3 Initial revision
kono
parents:
diff changeset
63 * If searching forward, we are already after the bracket.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
64 * If searching backward, skip back over the open bracket.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
65 */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
66 if (!forwdir)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
67 (void) ch_back_get();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
68
bce86c4163a3 Initial revision
kono
parents:
diff changeset
69 /*
bce86c4163a3 Initial revision
kono
parents:
diff changeset
70 * Search the file for the matching bracket.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
71 */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
72 chget = (forwdir) ? ch_forw_get : ch_back_get;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
73 nest = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
74 while ((c = (*chget)()) != EOI)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
75 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
76 if (c == obrac)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
77 nest++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
78 else if (c == cbrac && --nest < 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
79 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
80 /*
bce86c4163a3 Initial revision
kono
parents:
diff changeset
81 * Found the matching bracket.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
82 * If searching backward, put it on the top line.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
83 * If searching forward, put it on the bottom line.
bce86c4163a3 Initial revision
kono
parents:
diff changeset
84 */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
85 jump_line_loc(ch_tell(), forwdir ? -1 : 1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
86 return;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
87 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
88 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
89 error("No matching bracket", NULL_PARG);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
90 }