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 (__TANDEM) | - |
25 | # include <floss.h> | - |
26 | #endif | - |
27 | | - |
28 | #if defined (HAVE_CONFIG_H) | - |
29 | # include <config.h> | - |
30 | #endif | - |
31 | | - |
32 | #include <stdio.h> | - |
33 | #include <sys/types.h> | - |
34 | #include <fcntl.h> | - |
35 | #if defined (HAVE_SYS_FILE_H) | - |
36 | # include <sys/file.h> | - |
37 | #endif /* HAVE_SYS_FILE_H */ | - |
38 | | - |
39 | #if defined (HAVE_UNISTD_H) | - |
40 | # include <unistd.h> | - |
41 | #endif /* HAVE_UNISTD_H */ | - |
42 | | - |
43 | #if defined (HAVE_STDLIB_H) | - |
44 | # include <stdlib.h> | - |
45 | #else | - |
46 | # include "ansi_stdlib.h" | - |
47 | #endif /* HAVE_STDLIB_H */ | - |
48 | | - |
49 | #include <errno.h> | - |
50 | | - |
51 | #if !defined (errno) | - |
52 | extern int errno; | - |
53 | #endif /* !errno */ | - |
54 | | - |
55 | #include "posixstat.h" | - |
56 | | - |
57 | | - |
58 | #include "rldefs.h" | - |
59 | | - |
60 | | - |
61 | #include "readline.h" | - |
62 | #include "history.h" | - |
63 | | - |
64 | #include "rlprivate.h" | - |
65 | #include "rlshell.h" | - |
66 | #include "xmalloc.h" | - |
67 | | - |
68 | #if !defined (strchr) && !defined (__STDC__) | - |
69 | extern char *strchr (), *strrchr (); | - |
70 | #endif /* !strchr && !__STDC__ */ | - |
71 | | - |
72 | | - |
73 | Keymap rl_binding_keymap; | - |
74 | | - |
75 | static int _rl_skip_to_delim PARAMS((char *, int, int)); | - |
76 | | - |
77 | #if defined (USE_VARARGS) && defined (PREFER_STDARG) | - |
78 | static void _rl_init_file_error (const char *, ...) __attribute__((__format__ (printf, 1, 2))); | - |
79 | #else | - |
80 | static void _rl_init_file_error (); | - |
81 | #endif | - |
82 | | - |
83 | static rl_command_func_t *_rl_function_of_keyseq_internal PARAMS((const char *, size_t, Keymap, int *)); | - |
84 | | - |
85 | static char *_rl_read_file PARAMS((char *, size_t *)); | - |
86 | static int _rl_read_init_file PARAMS((const char *, int)); | - |
87 | static int glean_key_from_name PARAMS((char *)); | - |
88 | | - |
89 | static int find_boolean_var PARAMS((const char *)); | - |
90 | static int find_string_var PARAMS((const char *)); | - |
91 | | - |
92 | static const char *boolean_varname PARAMS((int)); | - |
93 | static const char *string_varname PARAMS((int)); | - |
94 | | - |
95 | static char *_rl_get_string_variable_value PARAMS((const char *)); | - |
96 | static int substring_member_of_array PARAMS((const char *, const char * const *)); | - |
97 | | - |
98 | static int currently_reading_init_file; | - |
99 | | - |
100 | | - |
101 | static int _rl_prefer_visible_bell = 1; | - |
102 | | - |
103 | #define OP_EQ 1 | - |
104 | #define OP_NE 2 | - |
105 | #define OP_GT 3 | - |
106 | #define OP_GE 4 | - |
107 | #define OP_LT 5 | - |
108 | #define OP_LE 6 | - |
109 | | - |
110 | #define OPSTART(c) ((c) == '=' || (c) == '!' || (c) == '<' || (c) == '>') | - |
111 | #define CMPSTART(c) ((c) == '=' || (c) == '!') | - |
112 | | - |
113 | | - |
114 | | - |
115 | | - |
116 | | - |
117 | | - |
118 | | - |
119 | | - |
120 | | - |
121 | | - |
122 | int | - |
123 | rl_add_defun (const char *name, rl_command_func_t *function, int key) | - |
124 | { | - |
125 | if (key != -1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
126 | rl_bind_key (key, function); never executed: rl_bind_key (key, function); | 0 |
127 | rl_add_funmap_entry (name, function); | - |
128 | return 0; never executed: return 0; | 0 |
129 | } | - |
130 | | - |
131 | | - |
132 | int | - |
133 | rl_bind_key (int key, rl_command_func_t *function) | - |
134 | { | - |
135 | char keyseq[3]; | - |
136 | int l; | - |
137 | | - |
138 | if (key < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
139 | return (key); never executed: return (key); | 0 |
140 | | - |
141 | if (META_CHAR (key) && _rl_convert_meta_chars_to_ascii)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
142 | { | - |
143 | if (_rl_keymap[ESC].type == ISKMAP)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
144 | { | - |
145 | Keymap escmap; | - |
146 | | - |
147 | escmap = FUNCTION_TO_KEYMAP (_rl_keymap, ESC); | - |
148 | key = UNMETA (key); | - |
149 | escmap[key].type = ISFUNC; | - |
150 | escmap[key].function = function; | - |
151 | return (0); never executed: return (0); | 0 |
152 | } | - |
153 | return (key); never executed: return (key); | 0 |
154 | } | - |
155 | | - |
156 | | - |
157 | | - |
158 | | - |
159 | | - |
160 | if (_rl_keymap[key].type != ISKMAP)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
161 | { | - |
162 | _rl_keymap[key].type = ISFUNC; | - |
163 | _rl_keymap[key].function = function; | - |
164 | } never executed: end of block | 0 |
165 | else | - |
166 | { | - |
167 | l = 0; | - |
168 | if (key == '\\')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
169 | keyseq[l++] = '\\'; never executed: keyseq[l++] = '\\'; | 0 |
170 | keyseq[l++] = key; | - |
171 | keyseq[l] = '\0'; | - |
172 | rl_bind_keyseq (keyseq, function); | - |
173 | } never executed: end of block | 0 |
174 | rl_binding_keymap = _rl_keymap; | - |
175 | return (0); never executed: return (0); | 0 |
176 | } | - |
177 | | - |
178 | | - |
179 | | - |
180 | int | - |
181 | rl_bind_key_in_map (int key, rl_command_func_t *function, Keymap map) | - |
182 | { | - |
183 | int result; | - |
184 | Keymap oldmap; | - |
185 | | - |
186 | oldmap = _rl_keymap; | - |
187 | _rl_keymap = map; | - |
188 | result = rl_bind_key (key, function); | - |
189 | _rl_keymap = oldmap; | - |
190 | return (result); never executed: return (result); | 0 |
191 | } | - |
192 | | - |
193 | | - |
194 | | - |
195 | int | - |
196 | rl_bind_key_if_unbound_in_map (int key, rl_command_func_t *default_func, Keymap kmap) | - |
197 | { | - |
198 | char *keyseq; | - |
199 | | - |
200 | keyseq = rl_untranslate_keyseq ((unsigned char)key); | - |
201 | return (rl_bind_keyseq_if_unbound_in_map (keyseq, default_func, kmap)); never executed: return (rl_bind_keyseq_if_unbound_in_map (keyseq, default_func, kmap)); | 0 |
202 | } | - |
203 | | - |
204 | int | - |
205 | rl_bind_key_if_unbound (int key, rl_command_func_t *default_func) | - |
206 | { | - |
207 | char *keyseq; | - |
208 | | - |
209 | keyseq = rl_untranslate_keyseq ((unsigned char)key); | - |
210 | return (rl_bind_keyseq_if_unbound_in_map (keyseq, default_func, _rl_keymap)); never executed: return (rl_bind_keyseq_if_unbound_in_map (keyseq, default_func, _rl_keymap)); | 0 |
211 | } | - |
212 | | - |
213 | | - |
214 | | - |
215 | | - |
216 | int | - |
217 | rl_unbind_key (int key) | - |
218 | { | - |
219 | return (rl_bind_key (key, (rl_command_func_t *)NULL)); never executed: return (rl_bind_key (key, (rl_command_func_t *) ((void *)0) )); | 0 |
220 | } | - |
221 | | - |
222 | | - |
223 | int | - |
224 | rl_unbind_key_in_map (int key, Keymap map) | - |
225 | { | - |
226 | return (rl_bind_key_in_map (key, (rl_command_func_t *)NULL, map)); never executed: return (rl_bind_key_in_map (key, (rl_command_func_t *) ((void *)0) , map)); | 0 |
227 | } | - |
228 | | - |
229 | | - |
230 | int | - |
231 | rl_unbind_function_in_map (rl_command_func_t *func, Keymap map) | - |
232 | { | - |
233 | register int i, rval; | - |
234 | | - |
235 | for (i = rval = 0; i < KEYMAP_SIZE; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
236 | { | - |
237 | if (map[i].type == ISFUNC && map[i].function == func)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
238 | { | - |
239 | map[i].function = (rl_command_func_t *)NULL; | - |
240 | rval = 1; | - |
241 | } never executed: end of block | 0 |
242 | } never executed: end of block | 0 |
243 | return rval; never executed: return rval; | 0 |
244 | } | - |
245 | | - |
246 | | - |
247 | int | - |
248 | rl_unbind_command_in_map (const char *command, Keymap map) | - |
249 | { | - |
250 | rl_command_func_t *func; | - |
251 | | - |
252 | func = rl_named_function (command); | - |
253 | if (func == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
254 | return 0; never executed: return 0; | 0 |
255 | return (rl_unbind_function_in_map (func, map)); never executed: return (rl_unbind_function_in_map (func, map)); | 0 |
256 | } | - |
257 | | - |
258 | | - |
259 | | - |
260 | | - |
261 | int | - |
262 | rl_bind_keyseq (const char *keyseq, rl_command_func_t *function) | - |
263 | { | - |
264 | return (rl_generic_bind (ISFUNC, keyseq, (char *)function, _rl_keymap)); never executed: return (rl_generic_bind (0, keyseq, (char *)function, _rl_keymap)); | 0 |
265 | } | - |
266 | | - |
267 | | - |
268 | | - |
269 | | - |
270 | int | - |
271 | rl_bind_keyseq_in_map (const char *keyseq, rl_command_func_t *function, Keymap map) | - |
272 | { | - |
273 | return (rl_generic_bind (ISFUNC, keyseq, (char *)function, map)); never executed: return (rl_generic_bind (0, keyseq, (char *)function, map)); | 0 |
274 | } | - |
275 | | - |
276 | | - |
277 | int | - |
278 | rl_set_key (const char *keyseq, rl_command_func_t *function, Keymap map) | - |
279 | { | - |
280 | return (rl_generic_bind (ISFUNC, keyseq, (char *)function, map)); never executed: return (rl_generic_bind (0, keyseq, (char *)function, map)); | 0 |
281 | } | - |
282 | | - |
283 | | - |
284 | | - |
285 | | - |
286 | int | - |
287 | rl_bind_keyseq_if_unbound_in_map (const char *keyseq, rl_command_func_t *default_func, Keymap kmap) | - |
288 | { | - |
289 | rl_command_func_t *func; | - |
290 | char *keys; | - |
291 | int keys_len; | - |
292 | | - |
293 | if (keyseq)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
294 | { | - |
295 | | - |
296 | | - |
297 | keys = (char *)xmalloc (1 + (2 * strlen (keyseq))); | - |
298 | if (rl_translate_keyseq (keyseq, keys, &keys_len))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
299 | { | - |
300 | xfree (keys); | - |
301 | return -1; never executed: return -1; | 0 |
302 | } | - |
303 | func = rl_function_of_keyseq_len (keys, keys_len, kmap, (int *)NULL); | - |
304 | xfree (keys); | - |
305 | #if defined (VI_MODE) | - |
306 | if (!func || func == rl_do_lowercase_version || func == rl_vi_movement_mode)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
307 | #else | - |
308 | if (!func || func == rl_do_lowercase_version) | - |
309 | #endif | - |
310 | return (rl_bind_keyseq_in_map (keyseq, default_func, kmap)); never executed: return (rl_bind_keyseq_in_map (keyseq, default_func, kmap)); | 0 |
311 | else | - |
312 | return 1; never executed: return 1; | 0 |
313 | } | - |
314 | return 0; never executed: return 0; | 0 |
315 | } | - |
316 | | - |
317 | int | - |
318 | rl_bind_keyseq_if_unbound (const char *keyseq, rl_command_func_t *default_func) | - |
319 | { | - |
320 | return (rl_bind_keyseq_if_unbound_in_map (keyseq, default_func, _rl_keymap)); never executed: return (rl_bind_keyseq_if_unbound_in_map (keyseq, default_func, _rl_keymap)); | 0 |
321 | } | - |
322 | | - |
323 | | - |
324 | | - |
325 | | - |
326 | int | - |
327 | rl_macro_bind (const char *keyseq, const char *macro, Keymap map) | - |
328 | { | - |
329 | char *macro_keys; | - |
330 | int macro_keys_len; | - |
331 | | - |
332 | macro_keys = (char *)xmalloc ((2 * strlen (macro)) + 1); | - |
333 | | - |
334 | if (rl_translate_keyseq (macro, macro_keys, ¯o_keys_len))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
335 | { | - |
336 | xfree (macro_keys); | - |
337 | return -1; never executed: return -1; | 0 |
338 | } | - |
339 | rl_generic_bind (ISMACR, keyseq, macro_keys, map); | - |
340 | return 0; never executed: return 0; | 0 |
341 | } | - |
342 | | - |
343 | | - |
344 | | - |
345 | | - |
346 | | - |
347 | | - |
348 | int | - |
349 | rl_generic_bind (int type, const char *keyseq, char *data, Keymap map) | - |
350 | { | - |
351 | char *keys; | - |
352 | int keys_len, prevkey; | - |
353 | register int i; | - |
354 | KEYMAP_ENTRY k; | - |
355 | Keymap prevmap; | - |
356 | | - |
357 | k.function = 0; | - |
358 | | - |
359 | | - |
360 | if (keyseq == 0 || *keyseq == 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
361 | { | - |
362 | if (type == ISMACR)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
363 | xfree (data); never executed: xfree (data); | 0 |
364 | return -1; never executed: return -1; | 0 |
365 | } | - |
366 | | - |
367 | keys = (char *)xmalloc (1 + (2 * strlen (keyseq))); | - |
368 | | - |
369 | | - |
370 | | - |
371 | | - |
372 | if (rl_translate_keyseq (keyseq, keys, &keys_len))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
373 | { | - |
374 | xfree (keys); | - |
375 | return -1; never executed: return -1; | 0 |
376 | } | - |
377 | | - |
378 | prevmap = map; | - |
379 | prevkey = keys[0]; | - |
380 | | - |
381 | | - |
382 | for (i = 0; i < keys_len; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
383 | { | - |
384 | unsigned char uc = keys[i]; | - |
385 | int ic; | - |
386 | | - |
387 | if (i > 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
388 | prevkey = ic; never executed: prevkey = ic; | 0 |
389 | | - |
390 | ic = uc; | - |
391 | if (ic < 0 || ic >= KEYMAP_SIZE)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
392 | { | - |
393 | xfree (keys); | - |
394 | return -1; never executed: return -1; | 0 |
395 | } | - |
396 | | - |
397 | if (META_CHAR (ic) && _rl_convert_meta_chars_to_ascii)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
398 | { | - |
399 | ic = UNMETA (ic); | - |
400 | if (map[ESC].type == ISKMAP)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
401 | { | - |
402 | prevmap = map; | - |
403 | map = FUNCTION_TO_KEYMAP (map, ESC); | - |
404 | } never executed: end of block | 0 |
405 | } never executed: end of block | 0 |
406 | | - |
407 | if ((i + 1) < keys_len)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
408 | { | - |
409 | if (map[ic].type != ISKMAP)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
410 | { | - |
411 | | - |
412 | | - |
413 | | - |
414 | | - |
415 | | - |
416 | | - |
417 | | - |
418 | k = map[ic]; | - |
419 | | - |
420 | map[ic].type = ISKMAP; | - |
421 | map[ic].function = KEYMAP_TO_FUNCTION (rl_make_bare_keymap()); | - |
422 | } never executed: end of block | 0 |
423 | prevmap = map; | - |
424 | map = FUNCTION_TO_KEYMAP (map, ic); | - |
425 | | - |
426 | | - |
427 | | - |
428 | | - |
429 | | - |
430 | | - |
431 | if (k.function && ((k.type == ISFUNC && k.function != rl_do_lowercase_version) || k.type == ISMACR))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 |
432 | { | - |
433 | map[ANYOTHERKEY] = k; | - |
434 | k.function = 0; | - |
435 | } never executed: end of block | 0 |
436 | } never executed: end of block | 0 |
437 | else | - |
438 | { | - |
439 | if (map[ic].type == ISMACR)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
440 | xfree ((char *)map[ic].function); never executed: xfree ((char *)map[ic].function); | 0 |
441 | else if (map[ic].type == ISKMAP)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
442 | { | - |
443 | prevmap = map; | - |
444 | map = FUNCTION_TO_KEYMAP (map, ic); | - |
445 | ic = ANYOTHERKEY; | - |
446 | | - |
447 | | - |
448 | | - |
449 | | - |
450 | | - |
451 | if (type == ISFUNC && data == 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
452 | data = (char *)_rl_null_function; never executed: data = (char *)_rl_null_function; | 0 |
453 | } never executed: end of block | 0 |
454 | | - |
455 | map[ic].function = KEYMAP_TO_FUNCTION (data); | - |
456 | map[ic].type = type; | - |
457 | } never executed: end of block | 0 |
458 | | - |
459 | rl_binding_keymap = map; | - |
460 | | - |
461 | } never executed: end of block | 0 |
462 | | - |
463 | | - |
464 | | - |
465 | | - |
466 | | - |
467 | | - |
468 | | - |
469 | | - |
470 | if (type == ISFUNC && data == 0 &&TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
471 | prevmap[prevkey].type == ISKMAP &&TRUE | never evaluated | FALSE | never evaluated |
| 0 |
472 | (FUNCTION_TO_KEYMAP(prevmap, prevkey) == rl_binding_keymap) &&TRUE | never evaluated | FALSE | never evaluated |
| 0 |
473 | rl_binding_keymap[ANYOTHERKEY].type == ISFUNC &&TRUE | never evaluated | FALSE | never evaluated |
| 0 |
474 | rl_empty_keymap (rl_binding_keymap))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
475 | { | - |
476 | prevmap[prevkey].type = rl_binding_keymap[ANYOTHERKEY].type; | - |
477 | prevmap[prevkey].function = rl_binding_keymap[ANYOTHERKEY].function; | - |
478 | rl_discard_keymap (rl_binding_keymap); | - |
479 | rl_binding_keymap = prevmap; | - |
480 | } never executed: end of block | 0 |
481 | | - |
482 | xfree (keys); | - |
483 | return 0; never executed: return 0; | 0 |
484 | } | - |
485 | | - |
486 | | - |
487 | | - |
488 | | - |
489 | int | - |
490 | rl_translate_keyseq (const char *seq, char *array, int *len) | - |
491 | { | - |
492 | register int i, c, l, temp; | - |
493 | | - |
494 | for (i = l = 0; c = seq[i]; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
495 | { | - |
496 | if (c == '\\')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
497 | { | - |
498 | c = seq[++i]; | - |
499 | | - |
500 | if (c == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
501 | { | - |
502 | array[l++] = '\\'; | - |
503 | break; never executed: break; | 0 |
504 | } | - |
505 | | - |
506 | | - |
507 | if ((c == 'C' || c == 'M') && seq[i + 1] == '-')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
508 | { | - |
509 | | - |
510 | if (strncmp (&seq[i], "C-\\M-", 5) == 0) never executed: __result = (((const unsigned char *) (const char *) ( &seq[i] ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( "C-\\M-" ))[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 |
| 0 |
511 | { | - |
512 | array[l++] = ESC; | - |
513 | i += 5; | - |
514 | array[l++] = CTRL (_rl_to_upper (seq[i])); never executed: end of block never executed: __res = toupper ( (unsigned char)seq[i] ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)seq[i] )]; 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 |
515 | } never executed: end of block | 0 |
516 | else if (c == 'M')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
517 | { | - |
518 | i++; | - |
519 | | - |
520 | if (_rl_convert_meta_chars_to_ascii && _rl_keymap[ESC].type == ISKMAP)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
521 | array[l++] = ESC; never executed: array[l++] = (('[') & 0x1f); | 0 |
522 | else if (seq[i+1] == '\\' && seq[i+2] == 'C' && seq[i+3] == '-')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
523 | { | - |
524 | i += 4; | - |
525 | temp = (seq[i] == '?') ? RUBOUT : CTRL (_rl_to_upper (seq[i])); never executed: end of block never executed: __res = toupper ( (unsigned char)seq[i] ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)seq[i] )]; 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 |
526 | array[l++] = META (temp); | - |
527 | } never executed: end of block | 0 |
528 | else | - |
529 | { | - |
530 | | - |
531 | | - |
532 | | - |
533 | i++; | - |
534 | array[l++] = META (seq[i]); | - |
535 | } never executed: end of block | 0 |
536 | } | - |
537 | else if (c == 'C')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
538 | { | - |
539 | i += 2; | - |
540 | | - |
541 | array[l++] = (seq[i] == '?') ? RUBOUT : CTRL (_rl_to_upper (seq[i])); never executed: end of block never executed: __res = toupper ( (unsigned char)seq[i] ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)seq[i] )]; 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 |
542 | } never executed: end of block | 0 |
543 | if (seq[i] == '\0')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
544 | break; never executed: break; | 0 |
545 | continue; never executed: continue; | 0 |
546 | } | - |
547 | | - |
548 | | - |
549 | | - |
550 | | - |
551 | | - |
552 | switch (c) | - |
553 | { | - |
554 | case 'a': never executed: case 'a': | 0 |
555 | array[l++] = '\007'; | - |
556 | break; never executed: break; | 0 |
557 | case 'b': never executed: case 'b': | 0 |
558 | array[l++] = '\b'; | - |
559 | break; never executed: break; | 0 |
560 | case 'd': never executed: case 'd': | 0 |
561 | array[l++] = RUBOUT; | - |
562 | break; never executed: break; | 0 |
563 | case 'e': never executed: case 'e': | 0 |
564 | array[l++] = ESC; | - |
565 | break; never executed: break; | 0 |
566 | case 'f': never executed: case 'f': | 0 |
567 | array[l++] = '\f'; | - |
568 | break; never executed: break; | 0 |
569 | case 'n': never executed: case 'n': | 0 |
570 | array[l++] = NEWLINE; | - |
571 | break; never executed: break; | 0 |
572 | case 'r': never executed: case 'r': | 0 |
573 | array[l++] = RETURN; | - |
574 | break; never executed: break; | 0 |
575 | case 't': never executed: case 't': | 0 |
576 | array[l++] = TAB; | - |
577 | break; never executed: break; | 0 |
578 | case 'v': never executed: case 'v': | 0 |
579 | array[l++] = 0x0B; | - |
580 | break; never executed: break; | 0 |
581 | case '\\': never executed: case '\\': | 0 |
582 | array[l++] = '\\'; | - |
583 | break; never executed: break; | 0 |
584 | case '0': case '1': case '2': case '3': never executed: case '0': never executed: case '1': never executed: case '2': never executed: case '3': | 0 |
585 | case '4': case '5': case '6': case '7': never executed: case '4': never executed: case '5': never executed: case '6': never executed: case '7': | 0 |
586 | i++; | - |
587 | for (temp = 2, c -= '0'; ISOCTAL ((unsigned char)seq[i]) && temp--; i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
588 | c = (c * 8) + OCTVALUE (seq[i]); never executed: c = (c * 8) + ((seq[i]) - '0'); | 0 |
589 | i--; | - |
590 | array[l++] = c & largest_char; | - |
591 | break; never executed: break; | 0 |
592 | case 'x': never executed: case 'x': | 0 |
593 | i++; | - |
594 | for (temp = 2, c = 0; ISXDIGIT ((unsigned char)seq[i]) && temp--; i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
595 | c = (c * 16) + HEXVALUE (seq[i]); never executed: c = (c * 16) + (((seq[i]) >= 'a' && (seq[i]) <= 'f') ? (seq[i])-'a'+10 : (seq[i]) >= 'A' && (seq[i]) <= 'F' ? (seq[i])-'A'+10 : (seq[i])-'0'); 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 |
596 | if (temp == 2)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
597 | c = 'x'; never executed: c = 'x'; | 0 |
598 | i--; | - |
599 | array[l++] = c & largest_char; | - |
600 | break; never executed: break; | 0 |
601 | default: never executed: default: | 0 |
602 | array[l++] = c; | - |
603 | break; never executed: break; | 0 |
604 | } | - |
605 | continue; never executed: continue; | 0 |
606 | } | - |
607 | | - |
608 | array[l++] = c; | - |
609 | } never executed: end of block | 0 |
610 | | - |
611 | *len = l; | - |
612 | array[l] = '\0'; | - |
613 | return (0); never executed: return (0); | 0 |
614 | } | - |
615 | | - |
616 | static int | - |
617 | _rl_isescape (int c) | - |
618 | { | - |
619 | switch (c) | - |
620 | { | - |
621 | case '\007': never executed: case '\007': | 0 |
622 | case '\b': never executed: case '\b': | 0 |
623 | case '\f': never executed: case '\f': | 0 |
624 | case '\n': never executed: case '\n': | 0 |
625 | case '\r': never executed: case '\r': | 0 |
626 | case TAB: never executed: case '\t': | 0 |
627 | case 0x0b: return (1); never executed: return (1); never executed: case 0x0b: | 0 |
628 | default: return (0); never executed: return (0); never executed: default: | 0 |
629 | } | - |
630 | } | - |
631 | | - |
632 | static int | - |
633 | _rl_escchar (int c) | - |
634 | { | - |
635 | switch (c) | - |
636 | { | - |
637 | case '\007': return ('a'); never executed: return ('a'); never executed: case '\007': | 0 |
638 | case '\b': return ('b'); never executed: return ('b'); never executed: case '\b': | 0 |
639 | case '\f': return ('f'); never executed: return ('f'); never executed: case '\f': | 0 |
640 | case '\n': return ('n'); never executed: return ('n'); never executed: case '\n': | 0 |
641 | case '\r': return ('r'); never executed: return ('r'); never executed: case '\r': | 0 |
642 | case TAB: return ('t'); never executed: return ('t'); never executed: case '\t': | 0 |
643 | case 0x0b: return ('v'); never executed: return ('v'); never executed: case 0x0b: | 0 |
644 | default: return (c); never executed: return (c); never executed: default: | 0 |
645 | } | - |
646 | } | - |
647 | | - |
648 | char * | - |
649 | rl_untranslate_keyseq (int seq) | - |
650 | { | - |
651 | static char kseq[16]; | - |
652 | int i, c; | - |
653 | | - |
654 | i = 0; | - |
655 | c = seq; | - |
656 | if (META_CHAR (c))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
657 | { | - |
658 | kseq[i++] = '\\'; | - |
659 | kseq[i++] = 'M'; | - |
660 | kseq[i++] = '-'; | - |
661 | c = UNMETA (c); | - |
662 | } never executed: end of block | 0 |
663 | else if (c == ESC)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
664 | { | - |
665 | kseq[i++] = '\\'; | - |
666 | c = 'e'; | - |
667 | } never executed: end of block | 0 |
668 | else if (CTRL_CHAR (c))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
669 | { | - |
670 | kseq[i++] = '\\'; | - |
671 | kseq[i++] = 'C'; | - |
672 | kseq[i++] = '-'; | - |
673 | c = _rl_to_lower (UNCTRL (c)); never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = tolower ( (unsigned char)((((unsigned char)(((c)|0x40)) == (((c)|0x40))) && (1 && ((*__ctype_b_loc ())[(int) (( (unsigned char)((c)|0x40) ))] & (unsigned short int) _ISlower) )) ? (__extension__ ({ int __res; if (sizeof ( (unsigned char)((c)|0x40)...d char)((c)|0x40) ); __res = __c < -128 || __c > 255 ? __c : (*__ctype_toupper_loc ())[__c]; } else __res = toupper ( (unsigned char)((c)|0x40) ); } else __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; __res; })) : (((c)|0x40))) ); never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: __res = (*__ctype_tolower_loc ())[(int) ( (unsigned char)((((unsigned char)(((c)|0x40)) == (((c)|0x40))) && (1 && ((*__ctype_b_loc ())[(int) (( (unsigned char)((c)|0x40) ))] & (unsigned short int) _ISlower) )) ? (__extension__ ({ int __res; if (sizeof ( (... char)((c)|0x40) ); __res = __c < -128 || __c > 255 ? __c : (*__ctype_toupper_loc ())[__c]; } else __res = toupper ( (unsigned char)((c)|0x40) ); } else __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; __res; })) : (((c)|0x40))) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; 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 |
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 |
674 | } never executed: end of block | 0 |
675 | else if (c == RUBOUT)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
676 | { | - |
677 | kseq[i++] = '\\'; | - |
678 | kseq[i++] = 'C'; | - |
679 | kseq[i++] = '-'; | - |
680 | c = '?'; | - |
681 | } never executed: end of block | 0 |
682 | | - |
683 | if (c == ESC)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
684 | { | - |
685 | kseq[i++] = '\\'; | - |
686 | c = 'e'; | - |
687 | } never executed: end of block | 0 |
688 | else if (c == '\\' || c == '"')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
689 | { | - |
690 | kseq[i++] = '\\'; | - |
691 | } never executed: end of block | 0 |
692 | | - |
693 | kseq[i++] = (unsigned char) c; | - |
694 | kseq[i] = '\0'; | - |
695 | return kseq; never executed: return kseq; | 0 |
696 | } | - |
697 | | - |
698 | char * | - |
699 | _rl_untranslate_macro_value (char *seq, int use_escapes) | - |
700 | { | - |
701 | char *ret, *r, *s; | - |
702 | int c; | - |
703 | | - |
704 | r = ret = (char *)xmalloc (7 * strlen (seq) + 1); | - |
705 | for (s = seq; *s; s++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
706 | { | - |
707 | c = *s; | - |
708 | if (META_CHAR (c))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
709 | { | - |
710 | *r++ = '\\'; | - |
711 | *r++ = 'M'; | - |
712 | *r++ = '-'; | - |
713 | c = UNMETA (c); | - |
714 | } never executed: end of block | 0 |
715 | else if (c == ESC)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
716 | { | - |
717 | *r++ = '\\'; | - |
718 | c = 'e'; | - |
719 | } never executed: end of block | 0 |
720 | else if (CTRL_CHAR (c))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
721 | { | - |
722 | *r++ = '\\'; | - |
723 | if (use_escapes && _rl_isescape (c))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
724 | c = _rl_escchar (c); never executed: c = _rl_escchar (c); | 0 |
725 | else | - |
726 | { | - |
727 | *r++ = 'C'; | - |
728 | *r++ = '-'; | - |
729 | c = _rl_to_lower (UNCTRL (c)); never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = tolower ( (unsigned char)((((unsigned char)(((c)|0x40)) == (((c)|0x40))) && (1 && ((*__ctype_b_loc ())[(int) (( (unsigned char)((c)|0x40) ))] & (unsigned short int) _ISlower) )) ? (__extension__ ({ int __res; if (sizeof ( (unsigned char)((c)|0x40)...d char)((c)|0x40) ); __res = __c < -128 || __c > 255 ? __c : (*__ctype_toupper_loc ())[__c]; } else __res = toupper ( (unsigned char)((c)|0x40) ); } else __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; __res; })) : (((c)|0x40))) ); never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: __res = (*__ctype_tolower_loc ())[(int) ( (unsigned char)((((unsigned char)(((c)|0x40)) == (((c)|0x40))) && (1 && ((*__ctype_b_loc ())[(int) (( (unsigned char)((c)|0x40) ))] & (unsigned short int) _ISlower) )) ? (__extension__ ({ int __res; if (sizeof ( (... char)((c)|0x40) ); __res = __c < -128 || __c > 255 ? __c : (*__ctype_toupper_loc ())[__c]; } else __res = toupper ( (unsigned char)((c)|0x40) ); } else __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; __res; })) : (((c)|0x40))) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; 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 |
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 |
730 | } never executed: end of block | 0 |
731 | } | - |
732 | else if (c == RUBOUT)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
733 | { | - |
734 | *r++ = '\\'; | - |
735 | *r++ = 'C'; | - |
736 | *r++ = '-'; | - |
737 | c = '?'; | - |
738 | } never executed: end of block | 0 |
739 | | - |
740 | if (c == ESC)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
741 | { | - |
742 | *r++ = '\\'; | - |
743 | c = 'e'; | - |
744 | } never executed: end of block | 0 |
745 | else if (c == '\\' || c == '"')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
746 | *r++ = '\\'; never executed: *r++ = '\\'; | 0 |
747 | | - |
748 | *r++ = (unsigned char)c; | - |
749 | } never executed: end of block | 0 |
750 | *r = '\0'; | - |
751 | return ret; never executed: return ret; | 0 |
752 | } | - |
753 | | - |
754 | | - |
755 | | - |
756 | | - |
757 | rl_command_func_t * | - |
758 | rl_named_function (const char *string) | - |
759 | { | - |
760 | register int i; | - |
761 | | - |
762 | rl_initialize_funmap (); | - |
763 | | - |
764 | for (i = 0; funmap[i]; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
765 | if (_rl_stricmp (funmap[i]->name, string) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
766 | return (funmap[i]->function); never executed: return (funmap[i]->function); | 0 |
767 | return ((rl_command_func_t *)NULL); never executed: return ((rl_command_func_t *) ((void *)0) ); | 0 |
768 | } | - |
769 | | - |
770 | | - |
771 | | - |
772 | | - |
773 | | - |
774 | | - |
775 | static rl_command_func_t * | - |
776 | _rl_function_of_keyseq_internal (const char *keyseq, size_t len, Keymap map, int *type) | - |
777 | { | - |
778 | register int i; | - |
779 | | - |
780 | if (map == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
781 | map = _rl_keymap; never executed: map = _rl_keymap; | 0 |
782 | | - |
783 | for (i = 0; keyseq && i < len; i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
784 | { | - |
785 | unsigned char ic = keyseq[i]; | - |
786 | | - |
787 | if (META_CHAR (ic) && _rl_convert_meta_chars_to_ascii)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
788 | { | - |
789 | if (map[ESC].type == ISKMAP)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
790 | { | - |
791 | map = FUNCTION_TO_KEYMAP (map, ESC); | - |
792 | ic = UNMETA (ic); | - |
793 | } never executed: end of block | 0 |
794 | | - |
795 | | - |
796 | else | - |
797 | { | - |
798 | if (type)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
799 | *type = map[ESC].type; never executed: *type = map[(('[') & 0x1f)].type; | 0 |
800 | | - |
801 | return (map[ESC].function); never executed: return (map[(('[') & 0x1f)].function); | 0 |
802 | } | - |
803 | } | - |
804 | | - |
805 | if (map[ic].type == ISKMAP)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
806 | { | - |
807 | | - |
808 | | - |
809 | if (keyseq[i + 1] == '\0')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
810 | { | - |
811 | if (type)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
812 | *type = ISKMAP; never executed: *type = 1; | 0 |
813 | | - |
814 | return (map[ic].function); never executed: return (map[ic].function); | 0 |
815 | } | - |
816 | else | - |
817 | map = FUNCTION_TO_KEYMAP (map, ic); never executed: map = (Keymap)(map[ic].function); | 0 |
818 | } | - |
819 | | - |
820 | | - |
821 | | - |
822 | else if (map[ic].type != ISKMAP && keyseq[i+1])TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
823 | return ((rl_command_func_t *)NULL); never executed: return ((rl_command_func_t *) ((void *)0) ); | 0 |
824 | else | - |
825 | { | - |
826 | if (type)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
827 | *type = map[ic].type; never executed: *type = map[ic].type; | 0 |
828 | | - |
829 | return (map[ic].function); never executed: return (map[ic].function); | 0 |
830 | } | - |
831 | } | - |
832 | return ((rl_command_func_t *) NULL); never executed: return ((rl_command_func_t *) ((void *)0) ); | 0 |
833 | } | - |
834 | | - |
835 | rl_command_func_t * | - |
836 | rl_function_of_keyseq (const char *keyseq, Keymap map, int *type) | - |
837 | { | - |
838 | return _rl_function_of_keyseq_internal (keyseq, strlen (keyseq), map, type); never executed: return _rl_function_of_keyseq_internal (keyseq, strlen (keyseq), map, type); | 0 |
839 | } | - |
840 | | - |
841 | rl_command_func_t * | - |
842 | rl_function_of_keyseq_len (const char *keyseq, size_t len, Keymap map, int *type) | - |
843 | { | - |
844 | return _rl_function_of_keyseq_internal (keyseq, len, map, type); never executed: return _rl_function_of_keyseq_internal (keyseq, len, map, type); | 0 |
845 | } | - |
846 | | - |
847 | | - |
848 | static char *last_readline_init_file = (char *)NULL; | - |
849 | | - |
850 | | - |
851 | static const char *current_readline_init_file; | - |
852 | static int current_readline_init_include_level; | - |
853 | static int current_readline_init_lineno; | - |
854 | | - |
855 | | - |
856 | | - |
857 | | - |
858 | static char * | - |
859 | _rl_read_file (char *filename, size_t *sizep) | - |
860 | { | - |
861 | struct stat finfo; | - |
862 | size_t file_size; | - |
863 | char *buffer; | - |
864 | int i, file; | - |
865 | | - |
866 | file = -1; | - |
867 | if (((file = open (filename, O_RDONLY, 0666)) < 0) || (fstat (file, &finfo) < 0))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
868 | { | - |
869 | if (file >= 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
870 | close (file); never executed: close (file); | 0 |
871 | return ((char *)NULL); never executed: return ((char *) ((void *)0) ); | 0 |
872 | } | - |
873 | | - |
874 | file_size = (size_t)finfo.st_size; | - |
875 | | - |
876 | | - |
877 | if (file_size != finfo.st_size || file_size + 1 < file_size)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
878 | { | - |
879 | if (file >= 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
880 | close (file); never executed: close (file); | 0 |
881 | #if defined (EFBIG) | - |
882 | errno = EFBIG; | - |
883 | #endif | - |
884 | return ((char *)NULL); never executed: return ((char *) ((void *)0) ); | 0 |
885 | } | - |
886 | | - |
887 | | - |
888 | buffer = (char *)xmalloc (file_size + 1); | - |
889 | i = read (file, buffer, file_size); | - |
890 | close (file); | - |
891 | | - |
892 | if (i < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
893 | { | - |
894 | xfree (buffer); | - |
895 | return ((char *)NULL); never executed: return ((char *) ((void *)0) ); | 0 |
896 | } | - |
897 | | - |
898 | RL_CHECK_SIGNALS (); never executed: _rl_signal_handler (_rl_caught_signal); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
899 | | - |
900 | buffer[i] = '\0'; | - |
901 | if (sizep)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
902 | *sizep = i; never executed: *sizep = i; | 0 |
903 | | - |
904 | return (buffer); never executed: return (buffer); | 0 |
905 | } | - |
906 | | - |
907 | | - |
908 | int | - |
909 | rl_re_read_init_file (int count, int ignore) | - |
910 | { | - |
911 | int r; | - |
912 | r = rl_read_init_file ((const char *)NULL); | - |
913 | rl_set_keymap_from_edit_mode (); | - |
914 | return r; never executed: return r; | 0 |
915 | } | - |
916 | | - |
917 | | - |
918 | | - |
919 | | - |
920 | | - |
921 | | - |
922 | | - |
923 | | - |
924 | | - |
925 | int | - |
926 | rl_read_init_file (const char *filename) | - |
927 | { | - |
928 | | - |
929 | if (filename == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
930 | filename = last_readline_init_file; never executed: filename = last_readline_init_file; | 0 |
931 | if (filename == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
932 | filename = sh_get_env_value ("INPUTRC"); never executed: filename = sh_get_env_value ("INPUTRC"); | 0 |
933 | if (filename == 0 || *filename == 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
934 | { | - |
935 | filename = DEFAULT_INPUTRC; | - |
936 | | - |
937 | if (_rl_read_init_file (filename, 0) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
938 | return 0; never executed: return 0; | 0 |
939 | filename = SYS_INPUTRC; | - |
940 | } never executed: end of block | 0 |
941 | | - |
942 | #if defined (__MSDOS__) | - |
943 | if (_rl_read_init_file (filename, 0) == 0) | - |
944 | return 0; | - |
945 | filename = "~/_inputrc"; | - |
946 | #endif | - |
947 | return (_rl_read_init_file (filename, 0)); never executed: return (_rl_read_init_file (filename, 0)); | 0 |
948 | } | - |
949 | | - |
950 | static int | - |
951 | _rl_read_init_file (const char *filename, int include_level) | - |
952 | { | - |
953 | register int i; | - |
954 | char *buffer, *openname, *line, *end; | - |
955 | size_t file_size; | - |
956 | | - |
957 | current_readline_init_file = filename; | - |
958 | current_readline_init_include_level = include_level; | - |
959 | | - |
960 | openname = tilde_expand (filename); | - |
961 | buffer = _rl_read_file (openname, &file_size); | - |
962 | xfree (openname); | - |
963 | | - |
964 | RL_CHECK_SIGNALS (); never executed: _rl_signal_handler (_rl_caught_signal); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
965 | if (buffer == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
966 | return (errno); never executed: return ( (*__errno_location ()) ); | 0 |
967 | | - |
968 | if (include_level == 0 && filename != last_readline_init_file)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
969 | { | - |
970 | FREE (last_readline_init_file); never executed: free (last_readline_init_file); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
971 | last_readline_init_file = savestring (filename); | - |
972 | } never executed: end of block | 0 |
973 | | - |
974 | currently_reading_init_file = 1; | - |
975 | | - |
976 | | - |
977 | | - |
978 | current_readline_init_lineno = 1; | - |
979 | line = buffer; | - |
980 | end = buffer + file_size; | - |
981 | while (line < end)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
982 | { | - |
983 | | - |
984 | for (i = 0; line + i != end && line[i] != '\n'; i++); never executed: ; TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
985 | | - |
986 | #if defined (__CYGWIN__) | - |
987 | | - |
988 | if (line[i] == '\n' && line[i-1] == '\r') | - |
989 | line[i - 1] = '\0'; | - |
990 | #endif | - |
991 | | - |
992 | | - |
993 | line[i] = '\0'; | - |
994 | | - |
995 | | - |
996 | while (*line && whitespace (*line))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
997 | { | - |
998 | line++; | - |
999 | i--; | - |
1000 | } never executed: end of block | 0 |
1001 | | - |
1002 | | - |
1003 | if (*line && *line != '#')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1004 | rl_parse_and_bind (line); never executed: rl_parse_and_bind (line); | 0 |
1005 | | - |
1006 | | - |
1007 | line += i + 1; | - |
1008 | current_readline_init_lineno++; | - |
1009 | } never executed: end of block | 0 |
1010 | | - |
1011 | xfree (buffer); | - |
1012 | currently_reading_init_file = 0; | - |
1013 | return (0); never executed: return (0); | 0 |
1014 | } | - |
1015 | | - |
1016 | static void | - |
1017 | #if defined (PREFER_STDARG) | - |
1018 | _rl_init_file_error (const char *format, ...) | - |
1019 | #else | - |
1020 | _rl_init_file_error (va_alist) | - |
1021 | va_dcl | - |
1022 | #endif | - |
1023 | { | - |
1024 | va_list args; | - |
1025 | #if defined (PREFER_VARARGS) | - |
1026 | char *format; | - |
1027 | #endif | - |
1028 | | - |
1029 | #if defined (PREFER_STDARG) | - |
1030 | va_start (args, format); | - |
1031 | #else | - |
1032 | va_start (args); | - |
1033 | format = va_arg (args, char *); | - |
1034 | #endif | - |
1035 | | - |
1036 | fprintf (stderr, "readline: "); | - |
1037 | if (currently_reading_init_file)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1038 | fprintf (stderr, "%s: line %d: ", current_readline_init_file, never executed: fprintf ( stderr , "%s: line %d: ", current_readline_init_file, current_readline_init_lineno); | 0 |
1039 | current_readline_init_lineno); never executed: fprintf ( stderr , "%s: line %d: ", current_readline_init_file, current_readline_init_lineno); | 0 |
1040 | | - |
1041 | vfprintf (stderr, format, args); | - |
1042 | fprintf (stderr, "\n"); | - |
1043 | fflush (stderr); | - |
1044 | | - |
1045 | va_end (args); | - |
1046 | } never executed: end of block | 0 |
1047 | | - |
1048 | | - |
1049 | | - |
1050 | | - |
1051 | | - |
1052 | | - |
1053 | | - |
1054 | static int | - |
1055 | parse_comparison_op (s, indp) | - |
1056 | const char *s; | - |
1057 | int *indp; | - |
1058 | { | - |
1059 | int i, peekc, op; | - |
1060 | | - |
1061 | if (OPSTART (s[*indp]) == 0)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 |
1062 | return -1; never executed: return -1; | 0 |
1063 | i = *indp; | - |
1064 | peekc = s[i] ? s[i+1] : 0;TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1065 | op = -1; | - |
1066 | | - |
1067 | if (s[i] == '=')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1068 | { | - |
1069 | op = OP_EQ; | - |
1070 | if (peekc == '=')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1071 | i++; never executed: i++; | 0 |
1072 | i++; | - |
1073 | } never executed: end of block | 0 |
1074 | else if (s[i] == '!' && peekc == '=')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1075 | { | - |
1076 | op = OP_NE; | - |
1077 | i += 2; | - |
1078 | } never executed: end of block | 0 |
1079 | else if (s[i] == '<' && peekc == '=')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1080 | { | - |
1081 | op = OP_LE; | - |
1082 | i += 2; | - |
1083 | } never executed: end of block | 0 |
1084 | else if (s[i] == '>' && peekc == '=')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1085 | { | - |
1086 | op = OP_GE; | - |
1087 | i += 2; | - |
1088 | } never executed: end of block | 0 |
1089 | else if (s[i] == '<')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1090 | { | - |
1091 | op = OP_LT; | - |
1092 | i += 1; | - |
1093 | } never executed: end of block | 0 |
1094 | else if (s[i] == '>')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1095 | { | - |
1096 | op = OP_GT; | - |
1097 | i += 1; | - |
1098 | } never executed: end of block | 0 |
1099 | | - |
1100 | *indp = i; | - |
1101 | return op; never executed: return op; | 0 |
1102 | } | - |
1103 | | - |
1104 | | - |
1105 | | - |
1106 | | - |
1107 | | - |
1108 | | - |
1109 | | - |
1110 | typedef int _rl_parser_func_t PARAMS((char *)); | - |
1111 | | - |
1112 | | - |
1113 | const char * const _rl_possible_control_prefixes[] = { | - |
1114 | "Control-", "C-", "CTRL-", (const char *)NULL | - |
1115 | }; | - |
1116 | | - |
1117 | const char * const _rl_possible_meta_prefixes[] = { | - |
1118 | "Meta", "M-", (const char *)NULL | - |
1119 | }; | - |
1120 | | - |
1121 | | - |
1122 | | - |
1123 | | - |
1124 | const char *rl_readline_name = "other"; | - |
1125 | | - |
1126 | | - |
1127 | static unsigned char *if_stack = (unsigned char *)NULL; | - |
1128 | static int if_stack_depth; | - |
1129 | static int if_stack_size; | - |
1130 | | - |
1131 | | - |
1132 | | - |
1133 | static int | - |
1134 | parser_if (char *args) | - |
1135 | { | - |
1136 | int i, llen, boolvar, strvar; | - |
1137 | | - |
1138 | boolvar = strvar = -1; | - |
1139 | | - |
1140 | | - |
1141 | if (if_stack_depth + 1 >= if_stack_size)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1142 | { | - |
1143 | if (!if_stack)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1144 | if_stack = (unsigned char *)xmalloc (if_stack_size = 20); never executed: if_stack = (unsigned char *)xmalloc (if_stack_size = 20); | 0 |
1145 | else | - |
1146 | if_stack = (unsigned char *)xrealloc (if_stack, if_stack_size += 20); never executed: if_stack = (unsigned char *)xrealloc (if_stack, if_stack_size += 20); | 0 |
1147 | } | - |
1148 | if_stack[if_stack_depth++] = _rl_parsing_conditionalized_out; | - |
1149 | | - |
1150 | | - |
1151 | | - |
1152 | if (_rl_parsing_conditionalized_out)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1153 | return 0; never executed: return 0; | 0 |
1154 | | - |
1155 | llen = strlen (args); | - |
1156 | | - |
1157 | | - |
1158 | for (i = 0; args[i] && !whitespace (args[i]); i++); never executed: ; TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1159 | | - |
1160 | if (args[i])TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1161 | args[i++] = '\0'; never executed: args[i++] = '\0'; | 0 |
1162 | | - |
1163 | | - |
1164 | | - |
1165 | | - |
1166 | if (rl_terminal_name && _rl_strnicmp (args, "term=", 5) == 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1167 | { | - |
1168 | char *tem, *tname; | - |
1169 | | - |
1170 | | - |
1171 | tname = savestring (rl_terminal_name); | - |
1172 | tem = strchr (tname, '-');TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1173 | if (tem)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1174 | *tem = '\0'; never executed: *tem = '\0'; | 0 |
1175 | | - |
1176 | | - |
1177 | | - |
1178 | | - |
1179 | | - |
1180 | _rl_parsing_conditionalized_out = _rl_stricmp (args + 5, tname) &&TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1181 | _rl_stricmp (args + 5, rl_terminal_name);TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1182 | xfree (tname); | - |
1183 | } never executed: end of block | 0 |
1184 | #if defined (VI_MODE) | - |
1185 | else if (_rl_strnicmp (args, "mode=", 5) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1186 | { | - |
1187 | int mode; | - |
1188 | | - |
1189 | if (_rl_stricmp (args + 5, "emacs") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1190 | mode = emacs_mode; never executed: mode = 1; | 0 |
1191 | else if (_rl_stricmp (args + 5, "vi") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1192 | mode = vi_mode; never executed: mode = 0; | 0 |
1193 | else | - |
1194 | mode = no_mode; never executed: mode = -1; | 0 |
1195 | | - |
1196 | _rl_parsing_conditionalized_out = mode != rl_editing_mode; | - |
1197 | } never executed: end of block | 0 |
1198 | #endif /* VI_MODE */ | - |
1199 | else if (_rl_strnicmp (args, "version", 7) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1200 | { | - |
1201 | int rlversion, versionarg, op, previ, major, minor; | - |
1202 | | - |
1203 | _rl_parsing_conditionalized_out = 1; | - |
1204 | rlversion = RL_VERSION_MAJOR*10 + RL_VERSION_MINOR; | - |
1205 | | - |
1206 | | - |
1207 | | - |
1208 | if (i > 0 && i <= llen && args[i-1] == '\0')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1209 | args[i-1] = ' '; never executed: args[i-1] = ' '; | 0 |
1210 | args[llen] = '\0'; | - |
1211 | for (i = 7; whitespace (args[i]); i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1212 | ; never executed: ; | 0 |
1213 | if (OPSTART(args[i]) == 0)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 |
1214 | { | - |
1215 | _rl_init_file_error ("comparison operator expected, found `%s'", args[i] ? args + i : "end-of-line"); | - |
1216 | return 0; never executed: return 0; | 0 |
1217 | } | - |
1218 | previ = i; | - |
1219 | op = parse_comparison_op (args, &i); | - |
1220 | if (op <= 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1221 | { | - |
1222 | _rl_init_file_error ("comparison operator expected, found `%s'", args+previ); | - |
1223 | return 0; never executed: return 0; | 0 |
1224 | } | - |
1225 | for ( ; args[i] && whitespace (args[i]); i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1226 | ; never executed: ; | 0 |
1227 | if (args[i] == 0 || _rl_digit_p (args[i]) == 0)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 |
1228 | { | - |
1229 | _rl_init_file_error ("numeric argument expected, found `%s'", args+i); | - |
1230 | return 0; never executed: return 0; | 0 |
1231 | } | - |
1232 | major = minor = 0; | - |
1233 | previ = i; | - |
1234 | for ( ; args[i] && _rl_digit_p (args[i]); i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1235 | major = major*10 + _rl_digit_value (args[i]); never executed: major = major*10 + ((args[i]) - '0'); | 0 |
1236 | if (args[i] == '.')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1237 | { | - |
1238 | if (args[i + 1] && _rl_digit_p (args [i + 1]) == 0)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 |
1239 | { | - |
1240 | _rl_init_file_error ("numeric argument expected, found `%s'", args+previ); | - |
1241 | return 0; never executed: return 0; | 0 |
1242 | } | - |
1243 | for (++i; args[i] && _rl_digit_p (args[i]); i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1244 | minor = minor*10 + _rl_digit_value (args[i]); never executed: minor = minor*10 + ((args[i]) - '0'); | 0 |
1245 | } never executed: end of block | 0 |
1246 | | - |
1247 | | - |
1248 | previ = i; | - |
1249 | for ( ; args[i] && whitespace (args[i]); i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1250 | ; never executed: ; | 0 |
1251 | if (args[i] && args[i] != '#')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1252 | { | - |
1253 | _rl_init_file_error ("trailing garbage on line: `%s'", args+previ); | - |
1254 | return 0; never executed: return 0; | 0 |
1255 | } | - |
1256 | versionarg = major*10 + minor; | - |
1257 | | - |
1258 | switch (op) | - |
1259 | { | - |
1260 | case OP_EQ: never executed: case 1: | 0 |
1261 | _rl_parsing_conditionalized_out = rlversion == versionarg; | - |
1262 | break; never executed: break; | 0 |
1263 | case OP_NE: never executed: case 2: | 0 |
1264 | _rl_parsing_conditionalized_out = rlversion != versionarg; | - |
1265 | break; never executed: break; | 0 |
1266 | case OP_GT: never executed: case 3: | 0 |
1267 | _rl_parsing_conditionalized_out = rlversion > versionarg; | - |
1268 | break; never executed: break; | 0 |
1269 | case OP_GE: never executed: case 4: | 0 |
1270 | _rl_parsing_conditionalized_out = rlversion >= versionarg; | - |
1271 | break; never executed: break; | 0 |
1272 | case OP_LT: never executed: case 5: | 0 |
1273 | _rl_parsing_conditionalized_out = rlversion < versionarg; | - |
1274 | break; never executed: break; | 0 |
1275 | case OP_LE: never executed: case 6: | 0 |
1276 | _rl_parsing_conditionalized_out = rlversion <= versionarg; | - |
1277 | break; never executed: break; | 0 |
1278 | } | - |
1279 | } never executed: end of block | 0 |
1280 | | - |
1281 | | - |
1282 | else if (_rl_stricmp (args, rl_readline_name) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1283 | _rl_parsing_conditionalized_out = 0; never executed: _rl_parsing_conditionalized_out = 0; | 0 |
1284 | else if ((boolvar = find_boolean_var (args)) >= 0 || (strvar = find_string_var (args)) >= 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1285 | { | - |
1286 | int op, previ; | - |
1287 | size_t vlen; | - |
1288 | const char *vname; | - |
1289 | char *valuearg, *vval, prevc; | - |
1290 | | - |
1291 | _rl_parsing_conditionalized_out = 1; | - |
1292 | vname = (boolvar >= 0) ? boolean_varname (boolvar) : string_varname (strvar);TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1293 | vlen = strlen (vname); | - |
1294 | if (i > 0 && i <= llen && args[i-1] == '\0')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1295 | args[i-1] = ' '; never executed: args[i-1] = ' '; | 0 |
1296 | args[llen] = '\0'; | - |
1297 | for (i = vlen; whitespace (args[i]); i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1298 | ; never executed: ; | 0 |
1299 | if (CMPSTART(args[i]) == 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1300 | { | - |
1301 | _rl_init_file_error ("equality comparison operator expected, found `%s'", args[i] ? args + i : "end-of-line"); | - |
1302 | return 0; never executed: return 0; | 0 |
1303 | } | - |
1304 | previ = i; | - |
1305 | op = parse_comparison_op (args, &i); | - |
1306 | if (op != OP_EQ && op != OP_NE)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1307 | { | - |
1308 | _rl_init_file_error ("equality comparison operator expected, found `%s'", args+previ); | - |
1309 | return 0; never executed: return 0; | 0 |
1310 | } | - |
1311 | for ( ; args[i] && whitespace (args[i]); i++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1312 | ; never executed: ; | 0 |
1313 | if (args[i] == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1314 | { | - |
1315 | _rl_init_file_error ("argument expected, found `%s'", args+i); | - |
1316 | return 0; never executed: return 0; | 0 |
1317 | } | - |
1318 | previ = i; | - |
1319 | valuearg = args + i; | - |
1320 | for ( ; args[i] && whitespace (args[i]) == 0; i++)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 |
1321 | ; never executed: ; | 0 |
1322 | prevc = args[i]; | - |
1323 | args[i] = '\0'; | - |
1324 | vval = rl_variable_value (vname); | - |
1325 | if (op == OP_EQ)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1326 | _rl_parsing_conditionalized_out = _rl_stricmp (vval, valuearg) != 0; never executed: _rl_parsing_conditionalized_out = strcasecmp (vval, valuearg) != 0; | 0 |
1327 | else if (op == OP_NE)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1328 | _rl_parsing_conditionalized_out = _rl_stricmp (vval, valuearg) == 0; never executed: _rl_parsing_conditionalized_out = strcasecmp (vval, valuearg) == 0; | 0 |
1329 | args[i] = prevc; | - |
1330 | } never executed: end of block | 0 |
1331 | else | - |
1332 | _rl_parsing_conditionalized_out = 1; never executed: _rl_parsing_conditionalized_out = 1; | 0 |
1333 | return 0; never executed: return 0; | 0 |
1334 | } | - |
1335 | | - |
1336 | | - |
1337 | static int | - |
1338 | parser_else (char *args) | - |
1339 | { | - |
1340 | register int i; | - |
1341 | | - |
1342 | if (if_stack_depth == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1343 | { | - |
1344 | _rl_init_file_error ("$else found without matching $if"); | - |
1345 | return 0; never executed: return 0; | 0 |
1346 | } | - |
1347 | | - |
1348 | #if 0 | - |
1349 | | - |
1350 | | - |
1351 | for (i = 0; i < if_stack_depth - 1; i++) | - |
1352 | #else | - |
1353 | | - |
1354 | | - |
1355 | for (i = 0; i < if_stack_depth; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1356 | #endif | - |
1357 | if (if_stack[i] == 1)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1358 | return 0; never executed: return 0; | 0 |
1359 | | - |
1360 | | - |
1361 | _rl_parsing_conditionalized_out = !_rl_parsing_conditionalized_out; | - |
1362 | return 0; never executed: return 0; | 0 |
1363 | } | - |
1364 | | - |
1365 | | - |
1366 | | - |
1367 | static int | - |
1368 | parser_endif (char *args) | - |
1369 | { | - |
1370 | if (if_stack_depth)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1371 | _rl_parsing_conditionalized_out = if_stack[--if_stack_depth]; never executed: _rl_parsing_conditionalized_out = if_stack[--if_stack_depth]; | 0 |
1372 | else | - |
1373 | _rl_init_file_error ("$endif without matching $if"); never executed: _rl_init_file_error ("$endif without matching $if"); | 0 |
1374 | return 0; never executed: return 0; | 0 |
1375 | } | - |
1376 | | - |
1377 | static int | - |
1378 | parser_include (char *args) | - |
1379 | { | - |
1380 | const char *old_init_file; | - |
1381 | char *e; | - |
1382 | int old_line_number, old_include_level, r; | - |
1383 | | - |
1384 | if (_rl_parsing_conditionalized_out)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1385 | return (0); never executed: return (0); | 0 |
1386 | | - |
1387 | old_init_file = current_readline_init_file; | - |
1388 | old_line_number = current_readline_init_lineno; | - |
1389 | old_include_level = current_readline_init_include_level; | - |
1390 | | - |
1391 | e = strchr (args, '\n');TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1392 | if (e)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1393 | *e = '\0'; never executed: *e = '\0'; | 0 |
1394 | r = _rl_read_init_file ((const char *)args, old_include_level + 1); | - |
1395 | | - |
1396 | current_readline_init_file = old_init_file; | - |
1397 | current_readline_init_lineno = old_line_number; | - |
1398 | current_readline_init_include_level = old_include_level; | - |
1399 | | - |
1400 | return r; never executed: return r; | 0 |
1401 | } | - |
1402 | | - |
1403 | | - |
1404 | static const struct { | - |
1405 | const char * const name; | - |
1406 | _rl_parser_func_t *function; | - |
1407 | } parser_directives [] = { | - |
1408 | { "if", parser_if }, | - |
1409 | { "endif", parser_endif }, | - |
1410 | { "else", parser_else }, | - |
1411 | { "include", parser_include }, | - |
1412 | { (char *)0x0, (_rl_parser_func_t *)0x0 } | - |
1413 | }; | - |
1414 | | - |
1415 | | - |
1416 | | - |
1417 | static int | - |
1418 | handle_parser_directive (char *statement) | - |
1419 | { | - |
1420 | register int i; | - |
1421 | char *directive, *args; | - |
1422 | | - |
1423 | | - |
1424 | | - |
1425 | | - |
1426 | for (i = 0; whitespace (statement[i]); i++); never executed: ; TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1427 | | - |
1428 | directive = &statement[i]; | - |
1429 | | - |
1430 | for (; statement[i] && !whitespace (statement[i]); i++); never executed: ; TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1431 | | - |
1432 | if (statement[i])TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1433 | statement[i++] = '\0'; never executed: statement[i++] = '\0'; | 0 |
1434 | | - |
1435 | for (; statement[i] && whitespace (statement[i]); i++); never executed: ; TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1436 | | - |
1437 | args = &statement[i]; | - |
1438 | | - |
1439 | | - |
1440 | for (i = 0; parser_directives[i].name; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1441 | if (_rl_stricmp (directive, parser_directives[i].name) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1442 | { | - |
1443 | (*parser_directives[i].function) (args); | - |
1444 | return (0); never executed: return (0); | 0 |
1445 | } | - |
1446 | | - |
1447 | | - |
1448 | _rl_init_file_error ("%s: unknown parser directive", directive); | - |
1449 | return (1); never executed: return (1); | 0 |
1450 | } | - |
1451 | | - |
1452 | | - |
1453 | | - |
1454 | static int | - |
1455 | _rl_skip_to_delim (char *string, int start, int delim) | - |
1456 | { | - |
1457 | int i, c, passc; | - |
1458 | | - |
1459 | for (i = start,passc = 0; c = string[i]; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1460 | { | - |
1461 | if (passc)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1462 | { | - |
1463 | passc = 0; | - |
1464 | if (c == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1465 | break; never executed: break; | 0 |
1466 | continue; never executed: continue; | 0 |
1467 | } | - |
1468 | | - |
1469 | if (c == '\\')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1470 | { | - |
1471 | passc = 1; | - |
1472 | continue; never executed: continue; | 0 |
1473 | } | - |
1474 | | - |
1475 | if (c == delim)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1476 | break; never executed: break; | 0 |
1477 | } never executed: end of block | 0 |
1478 | | - |
1479 | return i; never executed: return i; | 0 |
1480 | } | - |
1481 | | - |
1482 | | - |
1483 | | - |
1484 | | - |
1485 | | - |
1486 | int | - |
1487 | rl_parse_and_bind (char *string) | - |
1488 | { | - |
1489 | char *funname, *kname; | - |
1490 | register int c, i; | - |
1491 | int key, equivalency, foundmod, foundsep; | - |
1492 | | - |
1493 | while (string && whitespace (*string))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1494 | string++; never executed: string++; | 0 |
1495 | | - |
1496 | if (string == 0 || *string == 0 || *string == '#')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1497 | return 0; never executed: return 0; | 0 |
1498 | | - |
1499 | | - |
1500 | if (*string == '$')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1501 | { | - |
1502 | handle_parser_directive (&string[1]); | - |
1503 | return 0; never executed: return 0; | 0 |
1504 | } | - |
1505 | | - |
1506 | | - |
1507 | if (_rl_parsing_conditionalized_out)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1508 | return 0; never executed: return 0; | 0 |
1509 | | - |
1510 | i = 0; | - |
1511 | | - |
1512 | | - |
1513 | | - |
1514 | if (*string == '"')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1515 | { | - |
1516 | i = _rl_skip_to_delim (string, 1, '"'); | - |
1517 | | - |
1518 | | - |
1519 | if (string[i] == '\0')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1520 | { | - |
1521 | _rl_init_file_error ("%s: no closing `\"' in key binding", string); | - |
1522 | return 1; never executed: return 1; | 0 |
1523 | } | - |
1524 | else | - |
1525 | i++; never executed: i++; | 0 |
1526 | } | - |
1527 | | - |
1528 | | - |
1529 | for (; (c = string[i]) && c != ':' && c != ' ' && c != '\t'; i++ ); never executed: ; 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 |
1530 | | - |
1531 | if (i == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1532 | { | - |
1533 | _rl_init_file_error ("`%s': invalid key binding: missing key sequence", string); | - |
1534 | return 1; never executed: return 1; | 0 |
1535 | } | - |
1536 | | - |
1537 | equivalency = (c == ':' && string[i + 1] == '=');TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1538 | | - |
1539 | foundsep = c != 0; | - |
1540 | | - |
1541 | | - |
1542 | if (string[i])TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1543 | string[i++] = '\0'; never executed: string[i++] = '\0'; | 0 |
1544 | | - |
1545 | | - |
1546 | if (equivalency)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1547 | string[i++] = '\0'; never executed: string[i++] = '\0'; | 0 |
1548 | | - |
1549 | | - |
1550 | if (_rl_stricmp (string, "set") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1551 | { | - |
1552 | char *var, *value, *e; | - |
1553 | int s; | - |
1554 | | - |
1555 | var = string + i; | - |
1556 | | - |
1557 | while (*var && whitespace (*var)) var++; never executed: var++; TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1558 | | - |
1559 | | - |
1560 | value = var; | - |
1561 | while (*value && whitespace (*value) == 0) value++; never executed: value++; 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 |
1562 | if (*value)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1563 | *value++ = '\0'; never executed: *value++ = '\0'; | 0 |
1564 | while (*value && whitespace (*value)) value++; never executed: value++; TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1565 | | - |
1566 | | - |
1567 | if (find_boolean_var (var) >= 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1568 | { | - |
1569 | | - |
1570 | remove_trailing: | - |
1571 | e = value + strlen (value) - 1; | - |
1572 | while (e >= value && whitespace (*e))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1573 | e--; never executed: e--; | 0 |
1574 | e++; | - |
1575 | | - |
1576 | if (*e && e >= value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1577 | *e = '\0'; never executed: *e = '\0'; | 0 |
1578 | } never executed: end of block | 0 |
1579 | else if ((i = find_string_var (var)) >= 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1580 | { | - |
1581 | | - |
1582 | if (*value == '"')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1583 | { | - |
1584 | i = _rl_skip_to_delim (value, 1, *value); | - |
1585 | value[i] = '\0'; | - |
1586 | value++; | - |
1587 | } never executed: end of block | 0 |
1588 | else | - |
1589 | goto remove_trailing; never executed: goto remove_trailing; | 0 |
1590 | } | - |
1591 | | - |
1592 | rl_variable_bind (var, value); | - |
1593 | return 0; never executed: return 0; | 0 |
1594 | } | - |
1595 | | - |
1596 | | - |
1597 | for (; string[i] && whitespace (string[i]); i++); never executed: ; TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1598 | funname = &string[i]; | - |
1599 | | - |
1600 | | - |
1601 | | - |
1602 | | - |
1603 | | - |
1604 | | - |
1605 | | - |
1606 | | - |
1607 | | - |
1608 | | - |
1609 | | - |
1610 | if (*funname == '\'' || *funname == '"')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1611 | { | - |
1612 | i = _rl_skip_to_delim (string, i+1, *funname); | - |
1613 | if (string[i])TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1614 | i++; never executed: i++; | 0 |
1615 | else | - |
1616 | { | - |
1617 | _rl_init_file_error ("`%s': missing closing quote for macro", funname); | - |
1618 | return 1; never executed: return 1; | 0 |
1619 | } | - |
1620 | } | - |
1621 | | - |
1622 | | - |
1623 | for (; string[i] && whitespace (string[i]) == 0; i++); never executed: ; 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 |
1624 | | - |
1625 | | - |
1626 | string[i] = '\0'; | - |
1627 | | - |
1628 | | - |
1629 | | - |
1630 | if (equivalency)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1631 | { | - |
1632 | return 0; never executed: return 0; | 0 |
1633 | } | - |
1634 | | - |
1635 | if (foundsep == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1636 | { | - |
1637 | _rl_init_file_error ("%s: no key sequence terminator", string); | - |
1638 | return 1; never executed: return 1; | 0 |
1639 | } | - |
1640 | | - |
1641 | | - |
1642 | | - |
1643 | if (*string == '"')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1644 | { | - |
1645 | char *seq; | - |
1646 | register int j, k, passc; | - |
1647 | | - |
1648 | seq = (char *)xmalloc (1 + strlen (string)); | - |
1649 | for (j = 1, k = passc = 0; string[j]; j++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1650 | { | - |
1651 | | - |
1652 | | - |
1653 | | - |
1654 | | - |
1655 | if (passc || (string[j] == '\\'))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1656 | { | - |
1657 | seq[k++] = string[j]; | - |
1658 | passc = !passc; | - |
1659 | continue; never executed: continue; | 0 |
1660 | } | - |
1661 | | - |
1662 | if (string[j] == '"')TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1663 | break; never executed: break; | 0 |
1664 | | - |
1665 | seq[k++] = string[j]; | - |
1666 | } never executed: end of block | 0 |
1667 | seq[k] = '\0'; | - |
1668 | | - |
1669 | | - |
1670 | if (*funname == '\'' || *funname == '"')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1671 | { | - |
1672 | j = strlen (funname); | - |
1673 | | - |
1674 | | - |
1675 | if (j && funname[j - 1] == *funname)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1676 | funname[j - 1] = '\0'; never executed: funname[j - 1] = '\0'; | 0 |
1677 | | - |
1678 | rl_macro_bind (seq, &funname[1], _rl_keymap); | - |
1679 | } never executed: end of block | 0 |
1680 | else | - |
1681 | rl_bind_keyseq (seq, rl_named_function (funname)); never executed: rl_bind_keyseq (seq, rl_named_function (funname)); | 0 |
1682 | | - |
1683 | xfree (seq); | - |
1684 | return 0; never executed: return 0; | 0 |
1685 | } | - |
1686 | | - |
1687 | | - |
1688 | kname = strrchr (string, '-'); | - |
1689 | if (kname == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1690 | kname = string; never executed: kname = string; | 0 |
1691 | else | - |
1692 | kname++; never executed: kname++; | 0 |
1693 | | - |
1694 | key = glean_key_from_name (kname); | - |
1695 | | - |
1696 | | - |
1697 | foundmod = 0; | - |
1698 | if (substring_member_of_array (string, _rl_possible_control_prefixes))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1699 | { | - |
1700 | key = CTRL (_rl_to_upper (key)); never executed: end of block never executed: __res = toupper ( (unsigned char)key ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)key )]; 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 |
1701 | foundmod = 1; | - |
1702 | } never executed: end of block | 0 |
1703 | | - |
1704 | if (substring_member_of_array (string, _rl_possible_meta_prefixes))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1705 | { | - |
1706 | key = META (key); | - |
1707 | foundmod = 1; | - |
1708 | } never executed: end of block | 0 |
1709 | | - |
1710 | if (foundmod == 0 && kname != string)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1711 | { | - |
1712 | _rl_init_file_error ("%s: unknown key modifier", string); | - |
1713 | return 1; never executed: return 1; | 0 |
1714 | } | - |
1715 | | - |
1716 | | - |
1717 | if (*funname == '\'' || *funname == '"')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1718 | { | - |
1719 | char useq[2]; | - |
1720 | int fl = strlen (funname); | - |
1721 | | - |
1722 | useq[0] = key; useq[1] = '\0'; | - |
1723 | if (fl && funname[fl - 1] == *funname)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1724 | funname[fl - 1] = '\0'; never executed: funname[fl - 1] = '\0'; | 0 |
1725 | | - |
1726 | rl_macro_bind (useq, &funname[1], _rl_keymap); | - |
1727 | } never executed: end of block | 0 |
1728 | #if defined (PREFIX_META_HACK) | - |
1729 | | - |
1730 | else if (_rl_stricmp (funname, "prefix-meta") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1731 | { | - |
1732 | char seq[2]; | - |
1733 | | - |
1734 | seq[0] = key; | - |
1735 | seq[1] = '\0'; | - |
1736 | rl_generic_bind (ISKMAP, seq, (char *)emacs_meta_keymap, _rl_keymap); | - |
1737 | } never executed: end of block | 0 |
1738 | #endif /* PREFIX_META_HACK */ | - |
1739 | else | - |
1740 | rl_bind_key (key, rl_named_function (funname)); never executed: rl_bind_key (key, rl_named_function (funname)); | 0 |
1741 | | - |
1742 | return 0; never executed: return 0; | 0 |
1743 | } | - |
1744 | | - |
1745 | | - |
1746 | | - |
1747 | | - |
1748 | | - |
1749 | #define V_SPECIAL 0x1 | - |
1750 | | - |
1751 | static const struct { | - |
1752 | const char * const name; | - |
1753 | int *value; | - |
1754 | int flags; | - |
1755 | } boolean_varlist [] = { | - |
1756 | { "bind-tty-special-chars", &_rl_bind_stty_chars, 0 }, | - |
1757 | { "blink-matching-paren", &rl_blink_matching_paren, V_SPECIAL }, | - |
1758 | { "byte-oriented", &rl_byte_oriented, 0 }, | - |
1759 | #if defined (COLOR_SUPPORT) | - |
1760 | { "colored-completion-prefix",&_rl_colored_completion_prefix, 0 }, | - |
1761 | { "colored-stats", &_rl_colored_stats, 0 }, | - |
1762 | #endif | - |
1763 | { "completion-ignore-case", &_rl_completion_case_fold, 0 }, | - |
1764 | { "completion-map-case", &_rl_completion_case_map, 0 }, | - |
1765 | { "convert-meta", &_rl_convert_meta_chars_to_ascii, 0 }, | - |
1766 | { "disable-completion", &rl_inhibit_completion, 0 }, | - |
1767 | { "echo-control-characters", &_rl_echo_control_chars, 0 }, | - |
1768 | { "enable-bracketed-paste", &_rl_enable_bracketed_paste, 0 }, | - |
1769 | { "enable-keypad", &_rl_enable_keypad, 0 }, | - |
1770 | { "enable-meta-key", &_rl_enable_meta, 0 }, | - |
1771 | { "expand-tilde", &rl_complete_with_tilde_expansion, 0 }, | - |
1772 | { "history-preserve-point", &_rl_history_preserve_point, 0 }, | - |
1773 | { "horizontal-scroll-mode", &_rl_horizontal_scroll_mode, 0 }, | - |
1774 | { "input-meta", &_rl_meta_flag, 0 }, | - |
1775 | { "mark-directories", &_rl_complete_mark_directories, 0 }, | - |
1776 | { "mark-modified-lines", &_rl_mark_modified_lines, 0 }, | - |
1777 | { "mark-symlinked-directories", &_rl_complete_mark_symlink_dirs, 0 }, | - |
1778 | { "match-hidden-files", &_rl_match_hidden_files, 0 }, | - |
1779 | { "menu-complete-display-prefix", &_rl_menu_complete_prefix_first, 0 }, | - |
1780 | { "meta-flag", &_rl_meta_flag, 0 }, | - |
1781 | { "output-meta", &_rl_output_meta_chars, 0 }, | - |
1782 | { "page-completions", &_rl_page_completions, 0 }, | - |
1783 | { "prefer-visible-bell", &_rl_prefer_visible_bell, V_SPECIAL }, | - |
1784 | { "print-completions-horizontally", &_rl_print_completions_horizontally, 0 }, | - |
1785 | { "revert-all-at-newline", &_rl_revert_all_at_newline, 0 }, | - |
1786 | { "show-all-if-ambiguous", &_rl_complete_show_all, 0 }, | - |
1787 | { "show-all-if-unmodified", &_rl_complete_show_unmodified, 0 }, | - |
1788 | { "show-mode-in-prompt", &_rl_show_mode_in_prompt, 0 }, | - |
1789 | { "skip-completed-text", &_rl_skip_completed_text, 0 }, | - |
1790 | #if defined (VISIBLE_STATS) | - |
1791 | { "visible-stats", &rl_visible_stats, 0 }, | - |
1792 | #endif /* VISIBLE_STATS */ | - |
1793 | { (char *)NULL, (int *)NULL, 0 } | - |
1794 | }; | - |
1795 | | - |
1796 | static int | - |
1797 | find_boolean_var (const char *name) | - |
1798 | { | - |
1799 | register int i; | - |
1800 | | - |
1801 | for (i = 0; boolean_varlist[i].name; i++)TRUE | evaluated 33 times by 1 test | FALSE | evaluated 1 time by 1 test |
| 1-33 |
1802 | if (_rl_stricmp (name, boolean_varlist[i].name) == 0)TRUE | never evaluated | FALSE | evaluated 33 times by 1 test |
| 0-33 |
1803 | return i; never executed: return i; | 0 |
1804 | return -1;executed 1 time by 1 test: return -1; | 1 |
1805 | } | - |
1806 | | - |
1807 | static const char * | - |
1808 | boolean_varname (int i) | - |
1809 | { | - |
1810 | return ((i >= 0) ? boolean_varlist[i].name : (char *)NULL); never executed: return ((i >= 0) ? boolean_varlist[i].name : (char *) ((void *)0) ); | 0 |
1811 | } | - |
1812 | | - |
1813 | | - |
1814 | | - |
1815 | | - |
1816 | static void | - |
1817 | hack_special_boolean_var (int i) | - |
1818 | { | - |
1819 | const char *name; | - |
1820 | | - |
1821 | name = boolean_varlist[i].name; | - |
1822 | | - |
1823 | if (_rl_stricmp (name, "blink-matching-paren") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1824 | _rl_enable_paren_matching (rl_blink_matching_paren); never executed: _rl_enable_paren_matching (rl_blink_matching_paren); | 0 |
1825 | else if (_rl_stricmp (name, "prefer-visible-bell") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1826 | { | - |
1827 | if (_rl_prefer_visible_bell)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1828 | _rl_bell_preference = VISIBLE_BELL; never executed: _rl_bell_preference = 2; | 0 |
1829 | else | - |
1830 | _rl_bell_preference = AUDIBLE_BELL; never executed: _rl_bell_preference = 1; | 0 |
1831 | } | - |
1832 | else if (_rl_stricmp (name, "show-mode-in-prompt") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1833 | _rl_reset_prompt (); never executed: _rl_reset_prompt (); | 0 |
1834 | } never executed: end of block | 0 |
1835 | | - |
1836 | typedef int _rl_sv_func_t PARAMS((const char *)); | - |
1837 | | - |
1838 | | - |
1839 | | - |
1840 | #define V_BELLSTYLE 0 | - |
1841 | #define V_COMBEGIN 1 | - |
1842 | #define V_EDITMODE 2 | - |
1843 | #define V_ISRCHTERM 3 | - |
1844 | #define V_KEYMAP 4 | - |
1845 | | - |
1846 | #define V_STRING 1 | - |
1847 | #define V_INT 2 | - |
1848 | | - |
1849 | | - |
1850 | static int sv_bell_style PARAMS((const char *)); | - |
1851 | static int sv_combegin PARAMS((const char *)); | - |
1852 | static int sv_dispprefix PARAMS((const char *)); | - |
1853 | static int sv_compquery PARAMS((const char *)); | - |
1854 | static int sv_compwidth PARAMS((const char *)); | - |
1855 | static int sv_editmode PARAMS((const char *)); | - |
1856 | static int sv_emacs_modestr PARAMS((const char *)); | - |
1857 | static int sv_histsize PARAMS((const char *)); | - |
1858 | static int sv_isrchterm PARAMS((const char *)); | - |
1859 | static int sv_keymap PARAMS((const char *)); | - |
1860 | static int sv_seqtimeout PARAMS((const char *)); | - |
1861 | static int sv_viins_modestr PARAMS((const char *)); | - |
1862 | static int sv_vicmd_modestr PARAMS((const char *)); | - |
1863 | | - |
1864 | static const struct { | - |
1865 | const char * const name; | - |
1866 | int flags; | - |
1867 | _rl_sv_func_t *set_func; | - |
1868 | } string_varlist[] = { | - |
1869 | { "bell-style", V_STRING, sv_bell_style }, | - |
1870 | { "comment-begin", V_STRING, sv_combegin }, | - |
1871 | { "completion-display-width", V_INT, sv_compwidth }, | - |
1872 | { "completion-prefix-display-length", V_INT, sv_dispprefix }, | - |
1873 | { "completion-query-items", V_INT, sv_compquery }, | - |
1874 | { "editing-mode", V_STRING, sv_editmode }, | - |
1875 | { "emacs-mode-string", V_STRING, sv_emacs_modestr }, | - |
1876 | { "history-size", V_INT, sv_histsize }, | - |
1877 | { "isearch-terminators", V_STRING, sv_isrchterm }, | - |
1878 | { "keymap", V_STRING, sv_keymap }, | - |
1879 | { "keyseq-timeout", V_INT, sv_seqtimeout }, | - |
1880 | { "vi-cmd-mode-string", V_STRING, sv_vicmd_modestr }, | - |
1881 | { "vi-ins-mode-string", V_STRING, sv_viins_modestr }, | - |
1882 | { (char *)NULL, 0, (_rl_sv_func_t *)0 } | - |
1883 | }; | - |
1884 | | - |
1885 | static int | - |
1886 | find_string_var (const char *name) | - |
1887 | { | - |
1888 | register int i; | - |
1889 | | - |
1890 | for (i = 0; string_varlist[i].name; i++)TRUE | evaluated 6 times by 1 test | FALSE | never evaluated |
| 0-6 |
1891 | if (_rl_stricmp (name, string_varlist[i].name) == 0)TRUE | evaluated 1 time by 1 test | FALSE | evaluated 5 times by 1 test |
| 1-5 |
1892 | return i;executed 1 time by 1 test: return i; | 1 |
1893 | return -1; never executed: return -1; | 0 |
1894 | } | - |
1895 | | - |
1896 | static const char * | - |
1897 | string_varname (int i) | - |
1898 | { | - |
1899 | return ((i >= 0) ? string_varlist[i].name : (char *)NULL); never executed: return ((i >= 0) ? string_varlist[i].name : (char *) ((void *)0) ); | 0 |
1900 | } | - |
1901 | | - |
1902 | | - |
1903 | | - |
1904 | | - |
1905 | static int | - |
1906 | bool_to_int (const char *value) | - |
1907 | { | - |
1908 | return (value == 0 || *value == '\0' || never executed: return (value == 0 || *value == '\0' || (strcasecmp (value, "on") == 0) || (value[0] == '1' && value[1] == '\0')); | 0 |
1909 | (_rl_stricmp (value, "on") == 0) || never executed: return (value == 0 || *value == '\0' || (strcasecmp (value, "on") == 0) || (value[0] == '1' && value[1] == '\0')); | 0 |
1910 | (value[0] == '1' && value[1] == '\0')); never executed: return (value == 0 || *value == '\0' || (strcasecmp (value, "on") == 0) || (value[0] == '1' && value[1] == '\0')); | 0 |
1911 | } | - |
1912 | | - |
1913 | char * | - |
1914 | rl_variable_value (const char *name) | - |
1915 | { | - |
1916 | register int i; | - |
1917 | | - |
1918 | | - |
1919 | i = find_boolean_var (name); | - |
1920 | if (i >= 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1921 | return (*boolean_varlist[i].value ? "on" : "off"); never executed: return (*boolean_varlist[i].value ? "on" : "off"); | 0 |
1922 | | - |
1923 | i = find_string_var (name); | - |
1924 | if (i >= 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1925 | return (_rl_get_string_variable_value (string_varlist[i].name)); never executed: return (_rl_get_string_variable_value (string_varlist[i].name)); | 0 |
1926 | | - |
1927 | | - |
1928 | return 0; never executed: return 0; | 0 |
1929 | } | - |
1930 | | - |
1931 | int | - |
1932 | rl_variable_bind (const char *name, const char *value) | - |
1933 | { | - |
1934 | register int i; | - |
1935 | int v; | - |
1936 | | - |
1937 | | - |
1938 | i = find_boolean_var (name); | - |
1939 | if (i >= 0)TRUE | never evaluated | FALSE | evaluated 1 time by 1 test |
| 0-1 |
1940 | { | - |
1941 | *boolean_varlist[i].value = bool_to_int (value); | - |
1942 | if (boolean_varlist[i].flags & V_SPECIAL)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1943 | hack_special_boolean_var (i); never executed: hack_special_boolean_var (i); | 0 |
1944 | return 0; never executed: return 0; | 0 |
1945 | } | - |
1946 | | - |
1947 | i = find_string_var (name); | - |
1948 | | - |
1949 | | - |
1950 | | - |
1951 | if (i < 0 || string_varlist[i].set_func == 0)TRUE | never evaluated | FALSE | evaluated 1 time by 1 test |
TRUE | never evaluated | FALSE | evaluated 1 time by 1 test |
| 0-1 |
1952 | { | - |
1953 | if (i < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1954 | _rl_init_file_error ("%s: unknown variable name", name); never executed: _rl_init_file_error ("%s: unknown variable name", name); | 0 |
1955 | return 0; never executed: return 0; | 0 |
1956 | } | - |
1957 | | - |
1958 | v = (*string_varlist[i].set_func) (value); | - |
1959 | return v;executed 1 time by 1 test: return v; | 1 |
1960 | } | - |
1961 | | - |
1962 | static int | - |
1963 | sv_editmode (const char *value) | - |
1964 | { | - |
1965 | if (_rl_strnicmp (value, "vi", 2) == 0)TRUE | never evaluated | FALSE | evaluated 1 time by 1 test |
| 0-1 |
1966 | { | - |
1967 | #if defined (VI_MODE) | - |
1968 | _rl_keymap = vi_insertion_keymap; | - |
1969 | rl_editing_mode = vi_mode; | - |
1970 | #endif /* VI_MODE */ | - |
1971 | return 0; never executed: return 0; | 0 |
1972 | } | - |
1973 | else if (_rl_strnicmp (value, "emacs", 5) == 0)TRUE | evaluated 1 time by 1 test | FALSE | never evaluated |
| 0-1 |
1974 | { | - |
1975 | _rl_keymap = emacs_standard_keymap; | - |
1976 | rl_editing_mode = emacs_mode; | - |
1977 | return 0;executed 1 time by 1 test: return 0; | 1 |
1978 | } | - |
1979 | return 1; never executed: return 1; | 0 |
1980 | } | - |
1981 | | - |
1982 | static int | - |
1983 | sv_combegin (const char *value) | - |
1984 | { | - |
1985 | if (value && *value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1986 | { | - |
1987 | FREE (_rl_comment_begin); never executed: free (_rl_comment_begin); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
1988 | _rl_comment_begin = savestring (value); | - |
1989 | return 0; never executed: return 0; | 0 |
1990 | } | - |
1991 | return 1; never executed: return 1; | 0 |
1992 | } | - |
1993 | | - |
1994 | static int | - |
1995 | sv_dispprefix (const char *value) | - |
1996 | { | - |
1997 | int nval = 0; | - |
1998 | | - |
1999 | if (value && *value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2000 | { | - |
2001 | nval = atoi (value); | - |
2002 | if (nval < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2003 | nval = 0; never executed: nval = 0; | 0 |
2004 | } never executed: end of block | 0 |
2005 | _rl_completion_prefix_display_length = nval; | - |
2006 | return 0; never executed: return 0; | 0 |
2007 | } | - |
2008 | | - |
2009 | static int | - |
2010 | sv_compquery (const char *value) | - |
2011 | { | - |
2012 | int nval = 100; | - |
2013 | | - |
2014 | if (value && *value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2015 | { | - |
2016 | nval = atoi (value); | - |
2017 | if (nval < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2018 | nval = 0; never executed: nval = 0; | 0 |
2019 | } never executed: end of block | 0 |
2020 | rl_completion_query_items = nval; | - |
2021 | return 0; never executed: return 0; | 0 |
2022 | } | - |
2023 | | - |
2024 | static int | - |
2025 | sv_compwidth (const char *value) | - |
2026 | { | - |
2027 | int nval = -1; | - |
2028 | | - |
2029 | if (value && *value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2030 | nval = atoi (value); never executed: nval = atoi (value); | 0 |
2031 | | - |
2032 | _rl_completion_columns = nval; | - |
2033 | return 0; never executed: return 0; | 0 |
2034 | } | - |
2035 | | - |
2036 | static int | - |
2037 | sv_histsize (const char *value) | - |
2038 | { | - |
2039 | int nval; | - |
2040 | | - |
2041 | nval = 500; | - |
2042 | if (value && *value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2043 | { | - |
2044 | nval = atoi (value); | - |
2045 | if (nval < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2046 | { | - |
2047 | unstifle_history (); | - |
2048 | return 0; never executed: return 0; | 0 |
2049 | } | - |
2050 | } never executed: end of block | 0 |
2051 | stifle_history (nval); | - |
2052 | return 0; never executed: return 0; | 0 |
2053 | } | - |
2054 | | - |
2055 | static int | - |
2056 | sv_keymap (const char *value) | - |
2057 | { | - |
2058 | Keymap kmap; | - |
2059 | | - |
2060 | kmap = rl_get_keymap_by_name (value); | - |
2061 | if (kmap)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2062 | { | - |
2063 | rl_set_keymap (kmap); | - |
2064 | return 0; never executed: return 0; | 0 |
2065 | } | - |
2066 | return 1; never executed: return 1; | 0 |
2067 | } | - |
2068 | | - |
2069 | static int | - |
2070 | sv_seqtimeout (const char *value) | - |
2071 | { | - |
2072 | int nval; | - |
2073 | | - |
2074 | nval = 0; | - |
2075 | if (value && *value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2076 | { | - |
2077 | nval = atoi (value); | - |
2078 | if (nval < 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2079 | nval = 0; never executed: nval = 0; | 0 |
2080 | } never executed: end of block | 0 |
2081 | _rl_keyseq_timeout = nval; | - |
2082 | return 0; never executed: return 0; | 0 |
2083 | } | - |
2084 | | - |
2085 | static int | - |
2086 | sv_bell_style (const char *value) | - |
2087 | { | - |
2088 | if (value == 0 || *value == '\0')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2089 | _rl_bell_preference = AUDIBLE_BELL; never executed: _rl_bell_preference = 1; | 0 |
2090 | else if (_rl_stricmp (value, "none") == 0 || _rl_stricmp (value, "off") == 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2091 | _rl_bell_preference = NO_BELL; never executed: _rl_bell_preference = 0; | 0 |
2092 | else if (_rl_stricmp (value, "audible") == 0 || _rl_stricmp (value, "on") == 0)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2093 | _rl_bell_preference = AUDIBLE_BELL; never executed: _rl_bell_preference = 1; | 0 |
2094 | else if (_rl_stricmp (value, "visible") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2095 | _rl_bell_preference = VISIBLE_BELL; never executed: _rl_bell_preference = 2; | 0 |
2096 | else | - |
2097 | return 1; never executed: return 1; | 0 |
2098 | return 0; never executed: return 0; | 0 |
2099 | } | - |
2100 | | - |
2101 | static int | - |
2102 | sv_isrchterm (const char *value) | - |
2103 | { | - |
2104 | int beg, end, delim; | - |
2105 | char *v; | - |
2106 | | - |
2107 | if (value == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2108 | return 1; never executed: return 1; | 0 |
2109 | | - |
2110 | | - |
2111 | v = savestring (value); | - |
2112 | FREE (_rl_isearch_terminators); never executed: free (_rl_isearch_terminators); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2113 | if (v[0] == '"' || v[0] == '\'')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2114 | { | - |
2115 | delim = v[0]; | - |
2116 | for (beg = end = 1; v[end] && v[end] != delim; end++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2117 | ; never executed: ; | 0 |
2118 | } never executed: end of block | 0 |
2119 | else | - |
2120 | { | - |
2121 | for (beg = end = 0; v[end] && whitespace (v[end]) == 0; end++)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 |
2122 | ; never executed: ; | 0 |
2123 | } never executed: end of block | 0 |
2124 | | - |
2125 | v[end] = '\0'; | - |
2126 | | - |
2127 | | - |
2128 | _rl_isearch_terminators = (char *)xmalloc (2 * strlen (v) + 1); | - |
2129 | rl_translate_keyseq (v + beg, _rl_isearch_terminators, &end); | - |
2130 | _rl_isearch_terminators[end] = '\0'; | - |
2131 | | - |
2132 | xfree (v); | - |
2133 | return 0; never executed: return 0; | 0 |
2134 | } | - |
2135 | | - |
2136 | extern char *_rl_emacs_mode_str; | - |
2137 | | - |
2138 | static int | - |
2139 | sv_emacs_modestr (const char *value) | - |
2140 | { | - |
2141 | if (value && *value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2142 | { | - |
2143 | FREE (_rl_emacs_mode_str); never executed: free (_rl_emacs_mode_str); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2144 | _rl_emacs_mode_str = (char *)xmalloc (2 * strlen (value) + 1); | - |
2145 | rl_translate_keyseq (value, _rl_emacs_mode_str, &_rl_emacs_modestr_len); | - |
2146 | _rl_emacs_mode_str[_rl_emacs_modestr_len] = '\0'; | - |
2147 | return 0; never executed: return 0; | 0 |
2148 | } | - |
2149 | else if (value)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2150 | { | - |
2151 | FREE (_rl_emacs_mode_str); never executed: free (_rl_emacs_mode_str); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2152 | _rl_emacs_mode_str = (char *)xmalloc (1); | - |
2153 | _rl_emacs_mode_str[_rl_emacs_modestr_len = 0] = '\0'; | - |
2154 | return 0; never executed: return 0; | 0 |
2155 | } | - |
2156 | else if (value == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2157 | { | - |
2158 | FREE (_rl_emacs_mode_str); never executed: free (_rl_emacs_mode_str); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2159 | _rl_emacs_mode_str = 0; | - |
2160 | _rl_emacs_modestr_len = 0; | - |
2161 | return 0; never executed: return 0; | 0 |
2162 | } | - |
2163 | return 1; never executed: return 1; | 0 |
2164 | } | - |
2165 | | - |
2166 | static int | - |
2167 | sv_viins_modestr (const char *value) | - |
2168 | { | - |
2169 | if (value && *value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2170 | { | - |
2171 | FREE (_rl_vi_ins_mode_str); never executed: free (_rl_vi_ins_mode_str); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2172 | _rl_vi_ins_mode_str = (char *)xmalloc (2 * strlen (value) + 1); | - |
2173 | rl_translate_keyseq (value, _rl_vi_ins_mode_str, &_rl_vi_ins_modestr_len); | - |
2174 | _rl_vi_ins_mode_str[_rl_vi_ins_modestr_len] = '\0'; | - |
2175 | return 0; never executed: return 0; | 0 |
2176 | } | - |
2177 | else if (value)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2178 | { | - |
2179 | FREE (_rl_vi_ins_mode_str); never executed: free (_rl_vi_ins_mode_str); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2180 | _rl_vi_ins_mode_str = (char *)xmalloc (1); | - |
2181 | _rl_vi_ins_mode_str[_rl_vi_ins_modestr_len = 0] = '\0'; | - |
2182 | return 0; never executed: return 0; | 0 |
2183 | } | - |
2184 | else if (value == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2185 | { | - |
2186 | FREE (_rl_vi_ins_mode_str); never executed: free (_rl_vi_ins_mode_str); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2187 | _rl_vi_ins_mode_str = 0; | - |
2188 | _rl_vi_ins_modestr_len = 0; | - |
2189 | return 0; never executed: return 0; | 0 |
2190 | } | - |
2191 | return 1; never executed: return 1; | 0 |
2192 | } | - |
2193 | | - |
2194 | static int | - |
2195 | sv_vicmd_modestr (const char *value) | - |
2196 | { | - |
2197 | if (value && *value)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2198 | { | - |
2199 | FREE (_rl_vi_cmd_mode_str); never executed: free (_rl_vi_cmd_mode_str); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2200 | _rl_vi_cmd_mode_str = (char *)xmalloc (2 * strlen (value) + 1); | - |
2201 | rl_translate_keyseq (value, _rl_vi_cmd_mode_str, &_rl_vi_cmd_modestr_len); | - |
2202 | _rl_vi_cmd_mode_str[_rl_vi_cmd_modestr_len] = '\0'; | - |
2203 | return 0; never executed: return 0; | 0 |
2204 | } | - |
2205 | else if (value)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2206 | { | - |
2207 | FREE (_rl_vi_cmd_mode_str); never executed: free (_rl_vi_cmd_mode_str); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2208 | _rl_vi_cmd_mode_str = (char *)xmalloc (1); | - |
2209 | _rl_vi_cmd_mode_str[_rl_vi_cmd_modestr_len = 0] = '\0'; | - |
2210 | return 0; never executed: return 0; | 0 |
2211 | } | - |
2212 | else if (value == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2213 | { | - |
2214 | FREE (_rl_vi_cmd_mode_str); never executed: free (_rl_vi_cmd_mode_str); TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2215 | _rl_vi_cmd_mode_str = 0; | - |
2216 | _rl_vi_cmd_modestr_len = 0; | - |
2217 | return 0; never executed: return 0; | 0 |
2218 | } | - |
2219 | return 1; never executed: return 1; | 0 |
2220 | } | - |
2221 | | - |
2222 | | - |
2223 | | - |
2224 | | - |
2225 | typedef struct { | - |
2226 | const char * const name; | - |
2227 | int value; | - |
2228 | } assoc_list; | - |
2229 | | - |
2230 | static const assoc_list name_key_alist[] = { | - |
2231 | { "DEL", 0x7f }, | - |
2232 | { "ESC", '\033' }, | - |
2233 | { "Escape", '\033' }, | - |
2234 | { "LFD", '\n' }, | - |
2235 | { "Newline", '\n' }, | - |
2236 | { "RET", '\r' }, | - |
2237 | { "Return", '\r' }, | - |
2238 | { "Rubout", 0x7f }, | - |
2239 | { "SPC", ' ' }, | - |
2240 | { "Space", ' ' }, | - |
2241 | { "Tab", 0x09 }, | - |
2242 | { (char *)0x0, 0 } | - |
2243 | }; | - |
2244 | | - |
2245 | static int | - |
2246 | glean_key_from_name (char *name) | - |
2247 | { | - |
2248 | register int i; | - |
2249 | | - |
2250 | for (i = 0; name_key_alist[i].name; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2251 | if (_rl_stricmp (name, name_key_alist[i].name) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2252 | return (name_key_alist[i].value); never executed: return (name_key_alist[i].value); | 0 |
2253 | | - |
2254 | return (*(unsigned char *)name); never executed: return (*(unsigned char *)name); | 0 |
2255 | } | - |
2256 | | - |
2257 | | - |
2258 | static const struct { | - |
2259 | const char * const name; | - |
2260 | Keymap map; | - |
2261 | } keymap_names[] = { | - |
2262 | { "emacs", emacs_standard_keymap }, | - |
2263 | { "emacs-standard", emacs_standard_keymap }, | - |
2264 | { "emacs-meta", emacs_meta_keymap }, | - |
2265 | { "emacs-ctlx", emacs_ctlx_keymap }, | - |
2266 | #if defined (VI_MODE) | - |
2267 | { "vi", vi_movement_keymap }, | - |
2268 | { "vi-move", vi_movement_keymap }, | - |
2269 | { "vi-command", vi_movement_keymap }, | - |
2270 | { "vi-insert", vi_insertion_keymap }, | - |
2271 | #endif /* VI_MODE */ | - |
2272 | { (char *)0x0, (Keymap)0x0 } | - |
2273 | }; | - |
2274 | | - |
2275 | Keymap | - |
2276 | rl_get_keymap_by_name (const char *name) | - |
2277 | { | - |
2278 | register int i; | - |
2279 | | - |
2280 | for (i = 0; keymap_names[i].name; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2281 | if (_rl_stricmp (name, keymap_names[i].name) == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2282 | return (keymap_names[i].map); never executed: return (keymap_names[i].map); | 0 |
2283 | return ((Keymap) NULL); never executed: return ((Keymap) ((void *)0) ); | 0 |
2284 | } | - |
2285 | | - |
2286 | char * | - |
2287 | rl_get_keymap_name (Keymap map) | - |
2288 | { | - |
2289 | register int i; | - |
2290 | for (i = 0; keymap_names[i].name; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2291 | if (map == keymap_names[i].map)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2292 | return ((char *)keymap_names[i].name); never executed: return ((char *)keymap_names[i].name); | 0 |
2293 | return ((char *)NULL); never executed: return ((char *) ((void *)0) ); | 0 |
2294 | } | - |
2295 | | - |
2296 | void | - |
2297 | rl_set_keymap (Keymap map) | - |
2298 | { | - |
2299 | if (map)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2300 | _rl_keymap = map; never executed: _rl_keymap = map; | 0 |
2301 | } never executed: end of block | 0 |
2302 | | - |
2303 | Keymap | - |
2304 | rl_get_keymap (void) | - |
2305 | { | - |
2306 | return (_rl_keymap); never executed: return (_rl_keymap); | 0 |
2307 | } | - |
2308 | | - |
2309 | void | - |
2310 | rl_set_keymap_from_edit_mode (void) | - |
2311 | { | - |
2312 | if (rl_editing_mode == emacs_mode)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2313 | _rl_keymap = emacs_standard_keymap; never executed: _rl_keymap = emacs_standard_keymap; | 0 |
2314 | #if defined (VI_MODE) | - |
2315 | else if (rl_editing_mode == vi_mode)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2316 | _rl_keymap = vi_insertion_keymap; never executed: _rl_keymap = vi_insertion_keymap; | 0 |
2317 | #endif /* VI_MODE */ | - |
2318 | } never executed: end of block | 0 |
2319 | | - |
2320 | char * | - |
2321 | rl_get_keymap_name_from_edit_mode (void) | - |
2322 | { | - |
2323 | if (rl_editing_mode == emacs_mode)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2324 | return "emacs"; never executed: return "emacs"; | 0 |
2325 | #if defined (VI_MODE) | - |
2326 | else if (rl_editing_mode == vi_mode)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2327 | return "vi"; never executed: return "vi"; | 0 |
2328 | #endif /* VI_MODE */ | - |
2329 | else | - |
2330 | return "none"; never executed: return "none"; | 0 |
2331 | } | - |
2332 | | - |
2333 | | - |
2334 | | - |
2335 | | - |
2336 | | - |
2337 | | - |
2338 | | - |
2339 | | - |
2340 | | - |
2341 | | - |
2342 | | - |
2343 | | - |
2344 | | - |
2345 | void | - |
2346 | rl_list_funmap_names (void) | - |
2347 | { | - |
2348 | register int i; | - |
2349 | const char **funmap_names; | - |
2350 | | - |
2351 | funmap_names = rl_funmap_names (); | - |
2352 | | - |
2353 | if (!funmap_names)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2354 | return; never executed: return; | 0 |
2355 | | - |
2356 | for (i = 0; funmap_names[i]; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2357 | fprintf (rl_outstream, "%s\n", funmap_names[i]); never executed: fprintf (rl_outstream, "%s\n", funmap_names[i]); | 0 |
2358 | | - |
2359 | xfree (funmap_names); | - |
2360 | } never executed: end of block | 0 |
2361 | | - |
2362 | static char * | - |
2363 | _rl_get_keyname (int key) | - |
2364 | { | - |
2365 | char *keyname; | - |
2366 | int i, c; | - |
2367 | | - |
2368 | keyname = (char *)xmalloc (8); | - |
2369 | | - |
2370 | c = key; | - |
2371 | | - |
2372 | | - |
2373 | | - |
2374 | | - |
2375 | #if 1 | - |
2376 | | - |
2377 | | - |
2378 | | - |
2379 | | - |
2380 | | - |
2381 | if (c == ESC)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2382 | { | - |
2383 | keyname[0] = '\\'; | - |
2384 | keyname[1] = 'e'; | - |
2385 | keyname[2] = '\0'; | - |
2386 | return keyname; never executed: return keyname; | 0 |
2387 | } | - |
2388 | #endif | - |
2389 | | - |
2390 | | - |
2391 | if (key == RUBOUT)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2392 | { | - |
2393 | keyname[0] = '\\'; | - |
2394 | keyname[1] = 'C'; | - |
2395 | keyname[2] = '-'; | - |
2396 | keyname[3] = '?'; | - |
2397 | keyname[4] = '\0'; | - |
2398 | return keyname; never executed: return keyname; | 0 |
2399 | } | - |
2400 | | - |
2401 | i = 0; | - |
2402 | | - |
2403 | | - |
2404 | if (CTRL_CHAR (c))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2405 | { | - |
2406 | keyname[i++] = '\\'; | - |
2407 | keyname[i++] = 'C'; | - |
2408 | keyname[i++] = '-'; | - |
2409 | c = _rl_to_lower (UNCTRL (c)); never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: end of block never executed: __res = tolower ( (unsigned char)((((unsigned char)(((c)|0x40)) == (((c)|0x40))) && (1 && ((*__ctype_b_loc ())[(int) (( (unsigned char)((c)|0x40) ))] & (unsigned short int) _ISlower) )) ? (__extension__ ({ int __res; if (sizeof ( (unsigned char)((c)|0x40)...d char)((c)|0x40) ); __res = __c < -128 || __c > 255 ? __c : (*__ctype_toupper_loc ())[__c]; } else __res = toupper ( (unsigned char)((c)|0x40) ); } else __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; __res; })) : (((c)|0x40))) ); never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; never executed: __res = (*__ctype_tolower_loc ())[(int) ( (unsigned char)((((unsigned char)(((c)|0x40)) == (((c)|0x40))) && (1 && ((*__ctype_b_loc ())[(int) (( (unsigned char)((c)|0x40) ))] & (unsigned short int) _ISlower) )) ? (__extension__ ({ int __res; if (sizeof ( (... char)((c)|0x40) ); __res = __c < -128 || __c > 255 ? __c : (*__ctype_toupper_loc ())[__c]; } else __res = toupper ( (unsigned char)((c)|0x40) ); } else __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; __res; })) : (((c)|0x40))) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((c)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((c)|0x40) )]; 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 |
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 |
2410 | } never executed: end of block | 0 |
2411 | | - |
2412 | | - |
2413 | | - |
2414 | | - |
2415 | if (c >= 128 && c <= 159)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2416 | { | - |
2417 | keyname[i++] = '\\'; | - |
2418 | keyname[i++] = '2'; | - |
2419 | c -= 128; | - |
2420 | keyname[i++] = (c / 8) + '0'; | - |
2421 | c = (c % 8) + '0'; | - |
2422 | } never executed: end of block | 0 |
2423 | | - |
2424 | | - |
2425 | if (c == '\\' || c == '"')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2426 | keyname[i++] = '\\'; never executed: keyname[i++] = '\\'; | 0 |
2427 | | - |
2428 | | - |
2429 | keyname[i++] = (char) c; | - |
2430 | keyname[i] = '\0'; | - |
2431 | | - |
2432 | return keyname; never executed: return keyname; | 0 |
2433 | } | - |
2434 | | - |
2435 | | - |
2436 | | - |
2437 | char ** | - |
2438 | rl_invoking_keyseqs_in_map (rl_command_func_t *function, Keymap map) | - |
2439 | { | - |
2440 | register int key; | - |
2441 | char **result; | - |
2442 | int result_index, result_size; | - |
2443 | | - |
2444 | result = (char **)NULL; | - |
2445 | result_index = result_size = 0; | - |
2446 | | - |
2447 | for (key = 0; key < KEYMAP_SIZE; key++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2448 | { | - |
2449 | switch (map[key].type) | - |
2450 | { | - |
2451 | case ISMACR: never executed: case 2: | 0 |
2452 | | - |
2453 | | - |
2454 | case ISFUNC: never executed: case 0: | 0 |
2455 | | - |
2456 | | - |
2457 | if (map[key].function == function)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2458 | { | - |
2459 | char *keyname; | - |
2460 | | - |
2461 | keyname = _rl_get_keyname (key); | - |
2462 | | - |
2463 | if (result_index + 2 > result_size)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2464 | { | - |
2465 | result_size += 10; | - |
2466 | result = (char **)xrealloc (result, result_size * sizeof (char *)); | - |
2467 | } never executed: end of block | 0 |
2468 | | - |
2469 | result[result_index++] = keyname; | - |
2470 | result[result_index] = (char *)NULL; | - |
2471 | } never executed: end of block | 0 |
2472 | break; never executed: break; | 0 |
2473 | | - |
2474 | case ISKMAP: never executed: case 1: | 0 |
2475 | { | - |
2476 | char **seqs; | - |
2477 | register int i; | - |
2478 | | - |
2479 | | - |
2480 | | - |
2481 | if (map[key].function)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2482 | seqs = never executed: seqs = rl_invoking_keyseqs_in_map (function, (Keymap)(map[key].function)); | 0 |
2483 | rl_invoking_keyseqs_in_map (function, FUNCTION_TO_KEYMAP (map, key)); never executed: seqs = rl_invoking_keyseqs_in_map (function, (Keymap)(map[key].function)); | 0 |
2484 | else | - |
2485 | break; never executed: break; | 0 |
2486 | | - |
2487 | if (seqs == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2488 | break; never executed: break; | 0 |
2489 | | - |
2490 | for (i = 0; seqs[i]; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2491 | { | - |
2492 | char *keyname = (char *)xmalloc (6 + strlen (seqs[i])); | - |
2493 | | - |
2494 | if (key == ESC)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2495 | { | - |
2496 | | - |
2497 | | - |
2498 | | - |
2499 | | - |
2500 | if (_rl_convert_meta_chars_to_ascii && map[ESC].type == ISKMAP)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2501 | sprintf (keyname, "\\M-"); never executed: sprintf (keyname, "\\M-"); | 0 |
2502 | else | - |
2503 | sprintf (keyname, "\\e"); never executed: sprintf (keyname, "\\e"); | 0 |
2504 | } | - |
2505 | else if (CTRL_CHAR (key))TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2506 | sprintf (keyname, "\\C-%c", _rl_to_lower (UNCTRL (key))); never executed: sprintf (keyname, "\\C-%c", ((((unsigned char)(((((unsigned char)(((key)|0x40)) == (((key)|0x40))) && (1 && ((*__ctype_b_loc ())[(int) (( (unsigned char)((key)|0x40) ))] & (unsigned short int) _ISlower) )) ? (__extension__ ({ int __res; if (sizeof ( (unsi...key)|0x40) ); __res = __c < -128 || __c > 255 ? __c : (*__ctype_toupper_loc ())[__c]; } else __res = toupper ( (unsigned char)((key)|0x40) ); } else __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; __res; })) : (((key)|0x40)))))); never executed: end of block never executed: __res = toupper ( (unsigned char)((key)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((key)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((key)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((key)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((key)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; never executed: end of block never executed: __res = tolower ( (unsigned char)((((unsigned char)(((key)|0x40)) == (((key)|0x40))) && (1 && ((*__ctype_b_loc ())[(int) (( (unsigned char)((key)|0x40) ))] & (unsigned short int) _ISlower) )) ? (__extension__ ({ int __res; if (sizeof ( (unsigned char)((ke...(key)|0x40) ); __res = __c < -128 || __c > 255 ? __c : (*__ctype_toupper_loc ())[__c]; } else __res = toupper ( (unsigned char)((key)|0x40) ); } else __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; __res; })) : (((key)|0x40))) ); never executed: end of block never executed: __res = toupper ( (unsigned char)((key)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; never executed: __res = (*__ctype_tolower_loc ())[(int) ( (unsigned char)((((unsigned char)(((key)|0x40)) == (((key)|0x40))) && (1 && ((*__ctype_b_loc ())[(int) (( (unsigned char)((key)|0x40) ))] & (unsigned short int) _ISlower) )) ? (__extension__ ({ int __res; if (size...key)|0x40) ); __res = __c < -128 || __c > 255 ? __c : (*__ctype_toupper_loc ())[__c]; } else __res = toupper ( (unsigned char)((key)|0x40) ); } else __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; __res; })) : (((key)|0x40))) )]; never executed: end of block never executed: __res = toupper ( (unsigned char)((key)|0x40) ); never executed: __res = (*__ctype_toupper_loc ())[(int) ( (unsigned char)((key)|0x40) )]; 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 |
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 |
2507 | else if (key == RUBOUT)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2508 | sprintf (keyname, "\\C-?"); never executed: sprintf (keyname, "\\C-?"); | 0 |
2509 | else if (key == '\\' || key == '"')TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2510 | { | - |
2511 | keyname[0] = '\\'; | - |
2512 | keyname[1] = (char) key; | - |
2513 | keyname[2] = '\0'; | - |
2514 | } never executed: end of block | 0 |
2515 | else | - |
2516 | { | - |
2517 | keyname[0] = (char) key; | - |
2518 | keyname[1] = '\0'; | - |
2519 | } never executed: end of block | 0 |
2520 | | - |
2521 | strcat (keyname, seqs[i]); | - |
2522 | xfree (seqs[i]); | - |
2523 | | - |
2524 | if (result_index + 2 > result_size)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2525 | { | - |
2526 | result_size += 10; | - |
2527 | result = (char **)xrealloc (result, result_size * sizeof (char *)); | - |
2528 | } never executed: end of block | 0 |
2529 | | - |
2530 | result[result_index++] = keyname; | - |
2531 | result[result_index] = (char *)NULL; | - |
2532 | } never executed: end of block | 0 |
2533 | | - |
2534 | xfree (seqs); | - |
2535 | } | - |
2536 | break; never executed: break; | 0 |
2537 | } | - |
2538 | } never executed: end of block | 0 |
2539 | return (result); never executed: return (result); | 0 |
2540 | } | - |
2541 | | - |
2542 | | - |
2543 | | - |
2544 | char ** | - |
2545 | rl_invoking_keyseqs (rl_command_func_t *function) | - |
2546 | { | - |
2547 | return (rl_invoking_keyseqs_in_map (function, _rl_keymap)); never executed: return (rl_invoking_keyseqs_in_map (function, _rl_keymap)); | 0 |
2548 | } | - |
2549 | | - |
2550 | | - |
2551 | | - |
2552 | | - |
2553 | void | - |
2554 | rl_function_dumper (int print_readably) | - |
2555 | { | - |
2556 | register int i; | - |
2557 | const char **names; | - |
2558 | const char *name; | - |
2559 | | - |
2560 | names = rl_funmap_names (); | - |
2561 | | - |
2562 | fprintf (rl_outstream, "\n"); | - |
2563 | | - |
2564 | for (i = 0; name = names[i]; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2565 | { | - |
2566 | rl_command_func_t *function; | - |
2567 | char **invokers; | - |
2568 | | - |
2569 | function = rl_named_function (name); | - |
2570 | invokers = rl_invoking_keyseqs_in_map (function, _rl_keymap); | - |
2571 | | - |
2572 | if (print_readably)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2573 | { | - |
2574 | if (!invokers)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2575 | fprintf (rl_outstream, "# %s (not bound)\n", name); never executed: fprintf (rl_outstream, "# %s (not bound)\n", name); | 0 |
2576 | else | - |
2577 | { | - |
2578 | register int j; | - |
2579 | | - |
2580 | for (j = 0; invokers[j]; j++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2581 | { | - |
2582 | fprintf (rl_outstream, "\"%s\": %s\n", | - |
2583 | invokers[j], name); | - |
2584 | xfree (invokers[j]); | - |
2585 | } never executed: end of block | 0 |
2586 | | - |
2587 | xfree (invokers); | - |
2588 | } never executed: end of block | 0 |
2589 | } | - |
2590 | else | - |
2591 | { | - |
2592 | if (!invokers)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2593 | fprintf (rl_outstream, "%s is not bound to any keys\n", never executed: fprintf (rl_outstream, "%s is not bound to any keys\n", name); | 0 |
2594 | name); never executed: fprintf (rl_outstream, "%s is not bound to any keys\n", name); | 0 |
2595 | else | - |
2596 | { | - |
2597 | register int j; | - |
2598 | | - |
2599 | fprintf (rl_outstream, "%s can be found on ", name); | - |
2600 | | - |
2601 | for (j = 0; invokers[j] && j < 5; j++)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2602 | { | - |
2603 | fprintf (rl_outstream, "\"%s\"%s", invokers[j], | - |
2604 | invokers[j + 1] ? ", " : ".\n"); | - |
2605 | } never executed: end of block | 0 |
2606 | | - |
2607 | if (j == 5 && invokers[j])TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2608 | fprintf (rl_outstream, "...\n"); never executed: fprintf (rl_outstream, "...\n"); | 0 |
2609 | | - |
2610 | for (j = 0; invokers[j]; j++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2611 | xfree (invokers[j]); never executed: xfree (invokers[j]); | 0 |
2612 | | - |
2613 | xfree (invokers); | - |
2614 | } never executed: end of block | 0 |
2615 | } | - |
2616 | } | - |
2617 | | - |
2618 | xfree (names); | - |
2619 | } never executed: end of block | 0 |
2620 | | - |
2621 | | - |
2622 | | - |
2623 | | - |
2624 | int | - |
2625 | rl_dump_functions (int count, int key) | - |
2626 | { | - |
2627 | if (rl_dispatching)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2628 | fprintf (rl_outstream, "\r\n"); never executed: fprintf (rl_outstream, "\r\n"); | 0 |
2629 | rl_function_dumper (rl_explicit_arg); | - |
2630 | rl_on_new_line (); | - |
2631 | return (0); never executed: return (0); | 0 |
2632 | } | - |
2633 | | - |
2634 | static void | - |
2635 | _rl_macro_dumper_internal (int print_readably, Keymap map, char *prefix) | - |
2636 | { | - |
2637 | register int key; | - |
2638 | char *keyname, *out; | - |
2639 | int prefix_len; | - |
2640 | | - |
2641 | for (key = 0; key < KEYMAP_SIZE; key++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2642 | { | - |
2643 | switch (map[key].type) | - |
2644 | { | - |
2645 | case ISMACR: never executed: case 2: | 0 |
2646 | keyname = _rl_get_keyname (key); | - |
2647 | out = _rl_untranslate_macro_value ((char *)map[key].function, 0); | - |
2648 | | - |
2649 | if (print_readably)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2650 | fprintf (rl_outstream, "\"%s%s\": \"%s\"\n", prefix ? prefix : "", never executed: fprintf (rl_outstream, "\"%s%s\": \"%s\"\n", prefix ? prefix : "", keyname, out ? out : ""); | 0 |
2651 | keyname, never executed: fprintf (rl_outstream, "\"%s%s\": \"%s\"\n", prefix ? prefix : "", keyname, out ? out : ""); | 0 |
2652 | out ? out : ""); never executed: fprintf (rl_outstream, "\"%s%s\": \"%s\"\n", prefix ? prefix : "", keyname, out ? out : ""); | 0 |
2653 | else | - |
2654 | fprintf (rl_outstream, "%s%s outputs %s\n", prefix ? prefix : "", never executed: fprintf (rl_outstream, "%s%s outputs %s\n", prefix ? prefix : "", keyname, out ? out : ""); | 0 |
2655 | keyname, never executed: fprintf (rl_outstream, "%s%s outputs %s\n", prefix ? prefix : "", keyname, out ? out : ""); | 0 |
2656 | out ? out : ""); never executed: fprintf (rl_outstream, "%s%s outputs %s\n", prefix ? prefix : "", keyname, out ? out : ""); | 0 |
2657 | xfree (keyname); | - |
2658 | xfree (out); | - |
2659 | break; never executed: break; | 0 |
2660 | case ISFUNC: never executed: case 0: | 0 |
2661 | break; never executed: break; | 0 |
2662 | case ISKMAP: never executed: case 1: | 0 |
2663 | prefix_len = prefix ? strlen (prefix) : 0;TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2664 | if (key == ESC)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2665 | { | - |
2666 | keyname = (char *)xmalloc (3 + prefix_len); | - |
2667 | if (prefix)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2668 | strcpy (keyname, prefix); never executed: strcpy (keyname, prefix); | 0 |
2669 | keyname[prefix_len] = '\\'; | - |
2670 | keyname[prefix_len + 1] = 'e'; | - |
2671 | keyname[prefix_len + 2] = '\0'; | - |
2672 | } never executed: end of block | 0 |
2673 | else | - |
2674 | { | - |
2675 | keyname = _rl_get_keyname (key); | - |
2676 | if (prefix)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2677 | { | - |
2678 | out = (char *)xmalloc (strlen (keyname) + prefix_len + 1); | - |
2679 | strcpy (out, prefix); | - |
2680 | strcpy (out + prefix_len, keyname); | - |
2681 | xfree (keyname); | - |
2682 | keyname = out; | - |
2683 | } never executed: end of block | 0 |
2684 | } never executed: end of block | 0 |
2685 | | - |
2686 | _rl_macro_dumper_internal (print_readably, FUNCTION_TO_KEYMAP (map, key), keyname); | - |
2687 | xfree (keyname); | - |
2688 | break; never executed: break; | 0 |
2689 | } | - |
2690 | } never executed: end of block | 0 |
2691 | } never executed: end of block | 0 |
2692 | | - |
2693 | void | - |
2694 | rl_macro_dumper (int print_readably) | - |
2695 | { | - |
2696 | _rl_macro_dumper_internal (print_readably, _rl_keymap, (char *)NULL); | - |
2697 | } never executed: end of block | 0 |
2698 | | - |
2699 | int | - |
2700 | rl_dump_macros (int count, int key) | - |
2701 | { | - |
2702 | if (rl_dispatching)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2703 | fprintf (rl_outstream, "\r\n"); never executed: fprintf (rl_outstream, "\r\n"); | 0 |
2704 | rl_macro_dumper (rl_explicit_arg); | - |
2705 | rl_on_new_line (); | - |
2706 | return (0); never executed: return (0); | 0 |
2707 | } | - |
2708 | | - |
2709 | static char * | - |
2710 | _rl_get_string_variable_value (const char *name) | - |
2711 | { | - |
2712 | static char numbuf[32]; | - |
2713 | char *ret; | - |
2714 | | - |
2715 | if (_rl_stricmp (name, "bell-style") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2716 | { | - |
2717 | switch (_rl_bell_preference) | - |
2718 | { | - |
2719 | case NO_BELL: never executed: case 0: | 0 |
2720 | return "none"; never executed: return "none"; | 0 |
2721 | case VISIBLE_BELL: never executed: case 2: | 0 |
2722 | return "visible"; never executed: return "visible"; | 0 |
2723 | case AUDIBLE_BELL: never executed: case 1: | 0 |
2724 | default: never executed: default: | 0 |
2725 | return "audible"; never executed: return "audible"; | 0 |
2726 | } | - |
2727 | } | - |
2728 | else if (_rl_stricmp (name, "comment-begin") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2729 | return (_rl_comment_begin ? _rl_comment_begin : RL_COMMENT_BEGIN_DEFAULT); never executed: return (_rl_comment_begin ? _rl_comment_begin : "#"); | 0 |
2730 | else if (_rl_stricmp (name, "completion-display-width") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2731 | { | - |
2732 | sprintf (numbuf, "%d", _rl_completion_columns); | - |
2733 | return (numbuf); never executed: return (numbuf); | 0 |
2734 | } | - |
2735 | else if (_rl_stricmp (name, "completion-prefix-display-length") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2736 | { | - |
2737 | sprintf (numbuf, "%d", _rl_completion_prefix_display_length); | - |
2738 | return (numbuf); never executed: return (numbuf); | 0 |
2739 | } | - |
2740 | else if (_rl_stricmp (name, "completion-query-items") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2741 | { | - |
2742 | sprintf (numbuf, "%d", rl_completion_query_items); | - |
2743 | return (numbuf); never executed: return (numbuf); | 0 |
2744 | } | - |
2745 | else if (_rl_stricmp (name, "editing-mode") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2746 | return (rl_get_keymap_name_from_edit_mode ()); never executed: return (rl_get_keymap_name_from_edit_mode ()); | 0 |
2747 | else if (_rl_stricmp (name, "history-size") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2748 | { | - |
2749 | sprintf (numbuf, "%d", history_is_stifled() ? history_max_entries : 0); | - |
2750 | return (numbuf); never executed: return (numbuf); | 0 |
2751 | } | - |
2752 | else if (_rl_stricmp (name, "isearch-terminators") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2753 | { | - |
2754 | if (_rl_isearch_terminators == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2755 | return 0; never executed: return 0; | 0 |
2756 | ret = _rl_untranslate_macro_value (_rl_isearch_terminators, 0); | - |
2757 | if (ret)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2758 | { | - |
2759 | strncpy (numbuf, ret, sizeof (numbuf) - 1); | - |
2760 | xfree (ret); | - |
2761 | numbuf[sizeof(numbuf) - 1] = '\0'; | - |
2762 | } never executed: end of block | 0 |
2763 | else | - |
2764 | numbuf[0] = '\0'; never executed: numbuf[0] = '\0'; | 0 |
2765 | return numbuf; never executed: return numbuf; | 0 |
2766 | } | - |
2767 | else if (_rl_stricmp (name, "keymap") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2768 | { | - |
2769 | ret = rl_get_keymap_name (_rl_keymap); | - |
2770 | if (ret == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2771 | ret = rl_get_keymap_name_from_edit_mode (); never executed: ret = rl_get_keymap_name_from_edit_mode (); | 0 |
2772 | return (ret ? ret : "none"); never executed: return (ret ? ret : "none"); | 0 |
2773 | } | - |
2774 | else if (_rl_stricmp (name, "keyseq-timeout") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2775 | { | - |
2776 | sprintf (numbuf, "%d", _rl_keyseq_timeout); | - |
2777 | return (numbuf); never executed: return (numbuf); | 0 |
2778 | } | - |
2779 | else if (_rl_stricmp (name, "emacs-mode-string") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2780 | return (_rl_emacs_mode_str ? _rl_emacs_mode_str : RL_EMACS_MODESTR_DEFAULT); never executed: return (_rl_emacs_mode_str ? _rl_emacs_mode_str : "@"); | 0 |
2781 | else if (_rl_stricmp (name, "vi-cmd-mode-string") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2782 | return (_rl_vi_cmd_mode_str ? _rl_vi_cmd_mode_str : RL_VI_CMD_MODESTR_DEFAULT); never executed: return (_rl_vi_cmd_mode_str ? _rl_vi_cmd_mode_str : "(cmd)"); | 0 |
2783 | else if (_rl_stricmp (name, "vi-ins-mode-string") == 0)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2784 | return (_rl_vi_ins_mode_str ? _rl_vi_ins_mode_str : RL_VI_INS_MODESTR_DEFAULT); never executed: return (_rl_vi_ins_mode_str ? _rl_vi_ins_mode_str : "(ins)"); | 0 |
2785 | else | - |
2786 | return (0); never executed: return (0); | 0 |
2787 | } | - |
2788 | | - |
2789 | void | - |
2790 | rl_variable_dumper (int print_readably) | - |
2791 | { | - |
2792 | int i; | - |
2793 | char *v; | - |
2794 | | - |
2795 | for (i = 0; boolean_varlist[i].name; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2796 | { | - |
2797 | if (print_readably)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2798 | fprintf (rl_outstream, "set %s %s\n", boolean_varlist[i].name, never executed: fprintf (rl_outstream, "set %s %s\n", boolean_varlist[i].name, *boolean_varlist[i].value ? "on" : "off"); | 0 |
2799 | *boolean_varlist[i].value ? "on" : "off"); never executed: fprintf (rl_outstream, "set %s %s\n", boolean_varlist[i].name, *boolean_varlist[i].value ? "on" : "off"); | 0 |
2800 | else | - |
2801 | fprintf (rl_outstream, "%s is set to `%s'\n", boolean_varlist[i].name, never executed: fprintf (rl_outstream, "%s is set to `%s'\n", boolean_varlist[i].name, *boolean_varlist[i].value ? "on" : "off"); | 0 |
2802 | *boolean_varlist[i].value ? "on" : "off"); never executed: fprintf (rl_outstream, "%s is set to `%s'\n", boolean_varlist[i].name, *boolean_varlist[i].value ? "on" : "off"); | 0 |
2803 | } | - |
2804 | | - |
2805 | for (i = 0; string_varlist[i].name; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2806 | { | - |
2807 | v = _rl_get_string_variable_value (string_varlist[i].name); | - |
2808 | if (v == 0) TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2809 | continue; never executed: continue; | 0 |
2810 | if (print_readably)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2811 | fprintf (rl_outstream, "set %s %s\n", string_varlist[i].name, v); never executed: fprintf (rl_outstream, "set %s %s\n", string_varlist[i].name, v); | 0 |
2812 | else | - |
2813 | fprintf (rl_outstream, "%s is set to `%s'\n", string_varlist[i].name, v); never executed: fprintf (rl_outstream, "%s is set to `%s'\n", string_varlist[i].name, v); | 0 |
2814 | } | - |
2815 | } never executed: end of block | 0 |
2816 | | - |
2817 | | - |
2818 | | - |
2819 | | - |
2820 | int | - |
2821 | rl_dump_variables (int count, int key) | - |
2822 | { | - |
2823 | if (rl_dispatching)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2824 | fprintf (rl_outstream, "\r\n"); never executed: fprintf (rl_outstream, "\r\n"); | 0 |
2825 | rl_variable_dumper (rl_explicit_arg); | - |
2826 | rl_on_new_line (); | - |
2827 | return (0); never executed: return (0); | 0 |
2828 | } | - |
2829 | | - |
2830 | | - |
2831 | static int | - |
2832 | substring_member_of_array (const char *string, const char * const *array) | - |
2833 | { | - |
2834 | while (*array)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2835 | { | - |
2836 | if (_rl_strindex (string, *array))TRUE | never evaluated | FALSE | never evaluated |
| 0 |
2837 | return (1); never executed: return (1); | 0 |
2838 | array++; | - |
2839 | } never executed: end of block | 0 |
2840 | return (0); never executed: return (0); | 0 |
2841 | } | - |
| | |