all repos — st @ 2cb539142b97bd2a5c1a322fd7c063c6afb67c9b

st (suckless terminal) config

x: do not instantiate a new nested list on each cursor move
Quentin Rameau quinq@fifth.space
commit

2cb539142b97bd2a5c1a322fd7c063c6afb67c9b

parent

99de33395126fc9708f442d155e737b9182f6ef4

1 files changed, 12 insertions(+), 4 deletions(-)

jump to
M x.cx.c

@@ -97,6 +97,8 @@ Atom xembed, wmdeletewin, netwmname, netwmpid;

struct { XIM xim; XIC xic; + XPoint spot; + XVaNestedList spotlist; } ime; Draw draw; Visual *vis;

@@ -1042,6 +1044,9 @@ xw.xic = XCreateIC(xw.ime.xim, XNInputStyle, XIMPreeditNothing | XIMStatusNothing,

XNClientWindow, xw.win, XNFocusWindow, xw.win, NULL); if (xw.xic == NULL) die("XCreateIC failed. Could not obtain input method.\n"); + + xw.ime.spotlist = XVaCreateNestedList(0, XNSpotLocation, &xw.ime.spot, + NULL); } void

@@ -1058,6 +1063,7 @@ {

xw.ime.xim = NULL; XRegisterIMInstantiateCallback(xw.dpy, NULL, NULL, NULL, ximinstantiate, NULL); + XFree(xw.ime.spotlist); } void

@@ -1603,11 +1609,13 @@

void xximspot(int x, int y) { - XPoint spot = { borderpx + x * win.cw, borderpx + (y + 1) * win.ch }; - XVaNestedList attr = XVaCreateNestedList(0, XNSpotLocation, &spot, NULL); + if (xw.ime.xic == NULL) + return; - XSetICValues(xw.xic, XNPreeditAttributes, attr, NULL); - XFree(attr); + xw.ime.spot.x = borderpx + x * win.cw; + xw.ime.spot.y = borderpx + (y + 1) * win.ch; + + XSetICValues(xw.ime.xic, XNPreeditAttributes, xw.ime.spotlist, NULL); } void