1
0
mirror of https://github.com/pevans/erc-c.git synced 2025-01-02 09:29:58 +00:00

Finish map, mapper handling for keyboard events

We still need to revise the test code we currently have for handling
keyboard functions; I imagine some code will need to be removed.
This commit is contained in:
Peter Evans 2018-01-17 01:07:31 -06:00
parent 8d4283b1dc
commit bf529d6c9b
7 changed files with 45 additions and 12 deletions

View File

@ -305,12 +305,10 @@ typedef struct {
vm_8bit memory_mode; vm_8bit memory_mode;
/* /*
* The last_key field is the ASCII value of the last key that was * We have a simple boolean value to determine if the strobe is set
* pressed. We also have a simple boolean value to determine if the * (it always is when the key is pressed, and stays that way until
* strobe is set (it always is when the key is pressed, and stays * someone reads the "any-key-down" soft switch).
* that way until someone reads the "any-key-down" soft switch).
*/ */
vm_8bit last_key;
bool strobe; bool strobe;
/* /*

View File

@ -2,6 +2,10 @@
#define _APPLE2_KB_H_ #define _APPLE2_KB_H_
#include "apple2.h" #include "apple2.h"
#include "vm_screen.h"
#include "vm_segment.h" #include "vm_segment.h"
extern void apple2_kb_map(vm_segment *);
extern SEGMENT_READER(apple2_kb_switch_read);
#endif #endif

View File

@ -5,6 +5,7 @@
#include <SDL.h> #include <SDL.h>
#include "vm_area.h" #include "vm_area.h"
#include "vm_bits.h"
typedef struct { typedef struct {
/* /*
@ -31,10 +32,12 @@ typedef struct {
int ycoords; int ycoords;
/* /*
* This is true when a key is pressed, and false if not. We * Hang onto the last key pressed and the status of whether a key
* determine this from an SDL_PollEvent() call. * is pressed right now or not.
*/ */
vm_8bit last_key;
bool key_pressed; bool key_pressed;
} vm_screen; } vm_screen;
extern bool vm_screen_active(vm_screen *); extern bool vm_screen_active(vm_screen *);

View File

@ -4,6 +4,7 @@ set(erc_sources
apple2.dbuf.c apple2.dbuf.c
apple2.dd.c apple2.dd.c
apple2.draw.c apple2.draw.c
apple2.kb.c
apple2.mem.c apple2.mem.c
apple2.pc.c apple2.pc.c
log.c log.c

View File

@ -4,6 +4,23 @@
#include "apple2.kb.h" #include "apple2.kb.h"
/*
* This mapper is considerably simpler than most, because it handles
* only two addresses and only read maps. It merely performs the mapping
* for keyboard switches.
*/
void
apple2_kb_map(vm_segment *seg)
{
vm_segment_read_map(seg, 0xC000, apple2_kb_switch_read);
vm_segment_read_map(seg, 0xC010, apple2_kb_switch_read);
}
/*
* This mapper handles reads to switches that report info on the
* keyboard state. Note that there is no write switch function; there
* are only reads that need to be handled.
*/
SEGMENT_READER(apple2_kb_switch_read) SEGMENT_READER(apple2_kb_switch_read)
{ {
apple2 *mach = (apple2 *)_mach; apple2 *mach = (apple2 *)_mach;
@ -50,4 +67,8 @@ SEGMENT_READER(apple2_kb_switch_read)
// pressed down. // pressed down.
return 0; return 0;
} }
// This can only happen if we were mapped to an address we weren't
// prepared to handle
return 0;
} }

View File

@ -4,9 +4,10 @@
#include "apple2.bank.h" #include "apple2.bank.h"
#include "apple2.dbuf.h" #include "apple2.dbuf.h"
#include "apple2.pc.h"
#include "apple2.h" #include "apple2.h"
#include "apple2.kb.h"
#include "apple2.mem.h" #include "apple2.mem.h"
#include "apple2.pc.h"
#include "objstore.h" #include "objstore.h"
static size_t switch_reads[] = { static size_t switch_reads[] = {
@ -49,8 +50,13 @@ apple2_mem_map(apple2 *mach, vm_segment *segment)
// Here we handle the 80STORE bit for our display buffers. // Here we handle the 80STORE bit for our display buffers.
apple2_dbuf_map(segment); apple2_dbuf_map(segment);
// All of our peripheral card (PC) mapper functions are handled
// here.
apple2_pc_map(segment); apple2_pc_map(segment);
// And this handles our keyboard soft switches
apple2_kb_map(segment);
// We will do the mapping for the zero page and stack addresses. // We will do the mapping for the zero page and stack addresses.
// Accessing those addresses can be affected by bank-switching, but // Accessing those addresses can be affected by bank-switching, but
// those addresses do not actually exist in the capital // those addresses do not actually exist in the capital

View File

@ -175,16 +175,16 @@ vm_screen_active(vm_screen *screen)
ch = '\0'; ch = '\0';
// It seems we may have pressed a key... // It seems we may have pressed a key...
if (event.key) { if (event.type == SDL_KEYDOWN || event.type == SDL_KEYUP) {
// The sym field is of type SDL_Keycode; this type, however, // The sym field is of type SDL_Keycode; this type, however,
// maps roughly to Unicode, which of course maps roughly to // maps roughly to Unicode, which of course maps roughly to
// ASCII in the low range. // ASCII in the low range.
ch = (char)event.key->keysym.sym; ch = (char)event.key.keysym.sym;
// If we had shift pressed, we need to uppercase the // If we had shift pressed, we need to uppercase the
// character. // character.
if (event.key->keysym.mod & KMOD_LSHIFT || if (event.key.keysym.mod & KMOD_LSHIFT ||
event.key->keysym.mod & KMOD_RSHIFT event.key.keysym.mod & KMOD_RSHIFT
) { ) {
ch = toupper(ch); ch = toupper(ch);
} }