Skip to content
This repository has been archived by the owner on Feb 11, 2021. It is now read-only.

Commit

Permalink
Browse files Browse the repository at this point in the history
Forward keyboard reworking from 1.2
  • Loading branch information
pmandin committed Sep 20, 2006
1 parent eac3f55 commit 1180af7
Show file tree
Hide file tree
Showing 6 changed files with 118 additions and 375 deletions.
77 changes: 77 additions & 0 deletions src/video/ataricommon/SDL_atarievents.c
Expand Up @@ -30,10 +30,13 @@
*/

#include <mint/cookie.h>
#include <mint/ostruct.h>
#include <mint/osbind.h>

#include "../../events/SDL_sysevents.h"
#include "../../events/SDL_events_c.h"

#include "SDL_atarikeys.h"
#include "SDL_atarievents_c.h"
#include "SDL_biosevents_c.h"
#include "SDL_gemdosevents_c.h"
Expand All @@ -49,6 +52,14 @@ enum
MCH_ARANYM
};

#ifndef KT_NOCHANGE
# define KT_NOCHANGE -1
#endif

/* The translation tables from a console scancode to a SDL keysym */
static SDLKey keymap[ATARIBIOS_MAXKEYS];
static unsigned char *keytab_normal;

void (*Atari_ShutdownEvents) (void);

static void
Expand Down Expand Up @@ -111,6 +122,8 @@ Atari_InitOSKeymap(_THIS)
{
Atari_InitializeEvents(this);

SDL_Atari_InitInternalKeymap(this);

/* Call choosen routine */
this->InitOSKeymap(this);
}
Expand All @@ -124,6 +137,47 @@ Atari_PumpEvents(_THIS)
this->PumpEvents(this);
}

void
SDL_Atari_InitInternalKeymap(_THIS)
{
int i;
_KEYTAB *key_tables;

/* Read system tables for scancode -> ascii translation */
key_tables = (_KEYTAB *) Keytbl(KT_NOCHANGE, KT_NOCHANGE, KT_NOCHANGE);
keytab_normal = key_tables->unshift;

/* Initialize keymap */
for ( i=0; i<ATARIBIOS_MAXKEYS; i++ )
keymap[i] = SDLK_UNKNOWN;

/* Functions keys */
for ( i = 0; i<10; i++ )
keymap[SCANCODE_F1 + i] = SDLK_F1+i;

/* Cursor keypad */
keymap[SCANCODE_HELP] = SDLK_HELP;
keymap[SCANCODE_UNDO] = SDLK_UNDO;
keymap[SCANCODE_INSERT] = SDLK_INSERT;
keymap[SCANCODE_CLRHOME] = SDLK_HOME;
keymap[SCANCODE_UP] = SDLK_UP;
keymap[SCANCODE_DOWN] = SDLK_DOWN;
keymap[SCANCODE_RIGHT] = SDLK_RIGHT;
keymap[SCANCODE_LEFT] = SDLK_LEFT;

/* Special keys */
keymap[SCANCODE_ESCAPE] = SDLK_ESCAPE;
keymap[SCANCODE_BACKSPACE] = SDLK_BACKSPACE;
keymap[SCANCODE_TAB] = SDLK_TAB;
keymap[SCANCODE_ENTER] = SDLK_RETURN;
keymap[SCANCODE_DELETE] = SDLK_DELETE;
keymap[SCANCODE_LEFTCONTROL] = SDLK_LCTRL;
keymap[SCANCODE_LEFTSHIFT] = SDLK_LSHIFT;
keymap[SCANCODE_RIGHTSHIFT] = SDLK_RSHIFT;
keymap[SCANCODE_LEFTALT] = SDLK_LALT;
keymap[SCANCODE_CAPSLOCK] = SDLK_CAPSLOCK;
}

/* Atari to Unicode charset translation table */

Uint16 SDL_AtariToUnicodeTable[256] = {
Expand Down Expand Up @@ -167,4 +221,27 @@ Uint16 SDL_AtariToUnicodeTable[256] = {
0x00B0, 0x2022, 0x00B7, 0x221A, 0x207F, 0x00B2, 0x00B3, 0x00AF
};

SDL_keysym *
SDL_Atari_TranslateKey(int scancode, SDL_keysym *keysym,
SDL_bool pressed)
{
int asciicode = 0;

/* Set the keysym information */
keysym->scancode = scancode;
keysym->mod = KMOD_NONE;
keysym->sym = keymap[scancode];
keysym->unicode = 0;

if (keysym->sym == SDLK_UNKNOWN) {
keysym->sym = asciicode = keytab_normal[scancode];
}

if (SDL_TranslateUNICODE && pressed) {
keysym->unicode = SDL_AtariToUnicodeTable[asciicode];
}

return(keysym);
}

/* vi: set ts=4 sw=4 expandtab: */
19 changes: 19 additions & 0 deletions src/video/ataricommon/SDL_atarievents_c.h
Expand Up @@ -35,13 +35,32 @@
/* Hidden "this" pointer for the video functions */
#define _THIS SDL_VideoDevice *this

#define ATARIBIOS_MAXKEYS 128

/* Special keys state */
#ifndef K_RSHIFT
enum {
K_RSHIFT=0,
K_LSHIFT,
K_CTRL,
K_ALT,
K_CAPSLOCK,
K_CLRHOME,
K_INSERT
};
#endif

extern void (*Atari_ShutdownEvents) (void);

extern void Atari_InitOSKeymap(_THIS);
extern void Atari_PumpEvents(_THIS);

extern void SDL_Atari_InitInternalKeymap(_THIS);

/* Atari to Unicode charset translation table */
extern Uint16 SDL_AtariToUnicodeTable[256];
SDL_keysym *SDL_Atari_TranslateKey(int scancode, SDL_keysym *keysym,
SDL_bool pressed);

#endif /* _SDL_ATARI_EVENTS_H_ */
/* vi: set ts=4 sw=4 expandtab: */
91 changes: 5 additions & 86 deletions src/video/ataricommon/SDL_biosevents.c
Expand Up @@ -39,31 +39,10 @@
#include "SDL_xbiosevents_c.h"
#include "SDL_ataridevmouse_c.h"

/* To save state of keyboard */
#define ATARIBIOS_MAXKEYS 128

static unsigned char bios_currentkeyboard[ATARIBIOS_MAXKEYS];
static unsigned char bios_previouskeyboard[ATARIBIOS_MAXKEYS];
static unsigned char bios_currentascii[ATARIBIOS_MAXKEYS];
static SDL_bool use_dev_mouse = SDL_FALSE;

/* Special keys state */
enum
{
K_RSHIFT = 0,
K_LSHIFT,
K_CTRL,
K_ALT,
K_CAPSLOCK,
K_CLRHOME,
K_INSERT
};

/* The translation tables from a console scancode to a SDL keysym */
static SDLKey keymap[ATARIBIOS_MAXKEYS];

static SDL_keysym *TranslateKey(int scancode, int asciicode,
SDL_keysym * keysym, SDL_bool pressed);
static void UpdateSpecialKeys(int special_keys_state);

void
Expand All @@ -75,36 +54,6 @@ AtariBios_InitOSKeymap(_THIS)
SDL_memset(bios_currentkeyboard, 0, sizeof(bios_currentkeyboard));
SDL_memset(bios_previouskeyboard, 0, sizeof(bios_previouskeyboard));

/* Initialize keymap */
for (i = 0; i < ATARIBIOS_MAXKEYS; i++)
keymap[i] = SDLK_UNKNOWN;

/* Functions keys */
for (i = 0; i < 10; i++)
keymap[SCANCODE_F1 + i] = SDLK_F1 + i;

/* Cursor keypad */
keymap[SCANCODE_HELP] = SDLK_HELP;
keymap[SCANCODE_UNDO] = SDLK_UNDO;
keymap[SCANCODE_INSERT] = SDLK_INSERT;
keymap[SCANCODE_CLRHOME] = SDLK_HOME;
keymap[SCANCODE_UP] = SDLK_UP;
keymap[SCANCODE_DOWN] = SDLK_DOWN;
keymap[SCANCODE_RIGHT] = SDLK_RIGHT;
keymap[SCANCODE_LEFT] = SDLK_LEFT;

/* Special keys */
keymap[SCANCODE_ESCAPE] = SDLK_ESCAPE;
keymap[SCANCODE_BACKSPACE] = SDLK_BACKSPACE;
keymap[SCANCODE_TAB] = SDLK_TAB;
keymap[SCANCODE_ENTER] = SDLK_RETURN;
keymap[SCANCODE_DELETE] = SDLK_DELETE;
keymap[SCANCODE_LEFTCONTROL] = SDLK_LCTRL;
keymap[SCANCODE_LEFTSHIFT] = SDLK_LSHIFT;
keymap[SCANCODE_RIGHTSHIFT] = SDLK_RSHIFT;
keymap[SCANCODE_LEFTALT] = SDLK_LALT;
keymap[SCANCODE_CAPSLOCK] = SDLK_CAPSLOCK;

use_dev_mouse = (SDL_AtariDevMouse_Open() != 0) ? SDL_TRUE : SDL_FALSE;

vectors_mask = ATARI_XBIOS_JOYSTICKEVENTS; /* XBIOS joystick events */
Expand All @@ -129,15 +78,8 @@ AtariBios_PumpEvents(_THIS)

while (Bconstat(_CON)) {
unsigned long key_pressed;
unsigned char asciicode, scancode;

key_pressed = Bconin(_CON);

asciicode = key_pressed;
scancode = key_pressed >> 16;

bios_currentkeyboard[scancode] = 0xFF;
bios_currentascii[scancode] = asciicode;
key_pressed=Bconin(_CON);
bios_currentkeyboard[(key_pressed>>16)&(ATARIBIOS_MAXKEYS-1)]=0xFF;
}

/* Read special keys */
Expand All @@ -148,14 +90,12 @@ AtariBios_PumpEvents(_THIS)
/* Key pressed ? */
if (bios_currentkeyboard[i] && !bios_previouskeyboard[i])
SDL_PrivateKeyboard(SDL_PRESSED,
TranslateKey(i, bios_currentascii[i],
&keysym, SDL_TRUE));
SDL_Atari_TranslateKey(i, &keysym, SDL_TRUE));

/* Key unpressed ? */
if (bios_previouskeyboard[i] && !bios_currentkeyboard[i])
SDL_PrivateKeyboard(SDL_RELEASED,
TranslateKey(i, bios_currentascii[i],
&keysym, SDL_FALSE));
SDL_Atari_TranslateKey(i, &keysym, SDL_FALSE));
}

if (use_dev_mouse) {
Expand All @@ -166,7 +106,7 @@ AtariBios_PumpEvents(_THIS)

/* Will be previous table */
SDL_memcpy(bios_previouskeyboard, bios_currentkeyboard,
ATARIBIOS_MAXKEYS);
sizeof(bios_previouskeyboard));
}

static void
Expand All @@ -187,27 +127,6 @@ UpdateSpecialKeys(int special_keys_state)
UPDATE_SPECIAL_KEYS(K_CAPSLOCK, SCANCODE_CAPSLOCK);
}

static SDL_keysym *
TranslateKey(int scancode, int asciicode, SDL_keysym * keysym,
SDL_bool pressed)
{
/* Set the keysym information */
keysym->scancode = scancode;

if (asciicode)
keysym->sym = asciicode;
else
keysym->sym = keymap[scancode];

keysym->mod = KMOD_NONE;
keysym->unicode = 0;
if (SDL_TranslateUNICODE && pressed) {
keysym->unicode = SDL_AtariToUnicodeTable[asciicode];
}

return (keysym);
}

void
AtariBios_ShutdownEvents(void)
{
Expand Down

0 comments on commit 1180af7

Please sign in to comment.