diff options
Diffstat (limited to 'libjava/gcj/array.h')
-rw-r--r-- | libjava/gcj/array.h | 70 |
1 files changed, 60 insertions, 10 deletions
diff --git a/libjava/gcj/array.h b/libjava/gcj/array.h index 29be1cc..8b355e2 100644 --- a/libjava/gcj/array.h +++ b/libjava/gcj/array.h @@ -55,18 +55,68 @@ typedef JArray<jfloat> *jfloatArray; typedef JArray<jdouble> *jdoubleArray; typedef JArray<jstring> *jstringArray; -extern "C" jbooleanArray JvNewBooleanArray (jint length); -extern "C" jbyteArray JvNewByteArray (jint length); -extern "C" jcharArray JvNewCharArray (jint length); -extern "C" jshortArray JvNewShortArray (jint length); -extern "C" jintArray JvNewIntArray (jint length); -extern "C" jlongArray JvNewLongArray (jint length); -extern "C" jfloatArray JvNewFloatArray (jint length); -extern "C" jdoubleArray JvNewDoubleArray (jint length); +extern class _Jv_PrimClass _Jv_byteClass, _Jv_shortClass, _Jv_intClass, + _Jv_longClass, _Jv_booleanClass, _Jv_charClass, _Jv_floatClass, + _Jv_doubleClass, _Jv_voidClass; +#define JvPrimClass(TYPE) ((jclass) & _Jv_##TYPE##Class) + extern "C" jobjectArray _Jv_NewObjectArray(jsize length, jclass, jobject init); +extern "C" jobject _Jv_NewPrimArray (jclass eltype, jint count); + +extern inline jobjectArray +JvNewObjectArray (jsize length, jclass cls, jobject init) +{ + return _Jv_NewObjectArray (length, cls, init); +} + +extern inline jcharArray +JvNewCharArray (jint length) +{ + return (jcharArray) _Jv_NewPrimArray (JvPrimClass (char), length); +} + +extern inline jbooleanArray +JvNewBooleanArray (jint length) +{ + return (jbooleanArray) _Jv_NewPrimArray (JvPrimClass (boolean), length); +} + +extern inline jbyteArray +JvNewByteArray (jint length) +{ + return (jbyteArray) _Jv_NewPrimArray (JvPrimClass (byte), length); +} + +extern inline jshortArray +JvNewShortArray (jint length) +{ + return (jshortArray) _Jv_NewPrimArray (JvPrimClass (short), length); +} + +extern inline jintArray +JvNewIntArray (jint length) +{ + return (jintArray) _Jv_NewPrimArray (JvPrimClass (int), length); +} + +extern inline jlongArray +JvNewLongArray (jint length) +{ + return (jlongArray) _Jv_NewPrimArray (JvPrimClass (long), length); +} + +extern inline jfloatArray +JvNewFloatArray (jint length) +{ + return (jfloatArray) _Jv_NewPrimArray (JvPrimClass (float), length); +} + +extern inline jdoubleArray +JvNewDoubleArray (jint length) +{ + return (jdoubleArray) _Jv_NewPrimArray (JvPrimClass (double), length); +} -inline jobjectArray JvNewObjectArray (jsize length, jclass cls, jobject init) -{ return _Jv_NewObjectArray (length, cls, init); } extern "C" jstringArray JvConvertArgv(int argc, const char **argv); |