1 /* Editor key translation.
3 Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
4 2005, 2006, 2007 Free Software Foundation, Inc.
6 Authors: 1996, 1997 Paul Sheer
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
25 * \brief Source: editor key translation
33 #include <sys/types.h>
42 #include "lib/global.h"
43 #include "lib/tty/tty.h" /* keys */
44 #include "lib/tty/key.h" /* KEY_M_SHIFT */
45 #include "lib/strutil.h" /* str_isutf8 () */
46 #include "lib/util.h" /* is_printable() */
47 #include "lib/charsets.h" /* convert_from_input_c() */
49 #include "edit-impl.h"
50 #include "edit-widget.h" /* edit->macro_i */
51 #include "editcmd_dialogs.h"
53 #include "src/cmddef.h" /* list of commands */
54 #include "src/keybind.h" /* keybind_lookup_keymap_command() */
55 #include "src/main.h" /* display_codepage */
57 /*** global variables ****************************************************************************/
59 /*** file scope macro definitions ****************************************************************/
61 /*** file scope type declarations ****************************************************************/
63 /*** file scope variables ************************************************************************/
65 /*** file scope functions ************************************************************************/
66 /* --------------------------------------------------------------------------------------------- */
68 /* --------------------------------------------------------------------------------------------- */
69 /*** public functions ****************************************************************************/
70 /* --------------------------------------------------------------------------------------------- */
73 * Translate the keycode into either 'command' or 'char_for_insertion'.
74 * 'command' is one of the editor commands from cmddef.h.
77 edit_translate_key (WEdit
* edit
, long x_key
, int *cmd
, int *ch
)
79 unsigned long command
= (unsigned long) CK_Insert_Char
;
80 int char_for_insertion
= -1;
83 /* an ordinary insertable character */
87 if (edit
->charpoint
>= 4)
90 edit
->charbuf
[edit
->charpoint
] = '\0';
92 if (edit
->charpoint
< 4)
94 edit
->charbuf
[edit
->charpoint
++] = x_key
;
95 edit
->charbuf
[edit
->charpoint
] = '\0';
98 /* input from 8-bit locale */
101 /* source in 8-bit codeset */
104 #endif /* HAVE_CHARSET */
105 c
= convert_from_input_c (x_key
);
106 if (is_printable (c
))
108 char_for_insertion
= c
;
115 c
= convert_from_input_c (x_key
);
116 if (is_printable (c
))
118 char_for_insertion
= convert_from_8bit_to_utf_c2 ((unsigned char) x_key
);
126 /* source in UTF-8 codeset */
129 int res
= str_is_valid_char (edit
->charbuf
, edit
->charpoint
);
134 edit
->charpoint
= 0; /* broken multibyte char, skip */
137 char_for_insertion
= x_key
;
142 edit
->charbuf
[edit
->charpoint
] = '\0';
144 if (g_unichar_isprint (g_utf8_get_char (edit
->charbuf
)))
146 char_for_insertion
= x_key
;
155 int res
= str_is_valid_char (edit
->charbuf
, edit
->charpoint
);
160 edit
->charpoint
= 0; /* broken multibyte char, skip */
163 /* not finised multibyte input (in meddle multibyte utf-8 char) */
168 if (g_unichar_isprint (g_utf8_get_char (edit
->charbuf
)))
170 c
= convert_from_utf_to_current (edit
->charbuf
);
171 edit
->charbuf
[0] = '\0';
173 char_for_insertion
= c
;
176 /* unprinteble utf input, skip it */
177 edit
->charbuf
[0] = '\0';
182 #endif /* HAVE_CHARSET */
185 /* Commands specific to the key emulation */
189 command
= keybind_lookup_keymap_command (editor_x_map
, x_key
);
192 command
= keybind_lookup_keymap_command (editor_map
, x_key
);
194 if (command
== CK_Ignore_Key
)
195 command
= CK_Insert_Char
;
198 *cmd
= (int) command
; /* FIXME */
199 *ch
= char_for_insertion
;
201 return (command
== (unsigned long) CK_Insert_Char
&& char_for_insertion
== -1) ? 0 : 1;
204 /* --------------------------------------------------------------------------------------------- */