[gimp] Bug 731279 - Tool Preset Editor not working correctly
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp] Bug 731279 - Tool Preset Editor not working correctly
- Date: Wed, 12 Oct 2016 21:52:51 +0000 (UTC)
commit 3d1c5641f79d65b2145fb22b6ddeed01fbd80c8b
Author: Michael Natterer <mitch gimp org>
Date: Wed Oct 12 23:51:24 2016 +0200
Bug 731279 - Tool Preset Editor not working correctly
Have "Save" and "Restore" buttons in both the tool preset list/grid
and the tool preset editor. The save button stores the active tool's
options in the preset, if possible.
app/actions/Makefile.am | 2 +
app/actions/tool-preset-editor-actions.c | 22 ++++++-
app/actions/tool-preset-editor-commands.c | 88 +++++++++++++++++++++++++++++
app/actions/tool-preset-editor-commands.h | 28 +++++++++
app/actions/tool-presets-actions.c | 8 +++
app/actions/tool-presets-commands.c | 42 ++++++++++++++
app/actions/tool-presets-commands.h | 2 +
app/widgets/gimphelp-ids.h | 2 +
app/widgets/gimptoolpreseteditor.c | 8 +++
app/widgets/gimptoolpresetfactoryview.c | 7 ++-
menus/tool-preset-editor-menu.xml | 3 +
menus/tool-presets-menu.xml | 1 +
po/POTFILES.in | 2 +
13 files changed, 211 insertions(+), 4 deletions(-)
---
diff --git a/app/actions/Makefile.am b/app/actions/Makefile.am
index b4c708d..1c144c0 100644
--- a/app/actions/Makefile.am
+++ b/app/actions/Makefile.am
@@ -172,6 +172,8 @@ libappactions_a_SOURCES = \
tool-presets-commands.h \
tool-preset-editor-actions.c \
tool-preset-editor-actions.h \
+ tool-preset-editor-commands.c \
+ tool-preset-editor-commands.h \
tools-actions.c \
tools-actions.h \
tools-commands.c \
diff --git a/app/actions/tool-preset-editor-actions.c b/app/actions/tool-preset-editor-actions.c
index 08b532b..0b9d12e 100644
--- a/app/actions/tool-preset-editor-actions.c
+++ b/app/actions/tool-preset-editor-actions.c
@@ -33,6 +33,7 @@
#include "data-editor-commands.h"
#include "tool-preset-editor-actions.h"
+#include "tool-preset-editor-commands.h"
#include "gimp-intl.h"
@@ -41,7 +42,20 @@ static const GimpActionEntry tool_preset_editor_actions[] =
{
{ "tool-preset-editor-popup", GIMP_STOCK_TOOL_PRESET,
NC_("tool-preset-editor-action", "Tool Preset Editor Menu"), NULL, NULL, NULL,
- GIMP_HELP_BRUSH_EDITOR_DIALOG }
+ GIMP_HELP_TOOL_PRESET_EDITOR_DIALOG },
+
+ { "tool-preset-editor-save", "document-save",
+ NC_("tool-preset-editor-action", "_Save Tool Options to Preset"), NULL,
+ NC_("tool-preset-editor-action", "Save the active tool options to this "
+ "tool preset"),
+ G_CALLBACK (tool_preset_editor_save_cmd_callback),
+ GIMP_HELP_TOOL_PRESET_SAVE },
+
+ { "tool-preset-editor-restore", "document-revert",
+ NC_("tool-preset-editor-action", "_Restore Tool Preset"), NULL,
+ NC_("tool-preset-editor-action", "Restore this tool preset"),
+ G_CALLBACK (tool_preset_editor_restore_cmd_callback),
+ GIMP_HELP_TOOL_PRESET_RESTORE }
};
@@ -51,7 +65,7 @@ static const GimpToggleActionEntry tool_preset_editor_toggle_actions[] =
NC_("tool-preset-editor-action", "Edit Active Tool Preset"), NULL, NULL,
G_CALLBACK (data_editor_edit_active_cmd_callback),
FALSE,
- GIMP_HELP_BRUSH_EDITOR_EDIT_ACTIVE }
+ GIMP_HELP_TOOL_PRESET_EDITOR_EDIT_ACTIVE }
};
@@ -82,7 +96,9 @@ tool_preset_editor_actions_update (GimpActionGroup *group,
#define SET_ACTIVE(action,condition) \
gimp_action_group_set_action_active (group, action, (condition) != 0)
- SET_ACTIVE ("tool-preset-editor-edit-active", edit_active);
+ SET_SENSITIVE ("tool-preset-editor-save", data_editor->data);
+ SET_SENSITIVE ("tool-preset-editor-restore", data_editor->data);
+ SET_ACTIVE ("tool-preset-editor-edit-active", edit_active);
#undef SET_SENSITIVE
#undef SET_ACTIVE
diff --git a/app/actions/tool-preset-editor-commands.c b/app/actions/tool-preset-editor-commands.c
new file mode 100644
index 0000000..21a7c05
--- /dev/null
+++ b/app/actions/tool-preset-editor-commands.c
@@ -0,0 +1,88 @@
+/* GIMP - The GNU Image Manipulation Program
+ * Copyright (C) 1995 Spencer Kimball and Peter Mattis
+ *
+ * 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 3 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "config.h"
+
+#include <gegl.h>
+#include <gtk/gtk.h>
+
+#include "libgimpconfig/gimpconfig.h"
+#include "libgimpwidgets/gimpwidgets.h"
+
+#include "actions-types.h"
+
+#include "core/gimp.h"
+#include "core/gimpcontext.h"
+#include "core/gimptoolinfo.h"
+#include "core/gimptoolpreset.h"
+
+#include "widgets/gimpdataeditor.h"
+
+#include "tool-preset-editor-commands.h"
+
+#include "gimp-intl.h"
+
+
+/* public functions */
+
+void
+tool_preset_editor_save_cmd_callback (GtkAction *action,
+ gpointer data)
+{
+ GimpDataEditor *editor = GIMP_DATA_EDITOR (data);
+ GimpContext *context = editor->context;
+ GimpToolPreset *preset;
+ GimpToolInfo *tool_info;
+
+ preset = GIMP_TOOL_PRESET (gimp_data_editor_get_data (editor));
+ tool_info = gimp_context_get_tool (gimp_get_user_context (context->gimp));
+
+ if (tool_info && preset)
+ {
+ GimpToolInfo *preset_tool;
+
+ preset_tool = gimp_context_get_tool (GIMP_CONTEXT (preset->tool_options));
+
+ if (tool_info != preset_tool)
+ {
+ gimp_message (context->gimp,
+ G_OBJECT (editor), GIMP_MESSAGE_WARNING,
+ _("Can't save '%s' tool options to an "
+ "existing '%s' tool preset."),
+ tool_info->blurb,
+ preset_tool->blurb);
+ return;
+ }
+
+ gimp_config_sync (G_OBJECT (tool_info->tool_options),
+ G_OBJECT (preset->tool_options), 0);
+ }
+}
+
+void
+tool_preset_editor_restore_cmd_callback (GtkAction *action,
+ gpointer data)
+{
+ GimpDataEditor *editor = GIMP_DATA_EDITOR (data);
+ GimpContext *context = editor->context;
+ GimpToolPreset *preset;
+
+ preset = GIMP_TOOL_PRESET (gimp_data_editor_get_data (editor));
+
+ if (preset)
+ gimp_context_tool_preset_changed (context);
+}
diff --git a/app/actions/tool-preset-editor-commands.h b/app/actions/tool-preset-editor-commands.h
new file mode 100644
index 0000000..324c31c
--- /dev/null
+++ b/app/actions/tool-preset-editor-commands.h
@@ -0,0 +1,28 @@
+/* GIMP - The GNU Image Manipulation Program
+ * Copyright (C) 1995 Spencer Kimball and Peter Mattis
+ *
+ * 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 3 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __TOOL_PRESET_EDITOR_COMMANDS_H__
+#define __TOOL_PRESET_EDITOR_COMMANDS_H__
+
+
+void tool_preset_editor_save_cmd_callback (GtkAction *action,
+ gpointer data);
+void tool_preset_editor_restore_cmd_callback (GtkAction *action,
+ gpointer data);
+
+
+#endif /* __TOOL_PRESET_EDITOR_COMMANDS_H__ */
diff --git a/app/actions/tool-presets-actions.c b/app/actions/tool-presets-actions.c
index 8b20dcb..4870955 100644
--- a/app/actions/tool-presets-actions.c
+++ b/app/actions/tool-presets-actions.c
@@ -70,6 +70,13 @@ static const GimpActionEntry tool_presets_actions[] =
G_CALLBACK (data_show_in_file_manager_cmd_callback),
GIMP_HELP_TOOL_PRESET_SHOW_IN_FILE_MANAGER },
+ { "tool-presets-save", "document-save",
+ NC_("tool-presets-action", "_Save Tool Options to Preset"), NULL,
+ NC_("tool-presets-action", "Save the active tool options to this "
+ "tool preset"),
+ G_CALLBACK (tool_presets_save_cmd_callback),
+ GIMP_HELP_TOOL_PRESET_SAVE },
+
{ "tool-presets-restore", "document-revert",
NC_("tool-presets-action", "_Restore Tool Preset"), NULL,
NC_("tool-presets-action", "Restore this tool preset"),
@@ -140,6 +147,7 @@ tool_presets_actions_update (GimpActionGroup *group,
SET_SENSITIVE ("tool-presets-duplicate", tool_preset && GIMP_DATA_GET_CLASS (data)->duplicate);
SET_SENSITIVE ("tool-presets-copy-location", file);
SET_SENSITIVE ("tool-presets-show-in-file-manager", file);
+ SET_SENSITIVE ("tool-presets-save", tool_preset);
SET_SENSITIVE ("tool-presets-restore", tool_preset);
SET_SENSITIVE ("tool-presets-delete", tool_preset && gimp_data_is_deletable (data));
diff --git a/app/actions/tool-presets-commands.c b/app/actions/tool-presets-commands.c
index 7ac7dec..816d227 100644
--- a/app/actions/tool-presets-commands.c
+++ b/app/actions/tool-presets-commands.c
@@ -20,21 +20,63 @@
#include <gegl.h>
#include <gtk/gtk.h>
+#include "libgimpconfig/gimpconfig.h"
#include "libgimpwidgets/gimpwidgets.h"
#include "actions-types.h"
+#include "core/gimp.h"
#include "core/gimpcontext.h"
+#include "core/gimptoolinfo.h"
+#include "core/gimptoolpreset.h"
#include "widgets/gimpcontainereditor.h"
#include "widgets/gimpcontainerview.h"
#include "tool-presets-commands.h"
+#include "gimp-intl.h"
+
/* public functions */
void
+tool_presets_save_cmd_callback (GtkAction *action,
+ gpointer data)
+{
+ GimpContainerEditor *editor = GIMP_CONTAINER_EDITOR (data);
+ GimpContext *context;
+ GimpToolPreset *preset;
+ GimpToolInfo *tool_info;
+
+ context = gimp_container_view_get_context (editor->view);
+
+ preset = gimp_context_get_tool_preset (context);
+ tool_info = gimp_context_get_tool (gimp_get_user_context (context->gimp));
+
+ if (tool_info && preset)
+ {
+ GimpToolInfo *preset_tool;
+
+ preset_tool = gimp_context_get_tool (GIMP_CONTEXT (preset->tool_options));
+
+ if (tool_info != preset_tool)
+ {
+ gimp_message (context->gimp,
+ G_OBJECT (editor), GIMP_MESSAGE_WARNING,
+ _("Can't save '%s' tool options to an "
+ "existing '%s' tool preset."),
+ tool_info->blurb,
+ preset_tool->blurb);
+ return;
+ }
+
+ gimp_config_sync (G_OBJECT (tool_info->tool_options),
+ G_OBJECT (preset->tool_options), 0);
+ }
+}
+
+void
tool_presets_restore_cmd_callback (GtkAction *action,
gpointer data)
{
diff --git a/app/actions/tool-presets-commands.h b/app/actions/tool-presets-commands.h
index e985931..3fd0548 100644
--- a/app/actions/tool-presets-commands.h
+++ b/app/actions/tool-presets-commands.h
@@ -19,6 +19,8 @@
#define __TOOL_PRESETS_COMMANDS_H__
+void tool_presets_save_cmd_callback (GtkAction *action,
+ gpointer data);
void tool_presets_restore_cmd_callback (GtkAction *action,
gpointer data);
diff --git a/app/widgets/gimphelp-ids.h b/app/widgets/gimphelp-ids.h
index 58233e9..8bfa8c0 100644
--- a/app/widgets/gimphelp-ids.h
+++ b/app/widgets/gimphelp-ids.h
@@ -352,6 +352,7 @@
#define GIMP_HELP_DYNAMICS_EDITOR_DIALOG "gimp-dynamics-editor-dialog"
#define GIMP_HELP_TOOL_PRESET_EDITOR_DIALOG "gimp-tool-preset-editor-dialog"
+#define GIMP_HELP_TOOL_PRESET_EDITOR_EDIT_ACTIVE "gimp-tool-preset-editor-edit-active"
#define GIMP_HELP_DYNAMICS_DIALOG "gimp-dynamics-dialog"
#define GIMP_HELP_DYNAMICS_EDIT "gimp-dynamics-edit"
@@ -452,6 +453,7 @@
#define GIMP_HELP_TOOL_PRESET_DUPLICATE "gimp-tool-preset-duplicate"
#define GIMP_HELP_TOOL_PRESET_COPY_LOCATION "gimp-tool-preset-copy-location"
#define GIMP_HELP_TOOL_PRESET_SHOW_IN_FILE_MANAGER "gimp-tool-preset-show-in-file-manager"
+#define GIMP_HELP_TOOL_PRESET_SAVE "gimp-tool-preset-save"
#define GIMP_HELP_TOOL_PRESET_RESTORE "gimp-tool-preset-restore"
#define GIMP_HELP_TOOL_PRESET_DELETE "gimp-tool-preset-delete"
#define GIMP_HELP_TOOL_PRESET_REFRESH "gimp-tool-preset-refresh"
diff --git a/app/widgets/gimptoolpreseteditor.c b/app/widgets/gimptoolpreseteditor.c
index 9321801..d8082ff 100644
--- a/app/widgets/gimptoolpreseteditor.c
+++ b/app/widgets/gimptoolpreseteditor.c
@@ -195,6 +195,14 @@ gimp_tool_preset_editor_constructed (GObject *object)
gtk_box_pack_start (GTK_BOX (data_editor), button, FALSE, FALSE, 0);
gtk_widget_show (button);
+ button = gimp_editor_add_action_button (GIMP_EDITOR (editor),
+ "tool-preset-editor",
+ "tool-preset-editor-save", NULL);
+
+ button = gimp_editor_add_action_button (GIMP_EDITOR (editor),
+ "tool-preset-editor",
+ "tool-preset-editor-restore", NULL);
+
if (data_editor->data)
gimp_tool_preset_editor_sync_data (editor);
}
diff --git a/app/widgets/gimptoolpresetfactoryview.c b/app/widgets/gimptoolpresetfactoryview.c
index d549f33..8ccc39c 100644
--- a/app/widgets/gimptoolpresetfactoryview.c
+++ b/app/widgets/gimptoolpresetfactoryview.c
@@ -90,9 +90,14 @@ gimp_tool_preset_factory_view_new (GimpViewType view_type,
editor = GIMP_EDITOR (GIMP_CONTAINER_EDITOR (factory_view)->view);
button = gimp_editor_add_action_button (editor, "tool-presets",
- "tool-presets-restore", NULL);
+ "tool-presets-save", NULL);
gtk_box_reorder_child (gimp_editor_get_button_box (editor),
button, 2);
+ button = gimp_editor_add_action_button (editor, "tool-presets",
+ "tool-presets-restore", NULL);
+ gtk_box_reorder_child (gimp_editor_get_button_box (editor),
+ button, 3);
+
return GTK_WIDGET (factory_view);
}
diff --git a/menus/tool-preset-editor-menu.xml b/menus/tool-preset-editor-menu.xml
index b4a8ee0..6bb744b 100644
--- a/menus/tool-preset-editor-menu.xml
+++ b/menus/tool-preset-editor-menu.xml
@@ -3,6 +3,9 @@
<ui>
<popup action="tool-preset-editor-popup">
+ <menuitem action="tool-preset-editor-save" />
+ <menuitem action="tool-preset-editor-restore" />
+ <separator />
<menuitem action="tool-preset-editor-edit-active" />
</popup>
</ui>
diff --git a/menus/tool-presets-menu.xml b/menus/tool-presets-menu.xml
index 7e17c53..585ebd0 100644
--- a/menus/tool-presets-menu.xml
+++ b/menus/tool-presets-menu.xml
@@ -9,6 +9,7 @@
<menuitem action="tool-presets-duplicate" />
<menuitem action="tool-presets-copy-location" />
<menuitem action="tool-presets-show-in-file-manager" />
+ <menuitem action="tool-presets-save" />
<menuitem action="tool-presets-restore" />
<menuitem action="tool-presets-delete" />
<separator />
diff --git a/po/POTFILES.in b/po/POTFILES.in
index 419a2f2..1c327f2 100644
--- a/po/POTFILES.in
+++ b/po/POTFILES.in
@@ -76,7 +76,9 @@ app/actions/text-tool-commands.c
app/actions/tool-options-actions.c
app/actions/tool-options-commands.c
app/actions/tool-preset-editor-actions.c
+app/actions/tool-preset-editor-commands.c
app/actions/tool-presets-actions.c
+app/actions/tool-presets-commands.c
app/actions/tools-actions.c
app/actions/vectors-actions.c
app/actions/vectors-commands.c
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]