]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame_incremental - readline/funmap.c
* config/sh/tm-sh.h (BELIEVE_PCC_PROMOTION): Define, so that
[thirdparty/binutils-gdb.git] / readline / funmap.c
... / ...
CommitLineData
1/* funmap.c -- attach names to functions. */
2
3/* Copyright (C) 1988,1989 Free Software Foundation, Inc.
4
5 This file is part of GNU Readline, a library for reading lines
6 of text with interactive input and history editing.
7
8 Readline is free software; you can redistribute it and/or modify it
9 under the terms of the GNU General Public License as published by the
10 Free Software Foundation; either version 1, or (at your option) any
11 later version.
12
13 Readline is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with Readline; see the file COPYING. If not, write to the Free
20 Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
21
22/* #define STATIC_MALLOC */
23#if !defined (STATIC_MALLOC)
24extern char *xmalloc (), *xrealloc ();
25#else
26static char *xmalloc (), *xrealloc ();
27#endif /* STATIC_MALLOC */
28
29#if !defined (BUFSIZ)
30#include <stdio.h>
31#endif /* BUFSIZ */
32
33#include "readline.h"
34
35FUNMAP **funmap = (FUNMAP **)NULL;
36static int funmap_size = 0;
37static int funmap_entry = 0;
38
39/* After initializing the function map, this is the index of the first
40 program specific function. */
41int funmap_program_specific_entry_start;
42
43static FUNMAP default_funmap[] = {
44
45 { "abort", rl_abort },
46 { "accept-line", rl_newline },
47 { "arrow-key-prefix", rl_arrow_keys },
48 { "backward-char", rl_backward },
49 { "backward-delete-char", rl_rubout },
50 { "backward-kill-line", rl_backward_kill_line },
51 { "backward-kill-word", rl_backward_kill_word },
52 { "backward-word", rl_backward_word },
53 { "beginning-of-history", rl_beginning_of_history },
54 { "beginning-of-line", rl_beg_of_line },
55 { "call-last-kbd-macro", rl_call_last_kbd_macro },
56 { "capitalize-word", rl_capitalize_word },
57 { "clear-screen", rl_clear_screen },
58 { "complete", rl_complete },
59 { "delete-char", rl_delete },
60 { "digit-argument", rl_digit_argument },
61 { "do-lowercase-version", rl_do_lowercase_version },
62 { "downcase-word", rl_downcase_word },
63 { "dump-functions", rl_dump_functions },
64 { "end-kbd-macro", rl_end_kbd_macro },
65 { "end-of-history", rl_end_of_history },
66 { "end-of-line", rl_end_of_line },
67 { "forward-char", rl_forward },
68 { "forward-search-history", rl_forward_search_history },
69 { "forward-word", rl_forward_word },
70 { "kill-line", rl_kill_line },
71 { "kill-word", rl_kill_word },
72 { "next-history", rl_get_next_history },
73 { "possible-completions", rl_possible_completions },
74 { "previous-history", rl_get_previous_history },
75 { "quoted-insert", rl_quoted_insert },
76 { "re-read-init-file", rl_re_read_init_file },
77 { "redraw-current-line", rl_refresh_line},
78 { "reverse-search-history", rl_reverse_search_history },
79 { "revert-line", rl_revert_line },
80 { "self-insert", rl_insert },
81 { "start-kbd-macro", rl_start_kbd_macro },
82 { "tab-insert", rl_tab_insert },
83 { "transpose-chars", rl_transpose_chars },
84 { "transpose-words", rl_transpose_words },
85 { "undo", rl_undo_command },
86 { "universal-argument", rl_universal_argument },
87 { "unix-line-discard", rl_unix_line_discard },
88 { "unix-word-rubout", rl_unix_word_rubout },
89 { "upcase-word", rl_upcase_word },
90 { "yank", rl_yank },
91 { "yank-nth-arg", rl_yank_nth_arg },
92 { "yank-pop", rl_yank_pop },
93
94#if defined (VI_MODE)
95
96 { "vi-append-eol", rl_vi_append_eol },
97 { "vi-append-mode", rl_vi_append_mode },
98 { "vi-arg-digit", rl_vi_arg_digit },
99 { "vi-bWord", rl_vi_bWord },
100 { "vi-bracktype", rl_vi_bracktype },
101 { "vi-bword", rl_vi_bword },
102 { "vi-change-case", rl_vi_change_case },
103 { "vi-change-char", rl_vi_change_char },
104 { "vi-change-to", rl_vi_change_to },
105 { "vi-char-search", rl_vi_char_search },
106 { "vi-column", rl_vi_column },
107 { "vi-comment", rl_vi_comment },
108 { "vi-complete", rl_vi_complete },
109 { "vi-delete", rl_vi_delete },
110 { "vi-delete-to", rl_vi_delete_to },
111 { "vi-dosearch", rl_vi_dosearch },
112 { "vi-eWord", rl_vi_eWord },
113 { "vi-editing-mode", rl_vi_editing_mode },
114 { "vi-end-word", rl_vi_end_word },
115 { "vi-eof-maybe", rl_vi_eof_maybe },
116 { "vi-eword", rl_vi_eword },
117 { "vi-fWord", rl_vi_fWord },
118 { "vi-first-print", rl_vi_first_print },
119 { "vi-fword", rl_vi_fword },
120 { "vi-insert-beg", rl_vi_insert_beg },
121 { "vi-insertion-mode", rl_vi_insertion_mode },
122 { "vi-match", rl_vi_match },
123 { "vi-movement-mode", rl_vi_movement_mode },
124 { "vi-next-word", rl_vi_next_word },
125 { "vi-overstrike", rl_vi_overstrike },
126 { "vi-overstrike-delete", rl_vi_overstrike_delete },
127 { "vi-prev-word", rl_vi_prev_word },
128 { "vi-put", rl_vi_put },
129 { "vi-replace, ", rl_vi_replace },
130 { "vi-search", rl_vi_search },
131 { "vi-search-again", rl_vi_search_again },
132 { "vi-subst", rl_vi_subst },
133 { "vi-yank-arg", rl_vi_yank_arg },
134 { "vi-yank-to", rl_vi_yank_to },
135
136#endif /* VI_MODE */
137
138 {(char *)NULL, (Function *)NULL }
139};
140
141rl_add_funmap_entry (name, function)
142 char *name;
143 Function *function;
144{
145 if (funmap_entry + 2 >= funmap_size)
146 if (!funmap)
147 funmap = (FUNMAP **)xmalloc ((funmap_size = 80) * sizeof (FUNMAP *));
148 else
149 funmap =
150 (FUNMAP **)xrealloc (funmap, (funmap_size += 80) * sizeof (FUNMAP *));
151
152 funmap[funmap_entry] = (FUNMAP *)xmalloc (sizeof (FUNMAP));
153 funmap[funmap_entry]->name = name;
154 funmap[funmap_entry]->function = function;
155
156 funmap[++funmap_entry] = (FUNMAP *)NULL;
157}
158
159static int funmap_initialized = 0;
160
161/* Make the funmap contain all of the default entries. */
162rl_initialize_funmap ()
163{
164 register int i;
165
166 if (funmap_initialized)
167 return;
168
169 for (i = 0; default_funmap[i].name; i++)
170 rl_add_funmap_entry (default_funmap[i].name, default_funmap[i].function);
171
172 funmap_initialized = 1;
173 funmap_program_specific_entry_start = i;
174}
175
176/* Stupid comparison routine for qsort () ing strings. */
177static int
178qsort_string_compare (s1, s2)
179 register char **s1, **s2;
180{
181 return (strcmp (*s1, *s2));
182}
183
184/* Produce a NULL terminated array of known function names. The array
185 is sorted. The array itself is allocated, but not the strings inside.
186 You should free () the array when you done, but not the pointrs. */
187char **
188rl_funmap_names ()
189{
190 char **result = (char **)NULL;
191 int result_size, result_index;
192
193 result_size = result_index = 0;
194
195 /* Make sure that the function map has been initialized. */
196 rl_initialize_funmap ();
197
198 for (result_index = 0; funmap[result_index]; result_index++)
199 {
200 if (result_index + 2 > result_size)
201 {
202 if (!result)
203 result = (char **)xmalloc ((result_size = 20) * sizeof (char *));
204 else
205 result = (char **)
206 xrealloc (result, (result_size += 20) * sizeof (char *));
207 }
208
209 result[result_index] = funmap[result_index]->name;
210 result[result_index + 1] = (char *)NULL;
211 }
212
213 qsort (result, result_index, sizeof (char *), qsort_string_compare);
214 return (result);
215}
216
217/* Things that mean `Control'. */
218char *possible_control_prefixes[] = {
219 "Control-", "C-", "CTRL-", (char *)NULL
220};
221
222char *possible_meta_prefixes[] = {
223 "Meta", "M-", (char *)NULL
224};
225
226#if defined (STATIC_MALLOC)
227\f
228/* **************************************************************** */
229/* */
230/* xmalloc and xrealloc () */
231/* */
232/* **************************************************************** */
233
234static void memory_error_and_abort ();
235
236static char *
237xmalloc (bytes)
238 int bytes;
239{
240 char *temp = (char *)malloc (bytes);
241
242 if (!temp)
243 memory_error_and_abort ();
244 return (temp);
245}
246
247static char *
248xrealloc (pointer, bytes)
249 char *pointer;
250 int bytes;
251{
252 char *temp;
253
254 if (!pointer)
255 temp = (char *)malloc (bytes);
256 else
257 temp = (char *)realloc (pointer, bytes);
258
259 if (!temp)
260 memory_error_and_abort ();
261 return (temp);
262}
263
264static void
265memory_error_and_abort ()
266{
267 fprintf (stderr, "history: Out of virtual memory!\n");
268 abort ();
269}
270#endif /* STATIC_MALLOC */