Simplify a bit more tdeletechar and tinsertblank
authorRoberto E. Vargas Caballero <k0ga@shike2.com>
Fri, 25 Apr 2014 15:24:12 +0000 (17:24 +0200)
committerRoberto E. Vargas Caballero <k0ga@shike2.com>
Fri, 25 Apr 2014 15:25:59 +0000 (17:25 +0200)
The large and repeated expression used in memmove to indirect
the line can be simplified using a pointer, that makes more
clear where begins and where ends the movement.

st.c

diff --git a/st.c b/st.c
index 263abaa50406b11f350de910bb39f4a944115638..e468d73cf522853325cc0c26921e91d0cf3bad05 100644 (file)
--- a/st.c
+++ b/st.c
@@ -1587,30 +1587,32 @@ tclearregion(int x1, int y1, int x2, int y2) {
 void
 tdeletechar(int n) {
        int dst, src, size;
+       Glyph *line;
 
        LIMIT(n, 0, term.col - term.c.x);
 
        dst = term.c.x;
        src = term.c.x + n;
        size = term.col - src;
+       line = term.line[term.c.y];
 
-       memmove(&term.line[term.c.y][dst], &term.line[term.c.y][src],
-               size * sizeof(Glyph));
+       memmove(&line[dst], &line[src], size * sizeof(Glyph));
        tclearregion(term.col-n, term.c.y, term.col-1, term.c.y);
 }
 
 void
 tinsertblank(int n) {
        int dst, src, size;
+       Glyph *line;
 
        LIMIT(n, 0, term.col - term.c.x);
 
        dst = term.c.x + n;
        src = term.c.x;
        size = term.col - dst;
+       line = term.line[term.c.y];
 
-       memmove(&term.line[term.c.y][dst], &term.line[term.c.y][src],
-               size * sizeof(Glyph));
+       memmove(&line[dst], &line[src], size * sizeof(Glyph));
        tclearregion(src, term.c.y, dst - 1, term.c.y);
 }