rework m_strformat so that it takes the cols number to use in case of
[apps/madmutt.git] / lib-ui / status.c
index 3462ffa..9c4bdf9 100644 (file)
@@ -46,11 +46,10 @@ static char *get_sort_str (char *buf, ssize_t buflen, int method)
  * %t = # of tagged messages [option]
  * %v = Madmutt version 
  * %V = currently active limit pattern [option] */
-static const char *status_format_str (char *buf, ssize_t buflen, char op,
-                                      const char *src, const char *prefix,
-                                      const char *ifstr,
-                                      const char *elstr,
-                                      anytype data, format_flag flags)
+static const char *
+status_format_str(char *buf, ssize_t buflen, char op, const char *src,
+                  const char *prefix, const char *ifstr, const char *elstr,
+                  anytype data, format_flag flags)
 {
   char fmt[STRING], tmp[STRING];
   const char *cp, *p;
@@ -279,19 +278,13 @@ static const char *status_format_str (char *buf, ssize_t buflen, char op,
     break;
   }
 
-  if (optional)
-    menu_status_line (buf, buflen, menu, ifstr);
-  else if (flags & M_FORMAT_OPTIONAL)
-    menu_status_line (buf, buflen, menu, elstr);
+  if (flags & M_FORMAT_OPTIONAL)
+    menu_status_line(buf, buflen, menu, optional ? ifstr : elstr);
 
   return (src);
 }
 
-void menu_status_line (char* buf, ssize_t len, MUTTMENU* menu, const char* p) {
-    /*
-     * if we have enough space for buffer, format lines to $COLS-$SidebarWidth
-     * only to not wrap past end of screen
-     */
-    int width = MIN(COLS - SW + 1, len);
-    m_strformat(buf, width, p, status_format_str, menu, 0);
+void menu_status_line(char* buf, ssize_t len, MUTTMENU* menu, const char* p)
+{
+    m_strformat(buf, len, COLS - SW, p, status_format_str, menu, 0);
 }