keyname.c revision 1.4.4.2 1 1.4.4.2 jdc /* $NetBSD: keyname.c,v 1.4.4.2 2007/08/04 08:36:50 jdc Exp $ */
2 1.4.4.2 jdc
3 1.4.4.2 jdc /*-
4 1.4.4.2 jdc * Copyright (c) 2003 The NetBSD Foundation, Inc.
5 1.4.4.2 jdc * All rights reserved.
6 1.4.4.2 jdc *
7 1.4.4.2 jdc * This code is derived from software contributed to The NetBSD Foundation
8 1.4.4.2 jdc * by Julian Coleman.
9 1.4.4.2 jdc *
10 1.4.4.2 jdc * Redistribution and use in source and binary forms, with or without
11 1.4.4.2 jdc * modification, are permitted provided that the following conditions
12 1.4.4.2 jdc * are met:
13 1.4.4.2 jdc * 1. Redistributions of source code must retain the above copyright
14 1.4.4.2 jdc * notice, this list of conditions and the following disclaimer.
15 1.4.4.2 jdc * 2. Redistributions in binary form must reproduce the above copyright
16 1.4.4.2 jdc * notice, this list of conditions and the following disclaimer in the
17 1.4.4.2 jdc * documentation and/or other materials provided with the distribution.
18 1.4.4.2 jdc * 3. All advertising materials mentioning features or use of this software
19 1.4.4.2 jdc * must display the following acknowledgement:
20 1.4.4.2 jdc * This product includes software developed by the NetBSD
21 1.4.4.2 jdc * Foundation, Inc. and its contributors.
22 1.4.4.2 jdc * 4. Neither the name of The NetBSD Foundation nor the names of its
23 1.4.4.2 jdc * contributors may be used to endorse or promote products derived
24 1.4.4.2 jdc * from this software without specific prior written permission.
25 1.4.4.2 jdc *
26 1.4.4.2 jdc * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
27 1.4.4.2 jdc * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
28 1.4.4.2 jdc * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29 1.4.4.2 jdc * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
30 1.4.4.2 jdc * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31 1.4.4.2 jdc * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
32 1.4.4.2 jdc * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
33 1.4.4.2 jdc * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
34 1.4.4.2 jdc * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
35 1.4.4.2 jdc * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36 1.4.4.2 jdc * POSSIBILITY OF SUCH DAMAGE.
37 1.4.4.2 jdc */
38 1.4.4.2 jdc
39 1.4.4.2 jdc #include <sys/cdefs.h>
40 1.4.4.2 jdc #ifndef lint
41 1.4.4.2 jdc __RCSID("$NetBSD: keyname.c,v 1.4.4.2 2007/08/04 08:36:50 jdc Exp $");
42 1.4.4.2 jdc #endif /* not lint */
43 1.4.4.2 jdc
44 1.4.4.2 jdc #include <stdlib.h>
45 1.4.4.2 jdc #include <string.h>
46 1.4.4.2 jdc
47 1.4.4.2 jdc #include "curses.h"
48 1.4.4.2 jdc #include "curses_private.h"
49 1.4.4.2 jdc
50 1.4.4.2 jdc #define KEYNAMEMAX (size_t) 14 /* "KEY_BACKSPACE\0" */
51 1.4.4.2 jdc /*
52 1.4.4.2 jdc * keyname --
53 1.4.4.2 jdc * Return name of key or NULL;
54 1.4.4.2 jdc */
55 1.4.4.2 jdc char *
56 1.4.4.2 jdc keyname(int key)
57 1.4.4.2 jdc {
58 1.4.4.2 jdc /* We don't bother with the large keyname table if SMALL is defined. */
59 1.4.4.2 jdc #ifdef SMALL
60 1.4.4.2 jdc return NULL;
61 1.4.4.2 jdc #else
62 1.4.4.2 jdc char *name;
63 1.4.4.2 jdc
64 1.4.4.2 jdc if (key < 0)
65 1.4.4.2 jdc return NULL;
66 1.4.4.2 jdc
67 1.4.4.2 jdc /* No name. */
68 1.4.4.2 jdc if (key == 0x100)
69 1.4.4.2 jdc return NULL;
70 1.4.4.2 jdc
71 1.4.4.2 jdc if ((name = malloc(KEYNAMEMAX + 1)) == NULL)
72 1.4.4.2 jdc return NULL;
73 1.4.4.2 jdc
74 1.4.4.2 jdc /* Control codes */
75 1.4.4.2 jdc if (key < 0x20) {
76 1.4.4.2 jdc name[0] = '^';
77 1.4.4.2 jdc name[1] = (char) (key + 64); /* Offset of '@' */
78 1.4.4.2 jdc name[2] = '\0';
79 1.4.4.2 jdc return name;
80 1.4.4.2 jdc }
81 1.4.4.2 jdc
82 1.4.4.2 jdc /* "Normal" keys */
83 1.4.4.2 jdc if (key < 0x7F) {
84 1.4.4.2 jdc name[0] = (char) key;
85 1.4.4.2 jdc name[1] = '\0';
86 1.4.4.2 jdc return name;
87 1.4.4.2 jdc }
88 1.4.4.2 jdc
89 1.4.4.2 jdc /* Delete key */
90 1.4.4.2 jdc if (key == 0x7F) {
91 1.4.4.2 jdc strcpy(name, "^?\0");
92 1.4.4.2 jdc return name;
93 1.4.4.2 jdc }
94 1.4.4.2 jdc
95 1.4.4.2 jdc /* Meta + control codes */
96 1.4.4.2 jdc if (key < 0x9F) {
97 1.4.4.2 jdc strcpy(name, "M-^");
98 1.4.4.2 jdc name[3] = (char) (key - 64); /* Offset of '@' */
99 1.4.4.2 jdc name[4] = '\0';
100 1.4.4.2 jdc return name;
101 1.4.4.2 jdc }
102 1.4.4.2 jdc
103 1.4.4.2 jdc /* Meta + "normal" keys */
104 1.4.4.2 jdc if (key < 0xFF) {
105 1.4.4.2 jdc strcpy (name, "M-");
106 1.4.4.2 jdc name[2] = (char) (key - 128);
107 1.4.4.2 jdc name[3] = '\0';
108 1.4.4.2 jdc return name;
109 1.4.4.2 jdc }
110 1.4.4.2 jdc
111 1.4.4.2 jdc /* Meta + delete key */
112 1.4.4.2 jdc if (key == 0xFF) {
113 1.4.4.2 jdc strcpy(name, "M-^?\0");
114 1.4.4.2 jdc return name;
115 1.4.4.2 jdc }
116 1.4.4.2 jdc
117 1.4.4.2 jdc /* Key names. Synchronise this with curses.h. */
118 1.4.4.2 jdc if (key == 0x101) {
119 1.4.4.2 jdc strncpy(name, "KEY_BREAK\0", KEYNAMEMAX);
120 1.4.4.2 jdc return name;
121 1.4.4.2 jdc }
122 1.4.4.2 jdc if (key == 0x102) {
123 1.4.4.2 jdc strncpy(name, "KEY_DOWN\0", KEYNAMEMAX);
124 1.4.4.2 jdc return name;
125 1.4.4.2 jdc }
126 1.4.4.2 jdc if (key == 0x103) {
127 1.4.4.2 jdc strncpy(name, "KEY_UP\0", KEYNAMEMAX);
128 1.4.4.2 jdc return name;
129 1.4.4.2 jdc }
130 1.4.4.2 jdc if (key == 0x104) {
131 1.4.4.2 jdc strncpy(name, "KEY_LEFT\0", KEYNAMEMAX);
132 1.4.4.2 jdc return name;
133 1.4.4.2 jdc }
134 1.4.4.2 jdc if (key == 0x105) {
135 1.4.4.2 jdc strncpy(name, "KEY_RIGHT\0", KEYNAMEMAX);
136 1.4.4.2 jdc return name;
137 1.4.4.2 jdc }
138 1.4.4.2 jdc if (key == 0x106) {
139 1.4.4.2 jdc strncpy(name, "KEY_HOME\0", KEYNAMEMAX);
140 1.4.4.2 jdc return name;
141 1.4.4.2 jdc }
142 1.4.4.2 jdc if (key == 0x107) {
143 1.4.4.2 jdc strncpy(name, "KEY_BACKSPACE\0", KEYNAMEMAX);
144 1.4.4.2 jdc return name;
145 1.4.4.2 jdc }
146 1.4.4.2 jdc /* Function key block (64 keys). */
147 1.4.4.2 jdc if (key < 0x148) {
148 1.4.4.2 jdc int i;
149 1.4.4.2 jdc
150 1.4.4.2 jdc strcpy(name, "KEY_F(");
151 1.4.4.2 jdc i = snprintf(&name[6], (size_t) 3, "%d", key - 0x108);
152 1.4.4.2 jdc name[6 + i] = ')';
153 1.4.4.2 jdc name[7 + i] = '\0';
154 1.4.4.2 jdc return name;
155 1.4.4.2 jdc }
156 1.4.4.2 jdc if (key == 0x148) {
157 1.4.4.2 jdc strncpy(name, "KEY_DL\0", KEYNAMEMAX);
158 1.4.4.2 jdc return name;
159 1.4.4.2 jdc }
160 1.4.4.2 jdc if (key == 0x149) {
161 1.4.4.2 jdc strncpy(name, "KEY_IL\0", KEYNAMEMAX);
162 1.4.4.2 jdc return name;
163 1.4.4.2 jdc }
164 1.4.4.2 jdc if (key == 0x14A) {
165 1.4.4.2 jdc strncpy(name, "KEY_DC\0", KEYNAMEMAX);
166 1.4.4.2 jdc return name;
167 1.4.4.2 jdc }
168 1.4.4.2 jdc if (key == 0x14B) {
169 1.4.4.2 jdc strncpy(name, "KEY_IC\0", KEYNAMEMAX);
170 1.4.4.2 jdc return name;
171 1.4.4.2 jdc }
172 1.4.4.2 jdc if (key == 0x14C) {
173 1.4.4.2 jdc strncpy(name, "KEY_EIC\0", KEYNAMEMAX);
174 1.4.4.2 jdc return name;
175 1.4.4.2 jdc }
176 1.4.4.2 jdc if (key == 0x14D) {
177 1.4.4.2 jdc strncpy(name, "KEY_CLEAR\0", KEYNAMEMAX);
178 1.4.4.2 jdc return name;
179 1.4.4.2 jdc }
180 1.4.4.2 jdc if (key == 0x14E) {
181 1.4.4.2 jdc strncpy(name, "KEY_EOS\0", KEYNAMEMAX);
182 1.4.4.2 jdc return name;
183 1.4.4.2 jdc }
184 1.4.4.2 jdc if (key == 0x14F) {
185 1.4.4.2 jdc strncpy(name, "KEY_EOL\0", KEYNAMEMAX);
186 1.4.4.2 jdc return name;
187 1.4.4.2 jdc }
188 1.4.4.2 jdc if (key == 0x150) {
189 1.4.4.2 jdc strncpy(name, "KEY_SF\0", KEYNAMEMAX);
190 1.4.4.2 jdc return name;
191 1.4.4.2 jdc }
192 1.4.4.2 jdc if (key == 0x151) {
193 1.4.4.2 jdc strncpy(name, "KEY_SR\0", KEYNAMEMAX);
194 1.4.4.2 jdc return name;
195 1.4.4.2 jdc }
196 1.4.4.2 jdc if (key == 0x152) {
197 1.4.4.2 jdc strncpy(name, "KEY_NPAGE\0", KEYNAMEMAX);
198 1.4.4.2 jdc return name;
199 1.4.4.2 jdc }
200 1.4.4.2 jdc if (key == 0x153) {
201 1.4.4.2 jdc strncpy(name, "KEY_PPAGE\0", KEYNAMEMAX);
202 1.4.4.2 jdc return name;
203 1.4.4.2 jdc }
204 1.4.4.2 jdc if (key == 0x154) {
205 1.4.4.2 jdc strncpy(name, "KEY_STAB\0", KEYNAMEMAX);
206 1.4.4.2 jdc return name;
207 1.4.4.2 jdc }
208 1.4.4.2 jdc if (key == 0x155) {
209 1.4.4.2 jdc strncpy(name, "KEY_CTAB\0", KEYNAMEMAX);
210 1.4.4.2 jdc return name;
211 1.4.4.2 jdc }
212 1.4.4.2 jdc if (key == 0x156) {
213 1.4.4.2 jdc strncpy(name, "KEY_CATAB\0", KEYNAMEMAX);
214 1.4.4.2 jdc return name;
215 1.4.4.2 jdc }
216 1.4.4.2 jdc if (key == 0x157) {
217 1.4.4.2 jdc strncpy(name, "KEY_ENTER\0", KEYNAMEMAX);
218 1.4.4.2 jdc return name;
219 1.4.4.2 jdc }
220 1.4.4.2 jdc if (key == 0x158) {
221 1.4.4.2 jdc strncpy(name, "KEY_SRESET\0", KEYNAMEMAX);
222 1.4.4.2 jdc return name;
223 1.4.4.2 jdc }
224 1.4.4.2 jdc if (key == 0x159) {
225 1.4.4.2 jdc strncpy(name, "KEY_RESET\0", KEYNAMEMAX);
226 1.4.4.2 jdc return name;
227 1.4.4.2 jdc }
228 1.4.4.2 jdc if (key == 0x15A) {
229 1.4.4.2 jdc strncpy(name, "KEY_PRINT\0", KEYNAMEMAX);
230 1.4.4.2 jdc return name;
231 1.4.4.2 jdc }
232 1.4.4.2 jdc if (key == 0x15B) {
233 1.4.4.2 jdc strncpy(name, "KEY_LL\0", KEYNAMEMAX);
234 1.4.4.2 jdc return name;
235 1.4.4.2 jdc }
236 1.4.4.2 jdc if (key == 0x15C) {
237 1.4.4.2 jdc strncpy(name, "KEY_A1\0", KEYNAMEMAX);
238 1.4.4.2 jdc return name;
239 1.4.4.2 jdc }
240 1.4.4.2 jdc if (key == 0x15D) {
241 1.4.4.2 jdc strncpy(name, "KEY_A3\0", KEYNAMEMAX);
242 1.4.4.2 jdc return name;
243 1.4.4.2 jdc }
244 1.4.4.2 jdc if (key == 0x15E) {
245 1.4.4.2 jdc strncpy(name, "KEY_B2\0", KEYNAMEMAX);
246 1.4.4.2 jdc return name;
247 1.4.4.2 jdc }
248 1.4.4.2 jdc if (key == 0x15F) {
249 1.4.4.2 jdc strncpy(name, "KEY_C1\0", KEYNAMEMAX);
250 1.4.4.2 jdc return name;
251 1.4.4.2 jdc }
252 1.4.4.2 jdc if (key == 0x160) {
253 1.4.4.2 jdc strncpy(name, "KEY_C3\0", KEYNAMEMAX);
254 1.4.4.2 jdc return name;
255 1.4.4.2 jdc }
256 1.4.4.2 jdc if (key == 0x161) {
257 1.4.4.2 jdc strncpy(name, "KEY_BTAB\0", KEYNAMEMAX);
258 1.4.4.2 jdc return name;
259 1.4.4.2 jdc }
260 1.4.4.2 jdc if (key == 0x162) {
261 1.4.4.2 jdc strncpy(name, "KEY_BEG\0", KEYNAMEMAX);
262 1.4.4.2 jdc return name;
263 1.4.4.2 jdc }
264 1.4.4.2 jdc if (key == 0x163) {
265 1.4.4.2 jdc strncpy(name, "KEY_CANCEL\0", KEYNAMEMAX);
266 1.4.4.2 jdc return name;
267 1.4.4.2 jdc }
268 1.4.4.2 jdc if (key == 0x164) {
269 1.4.4.2 jdc strncpy(name, "KEY_CLOSE\0", KEYNAMEMAX);
270 1.4.4.2 jdc return name;
271 1.4.4.2 jdc }
272 1.4.4.2 jdc if (key == 0x165) {
273 1.4.4.2 jdc strncpy(name, "KEY_COMMAND\0", KEYNAMEMAX);
274 1.4.4.2 jdc return name;
275 1.4.4.2 jdc }
276 1.4.4.2 jdc if (key == 0x166) {
277 1.4.4.2 jdc strncpy(name, "KEY_COPY\0", KEYNAMEMAX);
278 1.4.4.2 jdc return name;
279 1.4.4.2 jdc }
280 1.4.4.2 jdc if (key == 0x167) {
281 1.4.4.2 jdc strncpy(name, "KEY_CREATE\0", KEYNAMEMAX);
282 1.4.4.2 jdc return name;
283 1.4.4.2 jdc }
284 1.4.4.2 jdc if (key == 0x168) {
285 1.4.4.2 jdc strncpy(name, "KEY_END\0", KEYNAMEMAX);
286 1.4.4.2 jdc return name;
287 1.4.4.2 jdc }
288 1.4.4.2 jdc if (key == 0x169) {
289 1.4.4.2 jdc strncpy(name, "KEY_EXIT\0", KEYNAMEMAX);
290 1.4.4.2 jdc return name;
291 1.4.4.2 jdc }
292 1.4.4.2 jdc if (key == 0x16A) {
293 1.4.4.2 jdc strncpy(name, "KEY_FIND\0", KEYNAMEMAX);
294 1.4.4.2 jdc return name;
295 1.4.4.2 jdc }
296 1.4.4.2 jdc if (key == 0x16B) {
297 1.4.4.2 jdc strncpy(name, "KEY_HELP\0", KEYNAMEMAX);
298 1.4.4.2 jdc return name;
299 1.4.4.2 jdc }
300 1.4.4.2 jdc if (key == 0x16C) {
301 1.4.4.2 jdc strncpy(name, "KEY_MARK\0", KEYNAMEMAX);
302 1.4.4.2 jdc return name;
303 1.4.4.2 jdc }
304 1.4.4.2 jdc if (key == 0x16D) {
305 1.4.4.2 jdc strncpy(name, "KEY_MESSAGE\0", KEYNAMEMAX);
306 1.4.4.2 jdc return name;
307 1.4.4.2 jdc }
308 1.4.4.2 jdc if (key == 0x16E) {
309 1.4.4.2 jdc strncpy(name, "KEY_MOVE\0", KEYNAMEMAX);
310 1.4.4.2 jdc return name;
311 1.4.4.2 jdc }
312 1.4.4.2 jdc if (key == 0x16F) {
313 1.4.4.2 jdc strncpy(name, "KEY_NEXT\0", KEYNAMEMAX);
314 1.4.4.2 jdc return name;
315 1.4.4.2 jdc }
316 1.4.4.2 jdc if (key == 0x170) {
317 1.4.4.2 jdc strncpy(name, "KEY_OPEN\0", KEYNAMEMAX);
318 1.4.4.2 jdc return name;
319 1.4.4.2 jdc }
320 1.4.4.2 jdc if (key == 0x171) {
321 1.4.4.2 jdc strncpy(name, "KEY_OPTIONS\0", KEYNAMEMAX);
322 1.4.4.2 jdc return name;
323 1.4.4.2 jdc }
324 1.4.4.2 jdc if (key == 0x172) {
325 1.4.4.2 jdc strncpy(name, "KEY_PREVIOUS\0", KEYNAMEMAX);
326 1.4.4.2 jdc return name;
327 1.4.4.2 jdc }
328 1.4.4.2 jdc if (key == 0x173) {
329 1.4.4.2 jdc strncpy(name, "KEY_REDO\0", KEYNAMEMAX);
330 1.4.4.2 jdc return name;
331 1.4.4.2 jdc }
332 1.4.4.2 jdc if (key == 0x174) {
333 1.4.4.2 jdc strncpy(name, "KEY_REFERENCE\0", KEYNAMEMAX);
334 1.4.4.2 jdc return name;
335 1.4.4.2 jdc }
336 1.4.4.2 jdc if (key == 0x175) {
337 1.4.4.2 jdc strncpy(name, "KEY_REFRESH\0", KEYNAMEMAX);
338 1.4.4.2 jdc return name;
339 1.4.4.2 jdc }
340 1.4.4.2 jdc if (key == 0x176) {
341 1.4.4.2 jdc strncpy(name, "KEY_REPLACE\0", KEYNAMEMAX);
342 1.4.4.2 jdc return name;
343 1.4.4.2 jdc }
344 1.4.4.2 jdc if (key == 0x177) {
345 1.4.4.2 jdc strncpy(name, "KEY_RESTART\0", KEYNAMEMAX);
346 1.4.4.2 jdc return name;
347 1.4.4.2 jdc }
348 1.4.4.2 jdc if (key == 0x178) {
349 1.4.4.2 jdc strncpy(name, "KEY_RESUME\0", KEYNAMEMAX);
350 1.4.4.2 jdc return name;
351 1.4.4.2 jdc }
352 1.4.4.2 jdc if (key == 0x179) {
353 1.4.4.2 jdc strncpy(name, "KEY_SAVE\0", KEYNAMEMAX);
354 1.4.4.2 jdc return name;
355 1.4.4.2 jdc }
356 1.4.4.2 jdc if (key == 0x17A) {
357 1.4.4.2 jdc strncpy(name, "KEY_SBEG\0", KEYNAMEMAX);
358 1.4.4.2 jdc return name;
359 1.4.4.2 jdc }
360 1.4.4.2 jdc if (key == 0x17B) {
361 1.4.4.2 jdc strncpy(name, "KEY_SCANCEL\0", KEYNAMEMAX);
362 1.4.4.2 jdc return name;
363 1.4.4.2 jdc }
364 1.4.4.2 jdc if (key == 0x17C) {
365 1.4.4.2 jdc strncpy(name, "KEY_SCOMMAND\0", KEYNAMEMAX);
366 1.4.4.2 jdc return name;
367 1.4.4.2 jdc }
368 1.4.4.2 jdc if (key == 0x17D) {
369 1.4.4.2 jdc strncpy(name, "KEY_SCOPY\0", KEYNAMEMAX);
370 1.4.4.2 jdc return name;
371 1.4.4.2 jdc }
372 1.4.4.2 jdc if (key == 0x17E) {
373 1.4.4.2 jdc strncpy(name, "KEY_SCREATE\0", KEYNAMEMAX);
374 1.4.4.2 jdc return name;
375 1.4.4.2 jdc }
376 1.4.4.2 jdc if (key == 0x17F) {
377 1.4.4.2 jdc strncpy(name, "KEY_SDC\0", KEYNAMEMAX);
378 1.4.4.2 jdc return name;
379 1.4.4.2 jdc }
380 1.4.4.2 jdc if (key == 0x180) {
381 1.4.4.2 jdc strncpy(name, "KEY_SDL\0", KEYNAMEMAX);
382 1.4.4.2 jdc return name;
383 1.4.4.2 jdc }
384 1.4.4.2 jdc if (key == 0x181) {
385 1.4.4.2 jdc strncpy(name, "KEY_SELECT\0", KEYNAMEMAX);
386 1.4.4.2 jdc return name;
387 1.4.4.2 jdc }
388 1.4.4.2 jdc if (key == 0x182) {
389 1.4.4.2 jdc strncpy(name, "KEY_SEND\0", KEYNAMEMAX);
390 1.4.4.2 jdc return name;
391 1.4.4.2 jdc }
392 1.4.4.2 jdc if (key == 0x183) {
393 1.4.4.2 jdc strncpy(name, "KEY_SEOL\0", KEYNAMEMAX);
394 1.4.4.2 jdc return name;
395 1.4.4.2 jdc }
396 1.4.4.2 jdc if (key == 0x184) {
397 1.4.4.2 jdc strncpy(name, "KEY_SEXIT\0", KEYNAMEMAX);
398 1.4.4.2 jdc return name;
399 1.4.4.2 jdc }
400 1.4.4.2 jdc if (key == 0x185) {
401 1.4.4.2 jdc strncpy(name, "KEY_SFIND\0", KEYNAMEMAX);
402 1.4.4.2 jdc return name;
403 1.4.4.2 jdc }
404 1.4.4.2 jdc if (key == 0x186) {
405 1.4.4.2 jdc strncpy(name, "KEY_SHELP\0", KEYNAMEMAX);
406 1.4.4.2 jdc return name;
407 1.4.4.2 jdc }
408 1.4.4.2 jdc if (key == 0x187) {
409 1.4.4.2 jdc strncpy(name, "KEY_SHOME\0", KEYNAMEMAX);
410 1.4.4.2 jdc return name;
411 1.4.4.2 jdc }
412 1.4.4.2 jdc if (key == 0x188) {
413 1.4.4.2 jdc strncpy(name, "KEY_SIC\0", KEYNAMEMAX);
414 1.4.4.2 jdc return name;
415 1.4.4.2 jdc }
416 1.4.4.2 jdc if (key == 0x189) {
417 1.4.4.2 jdc strncpy(name, "KEY_SLEFT\0", KEYNAMEMAX);
418 1.4.4.2 jdc return name;
419 1.4.4.2 jdc }
420 1.4.4.2 jdc if (key == 0x18A) {
421 1.4.4.2 jdc strncpy(name, "KEY_SMESSAGE\0", KEYNAMEMAX);
422 1.4.4.2 jdc return name;
423 1.4.4.2 jdc }
424 1.4.4.2 jdc if (key == 0x18B) {
425 1.4.4.2 jdc strncpy(name, "KEY_SMOVE\0", KEYNAMEMAX);
426 1.4.4.2 jdc return name;
427 1.4.4.2 jdc }
428 1.4.4.2 jdc if (key == 0x18C) {
429 1.4.4.2 jdc strncpy(name, "KEY_SNEXT\0", KEYNAMEMAX);
430 1.4.4.2 jdc return name;
431 1.4.4.2 jdc }
432 1.4.4.2 jdc if (key == 0x18D) {
433 1.4.4.2 jdc strncpy(name, "KEY_SOPTIONS\0", KEYNAMEMAX);
434 1.4.4.2 jdc return name;
435 1.4.4.2 jdc }
436 1.4.4.2 jdc if (key == 0x18E) {
437 1.4.4.2 jdc strncpy(name, "KEY_SPREVIOUS\0", KEYNAMEMAX);
438 1.4.4.2 jdc return name;
439 1.4.4.2 jdc }
440 1.4.4.2 jdc if (key == 0x18F) {
441 1.4.4.2 jdc strncpy(name, "KEY_SPRINT\0", KEYNAMEMAX);
442 1.4.4.2 jdc return name;
443 1.4.4.2 jdc }
444 1.4.4.2 jdc if (key == 0x190) {
445 1.4.4.2 jdc strncpy(name, "KEY_SREDO\0", KEYNAMEMAX);
446 1.4.4.2 jdc return name;
447 1.4.4.2 jdc }
448 1.4.4.2 jdc if (key == 0x191) {
449 1.4.4.2 jdc strncpy(name, "KEY_SREPLACE\0", KEYNAMEMAX);
450 1.4.4.2 jdc return name;
451 1.4.4.2 jdc }
452 1.4.4.2 jdc if (key == 0x192) {
453 1.4.4.2 jdc strncpy(name, "KEY_SRIGHT\0", KEYNAMEMAX);
454 1.4.4.2 jdc return name;
455 1.4.4.2 jdc }
456 1.4.4.2 jdc if (key == 0x193) {
457 1.4.4.2 jdc strncpy(name, "KEY_SRSUME\0", KEYNAMEMAX);
458 1.4.4.2 jdc return name;
459 1.4.4.2 jdc }
460 1.4.4.2 jdc if (key == 0x194) {
461 1.4.4.2 jdc strncpy(name, "KEY_SSAVE\0", KEYNAMEMAX);
462 1.4.4.2 jdc return name;
463 1.4.4.2 jdc }
464 1.4.4.2 jdc if (key == 0x195) {
465 1.4.4.2 jdc strncpy(name, "KEY_SSUSPEND\0", KEYNAMEMAX);
466 1.4.4.2 jdc return name;
467 1.4.4.2 jdc }
468 1.4.4.2 jdc if (key == 0x196) {
469 1.4.4.2 jdc strncpy(name, "KEY_SUNDO\0", KEYNAMEMAX);
470 1.4.4.2 jdc return name;
471 1.4.4.2 jdc }
472 1.4.4.2 jdc if (key == 0x197) {
473 1.4.4.2 jdc strncpy(name, "KEY_SUSPEND\0", KEYNAMEMAX);
474 1.4.4.2 jdc return name;
475 1.4.4.2 jdc }
476 1.4.4.2 jdc if (key == 0x198) {
477 1.4.4.2 jdc strncpy(name, "KEY_UNDO\0", KEYNAMEMAX);
478 1.4.4.2 jdc return name;
479 1.4.4.2 jdc }
480 1.4.4.2 jdc if (key == 0x199) {
481 1.4.4.2 jdc strncpy(name, "KEY_MOUSE\0", KEYNAMEMAX);
482 1.4.4.2 jdc return name;
483 1.4.4.2 jdc }
484 1.4.4.2 jdc if (key == 0x200) {
485 1.4.4.2 jdc strncpy(name, "KEY_RESIZE\0", KEYNAMEMAX);
486 1.4.4.2 jdc return name;
487 1.4.4.2 jdc }
488 1.4.4.2 jdc /* No more names. */
489 1.4.4.2 jdc strncpy(name, "UNKOWN KEY\0", KEYNAMEMAX);
490 1.4.4.2 jdc return name;
491 1.4.4.2 jdc #endif
492 1.4.4.2 jdc }
493 1.4.4.2 jdc /*
494 1.4.4.2 jdc * key_name --
495 1.4.4.2 jdc * Return name of key or NULL;
496 1.4.4.2 jdc */
497 1.4.4.2 jdc char *
498 1.4.4.2 jdc key_name(wchar_t key)
499 1.4.4.2 jdc {
500 1.4.4.2 jdc #ifndef HAVE_WCHAR
501 1.4.4.2 jdc return NULL;
502 1.4.4.2 jdc #else
503 1.4.4.2 jdc /* We don't bother with the large keyname table if SMALL is defined. */
504 1.4.4.2 jdc #ifdef SMALL
505 1.4.4.2 jdc return NULL;
506 1.4.4.2 jdc #else
507 1.4.4.2 jdc char *name = keyname(( int )key );
508 1.4.4.2 jdc
509 1.4.4.2 jdc if ( !name )
510 1.4.4.2 jdc return NULL;
511 1.4.4.2 jdc if (!strncmp( name, "M-", 2 )) {
512 1.4.4.2 jdc free( name );
513 1.4.4.2 jdc name = NULL;
514 1.4.4.2 jdc }
515 1.4.4.2 jdc return name;
516 1.4.4.2 jdc #endif
517 1.4.4.2 jdc #endif /* HAVE_WCHAR */
518 1.4.4.2 jdc }
519 1.4.4.2 jdc
520