X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=sidebar.c;h=5692cddbba0949ff953b3890d80f79c415e3c135;hp=e136de6082e0c819a830499dc3cb8d5c8fac8abb;hb=777c7ccc259a8b7f5fadac70267c59e62a2cb300;hpb=99f13b54ae0060dae3e97e661c1d728d1dedd871 diff --git a/sidebar.c b/sidebar.c index e136de6..5692cdd 100644 --- a/sidebar.c +++ b/sidebar.c @@ -120,12 +120,16 @@ static char * shortened_hierarchy(char * box) { char *make_sidebar_entry(char *box, int size, int new, int flagged) { - char *c; - int i = 0, dlen = mutt_strlen (SidebarDelim), max = SidebarWidth-dlen-1, - shortened = 0; + int i = 0, dlen, max, shortened = 0; + int offset; - c = realloc(entry, SidebarWidth + 1); - if ( c ) entry = c; + if (SidebarWidth > COLS) + SidebarWidth = COLS; + + dlen = mutt_strlen(SidebarDelim); + max = SidebarWidth - dlen - 1; + + safe_realloc(&entry, SidebarWidth + 1); entry[SidebarWidth] = 0; for (; i < SidebarWidth; entry[i++] = ' ' ); #if USE_IMAP @@ -149,20 +153,30 @@ char *make_sidebar_entry(char *box, int size, int new, int flagged) if ( new ) { if (flagged>0) { - sprintf(entry + SidebarWidth - 5 - quick_log10(size) - dlen - quick_log10(new) - quick_log10(flagged), + offset = SidebarWidth - 5 - quick_log10(size) - dlen - quick_log10(new) - quick_log10(flagged); + if (offset<0) offset = 0; + snprintf(entry + offset, SidebarWidth - dlen - offset + 1, "% d(%d)[%d]", size, new, flagged); } else { - sprintf(entry + SidebarWidth - 3 - quick_log10(size) - dlen - quick_log10(new), + offset = SidebarWidth - 3 - quick_log10(size) - dlen - quick_log10(new); + if (offset<0) offset = 0; + snprintf(entry + offset, SidebarWidth - dlen - offset + 1, "% d(%d)", size, new); } } else { if (flagged>0) { - sprintf( entry + SidebarWidth - 3 - quick_log10(size) - dlen - quick_log10(flagged), "% d[%d]", size,flagged); + offset = SidebarWidth - 3 - quick_log10(size) - dlen - quick_log10(flagged); + if (offset<0) offset = 0; + snprintf( entry + offset, SidebarWidth - dlen - offset + 1, + "% d[%d]", size,flagged); } else { - sprintf( entry + SidebarWidth - 1 - quick_log10(size) - dlen, "% d", size); + offset = SidebarWidth - 1 - quick_log10(size) - dlen; + if (offset<0) offset = 0; + snprintf( entry + offset, SidebarWidth - dlen - offset + 1, + "% d", size); } - } + if (option(OPTSHORTENHIERARCHY) && shortened) { free(box); } @@ -229,7 +243,7 @@ int draw_sidebar(int menu) { } else if(!prev_show_value && option(OPTMBOXPANE)) { SidebarWidth = saveSidebarWidth; /* after toggle: force recounting of all mail */ - mutt_buffy_check(1); + mutt_buffy_check(2); } prev_show_value = option(OPTMBOXPANE); } @@ -237,7 +251,8 @@ int draw_sidebar(int menu) { if ( SidebarWidth == 0 ) return 0; /* draw the divider */ - SETCOLOR(MT_COLOR_STATUS); + /* SETCOLOR(MT_COLOR_STATUS); */ + SETCOLOR(MT_COLOR_SIDEBAR); for (lines = option (OPTSTATUSONTOP) ? 0 : 1; lines < LINES-1-(menu != MENU_PAGER || option (OPTSTATUSONTOP)); lines++ ) { move(lines, SidebarWidth - delim_len);