[gimp] app: implement gimp_get_mod_string() using gtk_accelerator_get_label()
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp] app: implement gimp_get_mod_string() using gtk_accelerator_get_label()
- Date: Tue, 4 Oct 2011 23:31:14 +0000 (UTC)
commit 3982ddc39b654d43ae010a718785015efbc12da2
Author: Michael Natterer <mitch gimp org>
Date: Wed Oct 5 01:28:45 2011 +0200
app: implement gimp_get_mod_string() using gtk_accelerator_get_label()
so it can handle all modifiers (also Mac ones).
Remove gimp_get_mod_name_shift,control,alt().
app/tools/gimpsourcetool.c | 2 +-
app/widgets/gimpwidgets-utils.c | 136 ++++++++++-----------------------------
app/widgets/gimpwidgets-utils.h | 3 -
3 files changed, 34 insertions(+), 107 deletions(-)
---
diff --git a/app/tools/gimpsourcetool.c b/app/tools/gimpsourcetool.c
index ddaa923..70b7ad4 100644
--- a/app/tools/gimpsourcetool.c
+++ b/app/tools/gimpsourcetool.c
@@ -320,7 +320,7 @@ gimp_source_tool_oper_update (GimpTool *tool,
else
{
gimp_tool_replace_status (tool, display, "%s%s%s",
- gimp_get_mod_name_control (),
+ gimp_get_mod_string (GDK_CONTROL_MASK),
gimp_get_mod_separator (),
source_tool->status_set_source);
}
diff --git a/app/widgets/gimpwidgets-utils.c b/app/widgets/gimpwidgets-utils.c
index 647ec5a..81db2b9 100644
--- a/app/widgets/gimpwidgets-utils.c
+++ b/app/widgets/gimpwidgets-utils.c
@@ -456,57 +456,6 @@ gimp_preview_tab_style_to_icon (GimpTabStyle tab_style)
}
const gchar *
-gimp_get_mod_name_shift (void)
-{
- static gchar *mod_name_shift = NULL;
-
- if (! mod_name_shift)
- {
- GtkAccelLabelClass *accel_label_class;
-
- accel_label_class = g_type_class_ref (GTK_TYPE_ACCEL_LABEL);
- mod_name_shift = g_strdup (accel_label_class->mod_name_shift);
- g_type_class_unref (accel_label_class);
- }
-
- return (const gchar *) mod_name_shift;
-}
-
-const gchar *
-gimp_get_mod_name_control (void)
-{
- static gchar *mod_name_control = NULL;
-
- if (! mod_name_control)
- {
- GtkAccelLabelClass *accel_label_class;
-
- accel_label_class = g_type_class_ref (GTK_TYPE_ACCEL_LABEL);
- mod_name_control = g_strdup (accel_label_class->mod_name_control);
- g_type_class_unref (accel_label_class);
- }
-
- return (const gchar *) mod_name_control;
-}
-
-const gchar *
-gimp_get_mod_name_alt (void)
-{
- static gchar *mod_name_alt = NULL;
-
- if (! mod_name_alt)
- {
- GtkAccelLabelClass *accel_label_class;
-
- accel_label_class = g_type_class_ref (GTK_TYPE_ACCEL_LABEL);
- mod_name_alt = g_strdup (accel_label_class->mod_name_alt);
- g_type_class_unref (accel_label_class);
- }
-
- return (const gchar *) mod_name_alt;
-}
-
-const gchar *
gimp_get_mod_separator (void)
{
static gchar *mod_separator = NULL;
@@ -526,61 +475,42 @@ gimp_get_mod_separator (void)
const gchar *
gimp_get_mod_string (GdkModifierType modifiers)
{
- static struct
- {
- GdkModifierType modifiers;
- gchar *name;
- }
- modifier_strings[] =
- {
- { GDK_SHIFT_MASK, NULL },
- { GDK_CONTROL_MASK, NULL },
- { GDK_MOD1_MASK, NULL },
- { GDK_SHIFT_MASK | GDK_CONTROL_MASK, NULL },
- { GDK_SHIFT_MASK | GDK_MOD1_MASK, NULL },
- { GDK_CONTROL_MASK | GDK_MOD1_MASK, NULL },
- { GDK_SHIFT_MASK | GDK_CONTROL_MASK | GDK_MOD1_MASK, NULL }
- };
-
- gint i;
-
- for (i = 0; i < G_N_ELEMENTS (modifier_strings); i++)
- {
- if (modifiers == modifier_strings[i].modifiers)
- {
- if (! modifier_strings[i].name)
- {
- GString *str = g_string_new (NULL);
+ static GHashTable *mod_labels;
- if (modifiers & GDK_SHIFT_MASK)
- {
- g_string_append (str, gimp_get_mod_name_shift ());
- }
+ GtkAccelLabelClass *accel_label_class;
+ gchar *label;
- if (modifiers & GDK_CONTROL_MASK)
- {
- if (str->len)
- g_string_append (str, gimp_get_mod_separator ());
+ if (! modifiers)
+ return NULL;
- g_string_append (str, gimp_get_mod_name_control ());
- }
+ if (G_UNLIKELY (! mod_labels))
+ mod_labels = g_hash_table_new (g_int_hash, g_int_equal);
- if (modifiers & GDK_MOD1_MASK)
- {
- if (str->len)
- g_string_append (str, gimp_get_mod_separator ());
+ label = g_hash_table_lookup (mod_labels, &modifiers);
- g_string_append (str, gimp_get_mod_name_alt ());
- }
+ if (label)
+ return label;
- modifier_strings[i].name = g_string_free (str, FALSE);
- }
+ label = gtk_accelerator_get_label (0, modifiers);
- return modifier_strings[i].name;
- }
+ accel_label_class = g_type_class_ref (GTK_TYPE_ACCEL_LABEL);
+
+ if (accel_label_class->mod_separator &&
+ strlen (accel_label_class->mod_separator))
+ {
+ gchar *sep = g_strrstr (label, accel_label_class->mod_separator);
+
+ if (sep - label == strlen (label) - strlen (accel_label_class->mod_separator))
+ *sep = '\0';
}
- return NULL;
+ g_type_class_unref (accel_label_class);
+
+ g_hash_table_insert (mod_labels,
+ g_memdup (&modifiers, sizeof (GdkModifierType)),
+ label);
+
+ return label;
}
#define BUF_SIZE 100
@@ -619,11 +549,11 @@ gimp_suggest_modifiers (const gchar *message,
if (shift_format && *shift_format)
{
g_snprintf (msg_buf[num_msgs], BUF_SIZE, shift_format,
- gimp_get_mod_name_shift ());
+ gimp_get_mod_string (GDK_SHIFT_MASK));
}
else
{
- g_strlcpy (msg_buf[num_msgs], gimp_get_mod_name_shift (), BUF_SIZE);
+ g_strlcpy (msg_buf[num_msgs], gimp_get_mod_string (GDK_SHIFT_MASK), BUF_SIZE);
try = TRUE;
}
@@ -635,11 +565,11 @@ gimp_suggest_modifiers (const gchar *message,
if (control_format && *control_format)
{
g_snprintf (msg_buf[num_msgs], BUF_SIZE, control_format,
- gimp_get_mod_name_control ());
+ gimp_get_mod_string (GDK_CONTROL_MASK));
}
else
{
- g_strlcpy (msg_buf[num_msgs], gimp_get_mod_name_control (), BUF_SIZE);
+ g_strlcpy (msg_buf[num_msgs], gimp_get_mod_string (GDK_CONTROL_MASK), BUF_SIZE);
try = TRUE;
}
@@ -651,11 +581,11 @@ gimp_suggest_modifiers (const gchar *message,
if (alt_format && *alt_format)
{
g_snprintf (msg_buf[num_msgs], BUF_SIZE, alt_format,
- gimp_get_mod_name_alt ());
+ gimp_get_mod_string (GDK_MOD1_MASK));
}
else
{
- g_strlcpy (msg_buf[num_msgs], gimp_get_mod_name_alt (), BUF_SIZE);
+ g_strlcpy (msg_buf[num_msgs], gimp_get_mod_string (GDK_MOD1_MASK), BUF_SIZE);
try = TRUE;
}
diff --git a/app/widgets/gimpwidgets-utils.h b/app/widgets/gimpwidgets-utils.h
index 8a2769c..fcfdbe2 100644
--- a/app/widgets/gimpwidgets-utils.h
+++ b/app/widgets/gimpwidgets-utils.h
@@ -50,9 +50,6 @@ GtkIconSize gimp_get_icon_size (GtkWidget *widget
gint width,
gint height);
GimpTabStyle gimp_preview_tab_style_to_icon (GimpTabStyle tab_style);
-const gchar * gimp_get_mod_name_shift (void);
-const gchar * gimp_get_mod_name_control (void);
-const gchar * gimp_get_mod_name_alt (void);
const gchar * gimp_get_mod_separator (void);
const gchar * gimp_get_mod_string (GdkModifierType modifiers);
gchar * gimp_suggest_modifiers (const gchar *message,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]