aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--filter/ChangeLog5
-rw-r--r--filter/filter-rule.c5
-rw-r--r--filter/rule-context.c22
-rw-r--r--filter/rule-editor.c5
4 files changed, 24 insertions, 13 deletions
diff --git a/filter/ChangeLog b/filter/ChangeLog
index f8b925c390..353ca7bdd8 100644
--- a/filter/ChangeLog
+++ b/filter/ChangeLog
@@ -1,3 +1,8 @@
+2001-03-21 Jeffrey Stedfast <fejj@ximian.com>
+
+ * rule-context.c (new_rule_clicked): Validate the rule before
+ closing.
+
2001-03-20 Jeffrey Stedfast <fejj@ximian.com>
* rule-editor.c (rule_edit): Set the editor dialog modal rather
diff --git a/filter/filter-rule.c b/filter/filter-rule.c
index e63e7df5fd..44dbeb0b1a 100644
--- a/filter/filter-rule.c
+++ b/filter/filter-rule.c
@@ -176,7 +176,8 @@ filter_rule_set_source (FilterRule *fr, const char *source)
fr->source = g_strdup (source);
}
-int filter_rule_validate (FilterRule *fr)
+int
+filter_rule_validate (FilterRule *fr)
{
g_assert(IS_FILTER_RULE(fr));
@@ -184,7 +185,7 @@ int filter_rule_validate (FilterRule *fr)
}
static int
-validate(FilterRule *fr)
+validate (FilterRule *fr)
{
int valid = TRUE;
GList *parts;
diff --git a/filter/rule-context.c b/filter/rule-context.c
index 386e2cb7ab..1133bc1f63 100644
--- a/filter/rule-context.c
+++ b/filter/rule-context.c
@@ -363,23 +363,29 @@ rule_context_add_rule(RuleContext * f, FilterRule * new)
}
static void
-new_rule_clicked(GtkWidget * w, int button, RuleContext * context)
+new_rule_clicked (GtkWidget *dialog, int button, RuleContext *context)
{
#ifndef NO_WARNINGS
#warning "Need a changed signal for this to work best"
#endif
if (button == 0) {
- FilterRule *rule = gtk_object_get_data((GtkObject *) w, "rule");
- char *user = gtk_object_get_data((GtkObject *) w, "path");
-
- gtk_object_ref((GtkObject *) rule);
- rule_context_add_rule(context, rule);
+ FilterRule *rule = gtk_object_get_data (GTK_OBJECT (dialog), "rule");
+ char *user = gtk_object_get_data (GTK_OBJECT (dialog), "path");
+
+ if (!filter_rule_validate (rule)) {
+ /* no need to popup a dialog because the validate code does that. */
+ return;
+ }
+
+ gtk_object_ref (GTK_OBJECT (rule));
+ rule_context_add_rule (context, rule);
if (user) {
- rule_context_save((RuleContext *) context, user);
+ rule_context_save ((RuleContext *) context, user);
}
}
+
if (button != -1) {
- gnome_dialog_close((GnomeDialog *) w);
+ gnome_dialog_close (GNOME_DIALOG (dialog));
}
}
diff --git a/filter/rule-editor.c b/filter/rule-editor.c
index 0098f959e9..4826cdf01c 100644
--- a/filter/rule-editor.c
+++ b/filter/rule-editor.c
@@ -190,7 +190,7 @@ add_editor_clicked (GtkWidget *dialog, int button, RuleEditor *re)
switch (button) {
case 0:
if (!filter_rule_validate (re->edit)) {
- /* FIXME: popup an error or somelthing? */
+ /* no need to popup a dialog because the validate code does that. */
return;
}
@@ -255,7 +255,7 @@ edit_editor_clicked (GtkWidget *dialog, int button, RuleEditor *re)
switch (button) {
case 0:
if (!filter_rule_validate (re->edit)) {
- /* FIXME: popup an error or something? */
+ /* no need to popup a dialog because the validate code does that. */
return;
}
@@ -471,4 +471,3 @@ rule_editor_construct(RuleEditor *re, RuleContext *context, GladeXML *gui, const
gnome_dialog_append_buttons((GnomeDialog *)re, GNOME_STOCK_BUTTON_OK, GNOME_STOCK_BUTTON_CANCEL, 0);
}
-