/* The GIMP -- an image manipulation program * Copyright (C) 1995 Spencer Kimball and Peter Mattis * * gimpmenufactory.c * Copyright (C) 2001-2004 Michael Natterer * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * 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 "config.h" #include #include #include "libgimpwidgets/gimpwidgets.h" #include "widgets-types.h" #include "core/gimp.h" #include "gimpactionfactory.h" #include "gimpmenufactory.h" #include "gimpuimanager.h" static void gimp_menu_factory_finalize (GObject *object); G_DEFINE_TYPE (GimpMenuFactory, gimp_menu_factory, GIMP_TYPE_OBJECT) #define parent_class gimp_menu_factory_parent_class static void gimp_menu_factory_class_init (GimpMenuFactoryClass *klass) { GObjectClass *object_class = G_OBJECT_CLASS (klass); object_class->finalize = gimp_menu_factory_finalize; } static void gimp_menu_factory_init (GimpMenuFactory *factory) { factory->gimp = NULL; factory->registered_menus = NULL; } static void gimp_menu_factory_finalize (GObject *object) { GimpMenuFactory *factory = GIMP_MENU_FACTORY (object); GList *list; for (list = factory->registered_menus; list; list = g_list_next (list)) { GimpMenuFactoryEntry *entry = list->data; GList *uis; g_free (entry->identifier); g_list_foreach (entry->action_groups, (GFunc) g_free, NULL); g_list_free (entry->action_groups); for (uis = entry->managed_uis; uis; uis = g_list_next (uis)) { GimpUIManagerUIEntry *ui_entry = uis->data; g_free (ui_entry->ui_path); g_free (ui_entry->basename); g_free (ui_entry); } g_list_free (entry->managed_uis); g_free (entry); } g_list_free (factory->registered_menus); factory->registered_menus = NULL; G_OBJECT_CLASS (parent_class)->finalize (object); } GimpMenuFactory * gimp_menu_factory_new (Gimp *gimp, GimpActionFactory *action_factory) { GimpMenuFactory *factory; g_return_val_if_fail (GIMP_IS_GIMP (gimp), NULL); g_return_val_if_fail (GIMP_IS_ACTION_FACTORY (action_factory), NULL); factory = g_object_new (GIMP_TYPE_MENU_FACTORY, NULL); factory->gimp = gimp; factory->action_factory = action_factory; return factory; } void gimp_menu_factory_manager_register (GimpMenuFactory *factory, const gchar *identifier, const gchar *first_group, ...) { GimpMenuFactoryEntry *entry; const gchar *group; const gchar *ui_path; va_list args; g_return_if_fail (GIMP_IS_MENU_FACTORY (factory)); g_return_if_fail (identifier != NULL); g_return_if_fail (first_group != NULL); entry = g_new0 (GimpMenuFactoryEntry, 1); entry->identifier = g_strdup (identifier); factory->registered_menus = g_list_prepend (factory->registered_menus, entry); va_start (args, first_group); for (group = first_group; group; group = va_arg (args, const gchar *)) { entry->action_groups = g_list_prepend (entry->action_groups, g_strdup (group)); } entry->action_groups = g_list_reverse (entry->action_groups); ui_path = va_arg (args, const gchar *); while (ui_path) { const gchar *ui_basename; GimpUIManagerSetupFunc setup_func; GimpUIManagerUIEntry *ui_entry; ui_basename = va_arg (args, const gchar *); setup_func = va_arg (args, GimpUIManagerSetupFunc); ui_entry = g_new0 (GimpUIManagerUIEntry, 1); ui_entry->ui_path = g_strdup (ui_path); ui_entry->basename = g_strdup (ui_basename); ui_entry->setup_func = setup_func; entry->managed_uis = g_list_prepend (entry->managed_uis, ui_entry); ui_path = va_arg (args, const gchar *); } entry->managed_uis = g_list_reverse (entry->managed_uis); va_end (args); } GimpUIManager * gimp_menu_factory_manager_new (GimpMenuFactory *factory, const gchar *identifier, gpointer callback_data, gboolean create_tearoff) { GList *list; g_return_val_if_fail (GIMP_IS_MENU_FACTORY (factory), NULL); g_return_val_if_fail (identifier != NULL, NULL); for (list = factory->registered_menus; list; list = g_list_next (list)) { GimpMenuFactoryEntry *entry = list->data; if (! strcmp (entry->identifier, identifier)) { GimpUIManager *manager; GtkAccelGroup *accel_group; GList *list; manager = gimp_ui_manager_new (factory->gimp, entry->identifier); gtk_ui_manager_set_add_tearoffs (GTK_UI_MANAGER (manager), create_tearoff); accel_group = gtk_ui_manager_get_accel_group (GTK_UI_MANAGER (manager)); for (list = entry->action_groups; list; list = g_list_next (list)) { GimpActionGroup *group; GList *actions; GList *list2; group = gimp_action_factory_group_new (factory->action_factory, (const gchar *) list->data, callback_data); actions = gtk_action_group_list_actions (GTK_ACTION_GROUP (group)); for (list2 = actions; list2; list2 = g_list_next (list2)) { GtkAction *action = list2->data; gtk_action_set_accel_group (action, accel_group); gtk_action_connect_accelerator (action); } g_list_free (actions); gtk_ui_manager_insert_action_group (GTK_UI_MANAGER (manager), GTK_ACTION_GROUP (group), -1); g_object_unref (group); } for (list = entry->managed_uis; list; list = g_list_next (list)) { GimpUIManagerUIEntry *ui_entry = list->data; gimp_ui_manager_ui_register (manager, ui_entry->ui_path, ui_entry->basename, ui_entry->setup_func); } return manager; } } g_warning ("%s: no entry registered for \"%s\"", G_STRFUNC, identifier); return NULL; }