diff options
author | Hiltjo Posthuma <hiltjo@codemadness.org> | 2019-03-15 20:40:16 +0100 |
---|---|---|
committer | Hiltjo Posthuma <hiltjo@codemadness.org> | 2019-03-15 20:40:16 +0100 |
commit | 21367a040f056f6a207fafa066bd1cb2d9cae586 (patch) | |
tree | 3e9e0e5802475c69d1c81c35a38b48561b7016d4 | |
parent | b650256044f867851725f712fdac58d4ff294808 (diff) | |
download | st-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.h | 7 | ||||
-rw-r--r-- | st.c | 3 | ||||
-rw-r--r-- | st.h | 2 |
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; | |||
28 | static float chscale = 1.0; | 28 | static 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 | */ |
36 | wchar_t *extrawordchars = L""; | 35 | wchar_t *worddelimiters = L" "; |
37 | 36 | ||
38 | /* selection timeouts (in milliseconds) */ | 37 | /* selection timeouts (in milliseconds) */ |
39 | static unsigned int doubleclicktimeout = 300; | 38 | static unsigned int doubleclicktimeout = 300; |
@@ -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 | ||
47 | enum term_mode { | 46 | enum term_mode { |
48 | MODE_WRAP = 1 << 0, | 47 | MODE_WRAP = 1 << 0, |
@@ -114,7 +114,7 @@ char *xstrdup(char *); | |||
114 | extern char *utmp; | 114 | extern char *utmp; |
115 | extern char *stty_args; | 115 | extern char *stty_args; |
116 | extern char *vtiden; | 116 | extern char *vtiden; |
117 | extern wchar_t *extrawordchars; | 117 | extern wchar_t *worddelimiters; |
118 | extern int allowaltscreen; | 118 | extern int allowaltscreen; |
119 | extern char *termname; | 119 | extern char *termname; |
120 | extern unsigned int tabspaces; | 120 | extern unsigned int tabspaces; |