+
+void
+modest_tny_send_queue_wakeup (ModestTnySendQueue *self)
+{
+ ModestTnySendQueuePrivate *priv;
+ TnyList *headers;
+ TnyIterator *iter;
+
+ g_return_if_fail (MODEST_IS_TNY_SEND_QUEUE (self));
+
+ priv = MODEST_TNY_SEND_QUEUE_GET_PRIVATE (self);
+
+ headers = tny_simple_list_new ();
+ tny_folder_get_headers (priv->outbox, headers, TRUE, NULL);
+
+ /* Wake up every single suspended header */
+ iter = tny_list_create_iterator (headers);
+ while (!tny_iterator_is_done (iter)) {
+ TnyHeader *header = TNY_HEADER (tny_iterator_get_current (iter));
+
+ if (tny_header_get_flags (header) & TNY_HEADER_FLAG_SUSPENDED) {
+ gchar *msg_id;
+ GList *item;
+ SendInfo *info;
+
+ /* Unset the suspended flag */
+ tny_header_unset_flag (header, TNY_HEADER_FLAG_SUSPENDED);
+
+ /* Notify view */
+ msg_id = modest_tny_send_queue_get_msg_id (header);
+ item = modest_tny_send_queue_lookup_info (MODEST_TNY_SEND_QUEUE (self), msg_id);
+ info = (SendInfo *) item->data;
+ info->status = MODEST_TNY_SEND_QUEUE_WAITING;
+ g_signal_emit (self, signals[STATUS_CHANGED_SIGNAL], 0, info->msg_id, info->status);
+
+ /* Frees */
+ g_free (msg_id);
+ }
+
+ /* Frees */
+ g_object_unref (header);
+ tny_iterator_next (iter);
+ }
+
+ /* Frees */
+ g_object_unref (iter);
+ g_object_unref (G_OBJECT (headers));
+}