use format=raw by default when requesting part with --part=
authorJameson Graef Rollins <jrollins@finestructure.net>
Mon, 23 May 2011 22:38:49 +0000 (15:38 -0700)
committerCarl Worth <cworth@cworth.org>
Tue, 24 May 2011 19:04:08 +0000 (12:04 -0700)
This makes part retrieval a little more intuitive, since generally one
will always want to retrieve parts in raw form.

notmuch-show.c

index c57f7bd075d4eb1aa05883b5b60bcef40ad0ad00..d11a2b81ef0c73398b1a6cf3063438d1bf08cc0f 100644 (file)
@@ -710,6 +710,7 @@ notmuch_show_command (void *ctx, unused (int argc), unused (char *argv[]))
     const notmuch_show_format_t *format = &format_text;
     notmuch_show_params_t params;
     int mbox = 0;
+    int format_specified = 0;
     int i;
 
     params.entire_thread = 0;
@@ -738,6 +739,7 @@ notmuch_show_command (void *ctx, unused (int argc), unused (char *argv[]))
                fprintf (stderr, "Invalid value for --format: %s\n", opt);
                return 1;
            }
+           format_specified = 1;
        } else if (STRNCMP_LITERAL (argv[i], "--part=") == 0) {
            params.part = atoi(argv[i] + sizeof ("--part=") - 1);
        } else if (STRNCMP_LITERAL (argv[i], "--entire-thread") == 0) {
@@ -782,6 +784,10 @@ notmuch_show_command (void *ctx, unused (int argc), unused (char *argv[]))
        return 1;
     }
 
+    /* if part was requested and format was not specified, use format=raw */
+    if (params.part >= 0 && !format_specified)
+       format = &format_raw;
+
     /* If --format=raw specified without specifying part, we can only
      * output single message, so set part=0 */
     if (params.raw && params.part < 0)