tweaks: remove the group handling for undoing/redoing (un)indents

Indenting/unindenting always happens in a single contiguous block.
Lines that cannot or should not be indented or unindented do not
need to remembered separately as it follows from their content.
master
Benno Schulenberg 2018-04-01 11:36:27 +02:00
parent d0d293b8af
commit 8965103a4d
1 changed files with 12 additions and 14 deletions

View File

@ -435,14 +435,15 @@ void do_unindent(void)
void handle_indent_action(undo *u, bool undoing, bool add_indent) void handle_indent_action(undo *u, bool undoing, bool add_indent)
{ {
undo_group *group = u->grouping; undo_group *group = u->grouping;
filestruct *line = fsfromline(group->top_line);
if (group->next != NULL)
statusline(ALERT, "Multiple groups -- please report a bug");
/* When redoing, reposition the cursor and let the indenter adjust it. */ /* When redoing, reposition the cursor and let the indenter adjust it. */
if (!undoing) if (!undoing)
goto_line_posx(u->lineno, u->begin); goto_line_posx(u->lineno, u->begin);
while (group) {
filestruct *line = fsfromline(group->top_line);
/* For each line in the group, add or remove the individual indent. */ /* For each line in the group, add or remove the individual indent. */
while (line && line->lineno <= group->bottom_line) { while (line && line->lineno <= group->bottom_line) {
char *blanks = group->indentations[line->lineno - group->top_line]; char *blanks = group->indentations[line->lineno - group->top_line];
@ -455,9 +456,6 @@ void handle_indent_action(undo *u, bool undoing, bool add_indent)
line = line->next; line = line->next;
} }
group = group->next;
}
/* When undoing, reposition the cursor to the recorded location. */ /* When undoing, reposition the cursor to the recorded location. */
if (undoing) if (undoing)
goto_line_posx(u->lineno, u->begin); goto_line_posx(u->lineno, u->begin);