summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Wilhelmi <wilhelmi@ira.uka.de>2001-04-02 16:34:08 +0000
committerSebastian Wilhelmi <wilhelmi@src.gnome.org>2001-04-02 16:34:08 +0000
commit7b06f826c942bf691b1fe6e52546ebcee3eecb5a (patch)
treea437c7c9cca4fb4c8dad9af014de3b8fc566ee8d
parent743f49cec9f4696c9eba32966d6ac78cd96c586d (diff)
Use the new GRealThread member "context" instead of a GStaticPrivate to
2001-04-02 Sebastian Wilhelmi <wilhelmi@ira.uka.de> * gmain.c: Use the new GRealThread member "context" instead of a GStaticPrivate to store the thread specific main loop context. * gthread.c: Added "context" member to GRealThread and updated g_thread_create, g_thread_self and g_thread_cleanup accordingly. * gthread.c, gthread.h: Removed the functions g_static_private_(get|set)_for_thread and adapted g_static_private_(get|set) and g_static_private_free accordingly.
-rw-r--r--ChangeLog12
-rw-r--r--ChangeLog.pre-2-012
-rw-r--r--ChangeLog.pre-2-1012
-rw-r--r--ChangeLog.pre-2-1212
-rw-r--r--ChangeLog.pre-2-212
-rw-r--r--ChangeLog.pre-2-412
-rw-r--r--ChangeLog.pre-2-612
-rw-r--r--ChangeLog.pre-2-812
-rw-r--r--glib/gmain.c22
-rw-r--r--glib/gthread.c77
-rw-r--r--glib/gthread.h6
-rw-r--r--gmain.c22
-rw-r--r--gthread.c77
-rw-r--r--gthread.h6
14 files changed, 208 insertions, 98 deletions
diff --git a/ChangeLog b/ChangeLog
index 7d132c38c..bd293a48b 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,15 @@
+2001-04-02 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
+
+ * gmain.c: Use the new GRealThread member "context" instead of a
+ GStaticPrivate to store the thread specific main loop context.
+
+ * gthread.c: Added "context" member to GRealThread and updated
+ g_thread_create, g_thread_self and g_thread_cleanup accordingly.
+
+ * gthread.c, gthread.h: Removed the functions
+ g_static_private_(get|set)_for_thread and adapted
+ g_static_private_(get|set) and g_static_private_free accordingly.
+
2001-03-30 Sven Neumann <sven@gimp.org>
* ghash.[ch]
diff --git a/ChangeLog.pre-2-0 b/ChangeLog.pre-2-0
index 7d132c38c..bd293a48b 100644
--- a/ChangeLog.pre-2-0
+++ b/ChangeLog.pre-2-0
@@ -1,3 +1,15 @@
+2001-04-02 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
+
+ * gmain.c: Use the new GRealThread member "context" instead of a
+ GStaticPrivate to store the thread specific main loop context.
+
+ * gthread.c: Added "context" member to GRealThread and updated
+ g_thread_create, g_thread_self and g_thread_cleanup accordingly.
+
+ * gthread.c, gthread.h: Removed the functions
+ g_static_private_(get|set)_for_thread and adapted
+ g_static_private_(get|set) and g_static_private_free accordingly.
+
2001-03-30 Sven Neumann <sven@gimp.org>
* ghash.[ch]
diff --git a/ChangeLog.pre-2-10 b/ChangeLog.pre-2-10
index 7d132c38c..bd293a48b 100644
--- a/ChangeLog.pre-2-10
+++ b/ChangeLog.pre-2-10
@@ -1,3 +1,15 @@
+2001-04-02 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
+
+ * gmain.c: Use the new GRealThread member "context" instead of a
+ GStaticPrivate to store the thread specific main loop context.
+
+ * gthread.c: Added "context" member to GRealThread and updated
+ g_thread_create, g_thread_self and g_thread_cleanup accordingly.
+
+ * gthread.c, gthread.h: Removed the functions
+ g_static_private_(get|set)_for_thread and adapted
+ g_static_private_(get|set) and g_static_private_free accordingly.
+
2001-03-30 Sven Neumann <sven@gimp.org>
* ghash.[ch]
diff --git a/ChangeLog.pre-2-12 b/ChangeLog.pre-2-12
index 7d132c38c..bd293a48b 100644
--- a/ChangeLog.pre-2-12
+++ b/ChangeLog.pre-2-12
@@ -1,3 +1,15 @@
+2001-04-02 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
+
+ * gmain.c: Use the new GRealThread member "context" instead of a
+ GStaticPrivate to store the thread specific main loop context.
+
+ * gthread.c: Added "context" member to GRealThread and updated
+ g_thread_create, g_thread_self and g_thread_cleanup accordingly.
+
+ * gthread.c, gthread.h: Removed the functions
+ g_static_private_(get|set)_for_thread and adapted
+ g_static_private_(get|set) and g_static_private_free accordingly.
+
2001-03-30 Sven Neumann <sven@gimp.org>
* ghash.[ch]
diff --git a/ChangeLog.pre-2-2 b/ChangeLog.pre-2-2
index 7d132c38c..bd293a48b 100644
--- a/ChangeLog.pre-2-2
+++ b/ChangeLog.pre-2-2
@@ -1,3 +1,15 @@
+2001-04-02 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
+
+ * gmain.c: Use the new GRealThread member "context" instead of a
+ GStaticPrivate to store the thread specific main loop context.
+
+ * gthread.c: Added "context" member to GRealThread and updated
+ g_thread_create, g_thread_self and g_thread_cleanup accordingly.
+
+ * gthread.c, gthread.h: Removed the functions
+ g_static_private_(get|set)_for_thread and adapted
+ g_static_private_(get|set) and g_static_private_free accordingly.
+
2001-03-30 Sven Neumann <sven@gimp.org>
* ghash.[ch]
diff --git a/ChangeLog.pre-2-4 b/ChangeLog.pre-2-4
index 7d132c38c..bd293a48b 100644
--- a/ChangeLog.pre-2-4
+++ b/ChangeLog.pre-2-4
@@ -1,3 +1,15 @@
+2001-04-02 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
+
+ * gmain.c: Use the new GRealThread member "context" instead of a
+ GStaticPrivate to store the thread specific main loop context.
+
+ * gthread.c: Added "context" member to GRealThread and updated
+ g_thread_create, g_thread_self and g_thread_cleanup accordingly.
+
+ * gthread.c, gthread.h: Removed the functions
+ g_static_private_(get|set)_for_thread and adapted
+ g_static_private_(get|set) and g_static_private_free accordingly.
+
2001-03-30 Sven Neumann <sven@gimp.org>
* ghash.[ch]
diff --git a/ChangeLog.pre-2-6 b/ChangeLog.pre-2-6
index 7d132c38c..bd293a48b 100644
--- a/ChangeLog.pre-2-6
+++ b/ChangeLog.pre-2-6
@@ -1,3 +1,15 @@
+2001-04-02 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
+
+ * gmain.c: Use the new GRealThread member "context" instead of a
+ GStaticPrivate to store the thread specific main loop context.
+
+ * gthread.c: Added "context" member to GRealThread and updated
+ g_thread_create, g_thread_self and g_thread_cleanup accordingly.
+
+ * gthread.c, gthread.h: Removed the functions
+ g_static_private_(get|set)_for_thread and adapted
+ g_static_private_(get|set) and g_static_private_free accordingly.
+
2001-03-30 Sven Neumann <sven@gimp.org>
* ghash.[ch]
diff --git a/ChangeLog.pre-2-8 b/ChangeLog.pre-2-8
index 7d132c38c..bd293a48b 100644
--- a/ChangeLog.pre-2-8
+++ b/ChangeLog.pre-2-8
@@ -1,3 +1,15 @@
+2001-04-02 Sebastian Wilhelmi <wilhelmi@ira.uka.de>
+
+ * gmain.c: Use the new GRealThread member "context" instead of a
+ GStaticPrivate to store the thread specific main loop context.
+
+ * gthread.c: Added "context" member to GRealThread and updated
+ g_thread_create, g_thread_self and g_thread_cleanup accordingly.
+
+ * gthread.c, gthread.h: Removed the functions
+ g_static_private_(get|set)_for_thread and adapted
+ g_static_private_(get|set) and g_static_private_free accordingly.
+
2001-03-30 Sven Neumann <sven@gimp.org>
* ghash.[ch]
diff --git a/glib/gmain.c b/glib/gmain.c
index 6435a15ce..1fa20fe59 100644
--- a/glib/gmain.c
+++ b/glib/gmain.c
@@ -496,7 +496,7 @@ g_poll (GPollFD *fds,
/* Called to clean up when a thread terminates
*/
-static void
+void
g_main_context_destroy (GMainContext *context)
{
GSource *source;
@@ -538,6 +538,18 @@ g_main_context_destroy (GMainContext *context)
g_free (context);
}
+/* This is an imcomplete (only the members up till context) version of
+ * GRealThread from gthread.h. Keep them in sync */
+typedef struct _GRealThread GRealThread;
+struct _GRealThread
+{
+ GThread thread;
+ GThreadFunc func;
+ gpointer arg;
+ gpointer private_data;
+ GMainContext *context;
+};
+
/**
* g_main_context_get:
* @thread: a #GThread
@@ -551,13 +563,13 @@ g_main_context_destroy (GMainContext *context)
GMainContext *
g_main_context_get (GThread *thread)
{
- static GStaticPrivate private_key = G_STATIC_PRIVATE_INIT;
+ GRealThread *real_thread = (GRealThread*)thread;
GMainContext *context;
g_return_val_if_fail (thread != NULL, NULL);
if (g_thread_supported ())
- context = g_static_private_get_for_thread (&private_key, thread);
+ context = real_thread->context;
else
context = default_main_context;
@@ -616,9 +628,7 @@ g_main_context_get (GThread *thread)
#endif
if (g_thread_supported ())
- g_static_private_set_for_thread (&private_key, thread,
- context,
- (GDestroyNotify)g_main_context_destroy);
+ real_thread->context = context;
else
default_main_context = context;
}
diff --git a/glib/gthread.c b/glib/gthread.c
index ef0f3c8e6..8ee0c99e8 100644
--- a/glib/gthread.c
+++ b/glib/gthread.c
@@ -69,6 +69,7 @@ g_thread_error_quark (void)
return quark;
}
+/* Keep this in sync with GRealThread in gmain.c! */
typedef struct _GRealThread GRealThread;
struct _GRealThread
{
@@ -76,6 +77,7 @@ struct _GRealThread
GThreadFunc func;
gpointer arg;
gpointer private_data;
+ GMainContext *context;
GSystemThread system_thread;
#ifdef G_THREAD_USE_PID_SURROGATE
pid_t pid;
@@ -346,17 +348,8 @@ g_static_private_init (GStaticPrivate *private_key)
gpointer
g_static_private_get (GStaticPrivate *private_key)
{
- return g_static_private_get_for_thread (private_key, g_thread_self ());
-}
-
-gpointer
-g_static_private_get_for_thread (GStaticPrivate *private_key,
- GThread *thread)
-{
+ GRealThread *self = (GRealThread*) g_thread_self ();
GArray *array;
- GRealThread *self = (GRealThread*) thread;
-
- g_return_val_if_fail (thread, NULL);
array = self->private_data;
if (!array)
@@ -365,7 +358,8 @@ g_static_private_get_for_thread (GStaticPrivate *private_key,
if (!private_key->index)
return NULL;
else if (private_key->index <= array->len)
- return g_array_index (array, GStaticPrivateNode, private_key->index - 1).data;
+ return g_array_index (array, GStaticPrivateNode,
+ private_key->index - 1).data;
else
return NULL;
}
@@ -375,23 +369,11 @@ g_static_private_set (GStaticPrivate *private_key,
gpointer data,
GDestroyNotify notify)
{
- g_static_private_set_for_thread (private_key, g_thread_self (),
- data, notify);
-}
-
-void
-g_static_private_set_for_thread (GStaticPrivate *private_key,
- GThread *thread,
- gpointer data,
- GDestroyNotify notify)
-{
+ GRealThread *self = (GRealThread*) g_thread_self ();
GArray *array;
- GRealThread *self =(GRealThread*) thread;
static guint next_index = 0;
GStaticPrivateNode *node;
- g_return_if_fail (thread);
-
array = self->private_data;
if (!array)
{
@@ -444,32 +426,48 @@ g_static_private_set_for_thread (GStaticPrivate *private_key,
void
g_static_private_free (GStaticPrivate *private_key)
{
- GStaticPrivate copied_key;
+ guint index = private_key->index;
GSList *list;
- copied_key.index = private_key->index;
- private_key->index = 0;
-
- if (!copied_key.index)
+ if (!index)
return;
+
+ private_key->index = 0;
G_LOCK (g_thread);
list = g_thread_all_threads;
while (list)
{
- GThread *thread = list->data;
+ GRealThread *thread = list->data;
+ GArray *array = thread->private_data;
list = list->next;
-
- G_UNLOCK (g_thread);
- g_static_private_set_for_thread (&copied_key, thread, NULL, NULL);
- G_LOCK (g_thread);
+
+ if (array && index <= array->len)
+ {
+ GStaticPrivateNode *node = &g_array_index (array,
+ GStaticPrivateNode,
+ index - 1);
+ gpointer ddata = node->data;
+ GDestroyNotify ddestroy = node->destroy;
+
+ node->data = NULL;
+ node->destroy = NULL;
+
+ if (ddestroy)
+ {
+ G_UNLOCK (g_thread);
+ ddestroy (ddata);
+ G_LOCK (g_thread);
+ }
+ }
}
- g_thread_free_indeces =
- g_slist_prepend (g_thread_free_indeces,
- GUINT_TO_POINTER (copied_key.index));
+ g_thread_free_indeces = g_slist_prepend (g_thread_free_indeces,
+ GUINT_TO_POINTER (index));
G_UNLOCK (g_thread);
}
+void g_main_context_destroy (GMainContext *context);
+
static void
g_thread_cleanup (gpointer data)
{
@@ -490,6 +488,9 @@ g_thread_cleanup (gpointer data)
}
g_array_free (array, TRUE);
}
+ if (thread->context)
+ g_main_context_destroy (thread->context);
+
/* We only free the thread structure, if it isn't joinable. If
it is, the structure is freed in g_thread_join */
if (!thread->thread.joinable)
@@ -559,6 +560,7 @@ g_thread_create (GThreadFunc thread_func,
result->func = thread_func;
result->arg = arg;
result->private_data = NULL;
+ result->context = NULL;
G_LOCK (g_thread);
G_THREAD_UF (thread_create, (g_thread_create_proxy, result,
stack_size, joinable, bound, priority,
@@ -643,6 +645,7 @@ g_thread_self (void)
thread->func = NULL;
thread->arg = NULL;
thread->private_data = NULL;
+ thread->context = NULL;
if (g_thread_supported ())
G_THREAD_UF (thread_self, (&thread->system_thread));
diff --git a/glib/gthread.h b/glib/gthread.h
index 098cfc47f..2f147b496 100644
--- a/glib/gthread.h
+++ b/glib/gthread.h
@@ -229,12 +229,6 @@ gpointer g_static_private_get (GStaticPrivate *private_key);
void g_static_private_set (GStaticPrivate *private_key,
gpointer data,
GDestroyNotify notify);
-gpointer g_static_private_get_for_thread (GStaticPrivate *private_key,
- GThread *thread);
-void g_static_private_set_for_thread (GStaticPrivate *private_key,
- GThread *thread,
- gpointer data,
- GDestroyNotify notify);
void g_static_private_free (GStaticPrivate *private_key);
typedef struct _GStaticRecMutex GStaticRecMutex;
diff --git a/gmain.c b/gmain.c
index 6435a15ce..1fa20fe59 100644
--- a/gmain.c
+++ b/gmain.c
@@ -496,7 +496,7 @@ g_poll (GPollFD *fds,
/* Called to clean up when a thread terminates
*/
-static void
+void
g_main_context_destroy (GMainContext *context)
{
GSource *source;
@@ -538,6 +538,18 @@ g_main_context_destroy (GMainContext *context)
g_free (context);
}
+/* This is an imcomplete (only the members up till context) version of
+ * GRealThread from gthread.h. Keep them in sync */
+typedef struct _GRealThread GRealThread;
+struct _GRealThread
+{
+ GThread thread;
+ GThreadFunc func;
+ gpointer arg;
+ gpointer private_data;
+ GMainContext *context;
+};
+
/**
* g_main_context_get:
* @thread: a #GThread
@@ -551,13 +563,13 @@ g_main_context_destroy (GMainContext *context)
GMainContext *
g_main_context_get (GThread *thread)
{
- static GStaticPrivate private_key = G_STATIC_PRIVATE_INIT;
+ GRealThread *real_thread = (GRealThread*)thread;
GMainContext *context;
g_return_val_if_fail (thread != NULL, NULL);
if (g_thread_supported ())
- context = g_static_private_get_for_thread (&private_key, thread);
+ context = real_thread->context;
else
context = default_main_context;
@@ -616,9 +628,7 @@ g_main_context_get (GThread *thread)
#endif
if (g_thread_supported ())
- g_static_private_set_for_thread (&private_key, thread,
- context,
- (GDestroyNotify)g_main_context_destroy);
+ real_thread->context = context;
else
default_main_context = context;
}
diff --git a/gthread.c b/gthread.c
index ef0f3c8e6..8ee0c99e8 100644
--- a/gthread.c
+++ b/gthread.c
@@ -69,6 +69,7 @@ g_thread_error_quark (void)
return quark;
}
+/* Keep this in sync with GRealThread in gmain.c! */
typedef struct _GRealThread GRealThread;
struct _GRealThread
{
@@ -76,6 +77,7 @@ struct _GRealThread
GThreadFunc func;
gpointer arg;
gpointer private_data;
+ GMainContext *context;
GSystemThread system_thread;
#ifdef G_THREAD_USE_PID_SURROGATE
pid_t pid;
@@ -346,17 +348,8 @@ g_static_private_init (GStaticPrivate *private_key)
gpointer
g_static_private_get (GStaticPrivate *private_key)
{
- return g_static_private_get_for_thread (private_key, g_thread_self ());
-}
-
-gpointer
-g_static_private_get_for_thread (GStaticPrivate *private_key,
- GThread *thread)
-{
+ GRealThread *self = (GRealThread*) g_thread_self ();
GArray *array;
- GRealThread *self = (GRealThread*) thread;
-
- g_return_val_if_fail (thread, NULL);
array = self->private_data;
if (!array)
@@ -365,7 +358,8 @@ g_static_private_get_for_thread (GStaticPrivate *private_key,
if (!private_key->index)
return NULL;
else if (private_key->index <= array->len)
- return g_array_index (array, GStaticPrivateNode, private_key->index - 1).data;
+ return g_array_index (array, GStaticPrivateNode,
+ private_key->index - 1).data;
else
return NULL;
}
@@ -375,23 +369,11 @@ g_static_private_set (GStaticPrivate *private_key,
gpointer data,
GDestroyNotify notify)
{
- g_static_private_set_for_thread (private_key, g_thread_self (),
- data, notify);
-}
-
-void
-g_static_private_set_for_thread (GStaticPrivate *private_key,
- GThread *thread,
- gpointer data,
- GDestroyNotify notify)
-{
+ GRealThread *self = (GRealThread*) g_thread_self ();
GArray *array;
- GRealThread *self =(GRealThread*) thread;
static guint next_index = 0;
GStaticPrivateNode *node;
- g_return_if_fail (thread);
-
array = self->private_data;
if (!array)
{
@@ -444,32 +426,48 @@ g_static_private_set_for_thread (GStaticPrivate *private_key,
void
g_static_private_free (GStaticPrivate *private_key)
{
- GStaticPrivate copied_key;
+ guint index = private_key->index;
GSList *list;
- copied_key.index = private_key->index;
- private_key->index = 0;
-
- if (!copied_key.index)
+ if (!index)
return;
+
+ private_key->index = 0;
G_LOCK (g_thread);
list = g_thread_all_threads;
while (list)
{
- GThread *thread = list->data;
+ GRealThread *thread = list->data;
+ GArray *array = thread->private_data;
list = list->next;
-
- G_UNLOCK (g_thread);
- g_static_private_set_for_thread (&copied_key, thread, NULL, NULL);
- G_LOCK (g_thread);
+
+ if (array && index <= array->len)
+ {
+ GStaticPrivateNode *node = &g_array_index (array,
+ GStaticPrivateNode,
+ index - 1);
+ gpointer ddata = node->data;
+ GDestroyNotify ddestroy = node->destroy;
+
+ node->data = NULL;
+ node->destroy = NULL;
+
+ if (ddestroy)
+ {
+ G_UNLOCK (g_thread);
+ ddestroy (ddata);
+ G_LOCK (g_thread);
+ }
+ }
}
- g_thread_free_indeces =
- g_slist_prepend (g_thread_free_indeces,
- GUINT_TO_POINTER (copied_key.index));
+ g_thread_free_indeces = g_slist_prepend (g_thread_free_indeces,
+ GUINT_TO_POINTER (index));
G_UNLOCK (g_thread);
}
+void g_main_context_destroy (GMainContext *context);
+
static void
g_thread_cleanup (gpointer data)
{
@@ -490,6 +488,9 @@ g_thread_cleanup (gpointer data)
}
g_array_free (array, TRUE);
}
+ if (thread->context)
+ g_main_context_destroy (thread->context);
+
/* We only free the thread structure, if it isn't joinable. If
it is, the structure is freed in g_thread_join */
if (!thread->thread.joinable)
@@ -559,6 +560,7 @@ g_thread_create (GThreadFunc thread_func,
result->func = thread_func;
result->arg = arg;
result->private_data = NULL;
+ result->context = NULL;
G_LOCK (g_thread);
G_THREAD_UF (thread_create, (g_thread_create_proxy, result,
stack_size, joinable, bound, priority,
@@ -643,6 +645,7 @@ g_thread_self (void)
thread->func = NULL;
thread->arg = NULL;
thread->private_data = NULL;
+ thread->context = NULL;
if (g_thread_supported ())
G_THREAD_UF (thread_self, (&thread->system_thread));
diff --git a/gthread.h b/gthread.h
index 098cfc47f..2f147b496 100644
--- a/gthread.h
+++ b/gthread.h
@@ -229,12 +229,6 @@ gpointer g_static_private_get (GStaticPrivate *private_key);
void g_static_private_set (GStaticPrivate *private_key,
gpointer data,
GDestroyNotify notify);
-gpointer g_static_private_get_for_thread (GStaticPrivate *private_key,
- GThread *thread);
-void g_static_private_set_for_thread (GStaticPrivate *private_key,
- GThread *thread,
- gpointer data,
- GDestroyNotify notify);
void g_static_private_free (GStaticPrivate *private_key);
typedef struct _GStaticRecMutex GStaticRecMutex;