referencetypeimpl.c

来自「This is a resource based on j2me embedde」· C语言 代码 · 共 632 行 · 第 1/2 页

C
632
字号
/* * @(#)ReferenceTypeImpl.c	1.45 06/10/25 * * Copyright  1990-2008 Sun Microsystems, Inc. All Rights Reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER *  * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License version * 2 only, as published by the Free Software Foundation.  *  * This program 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 * General Public License version 2 for more details (a copy is * included at /legal/license.txt).  *  * You should have received a copy of the GNU General Public License * version 2 along with this work; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA  *  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa * Clara, CA 95054 or visit www.sun.com if you need additional * information or have any questions.  */#include "util.h"#include "ReferenceTypeImpl.h"#include "inStream.h"#include "outStream.h"static jboolean signature(PacketInputStream *in, PacketOutputStream *out){    char *signature = NULL;        jclass clazz;    jvmtiError error;        clazz = inStream_readClassRef(getEnv(), in);    if (inStream_error(in)) {        return JNI_TRUE;    }    error = classSignature(clazz, &signature, NULL);    if (error != JVMTI_ERROR_NONE) {        outStream_setError(out, map2jdwpError(error));        return JNI_TRUE;    }    (void)outStream_writeString(out, signature);    jvmtiDeallocate(signature);        return JNI_TRUE;}static jbooleansignatureWithGeneric(PacketInputStream *in, PacketOutputStream *out){  /* Returns both the signature and the generic signature */    char *signature = NULL;    char *genericSignature = NULL;        jclass clazz;    jvmtiError error;        clazz = inStream_readClassRef(getEnv(), in);    if (inStream_error(in)) {        return JNI_TRUE;    }    error = classSignature(clazz, &signature, &genericSignature);    if (error != JVMTI_ERROR_NONE) {        outStream_setError(out, map2jdwpError(error));        return JNI_TRUE;    }    (void)outStream_writeString(out, signature);    writeGenericSignature(out, genericSignature);    jvmtiDeallocate(signature);    if (genericSignature != NULL) {      jvmtiDeallocate(genericSignature);    }        return JNI_TRUE;}static jboolean getClassLoader(PacketInputStream *in, PacketOutputStream *out){    jclass clazz;    jobject loader;    jvmtiError error;    JNIEnv *env;    env = getEnv();     clazz = inStream_readClassRef(env, in);    if (inStream_error(in)) {        return JNI_TRUE;    }    WITH_LOCAL_REFS(env, 1) {      error = classLoader(clazz, &loader);      if (error != JVMTI_ERROR_NONE) {        outStream_setError(out, map2jdwpError(error));      } else {        (void)outStream_writeObjectRef(env, out, loader);      }    } END_WITH_LOCAL_REFS(env);    return JNI_TRUE;}static jboolean modifiers(PacketInputStream *in, PacketOutputStream *out){    jint modifiers;    jclass clazz;    jvmtiError error;        clazz = inStream_readClassRef(getEnv(), in);    if (inStream_error(in)) {        return JNI_TRUE;    }    error = JVMTI_FUNC_PTR(gdata->jvmti,GetClassModifiers)                (gdata->jvmti, clazz, &modifiers);    if (error != JVMTI_ERROR_NONE) {        outStream_setError(out, map2jdwpError(error));        return JNI_TRUE;    }        (void)outStream_writeInt(out, modifiers);        return JNI_TRUE;}static void writeMethodInfo(PacketOutputStream *out, jclass clazz, jmethodID method,                int outputGenerics){    char *name = NULL;    char *signature = NULL;    char *genericSignature = NULL;    jint modifiers;    jvmtiError error;    jboolean isSynthetic;        error = isMethodSynthetic(method, &isSynthetic);    if (error != JVMTI_ERROR_NONE) {        outStream_setError(out, map2jdwpError(error));        return;    }    error = methodModifiers(method, &modifiers);    if (error != JVMTI_ERROR_NONE) {        outStream_setError(out, map2jdwpError(error));        return;    }        error = methodSignature(method, &name, &signature, &genericSignature);    if (error != JVMTI_ERROR_NONE) {        outStream_setError(out, map2jdwpError(error));        return;    }    if (isSynthetic) {        modifiers |= MOD_SYNTHETIC;    }    (void)outStream_writeMethodID(out, method);    (void)outStream_writeString(out, name);    (void)outStream_writeString(out, signature);    if (outputGenerics == 1) {        writeGenericSignature(out, genericSignature);    }    (void)outStream_writeInt(out, modifiers);    jvmtiDeallocate(name);    jvmtiDeallocate(signature);    if (genericSignature != NULL) {      jvmtiDeallocate(genericSignature);    }}static jboolean methods1(PacketInputStream *in, PacketOutputStream *out,         int outputGenerics){    int i;    jclass clazz;    jint methodCount = 0;    jmethodID *methods = NULL;    jvmtiError error;        clazz = inStream_readClassRef(getEnv(), in);    if (inStream_error(in)) {        return JNI_TRUE;    }    error = JVMTI_FUNC_PTR(gdata->jvmti,GetClassMethods)                (gdata->jvmti, clazz, &methodCount, &methods);    if (error != JVMTI_ERROR_NONE) {        outStream_setError(out, map2jdwpError(error));        return JNI_TRUE;    }    (void)outStream_writeInt(out, methodCount);    for (i = 0; (i < methodCount) && !outStream_error(out); i++) {        writeMethodInfo(out, clazz, methods[i], outputGenerics);    }    /* Free methods array */    if ( methods != NULL ) {        jvmtiDeallocate(methods);    }    return JNI_TRUE;}static jboolean methods(PacketInputStream *in, PacketOutputStream *out,         int outputGenerics){    return methods1(in, out, 0);}static jbooleanmethodsWithGeneric(PacketInputStream *in, PacketOutputStream *out) {    return methods1(in, out, 1);}static jbooleaninstances(PacketInputStream *in, PacketOutputStream *out) {    jint maxInstances;    jclass clazz;    JNIEnv *env;    if (gdata->vmDead) {        outStream_setError(out, JDWP_ERROR(VM_DEAD));                            return JNI_TRUE;    }    env = getEnv();    clazz = inStream_readClassRef(env, in);    maxInstances = inStream_readInt(in);    if (inStream_error(in)) {        return JNI_TRUE;    }            WITH_LOCAL_REFS(env, 1) {        jvmtiError   error;        ObjectBatch  batch;                error = classInstances(clazz, &batch, maxInstances);        if (error != JVMTI_ERROR_NONE) {            outStream_setError(out, map2jdwpError(error));        } else {            int kk;            jbyte typeKey;            (void)outStream_writeInt(out, batch.count);            if (batch.count > 0) {                /*                  * They are all instances of this class and will all have                  * the same typeKey, so just compute it once.                 */                typeKey = specificTypeKey(env, batch.objects[0]);                for (kk = 0; kk < batch.count; kk++) {                  jobject inst;                  inst = batch.objects[kk];                  (void)outStream_writeByte(out, typeKey);                  (void)outStream_writeObjectRef(env, out, inst);                }            }            jvmtiDeallocate(batch.objects);        }    } END_WITH_LOCAL_REFS(env);    return JNI_TRUE;}static jbooleangetClassVersion(PacketInputStream *in, PacketOutputStream *out) {    jclass clazz;    jvmtiError error;    jint majorVersion;    jint minorVersion;        clazz = inStream_readClassRef(getEnv(), in);    if (inStream_error(in)) {        return JNI_TRUE;    }    error = JVMTI_FUNC_PTR(gdata->jvmti, GetClassVersionNumbers)                (gdata->jvmti, clazz, &minorVersion, &majorVersion);    if (error != JVMTI_ERROR_NONE) {        outStream_setError(out, map2jdwpError(error));        return JNI_TRUE;    }     (void)outStream_writeInt(out, majorVersion);    (void)outStream_writeInt(out, minorVersion);    return JNI_TRUE;}static jbooleangetConstantPool(PacketInputStream *in, PacketOutputStream *out){    jclass clazz;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?