arraytypeimpl.c

来自「This is a resource based on j2me embedde」· C语言 代码 · 共 246 行

C
246
字号
/* * @(#)ArrayTypeImpl.c	1.23 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 "ArrayTypeImpl.h"#include "util.h"#include "inStream.h"#include "outStream.h"/* * Determine the component class by looking thru all classes for * one that has the signature of the component and the same class loadeer * as the array.  See JVM spec 5.3.3: *     If the component type is a reference type, C is marked as having *     been defined by the defining class loader of the component type. */static jdwpError getComponentClass(JNIEnv *env, jclass arrayClass, char *componentSignature,                 jclass *componentClassPtr) {    jobject arrayClassLoader;    jclass *classes;    jint count;    jclass componentClass = NULL;    jdwpError serror;    jvmtiError error;    serror = JDWP_ERROR(NONE);        error = classLoader(arrayClass, &arrayClassLoader);    if (error != JVMTI_ERROR_NONE) {        return map2jdwpError(error);    }        error = allLoadedClasses(&classes, &count);    if (error != JVMTI_ERROR_NONE) {        serror = map2jdwpError(error);    } else {        int i;        for (i = 0; (i < count) && (componentClass == NULL); i++) {            char *signature = NULL;            jclass clazz = classes[i];            jboolean match;            jvmtiError error;            /* signature must match */            error = classSignature(clazz, &signature, NULL);            if (error != JVMTI_ERROR_NONE) {                serror = map2jdwpError(error);                break;            }            match = strcmp(signature, componentSignature) == 0;            jvmtiDeallocate(signature);            /* if signature matches, get class loader to check if             * it matches              */            if (match) {                jobject loader;                error = classLoader(clazz, &loader);                if (error != JVMTI_ERROR_NONE) {                    return map2jdwpError(error);                }                match = isSameObject(env, loader, arrayClassLoader);            }            if (match) {                componentClass = clazz;            } else {            }        }        jvmtiDeallocate(classes);        *componentClassPtr = componentClass;    }    if (serror == JDWP_ERROR(NONE) && componentClass == NULL) {        /* per JVM spec, component class is always loaded          * before array class, so this should never occur.         */        serror = JDWP_ERROR(NOT_FOUND);    }    return serror;}static voidwriteNewObjectArray(JNIEnv *env, PacketOutputStream *out,                  jclass arrayClass, jint size, char *componentSignature){    WITH_LOCAL_REFS(env, 2000) {        jarray array;        jclass componentClass = NULL;        jdwpError serror;                serror = getComponentClass(env, arrayClass,                                        componentSignature, &componentClass);        if (serror != JDWP_ERROR(NONE)) {            outStream_setError(out, serror);        } else {            array = JNI_FUNC_PTR(env,NewObjectArray)(env, size, componentClass, 0);            if (JNI_FUNC_PTR(env,ExceptionOccurred)(env)) {                JNI_FUNC_PTR(env,ExceptionClear)(env);                array = NULL;            }            if (array == NULL) {                outStream_setError(out, JDWP_ERROR(OUT_OF_MEMORY));            } else {                (void)outStream_writeByte(out, specificTypeKey(env, array));                (void)outStream_writeObjectRef(env, out, array);            }        }    } END_WITH_LOCAL_REFS(env);}static voidwriteNewPrimitiveArray(JNIEnv *env, PacketOutputStream *out,                        jclass arrayClass, jint size, char *componentSignature) {    WITH_LOCAL_REFS(env, 1) {        jarray array = NULL;        switch (componentSignature[0]) {            case JDWP_TAG(BYTE):                array = JNI_FUNC_PTR(env,NewByteArray)(env, size);                break;            case JDWP_TAG(CHAR):                array = JNI_FUNC_PTR(env,NewCharArray)(env, size);                break;            case JDWP_TAG(FLOAT):                array = JNI_FUNC_PTR(env,NewFloatArray)(env, size);                break;            case JDWP_TAG(DOUBLE):                array = JNI_FUNC_PTR(env,NewDoubleArray)(env, size);                break;            case JDWP_TAG(INT):                array = JNI_FUNC_PTR(env,NewIntArray)(env, size);                break;            case JDWP_TAG(LONG):                array = JNI_FUNC_PTR(env,NewLongArray)(env, size);                break;            case JDWP_TAG(SHORT):                array = JNI_FUNC_PTR(env,NewShortArray)(env, size);                break;            case JDWP_TAG(BOOLEAN):                array = JNI_FUNC_PTR(env,NewBooleanArray)(env, size);                break;            default:                outStream_setError(out, JDWP_ERROR(TYPE_MISMATCH));                break;        }        if (JNI_FUNC_PTR(env,ExceptionOccurred)(env)) {            JNI_FUNC_PTR(env,ExceptionClear)(env);            array = NULL;        }        if (array == NULL) {            outStream_setError(out, JDWP_ERROR(OUT_OF_MEMORY));        } else {            (void)outStream_writeByte(out, specificTypeKey(env, array));            (void)outStream_writeObjectRef(env, out, array);        }    } END_WITH_LOCAL_REFS(env);}static jboolean newInstance(PacketInputStream *in, PacketOutputStream *out){    JNIEnv *env;    char *signature = NULL;    char *componentSignature;    jclass arrayClass;    jint size;    jvmtiError error;        env = getEnv();        arrayClass = inStream_readClassRef(env, in);    if (inStream_error(in)) {        return JNI_TRUE;    }    size = inStream_readInt(in);    if (inStream_error(in)) {        return JNI_TRUE;    }    error = classSignature(arrayClass, &signature, NULL);    if ( error != JVMTI_ERROR_NONE ) {        outStream_setError(out, map2jdwpError(error));        return JNI_FALSE;    }    componentSignature = &signature[1];    if ((componentSignature[0] == JDWP_TAG(OBJECT)) ||         (componentSignature[0] == JDWP_TAG(ARRAY))) {        writeNewObjectArray(env, out, arrayClass, size, componentSignature);    } else {        writeNewPrimitiveArray(env, out, arrayClass, size, componentSignature);    }    jvmtiDeallocate(signature);    return JNI_TRUE;}void *ArrayType_Cmds[] = { (void *)0x1                          ,(void *)newInstance};

⌨️ 快捷键说明

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