diff options
Diffstat (limited to 'libjava/jni')
-rw-r--r-- | libjava/jni/classpath/classpath_jawt.h | 4 | ||||
-rw-r--r-- | libjava/jni/gtk-peer/gtk_jawt.c | 31 |
2 files changed, 35 insertions, 0 deletions
diff --git a/libjava/jni/classpath/classpath_jawt.h b/libjava/jni/classpath/classpath_jawt.h index 1629505..6ff5c53 100644 --- a/libjava/jni/classpath/classpath_jawt.h +++ b/libjava/jni/classpath/classpath_jawt.h @@ -54,7 +54,11 @@ jint classpath_jawt_get_awt_version (); Display* classpath_jawt_get_default_display (JNIEnv* env, jobject canvas); Drawable classpath_jawt_get_drawable (JNIEnv* env, jobject canvas); VisualID classpath_jawt_get_visualID (JNIEnv* env, jobject canvas); +jint classpath_jawt_object_lock (jobject lock); +void classpath_jawt_object_unlock (jobject lock); jint classpath_jawt_lock (); void classpath_jawt_unlock (); +jobject classpath_jawt_create_lock (); +void classpath_jawt_destroy_lock (jobject lock); #endif /* __classpath_jawt_h__ */ diff --git a/libjava/jni/gtk-peer/gtk_jawt.c b/libjava/jni/gtk-peer/gtk_jawt.c index cba3b15..ed5f3f5 100644 --- a/libjava/jni/gtk-peer/gtk_jawt.c +++ b/libjava/jni/gtk-peer/gtk_jawt.c @@ -153,6 +153,21 @@ classpath_jawt_get_drawable (JNIEnv* env, jobject canvas) } jint +classpath_jawt_object_lock (jobject lock) +{ + JNIEnv *env = gdk_env(); + (*env)->MonitorEnter (env, lock); + return 0; +} + +void +classpath_jawt_object_unlock (jobject lock) +{ + JNIEnv *env = gdk_env(); + (*env)->MonitorExit (env, lock); +} + +jint classpath_jawt_lock () { gdk_threads_enter (); @@ -164,3 +179,19 @@ classpath_jawt_unlock () { gdk_threads_leave (); } + +jobject +classpath_jawt_create_lock () +{ + JNIEnv *env = gdk_env (); + jobject lock = (*env)->NewStringUTF (env, "jawt-lock"); + NSA_SET_GLOBAL_REF (env, lock); + return lock; +} + +void +classpath_jawt_destroy_lock (jobject lock) +{ + JNIEnv *env = gdk_env (); + NSA_DEL_GLOBAL_REF (env, lock); +} |