]> git.wh0rd.org Git - nano.git/commitdiff
Continued bugfixes/optimizations to display code. Tabs at COLS don't work still.
authorRobert Siemborski <rjs3@andrew.cmu.edu>
Wed, 7 Jun 2000 04:31:48 +0000 (04:31 +0000)
committerRobert Siemborski <rjs3@andrew.cmu.edu>
Wed, 7 Jun 2000 04:31:48 +0000 (04:31 +0000)
git-svn-id: svn://svn.savannah.gnu.org/nano/trunk/nano@13 35c25a1d-7b9e-4130-9fde-d3aeb78583b8

winio.c

diff --git a/winio.c b/winio.c
index bbf6d5a12f7d09f1e8fdb84e5858a48d58993373..a1b23f6277dc5761fbbb31db80b50bf1046b237f 100644 (file)
--- a/winio.c
+++ b/winio.c
@@ -169,7 +169,7 @@ void reset_cursor(void)
        wmove(edit, current_y, x);
     else
        wmove(edit, current_y, x -
-               get_page_start_virtual(get_page_from_virtual(xplustabs())));
+               get_page_start_virtual(get_page_from_virtual(x)));
 
 }
 
@@ -528,10 +528,10 @@ inline int get_page_from_virtual(int virtual) {
     int page = 2;
 
     if(virtual <= COLS - 2) return 1;
-    virtual -= (COLS - 2);
+    virtual -= (COLS - 1);
 
     while (virtual > COLS - 2 - 7) {
-       virtual -= (COLS - 2 - 7);
+       virtual -= (COLS - 1 - 7);
        page++;
     }
 
@@ -539,10 +539,7 @@ inline int get_page_from_virtual(int virtual) {
 }
 
 inline int get_page_start_virtual(int page) {
-    int virtual;
-    virtual = --page * (COLS - 7);
-    if(page) virtual -= 2 * page - 1;
-    return virtual;
+    return --page * (COLS - 7);
 }
 
 inline int get_page_end_virtual(int page) {
@@ -614,7 +611,8 @@ void add_marked_sameline(int begin, int end, filestruct *fileptr, int y)
 }
 #endif
 
-void edit_add(filestruct * fileptr, int yval, int xval, int start)
+/* we used to have xval.  turns out it should always be zero */
+void edit_add(filestruct * fileptr, int yval, int start)
 {
 #ifndef NANO_SMALL
     int col;
@@ -710,8 +708,8 @@ void edit_add(filestruct * fileptr, int yval, int xval, int start)
 
     } else
 #endif
-       mvwaddnstr(edit, yval, xval, &fileptr->data[start],
-          actual_x_from_start(fileptr,COLS - xval,start));
+       mvwaddnstr(edit, yval, 0, &fileptr->data[start],
+          actual_x_from_start(fileptr,COLS,start));
 
 }
 
@@ -738,13 +736,13 @@ void update_line(filestruct * fileptr, int index)
        col = get_page_start_virtual(page);
        actual_col = actual_x(filetmp, col);
 
-       edit_add(filetmp, line, 0, actual_col);
+       edit_add(filetmp, line, actual_col);
        mvwaddch(edit, line, 0, '$');
 
        if (strlenpt(fileptr->data) > get_page_end_virtual(page))
             mvwaddch(edit, line, COLS - 1, '$');
     } else {
-       edit_add(filetmp, line, 0, 0);
+       edit_add(filetmp, line, 0);
 
        if (strlenpt(&filetmp->data[actual_col]) > COLS)
             mvwaddch(edit, line, COLS - 1, '$');