[gtk+] entry: Use qdata with preallocated quarks
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] entry: Use qdata with preallocated quarks
- Date: Wed, 23 Sep 2015 11:08:25 +0000 (UTC)
commit b1bf153c99bb3db866496f6afd4b3fc78b0099fb
Author: Matthias Clasen <mclasen redhat com>
Date: Sun Sep 20 00:04:30 2015 -0400
entry: Use qdata with preallocated quarks
gtk/gtkentry.c | 23 +++++++++++++----------
1 files changed, 13 insertions(+), 10 deletions(-)
---
diff --git a/gtk/gtkentry.c b/gtk/gtkentry.c
index 16462c1..ea0bd61 100644
--- a/gtk/gtkentry.c
+++ b/gtk/gtkentry.c
@@ -115,8 +115,6 @@
*/
-#define GTK_ENTRY_COMPLETION_KEY "gtk-entry-completion-key"
-
#define MIN_ENTRY_WIDTH 150
#define DRAW_TIMEOUT 20
#define PASSWORD_HINT_MAX 8
@@ -131,6 +129,8 @@ static GQuark quark_inner_border = 0;
static GQuark quark_password_hint = 0;
static GQuark quark_cursor_hadjustment = 0;
static GQuark quark_capslock_feedback = 0;
+static GQuark quark_gtk_signal = 0;
+static GQuark quark_entry_completion = 0;
typedef struct _EntryIconInfo EntryIconInfo;
typedef struct _GtkEntryPasswordHint GtkEntryPasswordHint;
@@ -763,6 +763,8 @@ gtk_entry_class_init (GtkEntryClass *class)
quark_password_hint = g_quark_from_static_string ("gtk-entry-password-hint");
quark_cursor_hadjustment = g_quark_from_static_string ("gtk-hadjustment");
quark_capslock_feedback = g_quark_from_static_string ("gtk-entry-capslock-feedback");
+ quark_gtk_signal = g_quark_from_static_string ("gtk-signal");
+ quark_entry_completion = g_quark_from_static_string ("gtk-entry-completion-key");
g_object_class_override_property (gobject_class,
PROP_EDITING_CANCELED,
@@ -9475,7 +9477,9 @@ static void
activate_cb (GtkWidget *menuitem,
GtkEntry *entry)
{
- const gchar *signal = g_object_get_data (G_OBJECT (menuitem), "gtk-signal");
+ const gchar *signal;
+
+ signal = g_object_get_qdata (G_OBJECT (menuitem), quark_gtk_signal);
g_signal_emit_by_name (entry, signal);
}
@@ -9526,7 +9530,7 @@ append_action_signal (GtkEntry *entry,
{
GtkWidget *menuitem = gtk_menu_item_new_with_mnemonic (label);
- g_object_set_data (G_OBJECT (menuitem), I_("gtk-signal"), (char *)signal);
+ g_object_set_qdata (G_OBJECT (menuitem), quark_gtk_signal, (char *)signal);
g_signal_connect (menuitem, "activate",
G_CALLBACK (activate_cb), entry);
@@ -9747,7 +9751,7 @@ activate_bubble_cb (GtkWidget *item,
{
const gchar *signal;
- signal = g_object_get_data (G_OBJECT (item), "gtk-signal");
+ signal = g_object_get_qdata (G_OBJECT (item), quark_gtk_signal);
gtk_widget_hide (entry->priv->selection_bubble);
if (strcmp (signal, "select-all") == 0)
gtk_entry_select_all (entry);
@@ -9772,7 +9776,7 @@ append_bubble_action (GtkEntry *entry,
gtk_container_add (GTK_CONTAINER (item), image);
gtk_widget_set_tooltip_text (item, label);
gtk_style_context_add_class (gtk_widget_get_style_context (item), "image-button");
- g_object_set_data (G_OBJECT (item), I_("gtk-signal"), (char *)signal);
+ g_object_set_qdata (G_OBJECT (item), quark_gtk_signal, (char *)signal);
g_signal_connect (item, "clicked", G_CALLBACK (activate_bubble_cb), entry);
gtk_widget_set_sensitive (GTK_WIDGET (item), sensitive);
gtk_widget_show (GTK_WIDGET (item));
@@ -10485,7 +10489,7 @@ gtk_entry_set_completion (GtkEntry *entry,
if (!completion)
{
- g_object_set_data (G_OBJECT (entry), I_(GTK_ENTRY_COMPLETION_KEY), NULL);
+ g_object_set_qdata (G_OBJECT (entry), quark_entry_completion, NULL);
return;
}
@@ -10494,7 +10498,7 @@ gtk_entry_set_completion (GtkEntry *entry,
_gtk_entry_completion_connect (completion, entry);
- g_object_set_data (G_OBJECT (entry), I_(GTK_ENTRY_COMPLETION_KEY), completion);
+ g_object_set_qdata (G_OBJECT (entry), quark_entry_completion, completion);
g_object_notify_by_pspec (G_OBJECT (entry), entry_props[PROP_COMPLETION]);
}
@@ -10517,8 +10521,7 @@ gtk_entry_get_completion (GtkEntry *entry)
g_return_val_if_fail (GTK_IS_ENTRY (entry), NULL);
- completion = GTK_ENTRY_COMPLETION (g_object_get_data (G_OBJECT (entry),
- GTK_ENTRY_COMPLETION_KEY));
+ completion = GTK_ENTRY_COMPLETION (g_object_get_qdata (G_OBJECT (entry), quark_entry_completion));
return completion;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]