diff options
author | Lauri Tirkkonen <lotheac@iki.fi> | 2019-03-13 17:15:04 +0200 |
---|---|---|
committer | Hiltjo Posthuma <hiltjo@codemadness.org> | 2019-03-15 12:25:13 +0100 |
commit | add0211522737b79dad990ccd65c8af63b5cc1dd (patch) | |
tree | a64838abc0734a24b86229e610a339ef7cd35783 | |
parent | d5efd256aa3840476579a27293ef1fb92a4b51e7 (diff) | |
download | st-add0211522737b79dad990ccd65c8af63b5cc1dd.tar.gz st-add0211522737b79dad990ccd65c8af63b5cc1dd.zip |
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.
-rw-r--r-- | config.def.h | 7 | ||||
-rw-r--r-- | st.c | 3 | ||||
-rw-r--r-- | st.h | 2 |
3 files changed, 7 insertions, 5 deletions
diff --git a/config.def.h b/config.def.h index 482901e..9ce45a7 100644 --- a/config.def.h +++ b/config.def.h | |||
@@ -28,11 +28,12 @@ static float cwscale = 1.0; | |||
28 | static float chscale = 1.0; | 28 | static float chscale = 1.0; |
29 | 29 | ||
30 | /* | 30 | /* |
31 | * word delimiter string | 31 | * all space and punctuation characters are considered word delimiters, unless |
32 | * listed here. | ||
32 | * | 33 | * |
33 | * More advanced example: L" `'\"()[]{}" | 34 | * More advanced example: L"#$%&+,-./:=?_~" |
34 | */ | 35 | */ |
35 | wchar_t *worddelimiters = L" "; | 36 | wchar_t *extrawordchars = L"./:"; |
36 | 37 | ||
37 | /* selection timeouts (in milliseconds) */ | 38 | /* selection timeouts (in milliseconds) */ |
38 | static unsigned int doubleclicktimeout = 300; | 39 | static unsigned int doubleclicktimeout = 300; |
@@ -16,6 +16,7 @@ | |||
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> | ||
19 | 20 | ||
20 | #include "st.h" | 21 | #include "st.h" |
21 | #include "win.h" | 22 | #include "win.h" |
@@ -41,7 +42,7 @@ | |||
41 | #define ISCONTROLC0(c) (BETWEEN(c, 0, 0x1f) || (c) == '\177') | 42 | #define ISCONTROLC0(c) (BETWEEN(c, 0, 0x1f) || (c) == '\177') |
42 | #define ISCONTROLC1(c) (BETWEEN(c, 0x80, 0x9f)) | 43 | #define ISCONTROLC1(c) (BETWEEN(c, 0x80, 0x9f)) |
43 | #define ISCONTROL(c) (ISCONTROLC0(c) || ISCONTROLC1(c)) | 44 | #define ISCONTROL(c) (ISCONTROLC0(c) || ISCONTROLC1(c)) |
44 | #define ISDELIM(u) (u != 0 && wcschr(worddelimiters, u) != NULL) | 45 | #define ISDELIM(u) ((iswspace(u) || iswpunct(u)) && wcschr(extrawordchars, u) == NULL) |
45 | 46 | ||
46 | enum term_mode { | 47 | enum term_mode { |
47 | MODE_WRAP = 1 << 0, | 48 | 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 *worddelimiters; | 117 | extern wchar_t *extrawordchars; |
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; |