deepstone
annotate src/keyb.h @ 34:c6406e4aa0fb
better input, fixed emulated code to work again
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Mon, 23 Sep 2013 05:58:24 +0300 |
parents | |
children |
rev | line source |
---|---|
nuclear@33 | 1 /* |
nuclear@33 | 2 DOS interrupt-based keyboard driver. |
nuclear@33 | 3 Copyright (C) 2013 John Tsiombikas <nuclear@member.fsf.org> |
nuclear@33 | 4 |
nuclear@33 | 5 This program is free software: you can redistribute it and/or modify |
nuclear@33 | 6 it under the terms of the GNU General Public License as published by |
nuclear@33 | 7 the Free Software Foundation, either version 3 of the License, or |
nuclear@33 | 8 (at your option) any later version. |
nuclear@33 | 9 |
nuclear@33 | 10 This program is distributed in the hope that it will be useful, |
nuclear@33 | 11 but WITHOUT ANY WARRANTY; without even the implied warranty of |
nuclear@33 | 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
nuclear@33 | 13 GNU General Public License for more details. |
nuclear@33 | 14 |
nuclear@33 | 15 You should have received a copy of the GNU General Public License |
nuclear@33 | 16 along with the program. If not, see <http://www.gnu.org/licenses/> |
nuclear@33 | 17 */ |
nuclear@33 | 18 #ifndef KEYB_H_ |
nuclear@33 | 19 #define KEYB_H_ |
nuclear@33 | 20 |
nuclear@33 | 21 #define KB_ANY (-1) |
nuclear@33 | 22 |
nuclear@33 | 23 int kb_init(int bufsz); /* bufsz can be 0 for no buffered keys */ |
nuclear@33 | 24 void kb_shutdown(void); /* don't forget to call this at the end! */ |
nuclear@33 | 25 |
nuclear@33 | 26 /* Boolean predicate for testing the current state of a particular key. |
nuclear@33 | 27 * You may also pass KB_ANY to test if any key is held down. |
nuclear@33 | 28 */ |
nuclear@33 | 29 int kb_isdown(int key); |
nuclear@33 | 30 |
nuclear@33 | 31 /* waits for any keypress */ |
nuclear@33 | 32 void kb_wait(void); |
nuclear@33 | 33 |
nuclear@33 | 34 /* removes and returns a signle key from the input buffer. |
nuclear@33 | 35 * If buffering is disabled (initialized with kb_init(0)), then it always |
nuclear@33 | 36 * returns the last key pressed. |
nuclear@33 | 37 */ |
nuclear@33 | 38 int kb_getkey(void); |
nuclear@33 | 39 |
nuclear@33 | 40 #endif /* KEYB_H_ */ |