blob: 9e2d989cfe1aa6c9785680993a2692040317d393 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2009 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
#include "swt.h"
#include "xpcom_structs.h"
#ifndef NO_nsDynamicFunctionLoad
typedef struct nsDynamicFunctionLoad_FID_CACHE {
int cached;
jclass clazz;
jfieldID functionName, function;
} nsDynamicFunctionLoad_FID_CACHE;
nsDynamicFunctionLoad_FID_CACHE nsDynamicFunctionLoadFc;
void cachensDynamicFunctionLoadFields(JNIEnv *env, jobject lpObject)
{
if (nsDynamicFunctionLoadFc.cached) return;
nsDynamicFunctionLoadFc.clazz = env->GetObjectClass(lpObject);
nsDynamicFunctionLoadFc.functionName = env->GetFieldID(nsDynamicFunctionLoadFc.clazz, "functionName", I_J);
nsDynamicFunctionLoadFc.function = env->GetFieldID(nsDynamicFunctionLoadFc.clazz, "function", I_J);
nsDynamicFunctionLoadFc.cached = 1;
}
nsDynamicFunctionLoad *getnsDynamicFunctionLoadFields(JNIEnv *env, jobject lpObject, nsDynamicFunctionLoad *lpStruct)
{
if (!nsDynamicFunctionLoadFc.cached) cachensDynamicFunctionLoadFields(env, lpObject);
lpStruct->functionName = (const char *)env->GetIntLongField(lpObject, nsDynamicFunctionLoadFc.functionName);
lpStruct->function = (NSFuncPtr *)env->GetIntLongField(lpObject, nsDynamicFunctionLoadFc.function);
return lpStruct;
}
void setnsDynamicFunctionLoadFields(JNIEnv *env, jobject lpObject, nsDynamicFunctionLoad *lpStruct)
{
if (!nsDynamicFunctionLoadFc.cached) cachensDynamicFunctionLoadFields(env, lpObject);
env->SetIntLongField(lpObject, nsDynamicFunctionLoadFc.functionName, (jintLong)lpStruct->functionName);
env->SetIntLongField(lpObject, nsDynamicFunctionLoadFc.function, (jintLong)lpStruct->function);
}
#endif
#ifndef NO_nsID
typedef struct nsID_FID_CACHE {
int cached;
jclass clazz;
jfieldID m0, m1, m2, m3;
} nsID_FID_CACHE;
nsID_FID_CACHE nsIDFc;
void cachensIDFields(JNIEnv *env, jobject lpObject)
{
if (nsIDFc.cached) return;
nsIDFc.clazz = env->GetObjectClass(lpObject);
nsIDFc.m0 = env->GetFieldID(nsIDFc.clazz, "m0", "I");
nsIDFc.m1 = env->GetFieldID(nsIDFc.clazz, "m1", "S");
nsIDFc.m2 = env->GetFieldID(nsIDFc.clazz, "m2", "S");
nsIDFc.m3 = env->GetFieldID(nsIDFc.clazz, "m3", "[B");
nsIDFc.cached = 1;
}
nsID *getnsIDFields(JNIEnv *env, jobject lpObject, nsID *lpStruct)
{
if (!nsIDFc.cached) cachensIDFields(env, lpObject);
lpStruct->m0 = env->GetIntField(lpObject, nsIDFc.m0);
lpStruct->m1 = env->GetShortField(lpObject, nsIDFc.m1);
lpStruct->m2 = env->GetShortField(lpObject, nsIDFc.m2);
{
jbyteArray lpObject1 = (jbyteArray)env->GetObjectField(lpObject, nsIDFc.m3);
env->GetByteArrayRegion(lpObject1, 0, sizeof(lpStruct->m3), (jbyte *)lpStruct->m3);
}
return lpStruct;
}
void setnsIDFields(JNIEnv *env, jobject lpObject, nsID *lpStruct)
{
if (!nsIDFc.cached) cachensIDFields(env, lpObject);
env->SetIntField(lpObject, nsIDFc.m0, (jint)lpStruct->m0);
env->SetShortField(lpObject, nsIDFc.m1, (jshort)lpStruct->m1);
env->SetShortField(lpObject, nsIDFc.m2, (jshort)lpStruct->m2);
{
jbyteArray lpObject1 = (jbyteArray)env->GetObjectField(lpObject, nsIDFc.m3);
env->SetByteArrayRegion(lpObject1, 0, sizeof(lpStruct->m3), (jbyte *)lpStruct->m3);
}
}
#endif