Merge 1.x into master #1
|
@ -4,12 +4,10 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <fcntl.h>
|
|
||||||
|
|
||||||
#define CTRL_KEY(k) ((k) & 0x1f)
|
#define CTRL_KEY(k) ((k) & 0x1f)
|
||||||
|
|
||||||
static struct termios oldattr;
|
static struct termios oldattr;
|
||||||
static int stdin_flags;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
static char *strrev(char *str)
|
static char *strrev(char *str)
|
||||||
|
@ -30,23 +28,15 @@ static char *strrev(char *str)
|
||||||
static void setNormalMode(void)
|
static void setNormalMode(void)
|
||||||
{
|
{
|
||||||
tcsetattr(STDIN_FILENO, TCSANOW, &oldattr);
|
tcsetattr(STDIN_FILENO, TCSANOW, &oldattr);
|
||||||
fcntl(STDIN_FILENO, F_SETFL, stdin_flags);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setRawMode(void)
|
static void setRawMode(void)
|
||||||
{
|
{
|
||||||
tcgetattr(STDIN_FILENO, &oldattr);
|
tcgetattr(STDIN_FILENO, &oldattr);
|
||||||
atexit(setNormalMode);
|
|
||||||
|
|
||||||
struct termios raw = oldattr;
|
struct termios raw = oldattr;
|
||||||
|
|
||||||
raw.c_iflag &= ~(BRKINT | ICRNL | INPCK | ISTRIP | IXON);
|
cfmakeraw(&raw);
|
||||||
raw.c_oflag &= ~(OPOST);
|
|
||||||
raw.c_cflag |= (CS8);
|
|
||||||
raw.c_lflag &= ~(ECHO | ICANON | IEXTEN | ISIG);
|
|
||||||
raw.c_cc[VMIN] = 0;
|
|
||||||
raw.c_cc[VTIME] = 1;
|
|
||||||
|
|
||||||
tcsetattr(STDIN_FILENO, TCSANOW, &raw);
|
tcsetattr(STDIN_FILENO, TCSANOW, &raw);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -87,12 +77,12 @@ void _ungetc(int c) {
|
||||||
|
|
||||||
int readKey(void) {
|
int readKey(void) {
|
||||||
|
|
||||||
int bytesRead;
|
|
||||||
|
|
||||||
char key;
|
|
||||||
|
|
||||||
while ((key = fgetc(stdin)) == EOF) {
|
|
||||||
}
|
|
||||||
|
int key = getchar();
|
||||||
|
|
||||||
|
|
||||||
if (key == '\x1b') {
|
if (key == '\x1b') {
|
||||||
char seq[4];
|
char seq[4];
|
||||||
|
@ -161,6 +151,7 @@ int bytesRead;
|
||||||
|
|
||||||
int _getch(void) {
|
int _getch(void) {
|
||||||
|
|
||||||
|
atexit(setNormalMode);
|
||||||
setRawMode();
|
setRawMode();
|
||||||
|
|
||||||
int key = readKey();
|
int key = readKey();
|
||||||
|
|
Binary file not shown.
Loading…
Reference in New Issue