Fix the intended ordering of items in buffer mode - it should not always

be tag 0 when the tree is empty. GitHub issue 1759.
This commit is contained in:
nicm 2019-05-27 06:50:04 +00:00
parent 097973e3d5
commit 65e5e14561

View File

@ -384,7 +384,7 @@ mode_tree_build(struct mode_tree_data *mtd)
if (mtd->line_list != NULL) if (mtd->line_list != NULL)
tag = mtd->line_list[mtd->current].item->tag; tag = mtd->line_list[mtd->current].item->tag;
else else
tag = 0; tag = UINT64_MAX;
TAILQ_CONCAT(&mtd->saved, &mtd->children, entry); TAILQ_CONCAT(&mtd->saved, &mtd->children, entry);
TAILQ_INIT(&mtd->children); TAILQ_INIT(&mtd->children);
@ -400,6 +400,8 @@ mode_tree_build(struct mode_tree_data *mtd)
mode_tree_clear_lines(mtd); mode_tree_clear_lines(mtd);
mode_tree_build_lines(mtd, &mtd->children, 0); mode_tree_build_lines(mtd, &mtd->children, 0);
if (tag == UINT64_MAX)
tag = mtd->line_list[mtd->current].item->tag;
mode_tree_set_current(mtd, tag); mode_tree_set_current(mtd, tag);
mtd->width = screen_size_x(s); mtd->width = screen_size_x(s);