68337d49ee1d958b82d7e8cf034ec58696795c51
[cacao.git] / tests / regression / native / checkjni.c
1 /* src/tests/native/checkjni.c - for testing JNI stuff
2
3    Copyright (C) 1996-2005, 2006, 2008
4    CACAOVM - Verein zur Foerderung der freien virtuellen Maschine CACAO
5
6    This file is part of CACAO.
7
8    This program is free software; you can redistribute it and/or
9    modify it under the terms of the GNU General Public License as
10    published by the Free Software Foundation; either version 2, or (at
11    your option) any later version.
12
13    This program is distributed in the hope that it will be useful, but
14    WITHOUT ANY WARRANTY; without even the implied warranty of
15    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16    General Public License for more details.
17
18    You should have received a copy of the GNU General Public License
19    along with this program; if not, write to the Free Software
20    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21    02110-1301, USA.
22
23 */
24
25
26 #include "config.h"
27
28 #include <stdio.h>
29 #include <string.h>
30
31 #include "native/jni.hpp"
32
33
34 JNIEXPORT jboolean JNICALL Java_checkjni_IsAssignableFrom(JNIEnv *env, jclass clazz, jclass sub, jclass sup)
35 {
36   return (*env)->IsAssignableFrom(env, sub, sup);
37 }
38
39 JNIEXPORT jboolean JNICALL Java_checkjni_IsInstanceOf(JNIEnv *env, jclass clazz, jobject obj, jclass c)
40 {
41   return (*env)->IsInstanceOf(env, obj, c);
42 }
43
44 JNIEXPORT jboolean JNICALL Java_checkjni_IsSameObject(JNIEnv *env, jclass clazz, jobject obj1, jobject obj2)
45 {
46   return (*env)->IsSameObject(env, obj1, obj2);
47 }
48
49 JNIEXPORT jint     JNICALL Java_checkjni_PushLocalFrame(JNIEnv *env, jclass clazz, jint capacity)
50 {
51   return (*env)->PushLocalFrame(env, capacity);
52 }
53
54 JNIEXPORT void     JNICALL Java_checkjni_Throw(JNIEnv *env, jclass clazz)
55 {
56         jclass c = (*env)->FindClass(env, "java/lang/Exception");
57         (*env)->ThrowNew(env, c, "Exception from JNI");
58 }
59
60 JNIEXPORT jclass   JNICALL Java_checkjni_GetObjectClass(JNIEnv *env, jclass clazz, jobject obj)
61 {
62         return (*env)->GetObjectClass(env, obj);
63 }
64
65 #define CHECKJNI_GET_FIELD(type, name, fieldname, sig) \
66 JNIEXPORT type     JNICALL Java_checkjni_Get##name##Field(JNIEnv *env, jclass clazz, jobject obj) \
67 { \
68         jclass c = (*env)->GetObjectClass(env, obj); \
69         jfieldID id = (*env)->GetFieldID(env, c, fieldname, sig); \
70         if ((*env)->ExceptionCheck(env)) return 0; \
71         return (*env)->Get##name##Field(env, obj, id); \
72 }
73 CHECKJNI_GET_FIELD(jint,    Int,    "jfI", "I")
74 CHECKJNI_GET_FIELD(jobject, Object, "jfL", "Ljava/lang/Object;")
75
76 #define CHECKJNI_GET_STATIC_FIELD(type, name, fieldname, sig) \
77 JNIEXPORT type     JNICALL Java_checkjni_GetStatic##name##Field(JNIEnv *env, jclass clazz) \
78 { \
79         jfieldID id = (*env)->GetStaticFieldID(env, clazz, fieldname, sig); \
80         if ((*env)->ExceptionCheck(env)) return 0; \
81         return (*env)->GetStatic##name##Field(env, clazz, id); \
82 }
83 CHECKJNI_GET_STATIC_FIELD(jint,    Int,    "jsfI", "I")
84 CHECKJNI_GET_STATIC_FIELD(jobject, Object, "jsfL", "Ljava/lang/Object;")
85
86 #define CHECKJNI_SET_STATIC_FIELD(type, name, fieldname, sig) \
87 JNIEXPORT type     JNICALL Java_checkjni_SetStatic##name##Field(JNIEnv *env, jclass clazz, type val) \
88 { \
89         jfieldID id = (*env)->GetStaticFieldID(env, clazz, fieldname, sig); \
90         if ((*env)->ExceptionCheck(env)) return 0; \
91         (*env)->SetStatic##name##Field(env, clazz, id, val); \
92 }
93 CHECKJNI_SET_STATIC_FIELD(jint,    Int,    "jsfI", "I")
94 CHECKJNI_SET_STATIC_FIELD(jobject, Object, "jsfL", "Ljava/lang/Object;")
95
96 #define CHECKJNI_NEW_ARRAY(type, name) \
97 JNIEXPORT type##Array JNICALL Java_checkjni_New##name##Array(JNIEnv *env, jclass clazz, jint size) \
98 { \
99         int i; \
100         type##Array a; \
101         type *p; \
102         jboolean iscopy; \
103         a = (*env)->New##name##Array(env, size); \
104         p = (*env)->Get##name##ArrayElements(env, a, &iscopy); \
105         for (i = 0; i < size; i++) p[i] = i; \
106         (*env)->Release##name##ArrayElements(env, a, p, 0); \
107         return a; \
108 }
109 CHECKJNI_NEW_ARRAY(jint,    Int)
110 CHECKJNI_NEW_ARRAY(jlong,   Long)
111
112 JNIEXPORT jstring  JNICALL Java_checkjni_NewString(JNIEnv *env, jclass clazz, jint type)
113 {
114         if (type == 1)
115                 return (*env)->NewString(env, (jchar *) "Test String from JNI", (jsize) strlen("Test String from JNI"));
116         else
117                 return (*env)->NewStringUTF(env, "Test String from JNI with UTF");
118 }
119
120