nano-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Nano-devel] [PATCH 1/3] text: make indenting add to the beginning of th


From: Benno Schulenberg
Subject: [Nano-devel] [PATCH 1/3] text: make indenting add to the beginning of the line
Date: Mon, 14 Aug 2017 12:03:30 +0200

From: David Lawrence Ramsey <address@hidden>

Instead of inserting the extra whitespace after the current indentation
of a line, add it to the start of the line.  This causes a fixed amount
of visual whitespace to be added regardless of whether --tabstospaces
is used or not.

This fixes http://savannah.gnu.org/bugs/?51438,
and its ancestor https://savannah.gnu.org/bugs/?51408.
---
 src/text.c | 35 ++++++++++++++++++++---------------
 1 file changed, 20 insertions(+), 15 deletions(-)

diff --git a/src/text.c b/src/text.c
index 6fb72c2b..d4907c13 100644
--- a/src/text.c
+++ b/src/text.c
@@ -315,33 +315,38 @@ void do_indent(void)
 
     line_indent[line_indent_len] = '\0';
 
-    /* Go through each line of the text. */
+    /* Go through the lines to see if there's a non-empty one. */
+    for (f = top; f != bot->next; f = f->next) {
+       if (f->data[0] != '\0')
+           break;
+    }
+
+    /* If all lines are empty, there is nothing to do. */
+    if (f == bot->next)
+       return;
+
+    /* Go through each of the lines, but skip empty ones. */
     for (f = top; f != bot->next; f = f->next) {
        size_t line_len = strlen(f->data);
-       size_t indent_len = indent_length(f->data);
 
-       /* Add the characters in line_indent to
-        * the beginning of the non-whitespace text of this line. */
+       if (f->data[0] == '\0')
+           continue;
+
+       /* Add the fabricated indentation to the beginning of the line. */
        f->data = charealloc(f->data, line_len + line_indent_len + 1);
-       charmove(&f->data[indent_len + line_indent_len],
-               &f->data[indent_len], line_len - indent_len + 1);
-       strncpy(f->data + indent_len, line_indent, line_indent_len);
+       charmove(&f->data[line_indent_len], f->data, line_len + 1);
+       strncpy(f->data, line_indent, line_indent_len);
+
        openfile->totsize += line_indent_len;
 
        /* Keep track of the change in the current line. */
-       if (openfile->mark_set && f == openfile->mark_begin &&
-               openfile->mark_begin_x >= indent_len)
+       if (openfile->mark_set && f == openfile->mark_begin)
            openfile->mark_begin_x += line_indent_len;
 
-       if (f == openfile->current && openfile->current_x >= indent_len) {
+       if (f == openfile->current) {
            openfile->current_x += line_indent_len;
            openfile->placewewant = xplustabs();
        }
-
-       /* If the NO_NEWLINES flag isn't set, and this is the
-        * magicline, add a new magicline. */
-       if (!ISSET(NO_NEWLINES) && f == openfile->filebot)
-           new_magicline();
     }
 
     /* Clean up. */
-- 
2.14.1




reply via email to

[Prev in Thread] Current Thread [Next in Thread]