[gimp/goat-invasion: 365/526] app: add a ton of parameters to GimpImageMapTool::get_settings_ui()
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/goat-invasion: 365/526] app: add a ton of parameters to GimpImageMapTool::get_settings_ui()
- Date: Sun, 22 Apr 2012 13:29:56 +0000 (UTC)
commit 7c48153d7079fd75684fa3737c511f6c5d7f88b3
Author: Michael Natterer <mitch gimp org>
Date: Sat Mar 31 22:33:43 2012 +0200
app: add a ton of parameters to GimpImageMapTool::get_settings_ui()
so they can be passed in instead of being looked up in the class
struct, which enables freely configuring the settings stuff from
subclasses, such as soon GimpOperationTool.
app/tools/gimpimagemaptool-settings.c | 42 +++++++++++++-------------------
app/tools/gimpimagemaptool-settings.h | 6 ++++
app/tools/gimpimagemaptool.c | 28 ++++++++++++++++++----
app/tools/gimpimagemaptool.h | 6 ++++
4 files changed, 52 insertions(+), 30 deletions(-)
---
diff --git a/app/tools/gimpimagemaptool-settings.c b/app/tools/gimpimagemaptool-settings.c
index 1b59c62..b4c3320 100644
--- a/app/tools/gimpimagemaptool-settings.c
+++ b/app/tools/gimpimagemaptool-settings.c
@@ -60,21 +60,19 @@ static gboolean gimp_image_map_tool_settings_export (GimpSettingsBox *box,
GtkWidget *
gimp_image_map_tool_real_get_settings_ui (GimpImageMapTool *image_map_tool,
+ GimpContainer *settings,
+ const gchar *settings_filename,
+ const gchar *import_dialog_title,
+ const gchar *export_dialog_title,
+ const gchar *file_dialog_help_id,
+ const gchar *default_folder,
GtkWidget **settings_box)
{
- GimpImageMapToolClass *klass;
- GimpToolInfo *tool_info;
- GtkSizeGroup *label_group;
- GtkWidget *hbox;
- GtkWidget *label;
- GtkWidget *settings_combo;
- gchar *filename;
- gchar *folder;
-
- klass = GIMP_IMAGE_MAP_TOOL_GET_CLASS (image_map_tool);
-
- if (! klass->settings_name)
- return NULL;
+ GimpToolInfo *tool_info;
+ GtkSizeGroup *label_group;
+ GtkWidget *hbox;
+ GtkWidget *label;
+ GtkWidget *settings_combo;
tool_info = GIMP_TOOL (image_map_tool)->tool_info;
@@ -87,24 +85,18 @@ gimp_image_map_tool_real_get_settings_ui (GimpImageMapTool *image_map_tool,
gtk_size_group_add_widget (label_group, label);
gtk_widget_show (label);
- filename = gimp_tool_info_build_options_filename (tool_info, ".settings");
- folder = g_build_filename (gimp_directory (), klass->settings_name, NULL);
-
*settings_box = gimp_settings_box_new (tool_info->gimp,
image_map_tool->config,
- klass->recent_settings,
- filename,
- klass->import_dialog_title,
- klass->export_dialog_title,
- tool_info->help_id,
- folder,
+ settings,
+ settings_filename,
+ import_dialog_title,
+ export_dialog_title,
+ file_dialog_help_id,
+ default_folder,
NULL);
gtk_box_pack_start (GTK_BOX (hbox), *settings_box, TRUE, TRUE, 0);
gtk_widget_show (*settings_box);
- g_free (filename);
- g_free (folder);
-
settings_combo = gimp_settings_box_get_combo (GIMP_SETTINGS_BOX (*settings_box));
gtk_label_set_mnemonic_widget (GTK_LABEL (label), settings_combo);
diff --git a/app/tools/gimpimagemaptool-settings.h b/app/tools/gimpimagemaptool-settings.h
index 94cdccc..825c396 100644
--- a/app/tools/gimpimagemaptool-settings.h
+++ b/app/tools/gimpimagemaptool-settings.h
@@ -22,6 +22,12 @@
GtkWidget * gimp_image_map_tool_real_get_settings_ui (GimpImageMapTool *tool,
+ GimpContainer *settings,
+ const gchar *settings_filename,
+ const gchar *import_dialog_title,
+ const gchar *export_dialog_title,
+ const gchar *file_dialog_help_id,
+ const gchar *default_folder,
GtkWidget **settings_box);
gboolean gimp_image_map_tool_real_settings_import (GimpImageMapTool *tool,
const gchar *filename,
diff --git a/app/tools/gimpimagemaptool.c b/app/tools/gimpimagemaptool.c
index 8ecce5d..8c38124 100644
--- a/app/tools/gimpimagemaptool.c
+++ b/app/tools/gimpimagemaptool.c
@@ -297,7 +297,6 @@ gimp_image_map_tool_initialize (GimpTool *tool,
GtkWidget *dialog;
GtkWidget *vbox;
GtkWidget *toggle;
- GtkWidget *settings_ui;
klass = GIMP_IMAGE_MAP_TOOL_GET_CLASS (image_map_tool);
@@ -355,11 +354,30 @@ gimp_image_map_tool_initialize (GimpTool *tool,
G_CALLBACK (gimp_image_map_tool_response),
G_OBJECT (image_map_tool), 0);
- settings_ui = klass->get_settings_ui (image_map_tool,
- &image_map_tool->settings_box);
-
- if (settings_ui)
+ if (klass->settings_name)
{
+ GtkWidget *settings_ui;
+ gchar *settings_filename;
+ gchar *default_folder;
+
+ settings_filename =
+ gimp_tool_info_build_options_filename (tool_info, ".settings");
+
+ default_folder =
+ g_build_filename (gimp_directory (), klass->settings_name, NULL);
+
+ settings_ui = klass->get_settings_ui (image_map_tool,
+ klass->recent_settings,
+ settings_filename,
+ klass->import_dialog_title,
+ klass->export_dialog_title,
+ tool_info->help_id,
+ default_folder,
+ &image_map_tool->settings_box);
+
+ g_free (settings_filename);
+ g_free (default_folder);
+
gtk_box_pack_start (GTK_BOX (image_map_tool->main_vbox), settings_ui,
FALSE, FALSE, 0);
gtk_widget_show (settings_ui);
diff --git a/app/tools/gimpimagemaptool.h b/app/tools/gimpimagemaptool.h
index 62d8752..6b9d540 100644
--- a/app/tools/gimpimagemaptool.h
+++ b/app/tools/gimpimagemaptool.h
@@ -73,6 +73,12 @@ struct _GimpImageMapToolClass
void (* reset) (GimpImageMapTool *image_map_tool);
GtkWidget * (* get_settings_ui) (GimpImageMapTool *image_map_tool,
+ GimpContainer *settings,
+ const gchar *settings_filename,
+ const gchar *import_dialog_title,
+ const gchar *export_dialog_title,
+ const gchar *file_dialog_help_id,
+ const gchar *default_folder,
GtkWidget **settings_box);
gboolean (* settings_import) (GimpImageMapTool *image_map_tool,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]