summaryrefslogtreecommitdiff
path: root/gobject
diff options
context:
space:
mode:
authorPhilip Withnall <withnall@endlessm.com>2019-11-12 17:38:44 +0000
committerPhilip Withnall <withnall@endlessm.com>2019-11-15 11:06:14 +0000
commit90b51805b7f200b0b8de34c0e9794e869ae5bb69 (patch)
treee8572be2f749d194d15cee1995323d568ca79d72 /gobject
parentb8eb6025f1ea1d92b94f21ec2e6f45c64782acb0 (diff)
downloadglib-90b51805b7f200b0b8de34c0e9794e869ae5bb69.tar.gz
gsignal: Fold g_quark_try_string() call into signal_id_lookup()
This eliminates a call from every call site of signal_id_lookup(). It introduces no functional changes, but allows subsequent refactoring. Signed-off-by: Philip Withnall <withnall@endlessm.com>
Diffstat (limited to 'gobject')
-rw-r--r--gobject/gsignal.c20
1 files changed, 11 insertions, 9 deletions
diff --git a/gobject/gsignal.c b/gobject/gsignal.c
index 4a8996db1..6b6966dbd 100644
--- a/gobject/gsignal.c
+++ b/gobject/gsignal.c
@@ -145,8 +145,8 @@ typedef enum
/* --- prototypes --- */
-static inline guint signal_id_lookup (GQuark quark,
- GType itype);
+static inline guint signal_id_lookup (const gchar *name,
+ GType itype);
static void signal_destroy_R (SignalNode *signal_node);
static inline HandlerList* handler_list_ensure (guint signal_id,
gpointer instance);
@@ -341,13 +341,15 @@ LOOKUP_SIGNAL_NODE (guint signal_id)
/* --- functions --- */
static inline guint
-signal_id_lookup (GQuark quark,
- GType itype)
+signal_id_lookup (const gchar *name,
+ GType itype)
{
+ GQuark quark;
GType *ifaces, type = itype;
SignalKey key;
guint n_ifaces;
+ quark = g_quark_try_string (name);
key.quark = quark;
/* try looking up signals for this type and its ancestors */
@@ -1080,7 +1082,7 @@ signal_parse_name (const gchar *name,
if (!colon)
{
- signal_id = signal_id_lookup (g_quark_try_string (name), itype);
+ signal_id = signal_id_lookup (name, itype);
if (signal_id && detail_p)
*detail_p = 0;
}
@@ -1093,7 +1095,7 @@ signal_parse_name (const gchar *name,
{
memcpy (buffer, name, l);
buffer[l] = 0;
- signal_id = signal_id_lookup (g_quark_try_string (buffer), itype);
+ signal_id = signal_id_lookup (buffer, itype);
}
else
{
@@ -1101,7 +1103,7 @@ signal_parse_name (const gchar *name,
memcpy (signal, name, l);
signal[l] = 0;
- signal_id = signal_id_lookup (g_quark_try_string (signal), itype);
+ signal_id = signal_id_lookup (signal, itype);
g_free (signal);
}
@@ -1241,7 +1243,7 @@ g_signal_lookup (const gchar *name,
g_return_val_if_fail (G_TYPE_IS_INSTANTIATABLE (itype) || G_TYPE_IS_INTERFACE (itype), 0);
SIGNAL_LOCK ();
- signal_id = signal_id_lookup (g_quark_try_string (name), itype);
+ signal_id = signal_id_lookup (name, itype);
SIGNAL_UNLOCK ();
if (!signal_id)
{
@@ -1658,7 +1660,7 @@ g_signal_newv (const gchar *signal_name,
SIGNAL_LOCK ();
- signal_id = signal_id_lookup (g_quark_try_string (name), itype);
+ signal_id = signal_id_lookup (name, itype);
node = LOOKUP_SIGNAL_NODE (signal_id);
if (node && !node->destroyed)
{