/* * Copyright (C) 2000, 2001 Ximian Inc. * * Authors: Not Zed * Jeffrey Stedfast * * This program is free software; you can redistribute it and/or * modify it under the terms of version 2 of the GNU General Public * License as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ #include #include #include #include #include #include #include #include #include #include "filter-editor.h" #include "filter-context.h" #include "filter-filter.h" #define d(x) static FilterRule * create_rule(RuleEditor *re); static void filter_editor_class_init (FilterEditorClass *class); static void filter_editor_init (FilterEditor *gspaper); static void filter_editor_finalise (GtkObject *obj); #define _PRIVATE(x) (((FilterEditor *)(x))->priv) struct _FilterEditorPrivate { }; static GnomeDialogClass *parent_class; enum { LAST_SIGNAL }; static guint signals[LAST_SIGNAL] = { 0 }; guint filter_editor_get_type (void) { static guint type = 0; if (!type) { GtkTypeInfo type_info = { "FilterEditor", sizeof(FilterEditor), sizeof(FilterEditorClass), (GtkClassInitFunc)filter_editor_class_init, (GtkObjectInitFunc)filter_editor_init, (GtkArgSetFunc)NULL, (GtkArgGetFunc)NULL }; type = gtk_type_unique (rule_editor_get_type (), &type_info); } return type; } static void filter_editor_class_init (FilterEditorClass *class) { GtkObjectClass *object_class = (GtkObjectClass *)class; RuleEditorClass *re_class = (RuleEditorClass *)class; parent_class = gtk_type_class (gnome_dialog_get_type ()); object_class->finalize = filter_editor_finalise; /* override methods */ re_class->create_rule = create_rule; /* signals */ gtk_object_class_add_signals (object_class, signals, LAST_SIGNAL); } static void filter_editor_init (FilterEditor *o) { o->priv = g_malloc0 (sizeof (*o->priv)); } static void filter_editor_finalise (GtkObject *obj) { FilterEditor *o = (FilterEditor *)obj; g_free(o->priv); ((GtkObjectClass *)(parent_class))->finalize (obj); } /** * filter_editor_new: * * Create a new FilterEditor object. * * Return value: A new #FilterEditor object. **/ FilterEditor * filter_editor_new(FilterContext *f, const char **source_names) { FilterEditor *o = (FilterEditor *)gtk_type_new (filter_editor_get_type ()); GladeXML *gui; GtkWidget *w; gui = glade_xml_new (FILTER_GLADEDIR "/filter.glade", "rule_editor"); filter_editor_construct (o, f, gui, source_names); w = glade_xml_get_widget (gui, "rule_frame"); gtk_frame_set_label (GTK_FRAME (w), _("Filter Rules")); gtk_object_unref (GTK_OBJECT (gui)); return o; } static void select_source (GtkMenuItem *mi, FilterEditor *fe) { char *source; source = gtk_object_get_data (GTK_OBJECT (mi), "source"); g_assert (source); rule_editor_set_source ((RuleEditor *)fe, source); } void filter_editor_construct (FilterEditor *fe, FilterContext *fc, GladeXML *gui, const char **source_names) { GtkWidget *menu, *item, *omenu; int i; omenu = glade_xml_get_widget (gui, "filter_source"); gtk_option_menu_remove_menu (GTK_OPTION_MENU (omenu)); menu = gtk_menu_new (); for (i = 0; source_names[i]; i++) { item = gtk_menu_item_new_with_label (_(source_names[i])); gtk_object_set_data_full (GTK_OBJECT (item), "source", g_strdup (source_names[i]), g_free); gtk_menu_append (GTK_MENU (menu), item); gtk_widget_show (item); gtk_signal_connect (GTK_OBJECT (item), "activate", select_source, fe); } gtk_option_menu_set_menu (GTK_OPTION_MENU (omenu), menu); gtk_widget_show (omenu); rule_editor_construct ((RuleEditor *)fe, (RuleContext *)fc, gui, source_names[0]); } static FilterRule * create_rule (RuleEditor *re) { FilterRule *rule = filter_rule_new (); FilterPart *part; /* create a rule with 1 part & 1 action in it */ rule = (FilterRule *)filter_filter_new (); part = rule_context_next_part (re->context, NULL); filter_rule_add_part (rule, filter_part_clone (part)); part = filter_context_next_action ((FilterContext *)re->context, NULL); filter_filter_add_action ((FilterFilter *)rule, filter_part_clone (part)); return rule; }