diff options
author | Quentin Rameau <quinq@fifth.space> | 2021-07-19 21:23:32 +0200 |
---|---|---|
committer | Quentin Rameau <quinq@fifth.space> | 2021-07-19 22:27:50 +0200 |
commit | 11dca18a2d148e5a6463aba783567a3815424963 (patch) | |
tree | 520bb6b452806a7f9f7553ceef106a01c2852774 | |
parent | Improve SETPROP xprop parsing (diff) | |
download | surf-11dca18a2d148e5a6463aba783567a3815424963.tar.gz surf-11dca18a2d148e5a6463aba783567a3815424963.tar.bz2 surf-11dca18a2d148e5a6463aba783567a3815424963.zip |
Improve non-ASCII character search handling HEAD surf-webkit2
Before, the XA_STRING would only let use ASCII characters properly. Now UTF-8 characters should be handled correctly.
-rw-r--r-- | config.def.h | 4 | ||||
-rw-r--r-- | surf.c | 8 |
2 files changed, 7 insertions, 5 deletions
diff --git a/config.def.h b/config.def.h index 3a417f0..1355ba3 100644 --- a/config.def.h +++ b/config.def.h @@ -68,10 +68,10 @@ static WebKitFindOptions findopts = WEBKIT_FIND_OPTIONS_CASE_INSENSITIVE | #define SETPROP(r, s, p) { \ .v = (const char *[]){ "/bin/sh", "-c", \ "prop=\"$(printf '%b' \"$(xprop -id $1 "r" " \ - "| sed -e 's/^"r"(STRING) = \"\\(.*\\)\"/\\1/' " \ + "| sed -e 's/^"r"(UTF8_STRING) = \"\\(.*\\)\"/\\1/' " \ " -e 's/\\\\\\(.\\)/\\1/g')\" " \ "| dmenu -p '"p"' -w $1)\" " \ - "&& xprop -id $1 -f "s" 8s -set "s" \"$prop\"", \ + "&& xprop -id $1 -f "s" 8u -set "s" \"$prop\"", \ "surf-setprop", winid, NULL \ } \ } diff --git a/surf.c b/surf.c index c25def7..03d8242 100644 --- a/surf.c +++ b/surf.c @@ -37,7 +37,7 @@ #define LENGTH(x) (sizeof(x) / sizeof(x[0])) #define CLEANMASK(mask) (mask & (MODKEY|GDK_SHIFT_MASK)) -enum { AtomFind, AtomGo, AtomUri, AtomLast }; +enum { AtomFind, AtomGo, AtomUri, AtomUTF8, AtomLast }; enum { OnDoc = WEBKIT_HIT_TEST_RESULT_CONTEXT_DOCUMENT, @@ -339,6 +339,7 @@ setup(void) atoms[AtomFind] = XInternAtom(dpy, "_SURF_FIND", False); atoms[AtomGo] = XInternAtom(dpy, "_SURF_GO", False); atoms[AtomUri] = XInternAtom(dpy, "_SURF_URI", False); + atoms[AtomUTF8] = XInternAtom(dpy, "UTF8_STRING", False); gtk_init(NULL, NULL); @@ -608,7 +609,7 @@ void setatom(Client *c, int a, const char *v) { XChangeProperty(dpy, c->xid, - atoms[a], XA_STRING, 8, PropModeReplace, + atoms[a], atoms[AtomUTF8], 8, PropModeReplace, (unsigned char *)v, strlen(v) + 1); XSync(dpy, False); } @@ -623,7 +624,8 @@ getatom(Client *c, int a) unsigned char *p = NULL; XSync(dpy, False); - XGetWindowProperty(dpy, c->xid, atoms[a], 0L, BUFSIZ, False, XA_STRING, + XGetWindowProperty(dpy, c->xid, + atoms[a], 0L, BUFSIZ, False, atoms[AtomUTF8], &adummy, &idummy, &ldummy, &ldummy, &p); if (p) strncpy(buf, (char *)p, LENGTH(buf) - 1); |