This is just the raw message body for now, (so any MIME parsing will
be up to the consumer). And this will likely change in the future.
-static size_t
-_notmuch_message_file_get_header_size (notmuch_message_file_t *message)
+size_t
+notmuch_message_file_get_header_size (notmuch_message_file_t *message)
{
if (! message->parsing_finished)
notmuch_message_file_get_header (message, NULL);
{
if (! message->parsing_finished)
notmuch_message_file_get_header (message, NULL);
notmuch_message_file_get_all_headers (notmuch_message_file_t *message)
{
char *headers = NULL;
notmuch_message_file_get_all_headers (notmuch_message_file_t *message)
{
char *headers = NULL;
- size_t header_size = _notmuch_message_file_get_header_size (message);
+ size_t header_size = notmuch_message_file_get_header_size (message);
if (header_size == 0)
return "";
if (header_size == 0)
return "";
return notmuch_message_file_get_all_headers (message->message_file);
}
return notmuch_message_file_get_all_headers (message->message_file);
}
+size_t
+notmuch_message_get_header_size (notmuch_message_t *message)
+{
+ _notmuch_message_ensure_message_file (message);
+ if (message->message_file == NULL)
+ return 0;
+
+ return notmuch_message_file_get_header_size (message->message_file);
+
+}
+
const char *
notmuch_message_get_thread_id (notmuch_message_t *message)
{
const char *
notmuch_message_get_thread_id (notmuch_message_t *message)
{
const char *
notmuch_message_file_get_all_headers (notmuch_message_file_t *message);
const char *
notmuch_message_file_get_all_headers (notmuch_message_file_t *message);
+/* Get the size in bytes of the full header section of 'message'.
+ *
+ * Returns 0 in the case of any error.
+ */
+size_t
+notmuch_message_file_get_header_size (notmuch_message_file_t *message);
+
/* date.c */
/* Parse an RFC 8222 date string to a time_t value.
/* date.c */
/* Parse an RFC 8222 date string to a time_t value.
notmuch_query_t *query = NULL;
notmuch_message_results_t *messages;
notmuch_message_t *message;
notmuch_query_t *query = NULL;
notmuch_message_results_t *messages;
notmuch_message_t *message;
+ const char *filename;
+ FILE *file;
if (argc != 1) {
fprintf (stderr, "Error: \"notmuch show\" requires exactly one thread-ID argument.\n");
if (argc != 1) {
fprintf (stderr, "Error: \"notmuch show\" requires exactly one thread-ID argument.\n");
printf ("%s", notmuch_message_get_all_headers (message));
printf ("%%header}\n");
printf ("%s", notmuch_message_get_all_headers (message));
printf ("%%header}\n");
+
+ filename = notmuch_message_get_filename (message);
+
+ file = fopen (filename, "r");
+ if (file) {
+ size_t header_size = notmuch_message_get_header_size (message);
+ fseek (file, header_size + 1, SEEK_SET);
+ while (1) {
+ c = fgetc (file);
+ if (c == EOF)
+ break;
+ putchar (c);
+ }
+ }
+ fclose (file);
+
printf ("%%message}\n");
notmuch_message_destroy (message);
printf ("%%message}\n");
notmuch_message_destroy (message);
"\t\tmarks around any parenthesized expression)." },
{ "show", show_command,
"<thread-id>\n\n"
"\t\tmarks around any parenthesized expression)." },
{ "show", show_command,
"<thread-id>\n\n"
- "\t\tNote: The \"notmuch show\" command is not implemented yet.\n\n"
"\t\tShow the thread with the given thread ID (see 'search').",
"\t\tThread ID values are given as the first column in the\n"
"\t\toutput of the \"notmuch search\" command. These are the\n"
"\t\tShow the thread with the given thread ID (see 'search').",
"\t\tThread ID values are given as the first column in the\n"
"\t\toutput of the \"notmuch search\" command. These are the\n"
const char *
notmuch_message_get_filename (notmuch_message_t *message);
const char *
notmuch_message_get_filename (notmuch_message_t *message);
+/* Get the size in bytes of the full header section of 'message'.
+ *
+ * This is useful in conjunction with notmuch_message_get_filename
+ * for separately parsing the message header and content.
+ *
+ * Returns 0 in the case of any error.
+ */
+size_t
+notmuch_message_get_header_size (notmuch_message_t *message);
+
/* Get the value of the specified header from 'message'.
*
* The value will be read from the actual message file, not from the
/* Get the value of the specified header from 'message'.
*
* The value will be read from the actual message file, not from the