char *temp_hdr = NULL;
if (h->env)
- flags |= (h->env->irt_changed ? CH_UPDATE_IRT : 0)
- | (h->env->refs_changed ? CH_UPDATE_REFS : 0);
-
+ flags |= ((h->env->changed & MUTT_ENV_CHANGED_IRT) ? CH_UPDATE_IRT : 0)
+ | ((h->env->changed & MUTT_ENV_CHANGED_REFS) ? CH_UPDATE_REFS : 0);
+
if (mutt_copy_hdr (in, out, h->offset, h->content->offset, flags, prefix) == -1)
return -1;
/* if the message has been rethreaded or attachments have been deleted
* we delete the message and reupload it.
* This works better if we're expunging, of course. */
- if ((h->env && (h->env->refs_changed || h->env->irt_changed)) ||
+ if ((h->env && h->env->changed) ||
h->attach_del || h->xlabel_changed)
{
/* NOTE and TODO:
dprint (1, (debugfile, "imap_sync_mailbox: Error opening mailbox in append mode\n"));
else
_mutt_save_message (h, appendctx, 1, 0, 0);
+ /* TODO: why the check for h->env? Is this possible? */
+ if (h->env)
+ h->env->changed = 0;
h->xlabel_changed = 0;
#if USE_HCACHE
idata->hcache = imap_hcache_open (idata, NULL);
{
HEADER *h = ctx->hdrs[msgno];
+ /* TODO: why the h->env check? */
if (h->attach_del || h->xlabel_changed ||
- (h->env && (h->env->refs_changed || h->env->irt_changed)))
+ (h->env && h->env->changed))
+ {
if (mh_rewrite_message (ctx, msgno) != 0)
return -1;
+ /* TODO: why the env check? */
+ if (h->env)
+ h->env->changed = 0;
+ }
return 0;
}
char *p;
int rc = 0;
+ /* TODO: why the h->env check? */
if (h->attach_del || h->xlabel_changed ||
- (h->env && (h->env->refs_changed || h->env->irt_changed)))
+ (h->env && h->env->changed))
{
/* when doing attachment deletion/rethreading, fall back to the MH case. */
if (mh_rewrite_message (ctx, msgno) != 0)
return (-1);
+ /* TODO: why the env check? */
+ if (h->env)
+ h->env->changed = 0;
}
else
{
short num;
} ALIAS;
+#define MUTT_ENV_CHANGED_IRT (1<<0) /* In-Reply-To changed to link/break threads */
+#define MUTT_ENV_CHANGED_REFS (1<<1) /* References changed to break thread */
+
typedef struct envelope
{
ADDRESS *return_path;
LIST *in_reply_to; /* in-reply-to header content */
LIST *userhdrs; /* user defined headers */
- unsigned int irt_changed : 1; /* In-Reply-To changed to link/break threads */
- unsigned int refs_changed : 1; /* References changed to break thread */
+ unsigned char changed; /* The MUTT_ENV_CHANGED_* flags specify which
+ * fields are modified */
} ENVELOPE;
typedef struct parameter
MOVE_ELEM(supersedes);
MOVE_ELEM(date);
MOVE_ELEM(x_label);
- if (!base->refs_changed)
+ if (!(base->changed & MUTT_ENV_CHANGED_REFS))
{
MOVE_ELEM(references);
}
- if (!base->irt_changed)
+ if (!(base->changed & MUTT_ENV_CHANGED_IRT))
{
MOVE_ELEM(in_reply_to);
}
}
if (committing)
+ {
ctx->hdrs[j]->changed = 0;
+ ctx->hdrs[j]->env->changed = 0;
+ }
else if (ctx->hdrs[j]->changed)
ctx->changed = 1;
/* clearing the References: header from obsolete Message-ID(s) */
mutt_free_list (&ref->next);
- h->env->refs_changed = h->changed = 1;
+ h->changed = 1;
+ h->env->changed |= MUTT_ENV_CHANGED_REFS;
}
}
}
{
mutt_free_list (&hdr->env->in_reply_to);
mutt_free_list (&hdr->env->references);
- hdr->env->irt_changed = hdr->env->refs_changed = hdr->changed = 1;
+ hdr->changed = 1;
+ hdr->env->changed |= (MUTT_ENV_CHANGED_IRT | MUTT_ENV_CHANGED_REFS);
clean_references (hdr->thread, hdr->thread->child);
}
child->env->in_reply_to = mutt_new_list ();
child->env->in_reply_to->data = safe_strdup (parent->env->message_id);
-
+
mutt_set_flag (ctx, child, MUTT_TAG, 0);
-
- child->env->irt_changed = child->changed = 1;
+
+ child->changed = 1;
+ child->env->changed |= MUTT_ENV_CHANGED_IRT;
return 1;
}