fix ecore-fb.. so terminology works 100% perfectly in fb!

SVN revision: 73354
This commit is contained in:
Carsten Haitzler 2012-07-05 14:18:29 +00:00
parent c18872df78
commit a79dbaf286
4 changed files with 192 additions and 170 deletions

View File

@ -809,4 +809,6 @@
* Add ecore_evas_screen_dpi_get()
* Fix ecore_evas_screen_geometry_get(0 for x11 to return zone
pos/size as it should.
* Fix ecore-fb to use key repeat like x so apps dont break in fb
* Fix ecore-fb string lookup table to include ctrl+keys

View File

@ -1,7 +1,7 @@
static void _ecore_fb_event_free_key_down(void *data, void *ev);
static void _ecore_fb_event_free_key_up(void *data, void *ev);
static const char *_ecore_fb_kbd_syms[128 * 6] =
static const char *_ecore_fb_kbd_syms[128 * 7] =
{
#include "ecore_fb_keytable.h"
};
@ -179,9 +179,9 @@ _ecore_fb_kbd_fd_handler(void *data __UNUSED__, Ecore_Fd_Handler *fd_handler __U
if (_ecore_fb_shift) add = 1;
else if (_ecore_fb_lock) add = 2;
e->keyname = strdup(_ecore_fb_kbd_syms[(buf & 0x7f) * 6]);
e->keysymbol = strdup(_ecore_fb_kbd_syms[((buf & 0x7f) * 6) + add]);
e->key_compose = strdup(_ecore_fb_kbd_syms[((buf & 0x7f) * 6) + 3 + add]);
e->keyname = strdup(_ecore_fb_kbd_syms[(buf & 0x7f) * 7]);
e->keysymbol = strdup(_ecore_fb_kbd_syms[((buf & 0x7f) * 7) + add]);
e->key_compose = strdup(_ecore_fb_kbd_syms[((buf & 0x7f) * 7) + 3 + add]);
}
else
e->keyname = strdup(_ecore_fb_btn_syms[buf & 0x7f]);
@ -195,7 +195,6 @@ _ecore_fb_kbd_fd_handler(void *data __UNUSED__, Ecore_Fd_Handler *fd_handler __U
e->root_window = e->window;
e->same_screen = 1;
e->timestamp = ecore_loop_time_get() * 1000.0;
ecore_event_add(ECORE_FB_EVENT_KEY_DOWN, e, _ecore_fb_event_free_key_down, NULL);
if (!strcmp(e->keyname, "Control_L"))
_ecore_fb_ctrl++;
else if (!strcmp(e->keyname, "Control_R"))
@ -224,10 +223,22 @@ _ecore_fb_kbd_fd_handler(void *data __UNUSED__, Ecore_Fd_Handler *fd_handler __U
else if (!strcmp(e->keyname, "F12")) vt_switch = 11;
if (_ecore_fb_ctrl > 2) _ecore_fb_ctrl = 2;
if (_ecore_fb_alt > 2) _ecore_fb_alt = 2;
if ((_ecore_fb_kbd_fd == _ecore_fb_tty_fd) &&
(_ecore_fb_ctrl))
{
const char *ts = _ecore_fb_kbd_syms[(buf & 0x7f) + 3 + 3];
if (ts)
{
if (e->key_compose) free(e->key_compose);
e->key_compose = strdup(ts);
}
}
if ((vt_switch >= 0) &&
(_ecore_fb_ctrl) &&
(_ecore_fb_alt))
_ecore_fb_vt_switch(vt_switch);
ecore_event_add(ECORE_FB_EVENT_KEY_DOWN, e, _ecore_fb_event_free_key_down, NULL);
}
else
{
@ -242,9 +253,9 @@ _ecore_fb_kbd_fd_handler(void *data __UNUSED__, Ecore_Fd_Handler *fd_handler __U
if (_ecore_fb_shift) add = 1;
else if (_ecore_fb_lock) add = 2;
e->keyname = strdup(_ecore_fb_kbd_syms[(buf & 0x7f) * 6]);
e->keysymbol = strdup(_ecore_fb_kbd_syms[((buf & 0x7f) * 6) + add]);
e->key_compose = strdup(_ecore_fb_kbd_syms[((buf & 0x7f) * 6) + 3 + add]);
e->keyname = strdup(_ecore_fb_kbd_syms[(buf & 0x7f) * 7]);
e->keysymbol = strdup(_ecore_fb_kbd_syms[((buf & 0x7f) * 7) + add]);
e->key_compose = strdup(_ecore_fb_kbd_syms[((buf & 0x7f) * 7) + 3 + add]);
}
else
e->keyname = strdup(_ecore_fb_btn_syms[buf & 0x7f]);

View File

@ -1,129 +1,129 @@
/* this table was taken from ecore_fb, is the default en layout */
"0x00", "0x00", "0x00", /**/"", "", "",/***/
"Escape", "Escape", "Escape", /**/"", "", "",/***/
"1", "exclam", "1", /**/"1", "!", "1",/***/
"2", "at", "2", /**/"2", "@", "2",/***/
"3", "numbersign", "3", /**/"3", "#", "3",/***/
"4", "dollar", "4", /**/"4", "$", "4",/***/
"5", "percent", "5", /**/"5", "%", "5",/***/
"6", "asciicircumm", "6", /**/"6", "^", "6",/***/
"7", "ampersand", "7", /**/"7", "&", "7",/***/
"8", "asterisk", "8", /**/"8", "*", "8",/***/
"9", "parenleft", "9", /**/"9", "(", "9",/***/
"0", "parenright", "0", /**/"0", ")", "0",/***/
"minus", "underscore", "minus", /**/"-", "_", "-",/***/
"equal", "plus", "equal", /**/"=", "+", "=",/***/
"BackSpace", "BackSpace", "BackSpace", /**/"\010","\010","\010",/***/
"Tab", "ISO_Left_Tab", "Tab", /**/"\011","", "\011",/***/
"q", "Q", "Q", /**/"q", "Q", "Q",/***/
"w", "W", "W", /**/"w", "W", "W",/***/
"e", "E", "E", /**/"e", "E", "E",/***/
"r", "R", "R", /**/"r", "R", "R",/***/
"t", "T", "T", /**/"t", "T", "T",/***/
"y", "Y", "Y", /**/"y", "Y", "Y",/***/
"u", "U", "U", /**/"u", "U", "U",/***/
"i", "I", "I", /**/"i", "I", "I",/***/
"o", "O", "O", /**/"o", "O", "O",/***/
"p", "P", "P", /**/"p", "P", "P",/***/
"bracketleft", "braceleft", "bracketleft", /**/"[", "{", "[",/***/
"bracketright", "braceright", "bracketright", /**/"]", "}", "]",/***/
"Return", "Return", "Return", /**/"\015","\015","\015",/***/
"Control_L", "Control_L", "Control_L", /**/"", "", "",/***/
"a", "A", "A", /**/"a", "A", "A",/***/
"s", "S", "S", /**/"s", "S", "S",/***/
"d", "D", "D", /**/"d", "D", "D",/***/
"f", "F", "F", /**/"f", "F", "F",/***/
"g", "G", "G", /**/"g", "G", "G",/***/
"h", "h", "H", /**/"h", "H", "H",/***/
"j", "J", "J", /**/"j", "J", "J",/***/
"k", "K", "K", /**/"k", "K", "K",/***/
"l", "L", "L", /**/"l", "L", "L",/***/
"semicolon", "colon", "semicolon", /**/";", ":", ";",/***/
"apostrophe", "quotedbl", "apostrophe", /**/"'", "\"", "'",/***/
"grave", "asciitilde", "grave", /**/"`", "~", "`",/***/
"Shift_L", "Shift_L", "Shift_L", /**/"", "", "",/***/
"backslash", "bar", "backslash", /**/"\\", "|", "\\",/***/
"z", "Z", "Z", /**/"z", "Z", "Z",/***/
"x", "X", "X", /**/"x", "X", "X",/***/
"c", "C", "C", /**/"c", "C", "C",/***/
"v", "V", "V", /**/"v", "V", "V",/***/
"b", "B", "B", /**/"b", "B", "B",/***/
"n", "N", "N", /**/"n", "N", "N",/***/
"m", "M", "M", /**/"m", "M", "M",/***/
"comma", "less", "comma", /**/",", "<", ",",/***/
"period", "greater", "period", /**/".", ">", ".",/***/
"slash", "question", "slash", /**/"/", "?", "/",/***/
"Shift_R", "Shift_R", "Shift_R", /**/"", "", "",/***/
"KP_Multiply", "KP_Multiply", "KP_Multiply", /**/"", "*", "",/***/
"Alt_L", "Alt_L", "Alt_L", /**/"", "", "",/***/
"space", "space", "space", /**/" ", " ", " ",/***/
"Caps_Lock", "Caps_Lock", "Caps_Lock", /**/"", "", "",/***/
"F1", "F1", "F1", /**/"", "", "",/***/
"F2", "F2", "F2", /**/"", "", "",/***/
"F3", "F3", "F3", /**/"", "", "",/***/
"F4", "F4", "F4", /**/"", "", "",/***/
"F5", "F5", "F5", /**/"", "", "",/***/
"F6", "F6", "F6", /**/"", "", "",/***/
"F7", "F7", "F7", /**/"", "", "",/***/
"F8", "F8", "F8", /**/"", "", "",/***/
"F9", "F9", "F9", /**/"", "", "",/***/
"F10", "F10", "F10", /**/"", "", "",/***/
"Num_Lock", "Num_Lock", "Num_Lock", /**/"", "", "",/***/
"Scroll_Lock", "Scroll_Lock", "Scroll_Lock", /**/"", "", "",/***/
"KP_Home", "KP_7", "KP_Home", /**/"", "7", "",/***/
"KP_Up", "KP_8", "KP_Up", /**/"", "8", "",/***/
"KP_Prior", "KP_9", "KP_Prior", /**/"", "9", "",/***/
"KP_Subtract", "KP_Subtract", "KP_Subtract", /**/"", "", "",/***/
"KP_Left", "KP_4", "KP_Left", /**/"", "4", "",/***/
"KP_Begin", "KP_5", "KP_Begin", /**/"", "5", "",/***/
"KP_Right", "KP_6", "KP_Right", /**/"", "6", "",/***/
"KP_Add", "KP_Add", "KP_Add", /**/"", "", "",/***/
"KP_End", "KP_1", "KP_End", /**/"", "1", "",/***/
"KP_Down", "KP_2", "KP_Down", /**/"", "2", "",/***/
"KP_Next", "KP_3", "KP_Next", /**/"", "3", "",/***/
"KP_Insert", "KP_0", "KP_Insert", /**/"", "0", "",/***/
"KP_Delete", "KP_Decimal", "KP_Delete", /**/"", ".", "",/***/
"0x54", "0x54", "0x54", /**/"", "", "",/***/
"0x55", "0x55", "0x55", /**/"", "", "",/***/
"0x56", "0x56", "0x56", /**/"", "", "",/***/
"F11", "F11", "F11", /**/"", "", "",/***/
"F12", "F12", "F12", /**/"", "", "",/***/
"0x59", "0x59", "0x59", /**/"", "", "",/***/
"0x5a", "0x5a", "0x5a", /**/"", "", "",/***/
"0x5b", "0x5b", "0x5b", /**/"", "", "",/***/
"0x5c", "0x5c", "0x5c", /**/"", "", "",/***/
"0x5d", "0x5d", "0x5d", /**/"", "", "",/***/
"0x5e", "0x5e", "0x5e", /**/"", "", "",/***/
"0x5f", "0x5f", "0x5f", /**/"", "", "",/***/
"KP_Enter", "KP_Enter", "KP_Enter", /**/"", "", "",/***/
"Control_R", "Control_R", "Control_R", /**/"", "", "",/***/
"KP_Divide", "KP_Divide", "KP_Divide", /**/"", "", "",/***/
"Print", "Print", "Print", /**/"", "", "",/***/
"Alt_R", "Alt_R", "Alt_R", /**/"", "", "",/***/
"0x65", "0x65", "0x65", /**/"", "", "",/***/
"Home", "Home", "Home", /**/"", "", "",/***/
"Up", "Up", "Up", /**/"", "", "",/***/
"Prior", "Prior", "Prior", /**/"", "", "",/***/
"Left", "Left", "Left", /**/"", "", "",/***/
"Right", "Right", "Right", /**/"", "", "",/***/
"End", "End", "End", /**/"", "", "",/***/
"Down", "Down", "Down", /**/"", "", "",/***/
"Next", "Next", "Next", /**/"", "", "",/***/
"Insert", "Insert", "Insert", /**/"", "", "",/***/
"Delete", "Delete", "Delete", /**/"\177","\177","\177",/***/
"0x70", "0x70", "0x70", /**/"", "", "",/***/
"0x71", "0x71", "0x71", /**/"", "", "",/***/
"0x72", "0x72", "0x72", /**/"", "", "",/***/
"0x73", "0x73", "0x73", /**/"", "", "",/***/
"0x74", "0x74", "0x74", /**/"", "", "",/***/
"0x75", "0x75", "0x75", /**/"", "", "",/***/
"0x76", "0x76", "0x76", /**/"", "", "",/***/
"Pause", "Pause", "Pause", /**/"", "", "",/***/
"0x78", "0x78", "0x78", /**/"", "", "",/***/
"0x79", "0x79", "0x79", /**/"", "", "",/***/
"0x7a", "0x7a", "0x7a", /**/"", "", "",/***/
"0x7b", "0x7b", "0x7b", /**/"", "", "",/***/
"0x7c", "0x7c", "0x7c", /**/"", "", "",/***/
"Super_L", "Super_L", "Super_L", /**/"", "", "",/***/
"Super_R", "Super_R", "Super_R", /**/"", "", "",/***/
"0x7f", "0x7f", "0x7f", /**/"", "", "" /***/
"0x00", "0x00", "0x00", /**/"", "", "", NULL,/***/
"Escape", "Escape", "Escape", /**/"", "", "", "\x1b",/***/
"1", "exclam", "1", /**/"1", "!", "1", NULL,/***/
"2", "at", "2", /**/"2", "@", "2", "",/***/
"3", "numbersign", "3", /**/"3", "#", "3", "\x1b",/***/
"4", "dollar", "4", /**/"4", "$", "4", "\x1c",/***/
"5", "percent", "5", /**/"5", "%", "5", "\x1d",/***/
"6", "asciicircumm", "6", /**/"6", "^", "6", "\x1e",/***/
"7", "ampersand", "7", /**/"7", "&", "7", "\x1f",/***/
"8", "asterisk", "8", /**/"8", "*", "8", "\x7f",/***/
"9", "parenleft", "9", /**/"9", "(", "9", NULL,/***/
"0", "parenright", "0", /**/"0", ")", "0", NULL,/***/
"minus", "underscore", "minus", /**/"-", "_", "-", NULL,/***/
"equal", "plus", "equal", /**/"=", "+", "=", NULL,/***/
"BackSpace", "BackSpace", "BackSpace", /**/"\010","\010","\010", NULL,/***/
"Tab", "ISO_Left_Tab", "Tab", /**/"\011","", "\011", NULL,/***/
"q", "Q", "Q", /**/"q", "Q", "Q", "\x11",/***/
"w", "W", "W", /**/"w", "W", "W", "\x17",/***/
"e", "E", "E", /**/"e", "E", "E", "\x05",/***/
"r", "R", "R", /**/"r", "R", "R", "\x12",/***/
"t", "T", "T", /**/"t", "T", "T", "\x14",/***/
"y", "Y", "Y", /**/"y", "Y", "Y", "\x19",/***/
"u", "U", "U", /**/"u", "U", "U", "\x15",/***/
"i", "I", "I", /**/"i", "I", "I", "\x09",/***/
"o", "O", "O", /**/"o", "O", "O", "\x0f",/***/
"p", "P", "P", /**/"p", "P", "P", "\x10",/***/
"bracketleft", "braceleft", "bracketleft", /**/"[", "{", "[", "\x1b",/***/
"bracketright", "braceright", "bracketright", /**/"]", "}", "]", "\x1d",/***/
"Return", "Return", "Return", /**/"\015","\015","\015", NULL,/***/
"Control_L", "Control_L", "Control_L", /**/"", "", "", NULL,/***/
"a", "A", "A", /**/"a", "A", "A", "\x01",/***/
"s", "S", "S", /**/"s", "S", "S", "\x13",/***/
"d", "D", "D", /**/"d", "D", "D", "\x04",/***/
"f", "F", "F", /**/"f", "F", "F", "\x06",/***/
"g", "G", "G", /**/"g", "G", "G", "\x07",/***/
"h", "h", "H", /**/"h", "H", "H", "\x08",/***/
"j", "J", "J", /**/"j", "J", "J", "\x0a",/***/
"k", "K", "K", /**/"k", "K", "K", "\x0b",/***/
"l", "L", "L", /**/"l", "L", "L", "\x0c",/***/
"semicolon", "colon", "semicolon", /**/";", ":", ";", NULL,/***/
"apostrophe", "quotedbl", "apostrophe", /**/"'", "\"", "'", NULL,/***/
"grave", "asciitilde", "grave", /**/"`", "~", "`", "",/***/
"Shift_L", "Shift_L", "Shift_L", /**/"", "", "", NULL,/***/
"backslash", "bar", "backslash", /**/"\\", "|", "\\", "\x1c",/***/
"z", "Z", "Z", /**/"z", "Z", "Z", "\x1a",/***/
"x", "X", "X", /**/"x", "X", "X", "\x18",/***/
"c", "C", "C", /**/"c", "C", "C", "\x03",/***/
"v", "V", "V", /**/"v", "V", "V", "\x16",/***/
"b", "B", "B", /**/"b", "B", "B", "\x02",/***/
"n", "N", "N", /**/"n", "N", "N", "\x0e",/***/
"m", "M", "M", /**/"m", "M", "M", "\x0d",/***/
"comma", "less", "comma", /**/",", "<", ",", NULL,/***/
"period", "greater", "period", /**/".", ">", ".", NULL,/***/
"slash", "question", "slash", /**/"/", "?", "/", "",/***/
"Shift_R", "Shift_R", "Shift_R", /**/"", "", "", NULL,/***/
"KP_Multiply", "KP_Multiply", "KP_Multiply", /**/"", "*", "", NULL,/***/
"Alt_L", "Alt_L", "Alt_L", /**/"", "", "", NULL,/***/
"space", "space", "space", /**/" ", " ", " ", "",/***/
"Caps_Lock", "Caps_Lock", "Caps_Lock", /**/"", "", "", NULL,/***/
"F1", "F1", "F1", /**/"", "", "", NULL,/***/
"F2", "F2", "F2", /**/"", "", "", NULL,/***/
"F3", "F3", "F3", /**/"", "", "", NULL,/***/
"F4", "F4", "F4", /**/"", "", "", NULL,/***/
"F5", "F5", "F5", /**/"", "", "", NULL,/***/
"F6", "F6", "F6", /**/"", "", "", NULL,/***/
"F7", "F7", "F7", /**/"", "", "", NULL,/***/
"F8", "F8", "F8", /**/"", "", "", NULL,/***/
"F9", "F9", "F9", /**/"", "", "", NULL,/***/
"F10", "F10", "F10", /**/"", "", "", NULL,/***/
"Num_Lock", "Num_Lock", "Num_Lock", /**/"", "", "", NULL,/***/
"Scroll_Lock", "Scroll_Lock", "Scroll_Lock", /**/"", "", "", NULL,/***/
"KP_Home", "KP_7", "KP_Home", /**/"", "7", "", NULL,/***/
"KP_Up", "KP_8", "KP_Up", /**/"", "8", "", NULL,/***/
"KP_Prior", "KP_9", "KP_Prior", /**/"", "9", "", NULL,/***/
"KP_Subtract", "KP_Subtract", "KP_Subtract", /**/"", "", "", NULL,/***/
"KP_Left", "KP_4", "KP_Left", /**/"", "4", "", NULL,/***/
"KP_Begin", "KP_5", "KP_Begin", /**/"", "5", "", NULL,/***/
"KP_Right", "KP_6", "KP_Right", /**/"", "6", "", NULL,/***/
"KP_Add", "KP_Add", "KP_Add", /**/"", "", "", NULL,/***/
"KP_End", "KP_1", "KP_End", /**/"", "1", "", NULL,/***/
"KP_Down", "KP_2", "KP_Down", /**/"", "2", "", NULL,/***/
"KP_Next", "KP_3", "KP_Next", /**/"", "3", "", NULL,/***/
"KP_Insert", "KP_0", "KP_Insert", /**/"", "0", "", NULL,/***/
"KP_Delete", "KP_Decimal", "KP_Delete", /**/"", ".", "", NULL,/***/
"0x54", "0x54", "0x54", /**/"", "", "", NULL,/***/
"0x55", "0x55", "0x55", /**/"", "", "", NULL,/***/
"0x56", "0x56", "0x56", /**/"", "", "", NULL,/***/
"F11", "F11", "F11", /**/"", "", "", NULL,/***/
"F12", "F12", "F12", /**/"", "", "", NULL,/***/
"0x59", "0x59", "0x59", /**/"", "", "", NULL,/***/
"0x5a", "0x5a", "0x5a", /**/"", "", "", NULL,/***/
"0x5b", "0x5b", "0x5b", /**/"", "", "", NULL,/***/
"0x5c", "0x5c", "0x5c", /**/"", "", "", NULL,/***/
"0x5d", "0x5d", "0x5d", /**/"", "", "", NULL,/***/
"0x5e", "0x5e", "0x5e", /**/"", "", "", NULL,/***/
"0x5f", "0x5f", "0x5f", /**/"", "", "", NULL,/***/
"KP_Enter", "KP_Enter", "KP_Enter", /**/"\015", "\015", "\015", NULL,/***/
"Control_R", "Control_R", "Control_R", /**/"", "", "", NULL,/***/
"KP_Divide", "KP_Divide", "KP_Divide", /**/"", "", "", NULL,/***/
"Print", "Print", "Print", /**/"", "", "", NULL,/***/
"Alt_R", "Alt_R", "Alt_R", /**/"", "", "", NULL,/***/
"0x65", "0x65", "0x65", /**/"", "", "", NULL,/***/
"Home", "Home", "Home", /**/"", "", "", NULL,/***/
"Up", "Up", "Up", /**/"", "", "", NULL,/***/
"Prior", "Prior", "Prior", /**/"", "", "", NULL,/***/
"Left", "Left", "Left", /**/"", "", "", NULL,/***/
"Right", "Right", "Right", /**/"", "", "", NULL,/***/
"End", "End", "End", /**/"", "", "", NULL,/***/
"Down", "Down", "Down", /**/"", "", "", NULL,/***/
"Next", "Next", "Next", /**/"", "", "", NULL,/***/
"Insert", "Insert", "Insert", /**/"", "", "", NULL,/***/
"Delete", "Delete", "Delete", /**/"\177","\177","\177", NULL,/***/
"0x70", "0x70", "0x70", /**/"", "", "", NULL,/***/
"0x71", "0x71", "0x71", /**/"", "", "", NULL,/***/
"0x72", "0x72", "0x72", /**/"", "", "", NULL,/***/
"0x73", "0x73", "0x73", /**/"", "", "", NULL,/***/
"0x74", "0x74", "0x74", /**/"", "", "", NULL,/***/
"0x75", "0x75", "0x75", /**/"", "", "", NULL,/***/
"0x76", "0x76", "0x76", /**/"", "", "", NULL,/***/
"Pause", "Pause", "Pause", /**/"", "", "", NULL,/***/
"0x78", "0x78", "0x78", /**/"", "", "", NULL,/***/
"0x79", "0x79", "0x79", /**/"", "", "", NULL,/***/
"0x7a", "0x7a", "0x7a", /**/"", "", "", NULL,/***/
"0x7b", "0x7b", "0x7b", /**/"", "", "", NULL,/***/
"0x7c", "0x7c", "0x7c", /**/"", "", "", NULL,/***/
"Super_L", "Super_L", "Super_L", /**/"", "", "", NULL,/***/
"Super_R", "Super_R", "Super_R", /**/"", "", "", NULL,/***/
"0x7f", "0x7f", "0x7f", /**/"", "", "", NULL, /***/

View File

@ -11,7 +11,7 @@
static Eina_List *_ecore_fb_li_devices = NULL;
static const char *_ecore_fb_li_kbd_syms[128 * 6] =
static const char *_ecore_fb_li_kbd_syms[128 * 7] =
{
#include "ecore_fb_keytable.h"
};
@ -46,31 +46,33 @@ _ecore_fb_li_device_event_key(Ecore_Fb_Input_Device *dev, struct input_event *ie
if ((iev->code >= KEY_ESC) && (iev->code <= KEY_COMPOSE))
{
int offset = 0;
const char *keyname = _ecore_fb_li_kbd_syms[iev->code * 6];
const char *keyname = _ecore_fb_li_kbd_syms[iev->code * 7];
/* check the key table */
if (iev->value)
{
/* its a repeated key, dont increment */
if (iev->value == 2)
return;
if (!strcmp(keyname, "Control_L"))
dev->keyboard.ctrl++;
else if (!strcmp(keyname, "Control_R"))
dev->keyboard.ctrl++;
else if (!strcmp(keyname, "Alt_L"))
dev->keyboard.alt++;
else if (!strcmp(keyname, "Alt_R"))
dev->keyboard.alt++;
else if (!strcmp(keyname, "Shift_L"))
dev->keyboard.shift++;
else if (!strcmp(keyname, "Shift_R"))
dev->keyboard.shift++;
else if (!strcmp(keyname, "Caps_Lock"))
dev->keyboard.lock = !dev->keyboard.lock;
if (dev->keyboard.ctrl > 2) dev->keyboard.ctrl = 2;
if (dev->keyboard.alt > 2) dev->keyboard.alt = 2;
if (dev->keyboard.shift > 2) dev->keyboard.shift = 2;
if (dev->keyboard.lock > 1) dev->keyboard.lock = 1;
if (iev->value != 2)
{
if (!strcmp(keyname, "Control_L"))
dev->keyboard.ctrl++;
else if (!strcmp(keyname, "Control_R"))
dev->keyboard.ctrl++;
else if (!strcmp(keyname, "Alt_L"))
dev->keyboard.alt++;
else if (!strcmp(keyname, "Alt_R"))
dev->keyboard.alt++;
else if (!strcmp(keyname, "Shift_L"))
dev->keyboard.shift++;
else if (!strcmp(keyname, "Shift_R"))
dev->keyboard.shift++;
else if (!strcmp(keyname, "Caps_Lock"))
dev->keyboard.lock = !dev->keyboard.lock;
if (dev->keyboard.ctrl > 2) dev->keyboard.ctrl = 2;
if (dev->keyboard.alt > 2) dev->keyboard.alt = 2;
if (dev->keyboard.shift > 2) dev->keyboard.shift = 2;
if (dev->keyboard.lock > 1) dev->keyboard.lock = 1;
}
}
else
{
@ -98,8 +100,15 @@ _ecore_fb_li_device_event_key(Ecore_Fb_Input_Device *dev, struct input_event *ie
if (dev->keyboard.shift) offset = 1;
else if (dev->keyboard.lock) offset = 2;
const char *key = _ecore_fb_li_kbd_syms[(iev->code * 6) + offset];
const char *compose = _ecore_fb_li_kbd_syms[(iev->code * 6) + 3 + offset];
const char *key = _ecore_fb_li_kbd_syms[(iev->code * 7) + offset];
const char *compose = _ecore_fb_li_kbd_syms[(iev->code * 7) + 3 + offset];
if (dev->keyboard.ctrl)
{
const char *ts = _ecore_fb_li_kbd_syms[(iev->code * 7) + 3 + 3];
if (ts) compose = ts;
}
e = calloc(1, sizeof(Ecore_Event_Key) + strlen(key) +
strlen(keyname) + (compose ? strlen(compose) : 0) + 3);
@ -210,21 +219,21 @@ _ecore_fb_li_device_event_rel(Ecore_Fb_Input_Device *dev, struct input_event *ie
case REL_Y:
{
Ecore_Event_Mouse_Move *e;
if(iev->code == REL_X)
if (iev->code == REL_X)
{
dev->mouse.x += iev->value;
if(dev->mouse.x > dev->mouse.w - 1)
dev->mouse.x = dev->mouse.w;
if (dev->mouse.x > dev->mouse.w - 1)
dev->mouse.x = dev->mouse.w;
else if(dev->mouse.x < 0)
dev->mouse.x = 0;
dev->mouse.x = 0;
}
else
{
dev->mouse.y += iev->value;
if(dev->mouse.y > dev->mouse.h - 1)
dev->mouse.y = dev->mouse.h;
if (dev->mouse.y > dev->mouse.h - 1)
dev->mouse.y = dev->mouse.h;
else if(dev->mouse.y < 0)
dev->mouse.y = 0;
dev->mouse.y = 0;
}
e = calloc(1, sizeof(Ecore_Event_Mouse_Move));
@ -314,7 +323,7 @@ _ecore_fb_li_device_event_abs(Ecore_Fb_Input_Device *dev, struct input_event *ie
break;
case ABS_Y:
if(dev->mouse.h != 0)
if (dev->mouse.h != 0)
{
int tmp;
@ -537,8 +546,8 @@ ecore_fb_input_device_open(const char *dev)
/* set info */
for (event_type = 0; event_type < EV_MAX; event_type++)
{
if(!test_bit(event_type, event_type_bitmask))
continue;
if (!test_bit(event_type, event_type_bitmask))
continue;
switch (event_type)
{
case EV_SYN: