Line | Source | Count |
1 | | - |
2 | | - |
3 | | - |
4 | | - |
5 | | - |
6 | | - |
7 | | - |
8 | | - |
9 | | - |
10 | | - |
11 | | - |
12 | | - |
13 | | - |
14 | | - |
15 | | - |
16 | | - |
17 | | - |
18 | | - |
19 | | - |
20 | | - |
21 | | - |
22 | #define READLINE_LIBRARY | - |
23 | | - |
24 | #if defined (HAVE_CONFIG_H) | - |
25 | # include <config.h> | - |
26 | #endif | - |
27 | | - |
28 | #include <stdio.h> | - |
29 | #if defined (HAVE_STDLIB_H) | - |
30 | # include <stdlib.h> | - |
31 | #else | - |
32 | # include "ansi_stdlib.h" | - |
33 | #endif /* HAVE_STDLIB_H */ | - |
34 | | - |
35 | #if defined (HAVE_UNISTD_H) | - |
36 | # ifdef _MINIX | - |
37 | # include <sys/types.h> | - |
38 | # endif | - |
39 | # include <unistd.h> | - |
40 | #endif | - |
41 | | - |
42 | #if defined (HAVE_FNMATCH) | - |
43 | # include <fnmatch.h> | - |
44 | #endif | - |
45 | | - |
46 | #include "history.h" | - |
47 | #include "histlib.h" | - |
48 | #include "xmalloc.h" | - |
49 | | - |
50 | | - |
51 | | - |
52 | char *history_search_delimiter_chars = (char *)NULL; | - |
53 | | - |
54 | static int history_search_internal PARAMS((const char *, int, int)); | - |
55 | | - |
56 | | - |
57 | | - |
58 | | - |
59 | | - |
60 | | - |
61 | | - |
62 | | - |
63 | | - |
64 | | - |
65 | | - |
66 | static int | - |
67 | history_search_internal (const char *string, int direction, int flags) | - |
68 | { | - |
69 | register int i, reverse; | - |
70 | register char *line; | - |
71 | register int line_index; | - |
72 | int string_len, anchored, patsearch; | - |
73 | HIST_ENTRY **the_history; | - |
74 | | - |
75 | i = history_offset; | - |
76 | reverse = (direction < 0); | - |
77 | anchored = (flags & ANCHORED_SEARCH); | - |
78 | #if defined (HAVE_FNMATCH) | - |
79 | patsearch = (flags & PATTERN_SEARCH); | - |
80 | #else | - |
81 | patsearch = 0; | - |
82 | #endif | - |
83 | | - |
84 | | - |
85 | if (string == 0 || *string == '\0')TRUE | never evaluated | FALSE | evaluated 12 times by 1 test |
TRUE | never evaluated | FALSE | evaluated 12 times by 1 test |
| 0-12 |
86 | return (-1); never executed: return (-1); | 0 |
87 | | - |
88 | if (!history_length || ((i >= history_length) && !reverse))TRUE | never evaluated | FALSE | evaluated 12 times by 1 test |
TRUE | evaluated 12 times by 1 test | FALSE | never evaluated |
TRUE | never evaluated | FALSE | evaluated 12 times by 1 test |
| 0-12 |
89 | return (-1); never executed: return (-1); | 0 |
90 | | - |
91 | if (reverse && (i >= history_length))TRUE | evaluated 12 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 12 times by 1 test | FALSE | never evaluated |
| 0-12 |
92 | i = history_length - 1;executed 12 times by 1 test: i = history_length - 1; | 12 |
93 | | - |
94 | #define NEXT_LINE() do { if (reverse) i--; else i++; } while (0) | - |
95 | | - |
96 | the_history = history_list (); | - |
97 | string_len = strlen (string); | - |
98 | while (1) | - |
99 | { | - |
100 | | - |
101 | | - |
102 | | - |
103 | if ((reverse && i < 0) || (!reverse && i == history_length))TRUE | evaluated 39 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 1 time by 1 test | FALSE | evaluated 38 times by 1 test |
TRUE | never evaluated | FALSE | evaluated 38 times by 1 test |
TRUE | never evaluated | FALSE | never evaluated |
| 0-39 |
104 | return (-1);executed 1 time by 1 test: return (-1); | 1 |
105 | | - |
106 | line = the_history[i]->line; | - |
107 | line_index = strlen (line); | - |
108 | | - |
109 | | - |
110 | if (patsearch == 0 && (string_len > line_index))TRUE | evaluated 38 times by 1 test | FALSE | never evaluated |
TRUE | never evaluated | FALSE | evaluated 38 times by 1 test |
| 0-38 |
111 | { | - |
112 | NEXT_LINE (); never executed: i--; never executed: i++; TRUE | never evaluated | FALSE | never evaluated |
| 0 |
113 | continue; never executed: continue; | 0 |
114 | } | - |
115 | | - |
116 | | - |
117 | if (anchored == ANCHORED_SEARCH)TRUE | evaluated 24 times by 1 test | FALSE | evaluated 14 times by 1 test |
| 14-24 |
118 | { | - |
119 | #if defined (HAVE_FNMATCH) | - |
120 | if (patsearch)TRUE | never evaluated | FALSE | evaluated 24 times by 1 test |
| 0-24 |
121 | { | - |
122 | if (fnmatch (string, line, 0) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
123 | { | - |
124 | history_offset = i; | - |
125 | return (0); never executed: return (0); | 0 |
126 | } | - |
127 | } never executed: end of block | 0 |
128 | else | - |
129 | #endif | - |
130 | if (STREQN (string, line, string_len)) never executed: __result = (((const unsigned char *) (const char *) ( (string) ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( (line) ))[3] - __s2[3]); never executed: end of block never executed: end of block TRUE | evaluated 6 times by 1 test | FALSE | evaluated 18 times by 1 test |
TRUE | never evaluated | FALSE | evaluated 24 times by 1 test |
TRUE | evaluated 6 times by 1 test | FALSE | evaluated 18 times by 1 test |
TRUE | evaluated 6 times by 1 test | FALSE | never evaluated |
TRUE | never evaluated | FALSE | evaluated 6 times by 1 test |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0-24 |
131 | { | - |
132 | history_offset = i; | - |
133 | return (0);executed 6 times by 1 test: return (0); | 6 |
134 | } | - |
135 | | - |
136 | NEXT_LINE ();executed 18 times by 1 test: i--; never executed: i++; TRUE | evaluated 18 times by 1 test | FALSE | never evaluated |
| 0-18 |
137 | continue;executed 18 times by 1 test: continue; | 18 |
138 | } | - |
139 | | - |
140 | | - |
141 | if (reverse)TRUE | evaluated 14 times by 1 test | FALSE | never evaluated |
| 0-14 |
142 | { | - |
143 | line_index -= (patsearch == 0) ? string_len : 1;TRUE | evaluated 14 times by 1 test | FALSE | never evaluated |
| 0-14 |
144 | | - |
145 | while (line_index >= 0)TRUE | evaluated 176 times by 1 test | FALSE | evaluated 9 times by 1 test |
| 9-176 |
146 | { | - |
147 | #if defined (HAVE_FNMATCH) | - |
148 | if (patsearch)TRUE | never evaluated | FALSE | evaluated 176 times by 1 test |
| 0-176 |
149 | { | - |
150 | if (fnmatch (string, line + line_index, 0) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
151 | { | - |
152 | history_offset = i; | - |
153 | return (line_index); never executed: return (line_index); | 0 |
154 | } | - |
155 | } never executed: end of block | 0 |
156 | else | - |
157 | #endif | - |
158 | if (STREQN (string, line + line_index, string_len)) never executed: __result = (((const unsigned char *) (const char *) ( (string) ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( (line + line_index) ))[3] - __s2[3]); never executed: end of block never executed: end of block TRUE | evaluated 5 times by 1 test | FALSE | evaluated 171 times by 1 test |
TRUE | never evaluated | FALSE | evaluated 176 times by 1 test |
TRUE | evaluated 8 times by 1 test | FALSE | evaluated 168 times by 1 test |
TRUE | evaluated 5 times by 1 test | FALSE | evaluated 3 times by 1 test |
TRUE | never evaluated | FALSE | evaluated 8 times by 1 test |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0-176 |
159 | { | - |
160 | history_offset = i; | - |
161 | return (line_index);executed 5 times by 1 test: return (line_index); | 5 |
162 | } | - |
163 | line_index--; | - |
164 | }executed 171 times by 1 test: end of block | 171 |
165 | }executed 9 times by 1 test: end of block | 9 |
166 | else | - |
167 | { | - |
168 | register int limit; | - |
169 | | - |
170 | limit = line_index - string_len + 1; | - |
171 | line_index = 0; | - |
172 | | - |
173 | while (line_index < limit)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
174 | { | - |
175 | #if defined (HAVE_FNMATCH) | - |
176 | if (patsearch)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
177 | { | - |
178 | if (fnmatch (string, line + line_index, 0) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
179 | { | - |
180 | history_offset = i; | - |
181 | return (line_index); never executed: return (line_index); | 0 |
182 | } | - |
183 | } never executed: end of block | 0 |
184 | else | - |
185 | #endif | - |
186 | if (STREQN (string, line + line_index, string_len)) never executed: __result = (((const unsigned char *) (const char *) ( (string) ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( (line + line_index) ))[3] - __s2[3]); never executed: end of block never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
187 | { | - |
188 | history_offset = i; | - |
189 | return (line_index); never executed: return (line_index); | 0 |
190 | } | - |
191 | line_index++; | - |
192 | } never executed: end of block | 0 |
193 | } never executed: end of block | 0 |
194 | NEXT_LINE ();executed 9 times by 1 test: i--; never executed: i++; TRUE | evaluated 9 times by 1 test | FALSE | never evaluated |
| 0-9 |
195 | }executed 9 times by 1 test: end of block | 9 |
196 | } never executed: end of block | 0 |
197 | | - |
198 | int | - |
199 | _hs_history_patsearch (const char *string, int direction, int flags) | - |
200 | { | - |
201 | char *pat; | - |
202 | size_t len; | - |
203 | int ret, unescaped_backslash; | - |
204 | | - |
205 | #if defined (HAVE_FNMATCH) | - |
206 | | - |
207 | | - |
208 | len = strlen (string); | - |
209 | ret = len - 1; | - |
210 | | - |
211 | | - |
212 | if (unescaped_backslash = (string[ret] == '\\'))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
213 | { | - |
214 | while (ret > 0 && string[--ret] == '\\')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
215 | unescaped_backslash = 1 - unescaped_backslash; never executed: unescaped_backslash = 1 - unescaped_backslash; | 0 |
216 | } never executed: end of block | 0 |
217 | if (unescaped_backslash)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
218 | return -1; never executed: return -1; | 0 |
219 | pat = (char *)xmalloc (len + 2); | - |
220 | | - |
221 | | - |
222 | | - |
223 | | - |
224 | strcpy (pat, string); | - |
225 | if (pat[len - 1] != '*')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
226 | { | - |
227 | pat[len] = '*'; | - |
228 | pat[len+1] = '\0'; | - |
229 | } never executed: end of block | 0 |
230 | #else | - |
231 | pat = string; | - |
232 | #endif | - |
233 | | - |
234 | ret = history_search_internal (pat, direction, flags|PATTERN_SEARCH); | - |
235 | | - |
236 | if (pat != string)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
237 | free (pat); never executed: free (pat); | 0 |
238 | return ret; never executed: return ret; | 0 |
239 | } | - |
240 | | - |
241 | | - |
242 | int | - |
243 | history_search (const char *string, int direction) | - |
244 | { | - |
245 | return (history_search_internal (string, direction, NON_ANCHORED_SEARCH));executed 5 times by 1 test: return (history_search_internal (string, direction, 0)); | 5 |
246 | } | - |
247 | | - |
248 | | - |
249 | int | - |
250 | history_search_prefix (const char *string, int direction) | - |
251 | { | - |
252 | return (history_search_internal (string, direction, ANCHORED_SEARCH));executed 7 times by 1 test: return (history_search_internal (string, direction, 0x01)); | 7 |
253 | } | - |
254 | | - |
255 | | - |
256 | | - |
257 | | - |
258 | int | - |
259 | history_search_pos (const char *string, int dir, int pos) | - |
260 | { | - |
261 | int ret, old; | - |
262 | | - |
263 | old = where_history (); | - |
264 | history_set_pos (pos); | - |
265 | if (history_search (string, dir) == -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
266 | { | - |
267 | history_set_pos (old); | - |
268 | return (-1); never executed: return (-1); | 0 |
269 | } | - |
270 | ret = where_history (); | - |
271 | history_set_pos (old); | - |
272 | return ret; never executed: return ret; | 0 |
273 | } | - |
| | |