aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHiltjo Posthuma <hiltjo@codemadness.org>2019-03-15 20:40:16 +0100
committerHiltjo Posthuma <hiltjo@codemadness.org>2019-03-15 20:40:16 +0100
commit21367a040f056f6a207fafa066bd1cb2d9cae586 (patch)
tree3e9e0e5802475c69d1c81c35a38b48561b7016d4
parentb650256044f867851725f712fdac58d4ff294808 (diff)
downloadst-21367a040f056f6a207fafa066bd1cb2d9cae586.tar.gz
st-21367a040f056f6a207fafa066bd1cb2d9cae586.zip
revert part of commit add0211522737b79dad990ccd65c8af63b5cc1dd
"use iswspace()/iswpunct() to find word delimiters this inverts the configuration logic: you no longer provide a list of delimiters -- all space and punctuation characters are considered delimiters, unless listed in extrawordchars." Feedback from IRC and personal preference.
-rw-r--r--config.def.h7
-rw-r--r--st.c3
-rw-r--r--st.h2
3 files changed, 5 insertions, 7 deletions
diff --git a/config.def.h b/config.def.h
index ac5e8ce..482901e 100644
--- a/config.def.h
+++ b/config.def.h
@@ -28,12 +28,11 @@ static float cwscale = 1.0;
28static float chscale = 1.0; 28static float chscale = 1.0;
29 29
30/* 30/*
31 * all space and punctuation characters are considered word delimiters, unless 31 * word delimiter string
32 * listed here.
33 * 32 *
34 * More advanced example: L"#$%&+,-./:=?_~" 33 * More advanced example: L" `'\"()[]{}"
35 */ 34 */
36wchar_t *extrawordchars = L""; 35wchar_t *worddelimiters = L" ";
37 36
38/* selection timeouts (in milliseconds) */ 37/* selection timeouts (in milliseconds) */
39static unsigned int doubleclicktimeout = 300; 38static unsigned int doubleclicktimeout = 300;
diff --git a/st.c b/st.c
index 48d65ca..8e6ccb5 100644
--- a/st.c
+++ b/st.c
@@ -16,7 +16,6 @@
16#include <termios.h> 16#include <termios.h>
17#include <unistd.h> 17#include <unistd.h>
18#include <wchar.h> 18#include <wchar.h>
19#include <wctype.h>
20 19
21#include "st.h" 20#include "st.h"
22#include "win.h" 21#include "win.h"
@@ -42,7 +41,7 @@
42#define ISCONTROLC0(c) (BETWEEN(c, 0, 0x1f) || (c) == '\177') 41#define ISCONTROLC0(c) (BETWEEN(c, 0, 0x1f) || (c) == '\177')
43#define ISCONTROLC1(c) (BETWEEN(c, 0x80, 0x9f)) 42#define ISCONTROLC1(c) (BETWEEN(c, 0x80, 0x9f))
44#define ISCONTROL(c) (ISCONTROLC0(c) || ISCONTROLC1(c)) 43#define ISCONTROL(c) (ISCONTROLC0(c) || ISCONTROLC1(c))
45#define ISDELIM(u) ((iswspace(u) || iswpunct(u)) && wcschr(extrawordchars, u) == NULL) 44#define ISDELIM(u) (u && wcschr(worddelimiters, u))
46 45
47enum term_mode { 46enum term_mode {
48 MODE_WRAP = 1 << 0, 47 MODE_WRAP = 1 << 0,
diff --git a/st.h b/st.h
index a3b19de..4da3051 100644
--- a/st.h
+++ b/st.h
@@ -114,7 +114,7 @@ char *xstrdup(char *);
114extern char *utmp; 114extern char *utmp;
115extern char *stty_args; 115extern char *stty_args;
116extern char *vtiden; 116extern char *vtiden;
117extern wchar_t *extrawordchars; 117extern wchar_t *worddelimiters;
118extern int allowaltscreen; 118extern int allowaltscreen;
119extern char *termname; 119extern char *termname;
120extern unsigned int tabspaces; 120extern unsigned int tabspaces;