static void modest_mail_operation_queue_init (ModestMailOperationQueue *obj);
static void modest_mail_operation_queue_finalize (GObject *obj);
-static GObject *modest_mail_operation_queue_constructor (GType type, guint n_construct_params,
- GObjectConstructParam *construct_params);
-
static void modest_mail_operation_queue_cancel_no_block_wrapper (ModestMailOperation *mail_op,
ModestMailOperationQueue *op_queue);
ModestMailOperationQueuePrivate))
/* globals */
static GObjectClass *parent_class = NULL;
-static ModestMailOperationQueue *singleton = NULL;
/* uncomment the following if you have defined any signals */
/* static guint signals[LAST_SIGNAL] = {0}; */
parent_class = g_type_class_peek_parent (klass);
gobject_class->finalize = modest_mail_operation_queue_finalize;
- gobject_class->constructor = modest_mail_operation_queue_constructor;
g_type_class_add_private (gobject_class, sizeof(ModestMailOperationQueuePrivate));
}
priv->queue_lock = g_mutex_new ();
}
-static GObject*
-modest_mail_operation_queue_constructor (GType type, guint n_construct_params,
- GObjectConstructParam *construct_params)
-{
- GObject *object;
-
- if (!singleton) {
- object = G_OBJECT_CLASS (parent_class)->constructor (type,
- n_construct_params, construct_params);
-
- singleton = MODEST_MAIL_OPERATION_QUEUE (object);
- } else {
- object = G_OBJECT (singleton);
- g_object_freeze_notify (G_OBJECT (singleton));
- }
-
- return object;
-}
-
static void
modest_mail_operation_queue_finalize (GObject *obj)
{
}
ModestMailOperationQueue *
-modest_mail_operation_queue_get_instance (void)
+modest_mail_operation_queue_new (void)
{
ModestMailOperationQueue *self = g_object_new (MODEST_TYPE_MAIL_OPERATION_QUEUE, NULL);
}
void
-modest_mail_operation_queue_add (ModestMailOperationQueue *op_queue,
+modest_mail_operation_queue_add (ModestMailOperationQueue *self,
ModestMailOperation *mail_op)
{
ModestMailOperationQueuePrivate *priv;
- if (!MODEST_IS_MAIL_OPERATION (mail_op) ||
- !MODEST_IS_MAIL_OPERATION_QUEUE (op_queue)) {
- g_warning ("%s: bad parametters", G_GNUC_FUNCTION);
- return;
- }
-
- priv = MODEST_MAIL_OPERATION_QUEUE_GET_PRIVATE(op_queue);
+ g_return_if_fail (MODEST_IS_MAIL_OPERATION_QUEUE (self));
+ g_return_if_fail (MODEST_IS_MAIL_OPERATION (mail_op));
+
+ priv = MODEST_MAIL_OPERATION_QUEUE_GET_PRIVATE(self);
g_mutex_lock (priv->queue_lock);
g_queue_push_tail (priv->op_queue, g_object_ref (mail_op));
}
void
-modest_mail_operation_queue_remove (ModestMailOperationQueue *op_queue,
+modest_mail_operation_queue_remove (ModestMailOperationQueue *self,
ModestMailOperation *mail_op)
{
ModestMailOperationQueuePrivate *priv;
- if (!MODEST_IS_MAIL_OPERATION (mail_op) ||
- !MODEST_IS_MAIL_OPERATION_QUEUE (op_queue)) {
- g_warning ("%s: invalid paramette", G_GNUC_FUNCTION);
- return;
- }
+ g_return_if_fail (MODEST_IS_MAIL_OPERATION_QUEUE (self));
+ g_return_if_fail (MODEST_IS_MAIL_OPERATION (mail_op));
- priv = MODEST_MAIL_OPERATION_QUEUE_GET_PRIVATE(op_queue);
+ priv = MODEST_MAIL_OPERATION_QUEUE_GET_PRIVATE(self);
g_mutex_lock (priv->queue_lock);
g_queue_remove (priv->op_queue, mail_op);
g_mutex_unlock (priv->queue_lock);
-
- g_object_unref (G_OBJECT (mail_op));
}
/* Utility function intended to be used with g_queue_foreach */
static void
-modest_mail_operation_queue_cancel_no_block_wrapper (ModestMailOperation *mail_op,
+modest_mail_operation_queue_cancel_no_block_wrapper (ModestMailOperation *self,
ModestMailOperationQueue *op_queue)
{
- modest_mail_operation_queue_cancel_no_block (op_queue, mail_op);
+ modest_mail_operation_queue_cancel_no_block (op_queue, self);
}
static void
-modest_mail_operation_queue_cancel_no_block (ModestMailOperationQueue *op_queue,
+modest_mail_operation_queue_cancel_no_block (ModestMailOperationQueue *self,
ModestMailOperation *mail_op)
{
- /* TODO: place here the cancel code */
+ if (modest_mail_operation_is_finished (mail_op))
+ return;
+
+ /* TODO: the implementation is still empty */
+ modest_mail_operation_cancel (mail_op);
+
+ /* Remove from the queue */
+ modest_mail_operation_queue_remove (self, mail_op);
}
void
-modest_mail_operation_queue_cancel (ModestMailOperationQueue *op_queue,
+modest_mail_operation_queue_cancel (ModestMailOperationQueue *self,
ModestMailOperation *mail_op)
{
ModestMailOperationQueuePrivate *priv;
- GList *iter;
- if (!MODEST_IS_MAIL_OPERATION (mail_op) ||
- !MODEST_IS_MAIL_OPERATION_QUEUE (op_queue)) {
- g_warning ("%s: invalid paramette", G_GNUC_FUNCTION);
- return;
- }
+ g_return_if_fail (MODEST_IS_MAIL_OPERATION_QUEUE (self));
+ g_return_if_fail (MODEST_IS_MAIL_OPERATION (mail_op));
- priv = MODEST_MAIL_OPERATION_QUEUE_GET_PRIVATE(op_queue);
+ priv = MODEST_MAIL_OPERATION_QUEUE_GET_PRIVATE(self);
g_mutex_lock (priv->queue_lock);
- modest_mail_operation_queue_cancel_no_block (op_queue, mail_op);
+ modest_mail_operation_queue_cancel_no_block (self, mail_op);
g_mutex_unlock (priv->queue_lock);
}
void
-modest_mail_operation_queue_cancel_all (ModestMailOperationQueue *op_queue)
+modest_mail_operation_queue_cancel_all (ModestMailOperationQueue *self)
{
ModestMailOperationQueuePrivate *priv;
- if (!MODEST_IS_MAIL_OPERATION_QUEUE (op_queue)) {
- g_warning ("%s: invalid paramette", G_GNUC_FUNCTION);
- return;
- }
+ g_return_if_fail (MODEST_IS_MAIL_OPERATION_QUEUE (self));
- priv = MODEST_MAIL_OPERATION_QUEUE_GET_PRIVATE(op_queue);
+ priv = MODEST_MAIL_OPERATION_QUEUE_GET_PRIVATE(self);
g_mutex_lock (priv->queue_lock);
g_queue_foreach (priv->op_queue,
(GFunc) modest_mail_operation_queue_cancel_no_block_wrapper,
- op_queue);
+ self);
g_mutex_unlock (priv->queue_lock);
}