2016-11-05 14:47:09 -04:00
|
|
|
//
|
|
|
|
// KeyboardMachine.h
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 05/11/2016.
|
|
|
|
// Copyright © 2016 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef KeyboardMachine_h
|
|
|
|
#define KeyboardMachine_h
|
|
|
|
|
2017-11-09 22:04:49 -05:00
|
|
|
#include <cstdint>
|
2017-12-29 18:41:26 -05:00
|
|
|
#include <string>
|
2017-11-09 22:04:49 -05:00
|
|
|
|
2017-10-12 22:25:02 -04:00
|
|
|
#include "../Inputs/Keyboard.hpp"
|
|
|
|
|
2016-11-05 14:47:09 -04:00
|
|
|
namespace KeyboardMachine {
|
|
|
|
|
2018-03-09 15:19:02 -05:00
|
|
|
/*!
|
|
|
|
Covers just the actions necessary to communicate keyboard state, as a purely abstract class.
|
|
|
|
*/
|
|
|
|
struct KeyActions {
|
|
|
|
/*!
|
|
|
|
Indicates that the key @c key has been either pressed or released, according to
|
|
|
|
the state of @c isPressed.
|
|
|
|
*/
|
2018-04-15 21:11:30 -04:00
|
|
|
virtual void set_key_state(uint16_t key, bool is_pressed) {}
|
2018-03-09 15:19:02 -05:00
|
|
|
|
|
|
|
/*!
|
|
|
|
Instructs that all keys should now be treated as released.
|
|
|
|
*/
|
2018-04-15 21:11:30 -04:00
|
|
|
virtual void clear_all_keys() {}
|
2018-03-09 15:19:02 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
Describes the full functionality of being an emulated machine with a keyboard: not just being
|
|
|
|
able to receive key actions, but being able to vend a generic keyboard and a keyboard mapper.
|
|
|
|
*/
|
|
|
|
class Machine: public Inputs::Keyboard::Delegate, public KeyActions {
|
2016-11-05 14:47:09 -04:00
|
|
|
public:
|
2017-10-12 22:25:02 -04:00
|
|
|
Machine();
|
2017-11-07 22:51:06 -05:00
|
|
|
|
2017-12-29 18:30:46 -05:00
|
|
|
/*!
|
|
|
|
Causes the machine to attempt to type the supplied string.
|
|
|
|
|
|
|
|
This is best effort. Success or failure is permitted to be a function of machine and current state.
|
|
|
|
*/
|
|
|
|
virtual void type_string(const std::string &);
|
|
|
|
|
2017-10-12 22:25:02 -04:00
|
|
|
/*!
|
|
|
|
Provides a destination for keyboard input.
|
|
|
|
*/
|
|
|
|
virtual Inputs::Keyboard &get_keyboard();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
A keyboard mapper attempts to provide a physical mapping between host keys and emulated keys.
|
|
|
|
See the character mapper for logical mapping.
|
|
|
|
*/
|
|
|
|
class KeyboardMapper {
|
|
|
|
public:
|
|
|
|
virtual uint16_t mapped_key_for_key(Inputs::Keyboard::Key key) = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
/// Terminates a key sequence from the character mapper.
|
|
|
|
static const uint16_t KeyEndSequence = 0xffff;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
Indicates that a key is not mapped (for the keyboard mapper) or that a
|
|
|
|
character cannot be typed (for the character mapper).
|
|
|
|
*/
|
|
|
|
static const uint16_t KeyNotMapped = 0xfffe;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
Allows individual machines to provide the mapping between host keys
|
|
|
|
as per Inputs::Keyboard and their native scheme.
|
|
|
|
*/
|
2018-02-09 16:31:05 -05:00
|
|
|
virtual KeyboardMapper *get_keyboard_mapper();
|
2017-10-12 22:25:02 -04:00
|
|
|
|
|
|
|
private:
|
2017-10-14 22:07:11 -04:00
|
|
|
void keyboard_did_change_key(Inputs::Keyboard *keyboard, Inputs::Keyboard::Key key, bool is_pressed) override;
|
|
|
|
void reset_all_keys(Inputs::Keyboard *keyboard) override;
|
2017-10-12 22:25:02 -04:00
|
|
|
Inputs::Keyboard keyboard_;
|
2016-11-05 14:47:09 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* KeyboardMachine_h */
|