X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fmodest-dimming-rule.c;h=778f06d6461a7578543aef65508f1fe0c6cc617b;hp=884ccc76b3a4995b07d13c9602c5a9d5c625c7d9;hb=1ae76d480a98068ec23fb6fc6d231605302b809f;hpb=2da007966ea445b3574320d9c914c7475df64c59 diff --git a/src/modest-dimming-rule.c b/src/modest-dimming-rule.c index 884ccc7..778f06d 100644 --- a/src/modest-dimming-rule.c +++ b/src/modest-dimming-rule.c @@ -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); }