aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Makefile10
-rw-r--r--compile_commands.json648
-rw-r--r--include/libn.h1
-rw-r--r--sys/cmd/cat/rules.mk11
-rw-r--r--sys/cmd/rules.mk3
-rw-r--r--sys/cmd/term/config.h496
-rw-r--r--sys/cmd/term/rules.mk16
-rw-r--r--sys/cmd/term/term.c47
-rw-r--r--sys/cmd/term/term.h22
-rw-r--r--sys/libbio/rules.mk2
-rw-r--r--sys/libn/error.c8
-rw-r--r--sys/libn/rules.mk2
12 files changed, 331 insertions, 935 deletions
diff --git a/Makefile b/Makefile
index 4a70bac..dd18cc6 100644
--- a/Makefile
+++ b/Makefile
@@ -12,15 +12,15 @@ OBJ_DIR := build
TST_DIR := test
# C runtime library
-CINIT := #$(LIB_DIR)/crt/crt1.o $(LIB_DIR)/crt/x86_64/crti.o `gcc --print-file-name=crtbeginS.o`
-CFINI := #`gcc --print-file-name=crtendS.o` $(LIB_DIR)/crt/x86_64/crtn.o
+CINIT := $(LIB_DIR)/crt/crt1.o $(LIB_DIR)/crt/x86_64/crti.o `gcc --print-file-name=crtbeginS.o`
+CFINI := `gcc --print-file-name=crtendS.o` $(LIB_DIR)/crt/x86_64/crtn.o
# Flags, Libraries and Includes
CFLAGS := -g -march=native -fno-strict-aliasing -fwrapv -fms-extensions
-STATIC := #-nodefaultlibs -nostartfiles -static
+STATIC := -nodefaultlibs -nostartfiles -static
AFLAGS := -f elf64
-INCS := -I $(INC_DIR) #-isystem $(INC_DIR)/vendor/libc
-ELIBS := #-L$(LIB_DIR) -lc
+INCS := -I $(INC_DIR) -isystem $(INC_DIR)/vendor/libc
+ELIBS := -L$(LIB_DIR) -lc
# Named generic rules (must be evaluated lazily)
COMPILE = @echo "CC "$@;\
diff --git a/compile_commands.json b/compile_commands.json
index 82823e4..6883a53 100644
--- a/compile_commands.json
+++ b/compile_commands.json
@@ -8,653 +8,15 @@
"-fno-strict-aliasing",
"-fwrapv",
"-fms-extensions",
+ "-I/usr/include/libdrm",
+ "-I/usr/include/pixman-1",
"-I",
"include",
"-o",
- "build/libmath/blas1.o",
- "sys/libmath/blas1.c"
+ "build/cmd/dway/dway.o",
+ "sys/cmd/dway/dway.c"
],
"directory": "/home/nolln/root",
- "file": "sys/libmath/blas1.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/random.o",
- "sys/libn/random.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/random.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libbio/test.o",
- "sys/libbio/test.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libbio/test.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libbio/simulate.o",
- "sys/libbio/simulate.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libbio/simulate.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/os.o",
- "sys/libn/os.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/os.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/mmap.o",
- "sys/libn/mmap.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/mmap.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/error.o",
- "sys/libn/error.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/error.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-I/usr/include/freetype2",
- "-I/usr/include/libpng16",
- "-I/usr/include/harfbuzz",
- "-I/usr/include/glib-2.0",
- "-I/usr/lib/glib-2.0/include",
- "-I/usr/include/freetype2",
- "-I/usr/include/libpng16",
- "-I/usr/include/harfbuzz",
- "-I/usr/include/glib-2.0",
- "-I/usr/lib/glib-2.0/include",
- "-o",
- "build/cmd/term/x.o",
- "sys/cmd/term/x.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/cmd/term/x.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/cmd/cc/lex.o",
- "sys/cmd/cc/lex.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/cmd/cc/lex.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/io.o",
- "sys/libn/io.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/io.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-D_GNU_SOURCE",
- "-I",
- "include",
- "-o",
- "build/libmath/test.o",
- "sys/libmath/test.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libmath/test.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/flate.o",
- "sys/libn/flate.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/flate.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/test.o",
- "sys/libn/test.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/test.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/cmd/cc/bits.o",
- "sys/cmd/cc/bits.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/cmd/cc/bits.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/gz.o",
- "sys/libn/gz.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/gz.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/cmd/cc/pp.o",
- "sys/cmd/cc/pp.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/cmd/cc/pp.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-ffreestanding",
- "-fno-builtin",
- "-nostdlib",
- "-I",
- "include",
- "-o",
- "build/libc/stdio.o",
- "sys/libc/stdio.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libc/stdio.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libbio/io/newick.o",
- "sys/libbio/io/newick.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libbio/io/newick.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/memory.o",
- "sys/libn/memory.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/memory.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-ffreestanding",
- "-fno-builtin",
- "-nostdlib",
- "-I",
- "include",
- "-o",
- "build/libc/string.o",
- "sys/libc/string.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libc/string.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-I/usr/include/freetype2",
- "-I/usr/include/libpng16",
- "-I/usr/include/harfbuzz",
- "-I/usr/include/glib-2.0",
- "-I/usr/lib/glib-2.0/include",
- "-I/usr/include/freetype2",
- "-I/usr/include/libpng16",
- "-I/usr/include/harfbuzz",
- "-I/usr/include/glib-2.0",
- "-I/usr/lib/glib-2.0/include",
- "-o",
- "build/cmd/term/term.o",
- "sys/cmd/term/term.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/cmd/term/term.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libmath/blas3.o",
- "sys/libmath/blas3.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libmath/blas3.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libbio/phylo.o",
- "sys/libbio/phylo.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libbio/phylo.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libbio/io/fasta.o",
- "sys/libbio/io/fasta.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libbio/io/fasta.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libmath/blas2.o",
- "sys/libmath/blas2.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libmath/blas2.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/coro.o",
- "sys/libn/coro.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/coro.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-D_GNU_SOURCE",
- "-I",
- "include",
- "-o",
- "build/libmath/blas.o",
- "sys/libmath/blas.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libmath/blas.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/cmd/cc/cc.o",
- "sys/cmd/cc/cc.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/cmd/cc/cc.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/sort.o",
- "sys/libn/sort.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/sort.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/cmd/cc/ast.o",
- "sys/cmd/cc/ast.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/cmd/cc/ast.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/bufio.o",
- "sys/libn/bufio.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/bufio.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libmath/basic.o",
- "sys/libmath/basic.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libmath/basic.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libn/string.o",
- "sys/libn/string.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libn/string.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/cmd/cat/cat.o",
- "sys/cmd/cat/cat.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/cmd/cat/cat.c"
- },
- {
- "arguments": [
- "gcc",
- "-c",
- "-g",
- "-march=native",
- "-fno-strict-aliasing",
- "-fwrapv",
- "-fms-extensions",
- "-I",
- "include",
- "-o",
- "build/libbio/align.o",
- "sys/libbio/align.c"
- ],
- "directory": "/home/nolln/root",
- "file": "sys/libbio/align.c"
+ "file": "sys/cmd/dway/dway.c"
}
] \ No newline at end of file
diff --git a/include/libn.h b/include/libn.h
index a4b9bf5..5201b1c 100644
--- a/include/libn.h
+++ b/include/libn.h
@@ -341,6 +341,7 @@ vlong gz·seek(gz·Stream *s, long off, enum SeekPos whence);
// error handling functions
void errorf(byte* fmt, ...);
+void verrorf(byte* fmt, va_list args);
void panicf(byte *fmt, ...);
void vpanicf(byte *fmt, va_list args);
diff --git a/sys/cmd/cat/rules.mk b/sys/cmd/cat/rules.mk
index e4ac480..406d1da 100644
--- a/sys/cmd/cat/rules.mk
+++ b/sys/cmd/cat/rules.mk
@@ -4,21 +4,12 @@ include share/push.mk
# Local sources
SRCS_$(d) := $(d)/cat.c
-
-LIBS_$(d) :=
BINS_$(d) := $(d)/cat
-TSTS_$(d) :=
include share/paths.mk
-$(LIBS_$(d)): $(OBJS_$(d))
- $(ARCHIVE)
-
$(BINS_$(d)): TCLIBS := $(OBJ_DIR)/libn/libn.a
-$(BINS_$(d)): $(OBJS_$(d)) $(TCLIBS)
- $(LINK)
-
-$(UNTS_$(d)): $(TOBJS_$(d)) $(LIBS_$(d))
+$(BINS_$(d)): $(OBJS_$(d)) $(OBJ_DIR)/libn/libn.a
$(LINK)
include share/pop.mk
diff --git a/sys/cmd/rules.mk b/sys/cmd/rules.mk
index 63a92df..2ed048e 100644
--- a/sys/cmd/rules.mk
+++ b/sys/cmd/rules.mk
@@ -14,6 +14,9 @@ include $(DIR)/rules.mk
# DIR := $(d)/rc
# include $(DIR)/rules.mk
+DIR := $(d)/dway
+include $(DIR)/rules.mk
+
DIR := $(d)/term
include $(DIR)/rules.mk
diff --git a/sys/cmd/term/config.h b/sys/cmd/term/config.h
index 6f05dce..5a57641 100644
--- a/sys/cmd/term/config.h
+++ b/sys/cmd/term/config.h
@@ -1,11 +1,29 @@
/* See LICENSE file for copyright and license details. */
+/* temporary macros until we can remove X dependency */
+#define XKB_NO_MOD 1U
+#define ShiftMask (1U<<0)
+#define LockMask (1U<<1)
+#define ControlMask (1U<<2)
+#define Mod1Mask (1U<<3)
+#define Mod2Mask (1U<<4)
+#define Mod3Mask (1U<<5)
+#define Mod4Mask (1U<<6)
+#define Mod5Mask (1U<<7)
+#define XKB_ANY_MOD 1U
+
+#define Button1 1
+#define Button2 2
+#define Button3 3
+#define Button4 4
+#define Button5 5
+
/*
* appearance
*
* font: see http://freedesktop.org/software/fontconfig/fontconfig-user.html
*/
-static char *font = "Liberation Mono:pixelsize=12:antialias=true:autohint=true";
+static byte *font = "Inconsolata:pixelsize=12:antialias=true:autohint=true";
static int borderpx = 2;
/*
@@ -16,14 +34,14 @@ static int borderpx = 2;
* 4: value of shell in /etc/passwd
* 5: value of shell in config.h
*/
-static char *shell = "/bin/sh";
-char *utmp = NULL;
+static byte *shell = "/bin/sh";
+byte *utmp = nil;
/* scroll program: to enable use a string like "scroll" */
-char *scroll = NULL;
-char *stty_args = "stty raw pass8 nl -echo -iexten -cstopb 38400";
+byte *scroll = nil;
+byte *stty_args = "stty raw pass8 nl -echo -iexten -cstopb 38400";
/* identification sequence returned in DA and DECID */
-char *vtiden = "\033[?6c";
+byte *vtiden = "\033[?6c";
/* Kerning / character bounding-box multipliers */
static float cwscale = 1.0;
@@ -74,7 +92,7 @@ static unsigned int cursorthickness = 2;
static int bellvolume = 0;
/* default TERM value */
-char *termname = "st-256color";
+byte *termname = "term-256color";
/*
* spaces per tab
@@ -94,7 +112,7 @@ char *termname = "st-256color";
unsigned int tabspaces = 8;
/* Terminal colors (16 first used in escape sequence) */
-static const char *colorname[] = {
+static const byte *colorname[] = {
/* 8 normal colors */
"black",
"red3",
@@ -151,7 +169,7 @@ static unsigned int rows = 24;
/*
* Default colour and shape of the mouse cursor
*/
-static unsigned int mouseshape = XC_xterm;
+static unsigned int mouseshape = 1;
static unsigned int mousefg = 7;
static unsigned int mousebg = 0;
@@ -174,11 +192,11 @@ static uint forcemousemod = ShiftMask;
*/
static MouseShortcut mshortcuts[] = {
/* mask button function argument release */
- { XK_ANY_MOD, Button2, selpaste, {.i = 0}, 1 },
+ { XKB_ANY_MOD, Button2, selpaste, {.i = 0}, 1 },
{ ShiftMask, Button4, ttysend, {.s = "\033[5;2~"} },
- { XK_ANY_MOD, Button4, ttysend, {.s = "\031"} },
+ { XKB_ANY_MOD, Button4, ttysend, {.s = "\031"} },
{ ShiftMask, Button5, ttysend, {.s = "\033[6;2~"} },
- { XK_ANY_MOD, Button5, ttysend, {.s = "\005"} },
+ { XKB_ANY_MOD, Button5, ttysend, {.s = "\005"} },
};
/* Internal keyboard shortcuts. */
@@ -187,25 +205,25 @@ static MouseShortcut mshortcuts[] = {
static Shortcut shortcuts[] = {
/* mask keysym function argument */
- { XK_ANY_MOD, XK_Break, sendbreak, {.i = 0} },
- { ControlMask, XK_Print, toggleprinter, {.i = 0} },
- { ShiftMask, XK_Print, printscreen, {.i = 0} },
- { XK_ANY_MOD, XK_Print, printsel, {.i = 0} },
- { TERMMOD, XK_Prior, zoom, {.f = +1} },
- { TERMMOD, XK_Next, zoom, {.f = -1} },
- { TERMMOD, XK_Home, zoomreset, {.f = 0} },
- { TERMMOD, XK_C, clipcopy, {.i = 0} },
- { TERMMOD, XK_V, clippaste, {.i = 0} },
- { TERMMOD, XK_Y, selpaste, {.i = 0} },
- { ShiftMask, XK_Insert, selpaste, {.i = 0} },
- { TERMMOD, XK_Num_Lock, numlock, {.i = 0} },
+ { XKB_ANY_MOD, XKB_KEY_Break, sendbreak, {.i = 0} },
+ { ControlMask, XKB_KEY_Print, toggleprinter, {.i = 0} },
+ { ShiftMask, XKB_KEY_Print, printscreen, {.i = 0} },
+ { XKB_ANY_MOD, XKB_KEY_Print, printsel, {.i = 0} },
+ { TERMMOD, XKB_KEY_Prior, zoom, {.f = +1} },
+ { TERMMOD, XKB_KEY_Next, zoom, {.f = -1} },
+ { TERMMOD, XKB_KEY_Home, zoomreset, {.f = 0} },
+ { TERMMOD, XKB_KEY_C, clipcopy, {.i = 0} },
+ { TERMMOD, XKB_KEY_V, clippaste, {.i = 0} },
+ { TERMMOD, XKB_KEY_Y, selpaste, {.i = 0} },
+ { ShiftMask, XKB_KEY_Insert, selpaste, {.i = 0} },
+ { TERMMOD, XKB_KEY_Num_Lock, numlock, {.i = 0} },
};
/*
* Special keys (change & recompile st.info accordingly)
*
* Mask value:
- * * Use XK_ANY_MOD to match the key no matter modifiers state
+ * * Use XKB_ANY_MOD to match the key no matter modifiers state
* * Use XK_NO_MOD to match the key alone (no modifiers)
* appkey value:
* * 0: no value
@@ -218,7 +236,7 @@ static Shortcut shortcuts[] = {
* * < 0: cursor application mode disabled
*
* Be careful with the order of the definitions because st searches in
- * this table sequentially, so any XK_ANY_MOD must be in the last
+ * this table sequentially, so any XKB_ANY_MOD must be in the last
* position for a key.
*/
@@ -226,229 +244,229 @@ static Shortcut shortcuts[] = {
* If you want keys other than the X11 function keys (0xFD00 - 0xFFFF)
* to be mapped below, add them to this array.
*/
-static KeySym mappedkeys[] = { -1 };
+static ulong mappedkeys[] = { -1 };
/*
* State bits to ignore when matching key or button events. By default,
* numlock (Mod2Mask) and keyboard layout (XK_SWITCH_MOD) are ignored.
*/
-static uint ignoremod = Mod2Mask|XK_SWITCH_MOD;
+static uint ignoremod = Mod2Mask;//|XK_SWITCH_MOD;
/*
* This is the huge key array which defines all compatibility to the Linux
* world. Please decide about changes wisely.
*/
static Key key[] = {
- /* keysym mask string appkey appcursor */
- { XK_KP_Home, ShiftMask, "\033[2J", 0, -1},
- { XK_KP_Home, ShiftMask, "\033[1;2H", 0, +1},
- { XK_KP_Home, XK_ANY_MOD, "\033[H", 0, -1},
- { XK_KP_Home, XK_ANY_MOD, "\033[1~", 0, +1},
- { XK_KP_Up, XK_ANY_MOD, "\033Ox", +1, 0},
- { XK_KP_Up, XK_ANY_MOD, "\033[A", 0, -1},
- { XK_KP_Up, XK_ANY_MOD, "\033OA", 0, +1},
- { XK_KP_Down, XK_ANY_MOD, "\033Or", +1, 0},
- { XK_KP_Down, XK_ANY_MOD, "\033[B", 0, -1},
- { XK_KP_Down, XK_ANY_MOD, "\033OB", 0, +1},
- { XK_KP_Left, XK_ANY_MOD, "\033Ot", +1, 0},
- { XK_KP_Left, XK_ANY_MOD, "\033[D", 0, -1},
- { XK_KP_Left, XK_ANY_MOD, "\033OD", 0, +1},
- { XK_KP_Right, XK_ANY_MOD, "\033Ov", +1, 0},
- { XK_KP_Right, XK_ANY_MOD, "\033[C", 0, -1},
- { XK_KP_Right, XK_ANY_MOD, "\033OC", 0, +1},
- { XK_KP_Prior, ShiftMask, "\033[5;2~", 0, 0},
- { XK_KP_Prior, XK_ANY_MOD, "\033[5~", 0, 0},
- { XK_KP_Begin, XK_ANY_MOD, "\033[E", 0, 0},
- { XK_KP_End, ControlMask, "\033[J", -1, 0},
- { XK_KP_End, ControlMask, "\033[1;5F", +1, 0},
- { XK_KP_End, ShiftMask, "\033[K", -1, 0},
- { XK_KP_End, ShiftMask, "\033[1;2F", +1, 0},
- { XK_KP_End, XK_ANY_MOD, "\033[4~", 0, 0},
- { XK_KP_Next, ShiftMask, "\033[6;2~", 0, 0},
- { XK_KP_Next, XK_ANY_MOD, "\033[6~", 0, 0},
- { XK_KP_Insert, ShiftMask, "\033[2;2~", +1, 0},
- { XK_KP_Insert, ShiftMask, "\033[4l", -1, 0},
- { XK_KP_Insert, ControlMask, "\033[L", -1, 0},
- { XK_KP_Insert, ControlMask, "\033[2;5~", +1, 0},
- { XK_KP_Insert, XK_ANY_MOD, "\033[4h", -1, 0},
- { XK_KP_Insert, XK_ANY_MOD, "\033[2~", +1, 0},
- { XK_KP_Delete, ControlMask, "\033[M", -1, 0},
- { XK_KP_Delete, ControlMask, "\033[3;5~", +1, 0},
- { XK_KP_Delete, ShiftMask, "\033[2K", -1, 0},
- { XK_KP_Delete, ShiftMask, "\033[3;2~", +1, 0},
- { XK_KP_Delete, XK_ANY_MOD, "\033[P", -1, 0},
- { XK_KP_Delete, XK_ANY_MOD, "\033[3~", +1, 0},
- { XK_KP_Multiply, XK_ANY_MOD, "\033Oj", +2, 0},
- { XK_KP_Add, XK_ANY_MOD, "\033Ok", +2, 0},
- { XK_KP_Enter, XK_ANY_MOD, "\033OM", +2, 0},
- { XK_KP_Enter, XK_ANY_MOD, "\r", -1, 0},
- { XK_KP_Subtract, XK_ANY_MOD, "\033Om", +2, 0},
- { XK_KP_Decimal, XK_ANY_MOD, "\033On", +2, 0},
- { XK_KP_Divide, XK_ANY_MOD, "\033Oo", +2, 0},
- { XK_KP_0, XK_ANY_MOD, "\033Op", +2, 0},
- { XK_KP_1, XK_ANY_MOD, "\033Oq", +2, 0},
- { XK_KP_2, XK_ANY_MOD, "\033Or", +2, 0},
- { XK_KP_3, XK_ANY_MOD, "\033Os", +2, 0},
- { XK_KP_4, XK_ANY_MOD, "\033Ot", +2, 0},
- { XK_KP_5, XK_ANY_MOD, "\033Ou", +2, 0},
- { XK_KP_6, XK_ANY_MOD, "\033Ov", +2, 0},
- { XK_KP_7, XK_ANY_MOD, "\033Ow", +2, 0},
- { XK_KP_8, XK_ANY_MOD, "\033Ox", +2, 0},
- { XK_KP_9, XK_ANY_MOD, "\033Oy", +2, 0},
- { XK_Up, ShiftMask, "\033[1;2A", 0, 0},
- { XK_Up, Mod1Mask, "\033[1;3A", 0, 0},
- { XK_Up, ShiftMask|Mod1Mask,"\033[1;4A", 0, 0},
- { XK_Up, ControlMask, "\033[1;5A", 0, 0},
- { XK_Up, ShiftMask|ControlMask,"\033[1;6A", 0, 0},
- { XK_Up, ControlMask|Mod1Mask,"\033[1;7A", 0, 0},
- { XK_Up,ShiftMask|ControlMask|Mod1Mask,"\033[1;8A", 0, 0},
- { XK_Up, XK_ANY_MOD, "\033[A", 0, -1},
- { XK_Up, XK_ANY_MOD, "\033OA", 0, +1},
- { XK_Down, ShiftMask, "\033[1;2B", 0, 0},
- { XK_Down, Mod1Mask, "\033[1;3B", 0, 0},
- { XK_Down, ShiftMask|Mod1Mask,"\033[1;4B", 0, 0},
- { XK_Down, ControlMask, "\033[1;5B", 0, 0},
- { XK_Down, ShiftMask|ControlMask,"\033[1;6B", 0, 0},
- { XK_Down, ControlMask|Mod1Mask,"\033[1;7B", 0, 0},
- { XK_Down,ShiftMask|ControlMask|Mod1Mask,"\033[1;8B",0, 0},
- { XK_Down, XK_ANY_MOD, "\033[B", 0, -1},
- { XK_Down, XK_ANY_MOD, "\033OB", 0, +1},
- { XK_Left, ShiftMask, "\033[1;2D", 0, 0},
- { XK_Left, Mod1Mask, "\033[1;3D", 0, 0},
- { XK_Left, ShiftMask|Mod1Mask,"\033[1;4D", 0, 0},
- { XK_Left, ControlMask, "\033[1;5D", 0, 0},
- { XK_Left, ShiftMask|ControlMask,"\033[1;6D", 0, 0},
- { XK_Left, ControlMask|Mod1Mask,"\033[1;7D", 0, 0},
- { XK_Left,ShiftMask|ControlMask|Mod1Mask,"\033[1;8D",0, 0},
- { XK_Left, XK_ANY_MOD, "\033[D", 0, -1},
- { XK_Left, XK_ANY_MOD, "\033OD", 0, +1},
- { XK_Right, ShiftMask, "\033[1;2C", 0, 0},
- { XK_Right, Mod1Mask, "\033[1;3C", 0, 0},
- { XK_Right, ShiftMask|Mod1Mask,"\033[1;4C", 0, 0},
- { XK_Right, ControlMask, "\033[1;5C", 0, 0},
- { XK_Right, ShiftMask|ControlMask,"\033[1;6C", 0, 0},
- { XK_Right, ControlMask|Mod1Mask,"\033[1;7C", 0, 0},
- { XK_Right,ShiftMask|ControlMask|Mod1Mask,"\033[1;8C",0, 0},
- { XK_Right, XK_ANY_MOD, "\033[C", 0, -1},
- { XK_Right, XK_ANY_MOD, "\033OC", 0, +1},
- { XK_ISO_Left_Tab, ShiftMask, "\033[Z", 0, 0},
- { XK_Return, Mod1Mask, "\033\r", 0, 0},
- { XK_Return, XK_ANY_MOD, "\r", 0, 0},
- { XK_Insert, ShiftMask, "\033[4l", -1, 0},
- { XK_Insert, ShiftMask, "\033[2;2~", +1, 0},
- { XK_Insert, ControlMask, "\033[L", -1, 0},
- { XK_Insert, ControlMask, "\033[2;5~", +1, 0},
- { XK_Insert, XK_ANY_MOD, "\033[4h", -1, 0},
- { XK_Insert, XK_ANY_MOD, "\033[2~", +1, 0},
- { XK_Delete, ControlMask, "\033[M", -1, 0},
- { XK_Delete, ControlMask, "\033[3;5~", +1, 0},
- { XK_Delete, ShiftMask, "\033[2K", -1, 0},
- { XK_Delete, ShiftMask, "\033[3;2~", +1, 0},
- { XK_Delete, XK_ANY_MOD, "\033[P", -1, 0},
- { XK_Delete, XK_ANY_MOD, "\033[3~", +1, 0},
- { XK_BackSpace, XK_NO_MOD, "\177", 0, 0},
- { XK_BackSpace, Mod1Mask, "\033\177", 0, 0},
- { XK_Home, ShiftMask, "\033[2J", 0, -1},
- { XK_Home, ShiftMask, "\033[1;2H", 0, +1},
- { XK_Home, XK_ANY_MOD, "\033[H", 0, -1},
- { XK_Home, XK_ANY_MOD, "\033[1~", 0, +1},
- { XK_End, ControlMask, "\033[J", -1, 0},
- { XK_End, ControlMask, "\033[1;5F", +1, 0},
- { XK_End, ShiftMask, "\033[K", -1, 0},
- { XK_End, ShiftMask, "\033[1;2F", +1, 0},
- { XK_End, XK_ANY_MOD, "\033[4~", 0, 0},
- { XK_Prior, ControlMask, "\033[5;5~", 0, 0},
- { XK_Prior, ShiftMask, "\033[5;2~", 0, 0},
- { XK_Prior, XK_ANY_MOD, "\033[5~", 0, 0},
- { XK_Next, ControlMask, "\033[6;5~", 0, 0},
- { XK_Next, ShiftMask, "\033[6;2~", 0, 0},
- { XK_Next, XK_ANY_MOD, "\033[6~", 0, 0},
- { XK_F1, XK_NO_MOD, "\033OP" , 0, 0},
- { XK_F1, /* F13 */ ShiftMask, "\033[1;2P", 0, 0},
- { XK_F1, /* F25 */ ControlMask, "\033[1;5P", 0, 0},
- { XK_F1, /* F37 */ Mod4Mask, "\033[1;6P", 0, 0},
- { XK_F1, /* F49 */ Mod1Mask, "\033[1;3P", 0, 0},
- { XK_F1, /* F61 */ Mod3Mask, "\033[1;4P", 0, 0},
- { XK_F2, XK_NO_MOD, "\033OQ" , 0, 0},
- { XK_F2, /* F14 */ ShiftMask, "\033[1;2Q", 0, 0},
- { XK_F2, /* F26 */ ControlMask, "\033[1;5Q", 0, 0},
- { XK_F2, /* F38 */ Mod4Mask, "\033[1;6Q", 0, 0},
- { XK_F2, /* F50 */ Mod1Mask, "\033[1;3Q", 0, 0},
- { XK_F2, /* F62 */ Mod3Mask, "\033[1;4Q", 0, 0},
- { XK_F3, XK_NO_MOD, "\033OR" , 0, 0},
- { XK_F3, /* F15 */ ShiftMask, "\033[1;2R", 0, 0},
- { XK_F3, /* F27 */ ControlMask, "\033[1;5R", 0, 0},
- { XK_F3, /* F39 */ Mod4Mask, "\033[1;6R", 0, 0},
- { XK_F3, /* F51 */ Mod1Mask, "\033[1;3R", 0, 0},
- { XK_F3, /* F63 */ Mod3Mask, "\033[1;4R", 0, 0},
- { XK_F4, XK_NO_MOD, "\033OS" , 0, 0},
- { XK_F4, /* F16 */ ShiftMask, "\033[1;2S", 0, 0},
- { XK_F4, /* F28 */ ControlMask, "\033[1;5S", 0, 0},
- { XK_F4, /* F40 */ Mod4Mask, "\033[1;6S", 0, 0},
- { XK_F4, /* F52 */ Mod1Mask, "\033[1;3S", 0, 0},
- { XK_F5, XK_NO_MOD, "\033[15~", 0, 0},
- { XK_F5, /* F17 */ ShiftMask, "\033[15;2~", 0, 0},
- { XK_F5, /* F29 */ ControlMask, "\033[15;5~", 0, 0},
- { XK_F5, /* F41 */ Mod4Mask, "\033[15;6~", 0, 0},
- { XK_F5, /* F53 */ Mod1Mask, "\033[15;3~", 0, 0},
- { XK_F6, XK_NO_MOD, "\033[17~", 0, 0},
- { XK_F6, /* F18 */ ShiftMask, "\033[17;2~", 0, 0},
- { XK_F6, /* F30 */ ControlMask, "\033[17;5~", 0, 0},
- { XK_F6, /* F42 */ Mod4Mask, "\033[17;6~", 0, 0},
- { XK_F6, /* F54 */ Mod1Mask, "\033[17;3~", 0, 0},
- { XK_F7, XK_NO_MOD, "\033[18~", 0, 0},
- { XK_F7, /* F19 */ ShiftMask, "\033[18;2~", 0, 0},
- { XK_F7, /* F31 */ ControlMask, "\033[18;5~", 0, 0},
- { XK_F7, /* F43 */ Mod4Mask, "\033[18;6~", 0, 0},
- { XK_F7, /* F55 */ Mod1Mask, "\033[18;3~", 0, 0},
- { XK_F8, XK_NO_MOD, "\033[19~", 0, 0},
- { XK_F8, /* F20 */ ShiftMask, "\033[19;2~", 0, 0},
- { XK_F8, /* F32 */ ControlMask, "\033[19;5~", 0, 0},
- { XK_F8, /* F44 */ Mod4Mask, "\033[19;6~", 0, 0},
- { XK_F8, /* F56 */ Mod1Mask, "\033[19;3~", 0, 0},
- { XK_F9, XK_NO_MOD, "\033[20~", 0, 0},
- { XK_F9, /* F21 */ ShiftMask, "\033[20;2~", 0, 0},
- { XK_F9, /* F33 */ ControlMask, "\033[20;5~", 0, 0},
- { XK_F9, /* F45 */ Mod4Mask, "\033[20;6~", 0, 0},
- { XK_F9, /* F57 */ Mod1Mask, "\033[20;3~", 0, 0},
- { XK_F10, XK_NO_MOD, "\033[21~", 0, 0},
- { XK_F10, /* F22 */ ShiftMask, "\033[21;2~", 0, 0},
- { XK_F10, /* F34 */ ControlMask, "\033[21;5~", 0, 0},
- { XK_F10, /* F46 */ Mod4Mask, "\033[21;6~", 0, 0},
- { XK_F10, /* F58 */ Mod1Mask, "\033[21;3~", 0, 0},
- { XK_F11, XK_NO_MOD, "\033[23~", 0, 0},
- { XK_F11, /* F23 */ ShiftMask, "\033[23;2~", 0, 0},
- { XK_F11, /* F35 */ ControlMask, "\033[23;5~", 0, 0},
- { XK_F11, /* F47 */ Mod4Mask, "\033[23;6~", 0, 0},
- { XK_F11, /* F59 */ Mod1Mask, "\033[23;3~", 0, 0},
- { XK_F12, XK_NO_MOD, "\033[24~", 0, 0},
- { XK_F12, /* F24 */ ShiftMask, "\033[24;2~", 0, 0},
- { XK_F12, /* F36 */ ControlMask, "\033[24;5~", 0, 0},
- { XK_F12, /* F48 */ Mod4Mask, "\033[24;6~", 0, 0},
- { XK_F12, /* F60 */ Mod1Mask, "\033[24;3~", 0, 0},
- { XK_F13, XK_NO_MOD, "\033[1;2P", 0, 0},
- { XK_F14, XK_NO_MOD, "\033[1;2Q", 0, 0},
- { XK_F15, XK_NO_MOD, "\033[1;2R", 0, 0},
- { XK_F16, XK_NO_MOD, "\033[1;2S", 0, 0},
- { XK_F17, XK_NO_MOD, "\033[15;2~", 0, 0},
- { XK_F18, XK_NO_MOD, "\033[17;2~", 0, 0},
- { XK_F19, XK_NO_MOD, "\033[18;2~", 0, 0},
- { XK_F20, XK_NO_MOD, "\033[19;2~", 0, 0},
- { XK_F21, XK_NO_MOD, "\033[20;2~", 0, 0},
- { XK_F22, XK_NO_MOD, "\033[21;2~", 0, 0},
- { XK_F23, XK_NO_MOD, "\033[23;2~", 0, 0},
- { XK_F24, XK_NO_MOD, "\033[24;2~", 0, 0},
- { XK_F25, XK_NO_MOD, "\033[1;5P", 0, 0},
- { XK_F26, XK_NO_MOD, "\033[1;5Q", 0, 0},
- { XK_F27, XK_NO_MOD, "\033[1;5R", 0, 0},
- { XK_F28, XK_NO_MOD, "\033[1;5S", 0, 0},
- { XK_F29, XK_NO_MOD, "\033[15;5~", 0, 0},
- { XK_F30, XK_NO_MOD, "\033[17;5~", 0, 0},
- { XK_F31, XK_NO_MOD, "\033[18;5~", 0, 0},
- { XK_F32, XK_NO_MOD, "\033[19;5~", 0, 0},
- { XK_F33, XK_NO_MOD, "\033[20;5~", 0, 0},
- { XK_F34, XK_NO_MOD, "\033[21;5~", 0, 0},
- { XK_F35, XK_NO_MOD, "\033[23;5~", 0, 0},
+ /* keysym mask string appkey appcursor */
+ { XKB_KEY_KP_Home, ShiftMask, "\033[2J", 0, -1},
+ { XKB_KEY_KP_Home, ShiftMask, "\033[1;2H", 0, +1},
+ { XKB_KEY_KP_Home, XKB_ANY_MOD, "\033[H", 0, -1},
+ { XKB_KEY_KP_Home, XKB_ANY_MOD, "\033[1~", 0, +1},
+ { XKB_KEY_KP_Up, XKB_ANY_MOD, "\033Ox", +1, 0},
+ { XKB_KEY_KP_Up, XKB_ANY_MOD, "\033[A", 0, -1},
+ { XKB_KEY_KP_Up, XKB_ANY_MOD, "\033OA", 0, +1},
+ { XKB_KEY_KP_Down, XKB_ANY_MOD, "\033Or", +1, 0},
+ { XKB_KEY_KP_Down, XKB_ANY_MOD, "\033[B", 0, -1},
+ { XKB_KEY_KP_Down, XKB_ANY_MOD, "\033OB", 0, +1},
+ { XKB_KEY_KP_Left, XKB_ANY_MOD, "\033Ot", +1, 0},
+ { XKB_KEY_KP_Left, XKB_ANY_MOD, "\033[D", 0, -1},
+ { XKB_KEY_KP_Left, XKB_ANY_MOD, "\033OD", 0, +1},
+ { XKB_KEY_KP_Right, XKB_ANY_MOD, "\033Ov", +1, 0},
+ { XKB_KEY_KP_Right, XKB_ANY_MOD, "\033[C", 0, -1},
+ { XKB_KEY_KP_Right, XKB_ANY_MOD, "\033OC", 0, +1},
+ { XKB_KEY_KP_Prior, ShiftMask, "\033[5;2~", 0, 0},
+ { XKB_KEY_KP_Prior, XKB_ANY_MOD, "\033[5~", 0, 0},
+ { XKB_KEY_KP_Begin, XKB_ANY_MOD, "\033[E", 0, 0},
+ { XKB_KEY_KP_End, ControlMask, "\033[J", -1, 0},
+ { XKB_KEY_KP_End, ControlMask, "\033[1;5F", +1, 0},
+ { XKB_KEY_KP_End, ShiftMask, "\033[K", -1, 0},
+ { XKB_KEY_KP_End, ShiftMask, "\033[1;2F", +1, 0},
+ { XKB_KEY_KP_End, XKB_ANY_MOD, "\033[4~", 0, 0},
+ { XKB_KEY_KP_Next, ShiftMask, "\033[6;2~", 0, 0},
+ { XKB_KEY_KP_Next, XKB_ANY_MOD, "\033[6~", 0, 0},
+ { XKB_KEY_KP_Insert, ShiftMask, "\033[2;2~", +1, 0},
+ { XKB_KEY_KP_Insert, ShiftMask, "\033[4l", -1, 0},
+ { XKB_KEY_KP_Insert, ControlMask, "\033[L", -1, 0},
+ { XKB_KEY_KP_Insert, ControlMask, "\033[2;5~", +1, 0},
+ { XKB_KEY_KP_Insert, XKB_ANY_MOD, "\033[4h", -1, 0},
+ { XKB_KEY_KP_Insert, XKB_ANY_MOD, "\033[2~", +1, 0},
+ { XKB_KEY_KP_Delete, ControlMask, "\033[M", -1, 0},
+ { XKB_KEY_KP_Delete, ControlMask, "\033[3;5~", +1, 0},
+ { XKB_KEY_KP_Delete, ShiftMask, "\033[2K", -1, 0},
+ { XKB_KEY_KP_Delete, ShiftMask, "\033[3;2~", +1, 0},
+ { XKB_KEY_KP_Delete, XKB_ANY_MOD, "\033[P", -1, 0},
+ { XKB_KEY_KP_Delete, XKB_ANY_MOD, "\033[3~", +1, 0},
+ { XKB_KEY_KP_Multiply, XKB_ANY_MOD, "\033Oj", +2, 0},
+ { XKB_KEY_KP_Add, XKB_ANY_MOD, "\033Ok", +2, 0},
+ { XKB_KEY_KP_Enter, XKB_ANY_MOD, "\033OM", +2, 0},
+ { XKB_KEY_KP_Enter, XKB_ANY_MOD, "\r", -1, 0},
+ { XKB_KEY_KP_Subtract, XKB_ANY_MOD, "\033Om", +2, 0},
+ { XKB_KEY_KP_Decimal, XKB_ANY_MOD, "\033On", +2, 0},
+ { XKB_KEY_KP_Divide, XKB_ANY_MOD, "\033Oo", +2, 0},
+ { XKB_KEY_KP_0, XKB_ANY_MOD, "\033Op", +2, 0},
+ { XKB_KEY_KP_1, XKB_ANY_MOD, "\033Oq", +2, 0},
+ { XKB_KEY_KP_2, XKB_ANY_MOD, "\033Or", +2, 0},
+ { XKB_KEY_KP_3, XKB_ANY_MOD, "\033Os", +2, 0},
+ { XKB_KEY_KP_4, XKB_ANY_MOD, "\033Ot", +2, 0},
+ { XKB_KEY_KP_5, XKB_ANY_MOD, "\033Ou", +2, 0},
+ { XKB_KEY_KP_6, XKB_ANY_MOD, "\033Ov", +2, 0},
+ { XKB_KEY_KP_7, XKB_ANY_MOD, "\033Ow", +2, 0},
+ { XKB_KEY_KP_8, XKB_ANY_MOD, "\033Ox", +2, 0},
+ { XKB_KEY_KP_9, XKB_ANY_MOD, "\033Oy", +2, 0},
+ { XKB_KEY_Up, ShiftMask, "\033[1;2A", 0, 0},
+ { XKB_KEY_Up, Mod1Mask, "\033[1;3A", 0, 0},
+ { XKB_KEY_Up, ShiftMask|Mod1Mask,"\033[1;4A", 0, 0},
+ { XKB_KEY_Up, ControlMask, "\033[1;5A", 0, 0},
+ { XKB_KEY_Up, ShiftMask|ControlMask,"\033[1;6A", 0, 0},
+ { XKB_KEY_Up, ControlMask|Mod1Mask,"\033[1;7A", 0, 0},
+ { XKB_KEY_Up,ShiftMask|ControlMask|Mod1Mask,"\033[1;8A", 0, 0},
+ { XKB_KEY_Up, XKB_ANY_MOD, "\033[A", 0, -1},
+ { XKB_KEY_Up, XKB_ANY_MOD, "\033OA", 0, +1},
+ { XKB_KEY_Down, ShiftMask, "\033[1;2B", 0, 0},
+ { XKB_KEY_Down, Mod1Mask, "\033[1;3B", 0, 0},
+ { XKB_KEY_Down, ShiftMask|Mod1Mask,"\033[1;4B", 0, 0},
+ { XKB_KEY_Down, ControlMask, "\033[1;5B", 0, 0},
+ { XKB_KEY_Down, ShiftMask|ControlMask,"\033[1;6B", 0, 0},
+ { XKB_KEY_Down, ControlMask|Mod1Mask,"\033[1;7B", 0, 0},
+ { XKB_KEY_Down,ShiftMask|ControlMask|Mod1Mask,"\033[1;8B",0, 0},
+ { XKB_KEY_Down, XKB_ANY_MOD, "\033[B", 0, -1},
+ { XKB_KEY_Down, XKB_ANY_MOD, "\033OB", 0, +1},
+ { XKB_KEY_Left, ShiftMask, "\033[1;2D", 0, 0},
+ { XKB_KEY_Left, Mod1Mask, "\033[1;3D", 0, 0},
+ { XKB_KEY_Left, ShiftMask|Mod1Mask,"\033[1;4D", 0, 0},
+ { XKB_KEY_Left, ControlMask, "\033[1;5D", 0, 0},
+ { XKB_KEY_Left, ShiftMask|ControlMask,"\033[1;6D", 0, 0},
+ { XKB_KEY_Left, ControlMask|Mod1Mask,"\033[1;7D", 0, 0},
+ { XKB_KEY_Left,ShiftMask|ControlMask|Mod1Mask,"\033[1;8D",0, 0},
+ { XKB_KEY_Left, XKB_ANY_MOD, "\033[D", 0, -1},
+ { XKB_KEY_Left, XKB_ANY_MOD, "\033OD", 0, +1},
+ { XKB_KEY_Right, ShiftMask, "\033[1;2C", 0, 0},
+ { XKB_KEY_Right, Mod1Mask, "\033[1;3C", 0, 0},
+ { XKB_KEY_Right, ShiftMask|Mod1Mask,"\033[1;4C", 0, 0},
+ { XKB_KEY_Right, ControlMask, "\033[1;5C", 0, 0},
+ { XKB_KEY_Right, ShiftMask|ControlMask,"\033[1;6C", 0, 0},
+ { XKB_KEY_Right, ControlMask|Mod1Mask,"\033[1;7C", 0, 0},
+ { XKB_KEY_Right,ShiftMask|ControlMask|Mod1Mask,"\033[1;8C",0, 0},
+ { XKB_KEY_Right, XKB_ANY_MOD, "\033[C", 0, -1},
+ { XKB_KEY_Right, XKB_ANY_MOD, "\033OC", 0, +1},
+ { XKB_KEY_ISO_Left_Tab, ShiftMask, "\033[Z", 0, 0},
+ { XKB_KEY_Return, Mod1Mask, "\033\r", 0, 0},
+ { XKB_KEY_Return, XKB_ANY_MOD, "\r", 0, 0},
+ { XKB_KEY_Insert, ShiftMask, "\033[4l", -1, 0},
+ { XKB_KEY_Insert, ShiftMask, "\033[2;2~", +1, 0},
+ { XKB_KEY_Insert, ControlMask, "\033[L", -1, 0},
+ { XKB_KEY_Insert, ControlMask, "\033[2;5~", +1, 0},
+ { XKB_KEY_Insert, XKB_ANY_MOD, "\033[4h", -1, 0},
+ { XKB_KEY_Insert, XKB_ANY_MOD, "\033[2~", +1, 0},
+ { XKB_KEY_Delete, ControlMask, "\033[M", -1, 0},
+ { XKB_KEY_Delete, ControlMask, "\033[3;5~", +1, 0},
+ { XKB_KEY_Delete, ShiftMask, "\033[2K", -1, 0},
+ { XKB_KEY_Delete, ShiftMask, "\033[3;2~", +1, 0},
+ { XKB_KEY_Delete, XKB_ANY_MOD, "\033[P", -1, 0},
+ { XKB_KEY_Delete, XKB_ANY_MOD, "\033[3~", +1, 0},
+ { XKB_KEY_BackSpace, XKB_NO_MOD, "\177", 0, 0},
+ { XKB_KEY_BackSpace, Mod1Mask, "\033\177", 0, 0},
+ { XKB_KEY_Home, ShiftMask, "\033[2J", 0, -1},
+ { XKB_KEY_Home, ShiftMask, "\033[1;2H", 0, +1},
+ { XKB_KEY_Home, XKB_ANY_MOD, "\033[H", 0, -1},
+ { XKB_KEY_Home, XKB_ANY_MOD, "\033[1~", 0, +1},
+ { XKB_KEY_End, ControlMask, "\033[J", -1, 0},
+ { XKB_KEY_End, ControlMask, "\033[1;5F", +1, 0},
+ { XKB_KEY_End, ShiftMask, "\033[K", -1, 0},
+ { XKB_KEY_End, ShiftMask, "\033[1;2F", +1, 0},
+ { XKB_KEY_End, XKB_ANY_MOD, "\033[4~", 0, 0},
+ { XKB_KEY_Prior, ControlMask, "\033[5;5~", 0, 0},
+ { XKB_KEY_Prior, ShiftMask, "\033[5;2~", 0, 0},
+ { XKB_KEY_Prior, XKB_ANY_MOD, "\033[5~", 0, 0},
+ { XKB_KEY_Next, ControlMask, "\033[6;5~", 0, 0},
+ { XKB_KEY_Next, ShiftMask, "\033[6;2~", 0, 0},
+ { XKB_KEY_Next, XKB_ANY_MOD, "\033[6~", 0, 0},
+ { XKB_KEY_F1, XKB_NO_MOD, "\033OP" , 0, 0},
+ { XKB_KEY_F1, /* F13 */ ShiftMask, "\033[1;2P", 0, 0},
+ { XKB_KEY_F1, /* F25 */ ControlMask, "\033[1;5P", 0, 0},
+ { XKB_KEY_F1, /* F37 */ Mod4Mask, "\033[1;6P", 0, 0},
+ { XKB_KEY_F1, /* F49 */ Mod1Mask, "\033[1;3P", 0, 0},
+ { XKB_KEY_F1, /* F61 */ Mod3Mask, "\033[1;4P", 0, 0},
+ { XKB_KEY_F2, XKB_NO_MOD, "\033OQ" , 0, 0},
+ { XKB_KEY_F2, /* F14 */ ShiftMask, "\033[1;2Q", 0, 0},
+ { XKB_KEY_F2, /* F26 */ ControlMask, "\033[1;5Q", 0, 0},
+ { XKB_KEY_F2, /* F38 */ Mod4Mask, "\033[1;6Q", 0, 0},
+ { XKB_KEY_F2, /* F50 */ Mod1Mask, "\033[1;3Q", 0, 0},
+ { XKB_KEY_F2, /* F62 */ Mod3Mask, "\033[1;4Q", 0, 0},
+ { XKB_KEY_F3, XKB_NO_MOD, "\033OR" , 0, 0},
+ { XKB_KEY_F3, /* F15 */ ShiftMask, "\033[1;2R", 0, 0},
+ { XKB_KEY_F3, /* F27 */ ControlMask, "\033[1;5R", 0, 0},
+ { XKB_KEY_F3, /* F39 */ Mod4Mask, "\033[1;6R", 0, 0},
+ { XKB_KEY_F3, /* F51 */ Mod1Mask, "\033[1;3R", 0, 0},
+ { XKB_KEY_F3, /* F63 */ Mod3Mask, "\033[1;4R", 0, 0},
+ { XKB_KEY_F4, XKB_NO_MOD, "\033OS" , 0, 0},
+ { XKB_KEY_F4, /* F16 */ ShiftMask, "\033[1;2S", 0, 0},
+ { XKB_KEY_F4, /* F28 */ ControlMask, "\033[1;5S", 0, 0},
+ { XKB_KEY_F4, /* F40 */ Mod4Mask, "\033[1;6S", 0, 0},
+ { XKB_KEY_F4, /* F52 */ Mod1Mask, "\033[1;3S", 0, 0},
+ { XKB_KEY_F5, XKB_NO_MOD, "\033[15~", 0, 0},
+ { XKB_KEY_F5, /* F17 */ ShiftMask, "\033[15;2~", 0, 0},
+ { XKB_KEY_F5, /* F29 */ ControlMask, "\033[15;5~", 0, 0},
+ { XKB_KEY_F5, /* F41 */ Mod4Mask, "\033[15;6~", 0, 0},
+ { XKB_KEY_F5, /* F53 */ Mod1Mask, "\033[15;3~", 0, 0},
+ { XKB_KEY_F6, XKB_NO_MOD, "\033[17~", 0, 0},
+ { XKB_KEY_F6, /* F18 */ ShiftMask, "\033[17;2~", 0, 0},
+ { XKB_KEY_F6, /* F30 */ ControlMask, "\033[17;5~", 0, 0},
+ { XKB_KEY_F6, /* F42 */ Mod4Mask, "\033[17;6~", 0, 0},
+ { XKB_KEY_F6, /* F54 */ Mod1Mask, "\033[17;3~", 0, 0},
+ { XKB_KEY_F7, XKB_NO_MOD, "\033[18~", 0, 0},
+ { XKB_KEY_F7, /* F19 */ ShiftMask, "\033[18;2~", 0, 0},
+ { XKB_KEY_F7, /* F31 */ ControlMask, "\033[18;5~", 0, 0},
+ { XKB_KEY_F7, /* F43 */ Mod4Mask, "\033[18;6~", 0, 0},
+ { XKB_KEY_F7, /* F55 */ Mod1Mask, "\033[18;3~", 0, 0},
+ { XKB_KEY_F8, XKB_NO_MOD, "\033[19~", 0, 0},
+ { XKB_KEY_F8, /* F20 */ ShiftMask, "\033[19;2~", 0, 0},
+ { XKB_KEY_F8, /* F32 */ ControlMask, "\033[19;5~", 0, 0},
+ { XKB_KEY_F8, /* F44 */ Mod4Mask, "\033[19;6~", 0, 0},
+ { XKB_KEY_F8, /* F56 */ Mod1Mask, "\033[19;3~", 0, 0},
+ { XKB_KEY_F9, XKB_NO_MOD, "\033[20~", 0, 0},
+ { XKB_KEY_F9, /* F21 */ ShiftMask, "\033[20;2~", 0, 0},
+ { XKB_KEY_F9, /* F33 */ ControlMask, "\033[20;5~", 0, 0},
+ { XKB_KEY_F9, /* F45 */ Mod4Mask, "\033[20;6~", 0, 0},
+ { XKB_KEY_F9, /* F57 */ Mod1Mask, "\033[20;3~", 0, 0},
+ { XKB_KEY_F10, XKB_NO_MOD, "\033[21~", 0, 0},
+ { XKB_KEY_F10, /* F22 */ ShiftMask, "\033[21;2~", 0, 0},
+ { XKB_KEY_F10, /* F34 */ ControlMask, "\033[21;5~", 0, 0},
+ { XKB_KEY_F10, /* F46 */ Mod4Mask, "\033[21;6~", 0, 0},
+ { XKB_KEY_F10, /* F58 */ Mod1Mask, "\033[21;3~", 0, 0},
+ { XKB_KEY_F11, XKB_NO_MOD, "\033[23~", 0, 0},
+ { XKB_KEY_F11, /* F23 */ ShiftMask, "\033[23;2~", 0, 0},
+ { XKB_KEY_F11, /* F35 */ ControlMask, "\033[23;5~", 0, 0},
+ { XKB_KEY_F11, /* F47 */ Mod4Mask, "\033[23;6~", 0, 0},
+ { XKB_KEY_F11, /* F59 */ Mod1Mask, "\033[23;3~", 0, 0},
+ { XKB_KEY_F12, XKB_NO_MOD, "\033[24~", 0, 0},
+ { XKB_KEY_F12, /* F24 */ ShiftMask, "\033[24;2~", 0, 0},
+ { XKB_KEY_F12, /* F36 */ ControlMask, "\033[24;5~", 0, 0},
+ { XKB_KEY_F12, /* F48 */ Mod4Mask, "\033[24;6~", 0, 0},
+ { XKB_KEY_F12, /* F60 */ Mod1Mask, "\033[24;3~", 0, 0},
+ { XKB_KEY_F13, XKB_NO_MOD, "\033[1;2P", 0, 0},
+ { XKB_KEY_F14, XKB_NO_MOD, "\033[1;2Q", 0, 0},
+ { XKB_KEY_F15, XKB_NO_MOD, "\033[1;2R", 0, 0},
+ { XKB_KEY_F16, XKB_NO_MOD, "\033[1;2S", 0, 0},
+ { XKB_KEY_F17, XKB_NO_MOD, "\033[15;2~", 0, 0},
+ { XKB_KEY_F18, XKB_NO_MOD, "\033[17;2~", 0, 0},
+ { XKB_KEY_F19, XKB_NO_MOD, "\033[18;2~", 0, 0},
+ { XKB_KEY_F20, XKB_NO_MOD, "\033[19;2~", 0, 0},
+ { XKB_KEY_F21, XKB_NO_MOD, "\033[20;2~", 0, 0},
+ { XKB_KEY_F22, XKB_NO_MOD, "\033[21;2~", 0, 0},
+ { XKB_KEY_F23, XKB_NO_MOD, "\033[23;2~", 0, 0},
+ { XKB_KEY_F24, XKB_NO_MOD, "\033[24;2~", 0, 0},
+ { XKB_KEY_F25, XKB_NO_MOD, "\033[1;5P", 0, 0},
+ { XKB_KEY_F26, XKB_NO_MOD, "\033[1;5Q", 0, 0},
+ { XKB_KEY_F27, XKB_NO_MOD, "\033[1;5R", 0, 0},
+ { XKB_KEY_F28, XKB_NO_MOD, "\033[1;5S", 0, 0},
+ { XKB_KEY_F29, XKB_NO_MOD, "\033[15;5~", 0, 0},
+ { XKB_KEY_F30, XKB_NO_MOD, "\033[17;5~", 0, 0},
+ { XKB_KEY_F31, XKB_NO_MOD, "\033[18;5~", 0, 0},
+ { XKB_KEY_F32, XKB_NO_MOD, "\033[19;5~", 0, 0},
+ { XKB_KEY_F33, XKB_NO_MOD, "\033[20;5~", 0, 0},
+ { XKB_KEY_F34, XKB_NO_MOD, "\033[21;5~", 0, 0},
+ { XKB_KEY_F35, XKB_NO_MOD, "\033[23;5~", 0, 0},
};
/*
@@ -466,7 +484,7 @@ static uint selmasks[] = {
* Printable characters in ASCII, used to estimate the advance width
* of single wide characters.
*/
-static char ascii_printable[] =
+static byte ascii_printable[] =
" !\"#$%&'()*+,-./0123456789:;<=>?"
"@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_"
"`abcdefghijklmnopqrstuvwxyz{|}~";
diff --git a/sys/cmd/term/rules.mk b/sys/cmd/term/rules.mk
index 2f7cabd..17043a1 100644
--- a/sys/cmd/term/rules.mk
+++ b/sys/cmd/term/rules.mk
@@ -2,17 +2,21 @@ include share/push.mk
# Iterate through subdirectory tree
# Local sources
-SRCS_$(d) := $(d)/term.c $(d)/x.c
+SRCS_$(d) := $(d)/term.c $(d)/wl.c $(d)/xdg-shell.c #$(d)/x.c
BINS_$(d) := $(d)/term
include share/paths.mk
# Local rules
-$(BINS_$(d)): TCINCS := `pkg-config --cflags fontconfig` \
- `pkg-config --cflags freetype2`
-$(BINS_$(d)): TCLIBS := -L/usr/lib -lX11 -lXft -lm -lrt -lutil \
- `pkg-config --libs fontconfig` \
- `pkg-config --libs freetype2` \
+
+include share/dynamic.mk
+$(BINS_$(d)): TCINCS := `pkg-config --cflags wayland-client` \
+ `pkg-config --cflags fontconfig` \
+ `pkg-config --cflags freetype2`
+$(BINS_$(d)): TCLIBS := -L/usr/lib -lm -lrt -lutil \
+ `pkg-config --libs wayland-client` \
+ `pkg-config --libs fontconfig`\
+ `pkg-config --libs freetype2`\
$(OBJ_DIR)/libn/libn.a
$(BINS_$(d)): $(OBJS_$(d)) $(TCLIBS)
diff --git a/sys/cmd/term/term.c b/sys/cmd/term/term.c
index a73e8f8..7bac567 100644
--- a/sys/cmd/term/term.c
+++ b/sys/cmd/term/term.c
@@ -13,10 +13,8 @@
#include <libutil.h>
#endif
-/* Arbitrary sizes */
-#define UTF_INVALID 0xFFFD
-#define UTF_SIZ 4
-#define ESC_BUF_SIZ (128*UTF_SIZ)
+/* arbitrary sizes */
+#define ESC_BUF_SIZ (128*UTFmax)
#define ESC_ARG_SIZ 16
#define STR_BUF_SIZ ESC_BUF_SIZ
#define STR_ARG_SIZ ESC_ARG_SIZ
@@ -28,7 +26,8 @@
#define ISCONTROL(c) (ISCONTROLC0(c) || ISCONTROLC1(c))
#define ISDELIM(u) (u && wcschr(worddelimiters, u))
-enum term_mode {
+enum term_mode
+{
MODE_WRAP = 1 << 0,
MODE_INSERT = 1 << 1,
MODE_ALTSCREEN = 1 << 2,
@@ -39,18 +38,21 @@ enum term_mode {
MODE_SIXEL = 1 << 7,
};
-enum cursor_movement {
+enum cursor_movement
+{
CURSOR_SAVE,
CURSOR_LOAD
};
-enum cursor_state {
+enum cursor_state
+{
CURSOR_DEFAULT = 0,
CURSOR_WRAPNEXT = 1,
CURSOR_ORIGIN = 2
};
-enum charset {
+enum charset
+{
CS_GRAPHIC0,
CS_GRAPHIC1,
CS_UK,
@@ -60,7 +62,8 @@ enum charset {
CS_FIN
};
-enum escape_state {
+enum escape_state
+{
ESC_START = 1,
ESC_CSI = 2,
ESC_STR = 4, /* OSC, PM, APC */
@@ -213,10 +216,10 @@ static int iofd = 1;
static int cmdfd;
static pid_t pid;
-static ubyte utfbyte[UTF_SIZ + 1] = {0x80, 0, 0xC0, 0xE0, 0xF0};
-static ubyte utfmask[UTF_SIZ + 1] = {0xC0, 0x80, 0xE0, 0xF0, 0xF8};
-static rune utfmin[UTF_SIZ + 1] = { 0, 0, 0x80, 0x800, 0x10000};
-static rune utfmax[UTF_SIZ + 1] = {0x10FFFF, 0x7F, 0x7FF, 0xFFFF, 0x10FFFF};
+static ubyte utfbyte[UTFmax + 1] = {0x80, 0, 0xC0, 0xE0, 0xF0};
+static ubyte utfmask[UTFmax + 1] = {0xC0, 0x80, 0xE0, 0xF0, 0xF8};
+static rune utfmin[UTFmax + 1] = { 0, 0, 0x80, 0x800, 0x10000};
+static rune utfmax[UTFmax + 1] = {0x10FFFF, 0x7F, 0x7FF, 0xFFFF, 0x10FFFF};
ssize_t
xwrite(int fd, const char *s, size_t len)
@@ -270,11 +273,11 @@ utf8decode(const char *c, rune *u, size_t clen)
size_t i, j, len, type;
rune udecoded;
- *u = UTF_INVALID;
+ *u = RuneErr;
if (!clen)
return 0;
udecoded = utf8decodebyte(c[0], &len);
- if (!BETWEEN(len, 1, UTF_SIZ))
+ if (!BETWEEN(len, 1, UTFmax))
return 1;
for (i = 1, j = 1; i < clen && j < len; ++i, ++j) {
udecoded = (udecoded << 6) | utf8decodebyte(c[i], &type);
@@ -305,7 +308,7 @@ utf8encode(rune u, char *c)
size_t len, i;
len = utf8validate(&u, 0);
- if (len > UTF_SIZ)
+ if (len > UTFmax)
return 0;
for (i = len - 1; i != 0; --i) {
@@ -327,7 +330,7 @@ size_t
utf8validate(rune *u, size_t i)
{
if (!BETWEEN(*u, utfmin[i], utfmax[i]) || BETWEEN(*u, 0xD800, 0xDFFF))
- *u = UTF_INVALID;
+ *u = RuneErr;
for (i = 1; *u > utfmax[i]; ++i)
;
@@ -583,7 +586,7 @@ getsel(void)
if (sel.ob.x == -1)
return nil;
- bufsize = (term.col+1) * (sel.ne.y-sel.nb.y+1) * UTF_SIZ;
+ bufsize = (term.col+1) * (sel.ne.y-sel.nb.y+1) * UTFmax;
ptr = str = xmalloc(bufsize);
/* append every set & selected glyph to the selection */
@@ -1179,7 +1182,7 @@ tsetchar(rune u, Glyph *attr, int x, int y)
*/
if (term.trantbl[term.charset] == CS_GRAPHIC0 &&
BETWEEN(u, 0x41, 0x7e) && vt100_0[u - 0x41])
- utf8decode(vt100_0[u - 0x41], &u, UTF_SIZ);
+ utf8decode(vt100_0[u - 0x41], &u, UTFmax);
if (term.line[y][x].mode & ATTR_WIDE) {
if (x+1 < term.col) {
@@ -1987,7 +1990,7 @@ tdumpsel(void)
void
tdumpline(int n)
{
- char buf[UTF_SIZ];
+ char buf[UTFmax];
Glyph *bp, *end;
bp = &term.line[n][0];
@@ -2272,7 +2275,7 @@ eschandle(ubyte ascii)
void
tputc(rune u)
{
- char c[UTF_SIZ];
+ char c[UTFmax];
int control;
int width, len;
Glyph *gp;
@@ -2330,7 +2333,7 @@ tputc(rune u)
* term.esc = 0;
* strhandle();
*/
- if (strescseq.siz > (SIZE_MAX - UTF_SIZ) / 2)
+ if (strescseq.siz > (SIZE_MAX - UTFmax) / 2)
return;
strescseq.siz *= 2;
strescseq.buf = xrealloc(strescseq.buf, strescseq.siz);
diff --git a/sys/cmd/term/term.h b/sys/cmd/term/term.h
index f5f20b3..841f30c 100644
--- a/sys/cmd/term/term.h
+++ b/sys/cmd/term/term.h
@@ -22,7 +22,8 @@
#define TRUECOLOR(r,g,b) (1 << 24 | (r) << 16 | (g) << 8 | (b))
#define IS_TRUECOL(x) (1 << 24 & (x))
-enum glyph_attribute {
+enum glyph_attribute
+{
ATTR_NULL = 0,
ATTR_BOLD = 1 << 0,
ATTR_FAINT = 1 << 1,
@@ -38,33 +39,38 @@ enum glyph_attribute {
ATTR_BOLD_FAINT = ATTR_BOLD | ATTR_FAINT,
};
-enum selection_mode {
+enum selection_mode
+{
SEL_IDLE = 0,
SEL_EMPTY = 1,
SEL_READY = 2
};
-enum selection_type {
+enum selection_type
+{
SEL_REGULAR = 1,
SEL_RECTANGULAR = 2
};
-enum selection_snap {
+enum selection_snap
+{
SNAP_WORD = 1,
SNAP_LINE = 2
};
#define Glyph Glyph_
-typedef struct {
- rune u; /* character code */
- ushort mode; /* attribute flags */
+typedef struct
+{
+ rune u; /* character code */
+ ushort mode; /* attribute flags */
uint32 fg; /* foreground */
uint32 bg; /* background */
} Glyph;
typedef Glyph *Line;
-typedef union {
+typedef union
+{
int i;
uint ui;
float f;
diff --git a/sys/libbio/rules.mk b/sys/libbio/rules.mk
index fdb4c74..6a029b1 100644
--- a/sys/libbio/rules.mk
+++ b/sys/libbio/rules.mk
@@ -25,7 +25,7 @@ $(LIBS_$(d)): $(OBJS_$(d)) $(OBJS_$(d)/io)
$(ARCHIVE)
$(UNTS_$(d)): TCLIBS := $(LIBS_$(d)) $(OBJ_DIR)/libn/libn.a
-$(UNTS_$(d)): $(TOBJS_$(d)) $(TCLIBS)
+$(UNTS_$(d)): $(TOBJS_$(d)) $(LIBS_$(d)) $(OBJ_DIR)/libn/libn.a
$(LINK)
include share/pop.mk
diff --git a/sys/libn/error.c b/sys/libn/error.c
index 5595457..e0bb4d2 100644
--- a/sys/libn/error.c
+++ b/sys/libn/error.c
@@ -15,6 +15,14 @@ errorf(byte* fmt, ...)
}
void
+verrorf(byte* fmt, va_list args)
+{
+ printf("error: ");
+ vprintf(fmt, args);
+ printf("\n");
+}
+
+void
panicf(byte* fmt, ...)
{
int n;
diff --git a/sys/libn/rules.mk b/sys/libn/rules.mk
index 1fec258..61a56fe 100644
--- a/sys/libn/rules.mk
+++ b/sys/libn/rules.mk
@@ -32,7 +32,7 @@ $(LIBS_$(d)): $(OBJS_$(d))
$(ARCHIVE)
$(UNTS_$(d)): TCLIBS := $(LIBS_$(d))
-$(UNTS_$(d)): $(TOBJS_$(d)) $(TCLIBS)
+$(UNTS_$(d)): $(TOBJS_$(d)) $(LIBS_$(d))
$(LINK)
include share/pop.mk