[dev] [st] [PATCH] Correct shift amount on MODE_INSERT in tputc()

From: Rian Hunter <rian+suckless-dev_AT_thelig.ht>
Date: Thu, 29 Jan 2015 15:08:39 -0800

When MODE_INSERT is set we'd shift characters on the same
line forward before inserting our character in tputc().
This did not account for wide characters where width != 1.
This patch makes it so we shift the correct amount.
---
 st.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/st.c b/st.c
index db9a332..ab338db 100644
--- a/st.c
+++ b/st.c
_AT_@ -2675,8 +2675,8 @@ tputc(char *c, int len) {
 		tnewline(1);
 	}
 
-	if(IS_SET(MODE_INSERT) && term.c.x+1 < term.col)
-		memmove(gp+1, gp, (term.col - term.c.x - 1) * sizeof(Glyph));
+	if(IS_SET(MODE_INSERT) && term.c.x+width < term.col)
+		memmove(gp+width, gp, (term.col - term.c.x - 1) * sizeof(Glyph));
 
 	if(term.c.x+width > term.col)
 		tnewline(1);
-- 
2.1.4
Received on Fri Jan 30 2015 - 00:08:39 CET

This archive was generated by hypermail 2.3.0 : Fri Jan 30 2015 - 00:12:25 CET