From 524ee127958ee8be8b530154488f6f7faca1635e Mon Sep 17 00:00:00 2001 From: Christian Neukirchen Date: Sat, 6 Aug 2016 18:27:01 +0200 Subject: msort: add -U and -I to sort by flags --- msort.c | 36 ++++++++++++++++++++++++++++++++++-- 1 file changed, 34 insertions(+), 2 deletions(-) (limited to 'msort.c') diff --git a/msort.c b/msort.c index e003fb5..323717a 100644 --- a/msort.c +++ b/msort.c @@ -212,6 +212,36 @@ fileorder(const void *a, const void *b) return mystrverscmp(ia->file, ib->file); } +int +unreadorder(const void *a, const void *b) +{ + struct mail *ia = (struct mail *)a; + struct mail *ib = (struct mail *)b; + + char *fa = strstr(ia->file, ":2,"); + char *fb = strstr(ib->file, ":2,"); + + int unreada = fa ? !strchr(fa, 'S') : 0; + int unreadb = fb ? !strchr(fb, 'S') : 0; + + return unreada - unreadb; +} + +int +flaggedorder(const void *a, const void *b) +{ + struct mail *ia = (struct mail *)a; + struct mail *ib = (struct mail *)b; + + char *fa = strstr(ia->file, ":2,"); + char *fb = strstr(ib->file, ":2,"); + + int unreada = fa ? !!strchr(fa, 'F') : 0; + int unreadb = fb ? !!strchr(fb, 'F') : 0; + + return unreadb - unreada; +} + int idxorder(const void *a, const void *b) { @@ -269,7 +299,7 @@ main(int argc, char *argv[]) { int c, i; - while ((c = getopt(argc, argv, "fdsFMSr")) != -1) + while ((c = getopt(argc, argv, "fdsFMSUIr")) != -1) switch(c) { case 'f': addorder(fromorder); break; case 'd': addorder(dateorder); break; @@ -277,10 +307,12 @@ main(int argc, char *argv[]) case 'F': addorder(fileorder); break; case 'M': addorder(mtimeorder); break; case 'S': addorder(sizeorder); break; + case 'U': addorder(unreadorder); break; + case 'I': addorder(flaggedorder); break; case 'r': rflag = !rflag; break; default: fprintf(stderr, - "Usage: msort [-r] [-fdsFMS] [msgs...]\n"); + "Usage: msort [-r] [-fdsFMSUI] [msgs...]\n"); exit(1); } -- cgit 1.4.1