1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151
|
/* gthread-jni.c -- JNI threading routines for GLIB
Copyright (C) 1998 Free Software Foundation, Inc.
This file is part of the peer AWT libraries of GNU Classpath.
This library is free software; you can redistribute it and/or modify
it under the terms of the GNU Library General Public License as published
by the Free Software Foundation, either version 2 of the License, or
(at your option) any later verion.
This library is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; if not, write to the Free Software Foundation
Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307 USA. */
#include "gthread-jni.h"
/*
* This code has been written specifically to be used with GTK+ 1.2.
* `Real' GLIB threading is not supported. We fake things where necessary.
* Once we know we're running on a 1.2 VM, we can write a real implementation.
*/
static GMutex *
g_mutex_new_jni_impl (void)
{
jclass obj_class;
jobject *mutex;
obj_class = (*gdk_env)->FindClass (gdk_env, "java/lang/Object");
if (obj_class == NULL)
return NULL;
mutex = (jobject *) g_malloc (sizeof (jobject));
*mutex = (*gdk_env)->AllocObject (gdk_env, obj_class);
if (*mutex == NULL)
{
g_free (mutex);
return NULL;
}
*mutex = (*gdk_env)->NewGlobalRef (gdk_env, *mutex);
return (GMutex *) mutex;
}
static void
g_mutex_lock_jni_impl (GMutex *mutex)
{
if (mutex && mutex == gdk_threads_mutex)
(*gdk_env)->MonitorEnter (gdk_env, *((jobject *)mutex));
}
static gboolean
g_mutex_trylock_jni_impl (GMutex *mutex)
{
return FALSE;
}
static void
g_mutex_unlock_jni_impl (GMutex *mutex)
{
if (mutex && mutex == gdk_threads_mutex)
(*gdk_env)->MonitorExit (gdk_env, *((jobject *)mutex));
}
static void
g_mutex_free_jni_impl (GMutex *mutex)
{
if (mutex && mutex == gdk_threads_mutex)
{
(*gdk_env)->DeleteGlobalRef (gdk_env, *((jobject *)mutex));
g_free (mutex);
}
}
static GPrivate *
g_private_new_jni_impl (GDestroyNotify notify)
{
return NULL;
}
static gpointer
g_private_get_jni_impl (GPrivate *private)
{
return NULL;
}
static void
g_private_set_jni_impl (GPrivate *private, gpointer data)
{
}
static GCond *
g_cond_new_jni_impl ()
{
return NULL;
}
static void
g_cond_signal_jni_impl (GCond *cond)
{
}
static void
g_cond_broadcast_jni_impl (GCond *cond)
{
}
static void
g_cond_wait_jni_impl (GCond *cond, GMutex *mutex)
{
}
static gboolean
g_cond_timed_wait_jni_impl (GCond *cond, GMutex *mutex)
{
return FALSE;
}
static void
g_cond_free_jni_impl (GCond *cond)
{
}
GThreadFunctions g_thread_jni_functions =
{
g_mutex_new_jni_impl, /* mutex_new */
g_mutex_lock_jni_impl, /* mutex_lock */
g_mutex_trylock_jni_impl, /* mutex_try_lock */
g_mutex_unlock_jni_impl, /* mutex_unlock */
g_mutex_free_jni_impl, /* mutex_free */
g_cond_new_jni_impl, /* cond_new */
g_cond_signal_jni_impl, /* cond_signal */
g_cond_broadcast_jni_impl, /* cond_broadcast */
g_cond_wait_jni_impl, /* cond_wait */
g_cond_timed_wait_jni_impl, /* cond_timed_wait */
g_cond_free_jni_impl, /* cond_free */
g_private_new_jni_impl, /* private_new */
g_private_get_jni_impl, /* private_get */
g_private_set_jni_impl /* private_set */
};
void
gdk_threads_wake ()
{
}
|