-
- /* Delete previous msg_id */
- if (priv->current_msg_id != NULL)
- g_free(priv->current_msg_id);
-
- /* Unset current msg_id */
- priv->current_msg_id = NULL;
+
+ header = tny_msg_get_header (msg);
+
+ /* TODO: Use this version as soon as the msg-sending
+ * notification works */
+#if 0
+ item = priv->current;
+ g_assert(item != NULL);
+#else
+ item = modest_tny_send_queue_lookup_info (MODEST_TNY_SEND_QUEUE (self), tny_header_get_message_id(header));
+ g_assert(item != NULL);
+#endif
+
+ modest_tny_send_queue_info_free (item->data);
+ g_queue_delete_link (priv->queue, item);
+ priv->current = NULL;
+}
+
+static void _on_msg_error_happened (TnySendQueue *self,
+ TnyHeader *header,
+ TnyMsg *msg,
+ GError *err,
+ gpointer user_data)
+{
+ ModestTnySendQueuePrivate *priv;
+ SendInfo *info;
+ GList *item;
+
+ priv = MODEST_TNY_SEND_QUEUE_GET_PRIVATE (self);
+
+ /* TODO: Use this version as soon as the msg-sending
+ * notification works */
+#if 0
+ item = priv->current;
+ g_assert(item != NULL);
+ info = priv->current->data;
+#else
+ /* TODO: Why do we get the msg and its header separately? The docs
+ * don't really tell. */
+ g_assert(header == tny_msg_get_header (msg)); // ????
+ item = modest_tny_send_queue_lookup_info (MODEST_TNY_SEND_QUEUE (self), tny_header_get_message_id (header));
+ g_assert(item != NULL);
+ info = item->data;
+#endif
+
+ /* Keep in queue so that we remember that the opertion has failed
+ * and was not just cancelled */
+ info->status = MODEST_TNY_SEND_QUEUE_FAILED;
+ g_signal_emit (self, signals[STATUS_CHANGED], 0, info->msg_id, info->status);