* check for a valid foldername
[modest] / src / modest-dimming-rule.c
index 884ccc7..778f06d 100644 (file)
@@ -35,9 +35,11 @@ static void modest_dimming_rule_finalize   (GObject *obj);
 
 typedef struct _ModestDimmingRulePrivate ModestDimmingRulePrivate;
 struct _ModestDimmingRulePrivate {
+       ModestDimmingRulesGroup *group;
        ModestWindow *win;
        ModestDimmingCallback dimming_rule;
        gchar *action_path;
+       gchar *notification;
 };
 
 #define MODEST_DIMMING_RULE_GET_PRIVATE(o)      (G_TYPE_INSTANCE_GET_PRIVATE((o), \
@@ -89,9 +91,11 @@ modest_dimming_rule_init (ModestDimmingRule *obj)
        ModestDimmingRulePrivate *priv;
 
        priv = MODEST_DIMMING_RULE_GET_PRIVATE(obj);
+       priv->group= NULL;
        priv->win = NULL;
        priv->dimming_rule = NULL;
        priv->action_path = NULL;
+       priv->notification = NULL;
 }
 
 static void
@@ -101,8 +105,12 @@ modest_dimming_rule_finalize (GObject *obj)
 
        priv = MODEST_DIMMING_RULE_GET_PRIVATE(obj);
 
+       if (priv->group != NULL)
+               g_object_unref(priv->group);
        if (priv->action_path != NULL)
                g_free(priv->action_path);
+       if (priv->notification != NULL)
+               g_free(priv->notification);
 
        G_OBJECT_CLASS(parent_class)->finalize (obj);
 }
@@ -145,10 +153,72 @@ modest_dimming_rule_process (ModestDimmingRule *self)
        g_return_if_fail (priv->action_path != NULL);
 
        /* process dimming rule */
-       dimmed = priv->dimming_rule (priv->win, NULL);
+       dimmed = priv->dimming_rule (priv->win, self);
 
        /* Update dimming status */
         action = modest_window_get_action (priv->win, priv->action_path);      
-       g_return_if_fail (action != NULL);
-       gtk_action_set_sensitive (action, !dimmed);
+       if (action == NULL)
+               g_printerr ("modest: action path '%s' has not associatd action\n", priv->action_path);
+       else
+               gtk_action_set_sensitive (action, !dimmed);
+}
+
+void
+modest_dimming_rule_set_group (ModestDimmingRule *rule,
+                              ModestDimmingRulesGroup *group)
+{
+       ModestDimmingRulePrivate *priv = NULL;
+
+       g_return_if_fail (MODEST_IS_DIMMING_RULE (rule));
+       g_return_if_fail (MODEST_IS_DIMMING_RULES_GROUP (group));
+       priv = MODEST_DIMMING_RULE_GET_PRIVATE(rule);
+
+       if (priv->group == group) 
+               return;
+       if (priv->group != NULL) 
+               g_object_unref (priv->group);
+       priv->group = g_object_ref (group);                     
+}      
+
+ModestDimmingRulesGroup *
+modest_dimming_rule_get_group (ModestDimmingRule *rule)
+{
+       ModestDimmingRulePrivate *priv = NULL;
+       
+       g_return_val_if_fail (MODEST_IS_DIMMING_RULE (rule), NULL);
+       priv = MODEST_DIMMING_RULE_GET_PRIVATE(rule);
+       g_return_val_if_fail (MODEST_IS_DIMMING_RULES_GROUP (priv->group), NULL);
+       
+       return g_object_ref(priv->group);
+}
+
+void
+modest_dimming_rule_set_notification (ModestDimmingRule *rule,
+                                     const gchar *notification)
+{
+       ModestDimmingRulePrivate *priv = NULL;
+
+       g_return_if_fail (MODEST_IS_DIMMING_RULE (rule));
+       priv = MODEST_DIMMING_RULE_GET_PRIVATE(rule);
+       
+       /* Free previous notification */
+       if (priv->notification != NULL) {
+               g_free(priv->notification);
+               priv->notification = NULL;
+       }
+
+       /* Set new notification message */
+       if (notification != NULL)
+               priv->notification = g_strdup(notification);
+}
+
+gchar *
+modest_dimming_rule_get_notification (ModestDimmingRule *rule)
+{
+       ModestDimmingRulePrivate *priv = NULL;
+
+       g_return_val_if_fail (MODEST_IS_DIMMING_RULE (rule), NULL);
+       priv = MODEST_DIMMING_RULE_GET_PRIVATE(rule);
+       
+       return g_strdup(priv->notification);
 }