summaryrefslogtreecommitdiff
path: root/jet.c
diff options
context:
space:
mode:
authorJuan Manuel Tomás <jtomas1815@gmail.com>2020-04-09 01:31:44 -0300
committerJuan Manuel Tomás <jtomas1815@gmail.com>2020-04-09 01:31:44 -0300
commit3a057c037f3a8f28e27c520db041f8025eba53c2 (patch)
treee932e90ef276b3e7774838956d35e7c2315618ba /jet.c
parent1caf059c2cdffd3162fe030f824ded2bd5b03997 (diff)
downloadjet-3a057c037f3a8f28e27c520db041f8025eba53c2.tar.gz
jet-3a057c037f3a8f28e27c520db041f8025eba53c2.zip
Redraw only if line changed
Diffstat (limited to 'jet.c')
-rw-r--r--jet.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/jet.c b/jet.c
index 0d1181a..b65ef81 100644
--- a/jet.c
+++ b/jet.c
@@ -37,15 +37,19 @@ int main(int argc, char *argv[]) {
for (int i = 0; i < file_size; i++) {
if (buffer[i] == '\n') number_of_lines++;
}
+ int old_line = -1;
while (1) {
- int iter_line = 0;
- for (int i = 0; i < file_size && iter_line < window_height + current_line; i++) {
- if (iter_line >= current_line) addch(buffer[i]);
- if (buffer[i] == '\n') iter_line++;
+ if (old_line != current_line) {
+ clear();
+ int iter_line = 0;
+ for (int i = 0; i < file_size && iter_line < window_height + current_line; i++) {
+ if (iter_line >= current_line) addch(buffer[i]);
+ if (buffer[i] == '\n') iter_line++;
+ }
}
+ old_line = current_line;
int input = getch();
- clear();
switch (input) {
case KEY_UP: