summaryrefslogtreecommitdiff
path: root/st.c
diff options
context:
space:
mode:
authorIvan Tham2020-04-19 19:38:39 +0200
committerHiltjo Posthuma2020-04-19 19:39:48 +0200
commit72e3f6c7c05b4d5b56388508bb20a863aec279f5 (patch)
treeb852a872a0919bcdb9470453084a60defc572004 /st.c
parent33a9a456644ceb235ea6ce61282f3bdce7a8b547 (diff)
downloadst-72e3f6c7c05b4d5b56388508bb20a863aec279f5.tar.gz
st-72e3f6c7c05b4d5b56388508bb20a863aec279f5.zip
Update XIM cursor position only if changed
Updating XIM cursor position is expensive, so only update it when cursor position changed.
Diffstat (limited to 'st.c')
-rw-r--r--st.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/st.c b/st.c
index 9e568c6..0ce6ac2 100644
--- a/st.c
+++ b/st.c
@@ -2571,6 +2571,7 @@ void
drawregion(int x1, int y1, int x2, int y2)
{
int y;
+
for (y = y1; y < y2; y++) {
if (!term.dirty[y])
continue;
@@ -2583,7 +2584,7 @@ drawregion(int x1, int y1, int x2, int y2)
void
draw(void)
{
- int cx = term.c.x;
+ int cx = term.c.x, ocx = term.ocx, ocy = term.ocy;
if (!xstartdraw())
return;
@@ -2599,9 +2600,11 @@ draw(void)
drawregion(0, 0, term.col, term.row);
xdrawcursor(cx, term.c.y, term.line[term.c.y][cx],
term.ocx, term.ocy, term.line[term.ocy][term.ocx]);
- term.ocx = cx, term.ocy = term.c.y;
+ term.ocx = cx;
+ term.ocy = term.c.y;
xfinishdraw();
- xximspot(term.ocx, term.ocy);
+ if (ocx != term.ocx || ocy != term.ocy)
+ xximspot(term.ocx, term.ocy);
}
void