From: Arun Prakash Jana Date: Tue, 14 Jan 2020 19:27:02 +0000 (+0530) Subject: While drawing lines, set correct color X-Git-Tag: v2.9~6 X-Git-Url: http://www.git.stargrave.org/?a=commitdiff_plain;h=a9ebe7ed8857bcf0496c454bf9e10006dfb0b41c;p=nnn.git While drawing lines, set correct color --- diff --git a/src/nnn.c b/src/nnn.c index d4fe44b7..f395a6e3 100644 --- a/src/nnn.c +++ b/src/nnn.c @@ -4327,26 +4327,38 @@ static int adjust_cols(int ncols) } else ncols -= 3; /* Preceding space, indicator, newline */ - attron(COLOR_PAIR(cfg.curctx + 1) | A_BOLD); - cfg.dircolor = 1; - return ncols; } static void draw_line(char *path, int ncols) { + bool dir = FALSE; + ncols = adjust_cols(ncols); + if (dents[last].flags & DIR_OR_LINK_TO_DIR) { + attron(COLOR_PAIR(cfg.curctx + 1) | A_BOLD); + dir = TRUE; + } move(2 + last - curscroll, 0); printptr(&dents[last], ncols, false); + + if (dents[cur].flags & DIR_OR_LINK_TO_DIR) { + if (!dir) {/* First file is not a directory */ + attron(COLOR_PAIR(cfg.curctx + 1) | A_BOLD); + dir = TRUE; + } + } else if (dir) { /* Second file is not a directory */ + attroff(COLOR_PAIR(cfg.curctx + 1) | A_BOLD); + dir = FALSE; + } + move(2 + cur - curscroll, 0); printptr(&dents[cur], ncols, true); /* Must reset e.g. no files in dir */ - if (cfg.dircolor) { + if (dir) attroff(COLOR_PAIR(cfg.curctx + 1) | A_BOLD); - cfg.dircolor = 0; - } statusbar(path); } @@ -4439,6 +4451,9 @@ static void redraw(char *path) ncols = adjust_cols(ncols); + attron(COLOR_PAIR(cfg.curctx + 1) | A_BOLD); + cfg.dircolor = 1; + /* Print listing */ for (i = curscroll; i < ndents && i < curscroll + onscreen; ++i) printptr(&dents[i], ncols, i == cur);