summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Jarosch <tomj@simonv.com>2011-02-19 00:32:05 +0000
committerThomas Jarosch <tomj@simonv.com>2011-02-19 00:32:05 +0000
commite80bd1df2a513daf7280ece32b054bebf89fa6b5 (patch)
treebc2492199c004262a92a30cec86dc3ca318500e3
parent70bb128ae9b92c23480cd40fa90805eedd0db4bc (diff)
downloadrockbox-e80bd1df2a513daf7280ece32b054bebf89fa6b5.tar.gz
rockbox-e80bd1df2a513daf7280ece32b054bebf89fa6b5.zip
N900: Prevent stuck up/down keys on systems with shared up/down cursor mapping
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@29331 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--firmware/target/hosted/sdl/button-sdl.c16
1 files changed, 15 insertions, 1 deletions
diff --git a/firmware/target/hosted/sdl/button-sdl.c b/firmware/target/hosted/sdl/button-sdl.c
index 4fab9e85d8..9f1c1f7519 100644
--- a/firmware/target/hosted/sdl/button-sdl.c
+++ b/firmware/target/hosted/sdl/button-sdl.c
@@ -68,6 +68,9 @@ struct event_queue button_queue;
68static int btn = 0; /* Hopefully keeps track of currently pressed keys... */ 68static int btn = 0; /* Hopefully keeps track of currently pressed keys... */
69 69
70int sdl_app_has_input_focus = 1; 70int sdl_app_has_input_focus = 1;
71#if (CONFIG_PLATFORM & PLATFORM_MAEMO)
72static int n900_updown_key_pressed = 0;
73#endif
71 74
72#ifdef HAS_BUTTON_HOLD 75#ifdef HAS_BUTTON_HOLD
73bool hold_button_state = false; 76bool hold_button_state = false;
@@ -230,8 +233,19 @@ static bool event_handler(SDL_Event *event)
230#if (CONFIG_PLATFORM & PLATFORM_MAEMO5) 233#if (CONFIG_PLATFORM & PLATFORM_MAEMO5)
231 /* N900 with shared up/down cursor mapping. Seen on the German, 234 /* N900 with shared up/down cursor mapping. Seen on the German,
232 Finnish, Italian, French and Russian version. Probably more. */ 235 Finnish, Italian, French and Russian version. Probably more. */
233 if (event->key.keysym.mod & KMOD_MODE) 236 if (event->key.keysym.mod & KMOD_MODE || n900_updown_key_pressed)
234 { 237 {
238 /* Prevent stuck up/down keys: If you release the ALT key before the cursor key,
239 rockbox will see a KEYUP event for left/right instead of up/down and
240 the previously pressed up/down key would stay active. */
241 if (ev_key == SDLK_LEFT || ev_key == SDLK_RIGHT)
242 {
243 if (event->type == SDL_KEYDOWN)
244 n900_updown_key_pressed = 1;
245 else
246 n900_updown_key_pressed = 0;
247 }
248
235 if (ev_key == SDLK_LEFT) 249 if (ev_key == SDLK_LEFT)
236 ev_key = SDLK_UP; 250 ev_key = SDLK_UP;
237 else if (ev_key == SDLK_RIGHT) 251 else if (ev_key == SDLK_RIGHT)