summaryrefslogtreecommitdiff
path: root/glib
diff options
context:
space:
mode:
authorTim Janik <timj@gtk.org>2000-02-03 20:43:00 +0000
committerTim Janik <timj@src.gnome.org>2000-02-03 20:43:00 +0000
commitbbb532d59ca7a65cb4e879877b193b66dd539a2c (patch)
tree7141a5ed64dd3a7b789563ef1106b15421cc1b1f /glib
parentc22cf34e923b81962da554c8edeb9366f044ae8c (diff)
downloadglib-bbb532d59ca7a65cb4e879877b193b66dd539a2c.tar.gz
return stolen data from g_datalist_id_remove_no_notify() and
Fri Feb 4 19:36:05 2000 Tim Janik <timj@gtk.org> * glib.h: * gdataset.c: return stolen data from g_datalist_id_remove_no_notify() and g_dataset_id_remove_no_notify() to avoid second lookup for common use.
Diffstat (limited to 'glib')
-rw-r--r--glib/gdataset.c34
-rw-r--r--glib/glib.h4
2 files changed, 26 insertions, 12 deletions
diff --git a/glib/gdataset.c b/glib/gdataset.c
index 2aa4032ab..e95301652 100644
--- a/glib/gdataset.c
+++ b/glib/gdataset.c
@@ -64,7 +64,7 @@ struct _GDataset
static inline GDataset* g_dataset_lookup (gconstpointer dataset_location);
static inline void g_datalist_clear_i (GData **datalist);
static void g_dataset_destroy_internal (GDataset *dataset);
-static inline void g_data_set_internal (GData **datalist,
+static inline gpointer g_data_set_internal (GData **datalist,
GQuark key_id,
gpointer data,
GDestroyNotify destroy_func,
@@ -198,7 +198,7 @@ g_dataset_destroy (gconstpointer dataset_location)
}
/* HOLDS: g_dataset_global_lock */
-static inline void
+static inline gpointer
g_data_set_internal (GData **datalist,
GQuark key_id,
gpointer data,
@@ -217,6 +217,8 @@ g_data_set_internal (GData **datalist,
{
if (list->id == key_id)
{
+ gpointer ret_data = NULL;
+
if (prev)
prev->next = list->next;
else
@@ -242,6 +244,8 @@ g_data_set_internal (GData **datalist,
list->destroy_func (list->data);
G_LOCK (g_dataset_global);
}
+ else
+ ret_data = list->data;
if (g_data_cache_length < G_DATA_CACHE_MAX)
{
@@ -252,7 +256,7 @@ g_data_set_internal (GData **datalist,
else
g_mem_chunk_free (g_data_mem_chunk, list);
- return;
+ return ret_data;
}
prev = list;
@@ -288,7 +292,7 @@ g_data_set_internal (GData **datalist,
G_LOCK (g_dataset_global);
}
- return;
+ return NULL;
}
list = list->next;
@@ -308,6 +312,8 @@ g_data_set_internal (GData **datalist,
list->destroy_func = destroy_func;
*datalist = list;
}
+
+ return NULL;
}
void
@@ -373,11 +379,13 @@ g_datalist_id_set_data_full (GData **datalist,
G_UNLOCK (g_dataset_global);
}
-void
+gpointer
g_dataset_id_remove_no_notify (gconstpointer dataset_location,
GQuark key_id)
{
- g_return_if_fail (dataset_location != NULL);
+ gpointer ret_data = NULL;
+
+ g_return_val_if_fail (dataset_location != NULL, NULL);
G_LOCK (g_dataset_global);
if (key_id && g_dataset_location_ht)
@@ -386,21 +394,27 @@ g_dataset_id_remove_no_notify (gconstpointer dataset_location,
dataset = g_dataset_lookup (dataset_location);
if (dataset)
- g_data_set_internal (&dataset->datalist, key_id, NULL, (GDestroyNotify) 42, dataset);
+ ret_data = g_data_set_internal (&dataset->datalist, key_id, NULL, (GDestroyNotify) 42, dataset);
}
G_UNLOCK (g_dataset_global);
+
+ return ret_data;
}
-void
+gpointer
g_datalist_id_remove_no_notify (GData **datalist,
GQuark key_id)
{
- g_return_if_fail (datalist != NULL);
+ gpointer ret_data = NULL;
+
+ g_return_val_if_fail (datalist != NULL, NULL);
G_LOCK (g_dataset_global);
if (key_id && g_dataset_location_ht)
- g_data_set_internal (datalist, key_id, NULL, (GDestroyNotify) 42, NULL);
+ ret_data = g_data_set_internal (datalist, key_id, NULL, (GDestroyNotify) 42, NULL);
G_UNLOCK (g_dataset_global);
+
+ return ret_data;
}
gpointer
diff --git a/glib/glib.h b/glib/glib.h
index 0a6d646e3..84c4170b3 100644
--- a/glib/glib.h
+++ b/glib/glib.h
@@ -1971,7 +1971,7 @@ void g_datalist_id_set_data_full (GData **datalist,
GQuark key_id,
gpointer data,
GDestroyNotify destroy_func);
-void g_datalist_id_remove_no_notify (GData **datalist,
+gpointer g_datalist_id_remove_no_notify (GData **datalist,
GQuark key_id);
void g_datalist_foreach (GData **datalist,
GDataForeachFunc func,
@@ -2001,7 +2001,7 @@ void g_dataset_id_set_data_full (gconstpointer dataset_location,
GQuark key_id,
gpointer data,
GDestroyNotify destroy_func);
-void g_dataset_id_remove_no_notify (gconstpointer dataset_location,
+gpointer g_dataset_id_remove_no_notify (gconstpointer dataset_location,
GQuark key_id);
void g_dataset_foreach (gconstpointer dataset_location,
GDataForeachFunc func,