nuclear@1: /* nuclear@1: DOS interrupt-based keyboard driver. nuclear@1: Copyright (C) 2013 John Tsiombikas nuclear@1: nuclear@1: This program is free software: you can redistribute it and/or modify nuclear@1: it under the terms of the GNU General Public License as published by nuclear@1: the Free Software Foundation, either version 3 of the License, or nuclear@1: (at your option) any later version. nuclear@1: nuclear@1: This program is distributed in the hope that it will be useful, nuclear@1: but WITHOUT ANY WARRANTY; without even the implied warranty of nuclear@1: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the nuclear@1: GNU General Public License for more details. nuclear@1: nuclear@1: You should have received a copy of the GNU General Public License nuclear@1: along with the program. If not, see nuclear@1: */ nuclear@1: #ifndef KEYB_H_ nuclear@1: #define KEYB_H_ nuclear@1: nuclear@12: #define KB_ANY (-1) nuclear@12: #define KB_ALT (-2) nuclear@12: #define KB_CTRL (-3) nuclear@12: #define KB_SHIFT (-4) nuclear@12: nuclear@12: /* special keys */ nuclear@12: enum { nuclear@12: KB_LALT, KB_RALT, nuclear@12: KB_LCTRL, KB_RCTRL, nuclear@12: KB_LSHIFT, KB_RSHIFT, nuclear@12: KB_F1, KB_F2, KB_F3, KB_F4, KB_F5, KB_F6, nuclear@12: KB_F7, KB_F8, KB_F9, KB_F10, KB_F11, KB_F12, nuclear@12: KB_CAPSLK, KB_NUMLK, KB_SCRLK, KB_SYSRQ, nuclear@12: KB_ESC = 27, nuclear@12: KB_INSERT, KB_DEL, KB_HOME, KB_END, KB_PGUP, KB_PGDN, nuclear@12: KB_LEFT, KB_RIGHT, KB_UP, KB_DOWN, nuclear@12: KB_NUM_DOT, KB_NUM_ENTER, KB_NUM_PLUS, KB_NUM_MINUS, KB_NUM_MUL, KB_NUM_DIV, nuclear@12: KB_NUM_0, KB_NUM_1, KB_NUM_2, KB_NUM_3, KB_NUM_4, nuclear@12: KB_NUM_5, KB_NUM_6, KB_NUM_7, KB_NUM_8, KB_NUM_9, nuclear@12: KB_BACKSP = 127 nuclear@12: }; nuclear@12: nuclear@1: nuclear@1: #ifdef __cplusplus nuclear@1: extern "C" { nuclear@1: #endif nuclear@1: nuclear@1: int kb_init(int bufsz); /* bufsz can be 0 for no buffered keys */ nuclear@1: void kb_shutdown(void); /* don't forget to call this at the end! */ nuclear@1: nuclear@1: /* Boolean predicate for testing the current state of a particular key. nuclear@1: * You may also pass KB_ANY to test if any key is held down. nuclear@1: */ nuclear@1: int kb_isdown(int key); nuclear@1: nuclear@1: /* waits for any keypress */ nuclear@1: void kb_wait(void); nuclear@1: nuclear@1: /* removes and returns a single key from the input buffer. nuclear@1: * If buffering is disabled (initialized with kb_init(0)), then it always nuclear@1: * returns the last key pressed. nuclear@1: */ nuclear@1: int kb_getkey(void); nuclear@1: nuclear@1: #ifdef __cplusplus nuclear@1: } nuclear@1: #endif nuclear@1: nuclear@1: #endif /* KEYB_H_ */