+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.
+
2000-02-01 Tor Lillqvist <tml@iki.fi>
* glib.h
+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.
+
2000-02-01 Tor Lillqvist <tml@iki.fi>
* glib.h
+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.
+
2000-02-01 Tor Lillqvist <tml@iki.fi>
* glib.h
+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.
+
2000-02-01 Tor Lillqvist <tml@iki.fi>
* glib.h
+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.
+
2000-02-01 Tor Lillqvist <tml@iki.fi>
* glib.h
+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.
+
2000-02-01 Tor Lillqvist <tml@iki.fi>
* glib.h
+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.
+
2000-02-01 Tor Lillqvist <tml@iki.fi>
* glib.h
+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.
+
2000-02-01 Tor Lillqvist <tml@iki.fi>
* glib.h
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,
}
/* HOLDS: g_dataset_global_lock */
-static inline void
+static inline gpointer
g_data_set_internal (GData **datalist,
GQuark key_id,
gpointer data,
{
if (list->id == key_id)
{
+ gpointer ret_data = NULL;
+
if (prev)
prev->next = list->next;
else
list->destroy_func (list->data);
G_LOCK (g_dataset_global);
}
+ else
+ ret_data = list->data;
if (g_data_cache_length < G_DATA_CACHE_MAX)
{
else
g_mem_chunk_free (g_data_mem_chunk, list);
- return;
+ return ret_data;
}
prev = list;
G_LOCK (g_dataset_global);
}
- return;
+ return NULL;
}
list = list->next;
list->destroy_func = destroy_func;
*datalist = list;
}
+
+ return NULL;
}
void
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)
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
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,
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,
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,
}
/* HOLDS: g_dataset_global_lock */
-static inline void
+static inline gpointer
g_data_set_internal (GData **datalist,
GQuark key_id,
gpointer data,
{
if (list->id == key_id)
{
+ gpointer ret_data = NULL;
+
if (prev)
prev->next = list->next;
else
list->destroy_func (list->data);
G_LOCK (g_dataset_global);
}
+ else
+ ret_data = list->data;
if (g_data_cache_length < G_DATA_CACHE_MAX)
{
else
g_mem_chunk_free (g_data_mem_chunk, list);
- return;
+ return ret_data;
}
prev = list;
G_LOCK (g_dataset_global);
}
- return;
+ return NULL;
}
list = list->next;
list->destroy_func = destroy_func;
*datalist = list;
}
+
+ return NULL;
}
void
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)
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
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,
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,