summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorC. McEnroe2020-02-02 19:34:35 -0500
committerC. McEnroe2020-02-02 19:34:35 -0500
commit5c328c7a8801d6a4aded769092ead9715d4ecf98 (patch)
treefd88d2ac2cc6d7df3c1fc52f939b1451a0068764
parent8ec17d4f8ce2edab30d998d6b279f0e5cd840022 (diff)
Remove term.c in favor of more curses APIs
-rw-r--r--Makefile1
-rw-r--r--chat.h15
-rw-r--r--term.c66
-rw-r--r--ui.c28
4 files changed, 26 insertions, 84 deletions
diff --git a/Makefile b/Makefile
index ce27d4e..6ba0ba5 100644
--- a/Makefile
+++ b/Makefile
@@ -8,7 +8,6 @@ LDLIBS = -lcurses -lcrypto -ltls
OBJS += chat.o
OBJS += handle.o
OBJS += irc.o
-OBJS += term.o
OBJS += ui.o
dev: tags all
diff --git a/chat.h b/chat.h
index 8a806f1..43f62fd 100644
--- a/chat.h
+++ b/chat.h
@@ -118,21 +118,6 @@ void uiFormat(
size_t id, enum Heat heat, const struct tm *time, const char *format, ...
) __attribute__((format(printf, 4, 5)));
-enum TermMode {
- TermFocus,
- TermPaste,
-};
-enum TermEvent {
- TermNone,
- TermFocusIn,
- TermFocusOut,
- TermPasteStart,
- TermPasteEnd,
-};
-void termNoFlow(void);
-void termMode(enum TermMode mode, bool set);
-enum TermEvent termEvent(char ch);
-
static inline enum Color hash(const char *str) {
if (*str == '~') str++;
uint32_t hash = 0;
diff --git a/term.c b/term.c
deleted file mode 100644
index 427cac6..0000000
--- a/term.c
+++ /dev/null
@@ -1,66 +0,0 @@
-/* Copyright (C) 2018, 2020 C. McEnroe <june@causal.agency>
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>.
- */
-
-#include <stdbool.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <termios.h>
-#include <unistd.h>
-
-#include "chat.h"
-
-void termNoFlow(void) {
- struct termios attr;
- int error = tcgetattr(STDIN_FILENO, &attr);
- if (error) return;
- attr.c_iflag &= ~IXON;
- attr.c_cc[VDISCARD] = _POSIX_VDISABLE;
- tcsetattr(STDIN_FILENO, TCSANOW, &attr);
-}
-
-static void privateMode(const char *mode, bool set) {
- printf("\33[?%s%c", mode, (set ? 'h' : 'l'));
- fflush(stdout);
-}
-
-void termMode(enum TermMode mode, bool set) {
- switch (mode) {
- break; case TermFocus: privateMode("1004", set);
- break; case TermPaste: privateMode("2004", set);
- }
-}
-
-enum { Esc = '\33' };
-
-enum TermEvent termEvent(char ch) {
- static int st;
-#define T(st, ch) ((st) << 8 | (ch))
- switch (T(st, ch)) {
- break; case T(0, Esc): st = 1;
- break; case T(1, '['): st = 2;
- break; case T(2, 'I'): st = 0; return TermFocusIn;
- break; case T(2, 'O'): st = 0; return TermFocusOut;
- break; case T(2, '2'): st = 3;
- break; case T(3, '0'): st = 4;
- break; case T(4, '0'): st = 5;
- break; case T(5, '~'): st = 0; return TermPasteStart;
- break; case T(4, '1'): st = 6;
- break; case T(6, '~'): st = 0; return TermPasteEnd;
- break; default: st = 0;
- }
- return 0;
-#undef T
-}
diff --git a/ui.c b/ui.c
index f434289..5d626ce 100644
--- a/ui.c
+++ b/ui.c
@@ -25,7 +25,9 @@
#include <string.h>
#include <sysexits.h>
#include <term.h>
+#include <termios.h>
#include <time.h>
+#include <unistd.h>
#include <wchar.h>
#include <wctype.h>
@@ -125,6 +127,23 @@ static struct Window *windowFor(size_t id) {
return window;
}
+enum {
+ KeyFocusIn = KEY_MAX + 1,
+ KeyFocusOut,
+ KeyPasteOn,
+ KeyPasteOff,
+};
+
+static void disableFlowControl(void) {
+ struct termios term;
+ int error = tcgetattr(STDOUT_FILENO, &term);
+ if (error) err(EX_OSERR, "tcgetattr");
+ term.c_iflag &= ~IXON;
+ term.c_cc[VDISCARD] = _POSIX_VDISABLE;
+ error = tcsetattr(STDOUT_FILENO, TCSADRAIN, &term);
+ if (error) err(EX_OSERR, "tcsetattr");
+}
+
static void errExit(int eval) {
(void)eval;
reset_shell_mode();
@@ -134,15 +153,20 @@ void uiInit(void) {
initscr();
cbreak();
noecho();
- termNoFlow();
+ disableFlowControl();
def_prog_mode();
err_set_exit(errExit);
- colorInit();
+
if (!to_status_line && !strncmp(termname(), "xterm", 5)) {
to_status_line = "\33]2;";
from_status_line = "\7";
}
+ define_key("\33[I", KeyFocusIn);
+ define_key("\33[O", KeyFocusOut);
+ define_key("\33[200~", KeyPasteOn);
+ define_key("\33[201~", KeyPasteOff);
+ colorInit();
status = newwin(1, COLS, 0, 0);
input = newpad(1, InputCols);
keypad(input, true);