diff options
author | Luke Smith <luke@lukesmith.xyz> | 2020-03-20 08:40:22 -0400 |
---|---|---|
committer | Luke Smith <luke@lukesmith.xyz> | 2020-03-20 08:40:22 -0400 |
commit | 72c555f605858e6ddb3ff1c34c9914cf9677c34b (patch) | |
tree | 48a1a6d226c7d821e26b0c5628d829dfd2ae5df2 /st.c | |
parent | ec72bbe23e78e94167d72db27b3bbb4afd643672 (diff) | |
parent | 6725a2fde0127694176901ebf6217024b832fd8e (diff) |
Merge branch 'master' of github.com:LukeSmithxyz/st
Diffstat (limited to 'st.c')
-rw-r--r-- | st.c | 11 |
1 files changed, 10 insertions, 1 deletions
@@ -14,6 +14,7 @@ #include <sys/types.h> #include <sys/wait.h> #include <termios.h> +#include <time.h> #include <unistd.h> #include <wchar.h> @@ -142,6 +143,7 @@ typedef struct { int charset; /* current charset */ int icharset; /* selected charset for sequence */ int *tabs; + struct timespec last_ximspot_update; } Term; /* CSI Escape sequence structs */ @@ -1056,6 +1058,7 @@ void tnew(int col, int row) { term = (Term){ .c = { .attr = { .fg = defaultfg, .bg = defaultbg } } }; + clock_gettime(CLOCK_MONOTONIC, &term.last_ximspot_update); tresize(col, row); treset(); } @@ -2744,7 +2747,13 @@ draw(void) term.ocx, term.ocy, term.line[term.ocy][term.ocx]); term.ocx = cx, term.ocy = term.c.y; xfinishdraw(); - xximspot(term.ocx, term.ocy); + + struct timespec now; + clock_gettime(CLOCK_MONOTONIC, &now); + if (ximspot_update_interval && TIMEDIFF(now, term.last_ximspot_update) > ximspot_update_interval) { + xximspot(term.ocx, term.ocy); + term.last_ximspot_update = now; + } } void |