src/video/svga/SDL_svgaevents.c

/* [<][>]
[^][v][top][bottom][index][help] */

FUNCTIONS

This source file includes following functions.
  1. SVGA_initkeymaps
  2. SVGA_initkeymaps
  3. SVGA_mousecallback
  4. SVGA_keyboardcallback
  5. SVGA_PumpEvents
  6. SVGA_InitOSKeymap
  7. TranslateKey
  8. TranslateKey

   1 /*
   2     SDL - Simple DirectMedia Layer
   3     Copyright (C) 1997, 1998, 1999, 2000, 2001  Sam Lantinga
   4 
   5     This library is free software; you can redistribute it and/or
   6     modify it under the terms of the GNU Library General Public
   7     License as published by the Free Software Foundation; either
   8     version 2 of the License, or (at your option) any later version.
   9 
  10     This library is distributed in the hope that it will be useful,
  11     but WITHOUT ANY WARRANTY; without even the implied warranty of
  12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  13     Library General Public License for more details.
  14 
  15     You should have received a copy of the GNU Library General Public
  16     License along with this library; if not, write to the Free
  17     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  18 
  19     Sam Lantinga
  20     slouken@devolution.com
  21 */
  22 
  23 #ifdef SAVE_RCSID
  24 static char rcsid =
  25  "@(#) $Id: SDL_svgaevents.c,v 1.1.2.3 2001/02/10 07:20:07 hercules Exp $";
  26 #endif
  27 
  28 /* Handle the event stream, converting X11 events into SDL events */
  29 
  30 #include <stdio.h>
  31 
  32 #include <vga.h>
  33 #include <vgamouse.h>
  34 #include <vgakeyboard.h>
  35 #if defined(linux)
  36 #include <linux/kd.h>
  37 #include <linux/keyboard.h>
  38 #elif defined(__FreeBSD__)
  39 #include <sys/kbio.h>
  40 #else
  41 #error You must choose your operating system here
  42 #endif
  43 
  44 #include "SDL.h"
  45 #include "SDL_sysevents.h"
  46 #include "SDL_events_c.h"
  47 #include "SDL_svgavideo.h"
  48 #include "SDL_svgaevents_c.h"
  49 
  50 /* The translation tables from a console scancode to a SDL keysym */
  51 #if defined(linux)
  52 #define NUM_VGAKEYMAPS  (1<<KG_CAPSSHIFT)
  53 static Uint16 vga_keymap[NUM_VGAKEYMAPS][NR_KEYS];
  54 #elif defined(__FreeBSD__)
  55 /* FIXME: Free the keymap when we shut down the video mode */
  56 static keymap_t *vga_keymap = NULL;
  57 #else
  58 #error You must choose your operating system here
  59 #endif
  60 static SDLKey keymap[128];
  61 static SDL_keysym *TranslateKey(int scancode, SDL_keysym *keysym);
  62 
  63 /* Ugh, we have to duplicate the kernel's keysym mapping code...
  64    Oh, it's not so bad. :-)
  65 
  66    FIXME: Add keyboard LED handling code
  67  */
  68 #if defined(linux)
  69 int SVGA_initkeymaps(int fd)
     /* [<][>][^][v][top][bottom][index][help] */
  70 {
  71         struct kbentry entry;
  72         int map, i;
  73 
  74         /* Load all the keysym mappings */
  75         for ( map=0; map<NUM_VGAKEYMAPS; ++map ) {
  76                 memset(vga_keymap[map], 0, NR_KEYS*sizeof(Uint16));
  77                 for ( i=0; i<NR_KEYS; ++i ) {
  78                         entry.kb_table = map;
  79                         entry.kb_index = i;
  80                         if ( ioctl(fd, KDGKBENT, &entry) == 0 ) {
  81                                 /* The "Enter" key is a special case */
  82                                 if ( entry.kb_value == K_ENTER ) {
  83                                         entry.kb_value = K(KT_ASCII,13);
  84                                 }
  85                                 /* Handle numpad specially as well */
  86                                 if ( KTYP(entry.kb_value) == KT_PAD ) {
  87                                     switch ( entry.kb_value ) {
  88                                         case K_P0:
  89                                         case K_P1:
  90                                         case K_P2:
  91                                         case K_P3:
  92                                         case K_P4:
  93                                         case K_P5:
  94                                         case K_P6:
  95                                         case K_P7:
  96                                         case K_P8:
  97                                         case K_P9:
  98                                             vga_keymap[map][i]=entry.kb_value;
  99                                             vga_keymap[map][i]+= '0';
 100                                             break;
 101                                         case K_PPLUS:
 102                                             vga_keymap[map][i]=K(KT_ASCII,'+');
 103                                             break;
 104                                         case K_PMINUS:
 105                                             vga_keymap[map][i]=K(KT_ASCII,'-');
 106                                             break;
 107                                         case K_PSTAR:
 108                                             vga_keymap[map][i]=K(KT_ASCII,'*');
 109                                             break;
 110                                         case K_PSLASH:
 111                                             vga_keymap[map][i]=K(KT_ASCII,'/');
 112                                             break;
 113                                         case K_PENTER:
 114                                             vga_keymap[map][i]=K(KT_ASCII,'\r');
 115                                             break;
 116                                         case K_PCOMMA:
 117                                             vga_keymap[map][i]=K(KT_ASCII,',');
 118                                             break;
 119                                         case K_PDOT:
 120                                             vga_keymap[map][i]=K(KT_ASCII,'.');
 121                                             break;
 122                                         default:
 123                                             break;
 124                                     }
 125                                 }
 126                                 /* Do the normal key translation */
 127                                 if ( (KTYP(entry.kb_value) == KT_LATIN) ||
 128                                      (KTYP(entry.kb_value) == KT_ASCII) ||
 129                                      (KTYP(entry.kb_value) == KT_LETTER) ) {
 130                                         vga_keymap[map][i] = entry.kb_value;
 131                                 }
 132                         }
 133                 }
 134         }
 135         return(0);
 136 }
 137 #elif defined(__FreeBSD__)
 138 int SVGA_initkeymaps(int fd)
     /* [<][>][^][v][top][bottom][index][help] */
 139 {
 140         vga_keymap = malloc(sizeof(keymap_t));
 141         if ( ! vga_keymap ) {
 142                 SDL_OutOfMemory();
 143                 return(-1);
 144         }
 145         if (ioctl(fd, GIO_KEYMAP, vga_keymap) == -1) {
 146                 free(vga_keymap);
 147                 vga_keymap = NULL;
 148                 SDL_SetError("Unable to get keyboard map");
 149                 return(-1);
 150         }
 151         return(0);
 152 }
 153 #else
 154 #error You must choose your operating system here
 155 #endif
 156 
 157 int posted = 0;
 158 
 159 void SVGA_mousecallback(int button, int dx, int dy,
     /* [<][>][^][v][top][bottom][index][help] */
 160                           int u1,int u2,int u3, int u4)
 161 {
 162         if ( dx || dy ) {
 163                 posted += SDL_PrivateMouseMotion(0, 1, dx, dy);
 164         }
 165         if ( button & MOUSE_LEFTBUTTON ) {
 166                 if ( !(SDL_GetMouseState(NULL, NULL) & SDL_BUTTON(1)) ) {
 167                         posted += SDL_PrivateMouseButton(SDL_PRESSED, 1, 0, 0);
 168                 }
 169         } else {
 170                 if ( (SDL_GetMouseState(NULL, NULL) & SDL_BUTTON(1)) ) {
 171                         posted += SDL_PrivateMouseButton(SDL_RELEASED, 1, 0, 0);
 172                 }
 173         }
 174         if ( button & MOUSE_MIDDLEBUTTON ) {
 175                 if ( !(SDL_GetMouseState(NULL, NULL) & SDL_BUTTON(2)) ) {
 176                         posted += SDL_PrivateMouseButton(SDL_PRESSED, 2, 0, 0);
 177                 }
 178         } else {
 179                 if ( (SDL_GetMouseState(NULL, NULL) & SDL_BUTTON(2)) ) {
 180                         posted += SDL_PrivateMouseButton(SDL_RELEASED, 2, 0, 0);
 181                 }
 182         }
 183         if ( button & MOUSE_RIGHTBUTTON ) {
 184                 if ( !(SDL_GetMouseState(NULL, NULL) & SDL_BUTTON(3)) ) {
 185                         posted += SDL_PrivateMouseButton(SDL_PRESSED, 3, 0, 0);
 186                 }
 187         } else {
 188                 if ( (SDL_GetMouseState(NULL, NULL) & SDL_BUTTON(3)) ) {
 189                         posted += SDL_PrivateMouseButton(SDL_RELEASED, 3, 0, 0);
 190                 }
 191         }
 192 }
 193 
 194 void SVGA_keyboardcallback(int scancode, int pressed)
     /* [<][>][^][v][top][bottom][index][help] */
 195 {
 196         SDL_keysym keysym;
 197 
 198         if ( pressed ) {
 199                 posted += SDL_PrivateKeyboard(SDL_PRESSED,
 200                             TranslateKey(scancode, &keysym));
 201         } else {
 202                 posted += SDL_PrivateKeyboard(SDL_RELEASED,
 203                             TranslateKey(scancode, &keysym));
 204         }
 205 }
 206 
 207 void SVGA_PumpEvents(_THIS)
     /* [<][>][^][v][top][bottom][index][help] */
 208 {
 209         do {
 210                 posted = 0;
 211                 mouse_update();
 212                 keyboard_update();
 213         } while ( posted );
 214 }
 215 
 216 void SVGA_InitOSKeymap(_THIS)
     /* [<][>][^][v][top][bottom][index][help] */
 217 {
 218         int i;
 219 
 220         /* Initialize the BeOS key translation table */
 221         for ( i=0; i<SDL_TABLESIZE(keymap); ++i )
 222                 keymap[i] = SDLK_UNKNOWN;
 223 
 224         keymap[SCANCODE_ESCAPE] = SDLK_ESCAPE;
 225         keymap[SCANCODE_1] = SDLK_1;
 226         keymap[SCANCODE_2] = SDLK_2;
 227         keymap[SCANCODE_3] = SDLK_3;
 228         keymap[SCANCODE_4] = SDLK_4;
 229         keymap[SCANCODE_5] = SDLK_5;
 230         keymap[SCANCODE_6] = SDLK_6;
 231         keymap[SCANCODE_7] = SDLK_7;
 232         keymap[SCANCODE_8] = SDLK_8;
 233         keymap[SCANCODE_9] = SDLK_9;
 234         keymap[SCANCODE_0] = SDLK_0;
 235         keymap[SCANCODE_MINUS] = SDLK_MINUS;
 236         keymap[SCANCODE_EQUAL] = SDLK_EQUALS;
 237         keymap[SCANCODE_BACKSPACE] = SDLK_BACKSPACE;
 238         keymap[SCANCODE_TAB] = SDLK_TAB;
 239         keymap[SCANCODE_Q] = SDLK_q;
 240         keymap[SCANCODE_W] = SDLK_w;
 241         keymap[SCANCODE_E] = SDLK_e;
 242         keymap[SCANCODE_R] = SDLK_r;
 243         keymap[SCANCODE_T] = SDLK_t;
 244         keymap[SCANCODE_Y] = SDLK_y;
 245         keymap[SCANCODE_U] = SDLK_u;
 246         keymap[SCANCODE_I] = SDLK_i;
 247         keymap[SCANCODE_O] = SDLK_o;
 248         keymap[SCANCODE_P] = SDLK_p;
 249         keymap[SCANCODE_BRACKET_LEFT] = SDLK_LEFTBRACKET;
 250         keymap[SCANCODE_BRACKET_RIGHT] = SDLK_RIGHTBRACKET;
 251         keymap[SCANCODE_ENTER] = SDLK_RETURN;
 252         keymap[SCANCODE_LEFTCONTROL] = SDLK_LCTRL;
 253         keymap[SCANCODE_A] = SDLK_a;
 254         keymap[SCANCODE_S] = SDLK_s;
 255         keymap[SCANCODE_D] = SDLK_d;
 256         keymap[SCANCODE_F] = SDLK_f;
 257         keymap[SCANCODE_G] = SDLK_g;
 258         keymap[SCANCODE_H] = SDLK_h;
 259         keymap[SCANCODE_J] = SDLK_j;
 260         keymap[SCANCODE_K] = SDLK_k;
 261         keymap[SCANCODE_L] = SDLK_l;
 262         keymap[SCANCODE_SEMICOLON] = SDLK_SEMICOLON;
 263         keymap[SCANCODE_APOSTROPHE] = SDLK_QUOTE;
 264         keymap[SCANCODE_GRAVE] = SDLK_BACKQUOTE;
 265         keymap[SCANCODE_LEFTSHIFT] = SDLK_LSHIFT;
 266         keymap[SCANCODE_BACKSLASH] = SDLK_BACKSLASH;
 267         keymap[SCANCODE_Z] = SDLK_z;
 268         keymap[SCANCODE_X] = SDLK_x;
 269         keymap[SCANCODE_C] = SDLK_c;
 270         keymap[SCANCODE_V] = SDLK_v;
 271         keymap[SCANCODE_B] = SDLK_b;
 272         keymap[SCANCODE_N] = SDLK_n;
 273         keymap[SCANCODE_M] = SDLK_m;
 274         keymap[SCANCODE_COMMA] = SDLK_COMMA;
 275         keymap[SCANCODE_PERIOD] = SDLK_PERIOD;
 276         keymap[SCANCODE_SLASH] = SDLK_SLASH;
 277         keymap[SCANCODE_RIGHTSHIFT] = SDLK_RSHIFT;
 278         keymap[SCANCODE_KEYPADMULTIPLY] = SDLK_KP_MULTIPLY;
 279         keymap[SCANCODE_LEFTALT] = SDLK_LALT;
 280         keymap[SCANCODE_SPACE] = SDLK_SPACE;
 281         keymap[SCANCODE_CAPSLOCK] = SDLK_CAPSLOCK;
 282         keymap[SCANCODE_F1] = SDLK_F1;
 283         keymap[SCANCODE_F2] = SDLK_F2;
 284         keymap[SCANCODE_F3] = SDLK_F3;
 285         keymap[SCANCODE_F4] = SDLK_F4;
 286         keymap[SCANCODE_F5] = SDLK_F5;
 287         keymap[SCANCODE_F6] = SDLK_F6;
 288         keymap[SCANCODE_F7] = SDLK_F7;
 289         keymap[SCANCODE_F8] = SDLK_F8;
 290         keymap[SCANCODE_F9] = SDLK_F9;
 291         keymap[SCANCODE_F10] = SDLK_F10;
 292         keymap[SCANCODE_NUMLOCK] = SDLK_NUMLOCK;
 293         keymap[SCANCODE_SCROLLLOCK] = SDLK_SCROLLOCK;
 294         keymap[SCANCODE_KEYPAD7] = SDLK_KP7;
 295         keymap[SCANCODE_CURSORUPLEFT] = SDLK_KP7;
 296         keymap[SCANCODE_KEYPAD8] = SDLK_KP8;
 297         keymap[SCANCODE_CURSORUP] = SDLK_KP8;
 298         keymap[SCANCODE_KEYPAD9] = SDLK_KP9;
 299         keymap[SCANCODE_CURSORUPRIGHT] = SDLK_KP9;
 300         keymap[SCANCODE_KEYPADMINUS] = SDLK_KP_MINUS;
 301         keymap[SCANCODE_KEYPAD4] = SDLK_KP4;
 302         keymap[SCANCODE_CURSORLEFT] = SDLK_KP4;
 303         keymap[SCANCODE_KEYPAD5] = SDLK_KP5;
 304         keymap[SCANCODE_KEYPAD6] = SDLK_KP6;
 305         keymap[SCANCODE_CURSORRIGHT] = SDLK_KP6;
 306         keymap[SCANCODE_KEYPADPLUS] = SDLK_KP_PLUS;
 307         keymap[SCANCODE_KEYPAD1] = SDLK_KP1;
 308         keymap[SCANCODE_CURSORDOWNLEFT] = SDLK_KP1;
 309         keymap[SCANCODE_KEYPAD2] = SDLK_KP2;
 310         keymap[SCANCODE_CURSORDOWN] = SDLK_KP2;
 311         keymap[SCANCODE_KEYPAD3] = SDLK_KP3;
 312         keymap[SCANCODE_CURSORDOWNRIGHT] = SDLK_KP3;
 313         keymap[SCANCODE_KEYPAD0] = SDLK_KP0;
 314         keymap[SCANCODE_KEYPADPERIOD] = SDLK_KP_PERIOD;
 315         keymap[SCANCODE_LESS] = SDLK_LESS;
 316         keymap[SCANCODE_F11] = SDLK_F11;
 317         keymap[SCANCODE_F12] = SDLK_F12;
 318         keymap[SCANCODE_KEYPADENTER] = SDLK_KP_ENTER;
 319         keymap[SCANCODE_RIGHTCONTROL] = SDLK_RCTRL;
 320         keymap[SCANCODE_CONTROL] = SDLK_RCTRL;
 321         keymap[SCANCODE_KEYPADDIVIDE] = SDLK_KP_DIVIDE;
 322         keymap[SCANCODE_PRINTSCREEN] = SDLK_PRINT;
 323         keymap[SCANCODE_RIGHTALT] = SDLK_RALT;
 324         keymap[SCANCODE_BREAK] = SDLK_BREAK;
 325         keymap[SCANCODE_BREAK_ALTERNATIVE] = SDLK_UNKNOWN;
 326         keymap[SCANCODE_HOME] = SDLK_HOME;
 327         keymap[SCANCODE_CURSORBLOCKUP] = SDLK_UP;
 328         keymap[SCANCODE_PAGEUP] = SDLK_PAGEUP;
 329         keymap[SCANCODE_CURSORBLOCKLEFT] = SDLK_LEFT;
 330         keymap[SCANCODE_CURSORBLOCKRIGHT] = SDLK_RIGHT;
 331         keymap[SCANCODE_END] = SDLK_END;
 332         keymap[SCANCODE_CURSORBLOCKDOWN] = SDLK_DOWN;
 333         keymap[SCANCODE_PAGEDOWN] = SDLK_PAGEDOWN;
 334         keymap[SCANCODE_INSERT] = SDLK_INSERT;
 335         keymap[SCANCODE_REMOVE] = SDLK_DELETE;
 336         keymap[119] = SDLK_PAUSE;
 337         keymap[SCANCODE_RIGHTWIN] = SDLK_RSUPER;
 338         keymap[SCANCODE_LEFTWIN] = SDLK_LSUPER;
 339         keymap[127] = SDLK_MENU;
 340 }
 341 
 342 #if defined(linux)
 343 static SDL_keysym *TranslateKey(int scancode, SDL_keysym *keysym)
     /* [<][>][^][v][top][bottom][index][help] */
 344 {
 345         /* Set the keysym information */
 346         keysym->scancode = scancode;
 347         keysym->sym = keymap[scancode];
 348         keysym->mod = KMOD_NONE;
 349 
 350         /* If UNICODE is on, get the UNICODE value for the key */
 351         keysym->unicode = 0;
 352         if ( SDL_TranslateUNICODE ) {
 353                 int map;
 354                 SDLMod modstate;
 355 
 356                 modstate = SDL_GetModState();
 357                 map = 0;
 358                 if ( modstate & KMOD_SHIFT ) {
 359                         map |= (1<<KG_SHIFT);
 360                 }
 361                 if ( modstate & KMOD_CTRL ) {
 362                         map |= (1<<KG_CTRL);
 363                 }
 364                 if ( modstate & KMOD_ALT ) {
 365                         map |= (1<<KG_ALT);
 366                 }
 367                 if ( modstate & KMOD_MODE ) {
 368                         map |= (1<<KG_ALTGR);
 369                 }
 370                 if ( KTYP(vga_keymap[map][scancode]) == KT_LETTER ) {
 371                         if ( modstate & KMOD_CAPS ) {
 372                                 map ^= (1<<KG_SHIFT);
 373                         }
 374                 }
 375                 if ( KTYP(vga_keymap[map][scancode]) == KT_PAD ) {
 376                         if ( modstate & KMOD_NUM ) {
 377                                 keysym->unicode=KVAL(vga_keymap[map][scancode]);
 378                         }
 379                 } else {
 380                         keysym->unicode = KVAL(vga_keymap[map][scancode]);
 381                 }
 382         }
 383         return(keysym);
 384 }
 385 #elif defined(__FreeBSD__)
 386 static SDL_keysym *TranslateKey(int scancode, SDL_keysym *keysym)
     /* [<][>][^][v][top][bottom][index][help] */
 387 {
 388         /* Set the keysym information */
 389         keysym->scancode = scancode;
 390         keysym->sym = keymap[scancode];
 391         keysym->mod = KMOD_NONE;
 392 
 393         /* If UNICODE is on, get the UNICODE value for the key */
 394         keysym->unicode = 0;
 395         if ( SDL_TranslateUNICODE && vga_keymap ) {
 396                 int map;
 397                 SDLMod modstate;
 398 
 399                 modstate = SDL_GetModState();
 400                 map = 0;
 401                 if ( modstate & KMOD_SHIFT ) {
 402                         map += 1;
 403                 }
 404                 if ( modstate & KMOD_CTRL ) {
 405                         map += 2;
 406                 }
 407                 if ( modstate & KMOD_ALT ) {
 408                         map += 4;
 409                 }
 410                 if ( !(vga_keymap->key[scancode].spcl & (0x80 >> map)) ) {
 411                         keysym->unicode = vga_keymap->key[scancode].map[map];
 412                 }
 413 
 414         }
 415         return(keysym);
 416 }
 417 #else
 418 #error You must choose your operating system here
 419 #endif

/* [<][>][^][v][top][bottom][index][help] */