avoid redraw when there's no change

while i was timing the performance issue, i noticed that there was lots
of random redrawing going on.

turns out there were coming from here; if someone presses CTRL/ALT etc
without pressing anything else, nothing will be inserted, so nothing
will change. but the code will `break`, go down and do a needless redraw.

this patch changes it to simply return if the keypress iscntrl()

also avoid potential UB by casting *buf into an unsigned char.
main
NRK 2022-03-25 22:51:45 +01:00 committed by Chewing_Bever
parent cced315e68
commit ad50c7b741
Signed by: Jef Roosens
GPG Key ID: B75D4F293C7052DB
1 changed files with 3 additions and 2 deletions

View File

@ -503,8 +503,9 @@ keypress(XKeyEvent *ev)
switch(ksym) {
default:
insert:
if (!iscntrl(*buf))
insert(buf, len);
if (iscntrl((unsigned char)*buf))
return;
insert(buf, len);
break;
case XK_Delete:
case XK_KP_Delete: