Ejemplo n.º 1
0
jboolean rvmThrowInternalErrorErrno(Env* env, int errnum) {
    char message[THROW_FORMAT_BUF_SIZE];
    if (strerror_r(errnum, message, THROW_FORMAT_BUF_SIZE) == 0) {
        return rvmThrowNew(env, java_lang_InternalError, message);
    } else {
        return rvmThrowNew(env, java_lang_InternalError, NULL);
    }
}
static void throwSocketExceptionErrno(Env* env, int errnum) {
    char message[512];
    JClass* exCls = rvmFindClassUsingLoader(env, "java/net/SocketException", NULL);
    if (!exCls) {
        return;
    }
    if (strerror_r(errnum, message, 512) == 0) {
        rvmThrowNew(env, exCls, message);
    } else {
        rvmThrowNew(env, exCls, NULL);
    }
}
Ejemplo n.º 3
0
jboolean rvmThrowNewf(Env* env, Class* clazz, const char* format, ...) {
    va_list ap;
    char message[THROW_FORMAT_BUF_SIZE];
    va_start(ap, format);
    vsnprintf(message, THROW_FORMAT_BUF_SIZE, format, ap);
    va_end(ap);
    return rvmThrowNew(env, clazz, message);
}
Ejemplo n.º 4
0
static Class* findType(Env* env, const char* classDesc, Object* loader) {
    Class* c = rvmFindClassByDescriptor(env, classDesc, loader);
    if (!c) {
        if (rvmExceptionOccurred(env)->clazz == java_lang_ClassNotFoundException) {
            rvmExceptionClear(env);
            char* className = rvmCopyMemoryAtomicZ(env, classDesc);
            className[strlen(className)] = 0;
            rvmThrowNew(env, java_lang_TypeNotPresentException, rvmFromBinaryClassName(env, &className[1]));
        }
    }
    return c;
}
Ejemplo n.º 5
0
char* toBinaryName(Env* env, Object* className) {
    if (!className) {
        rvmThrowNew(env, java_lang_NullPointerException, "className");
        return NULL;
    }
    char* classNameUTF = rvmGetStringUTFChars(env, className);
    if (!classNameUTF) return NULL;
    jint i;
    for (i = 0; classNameUTF[i] != '\0'; i++) {
        if (classNameUTF[i] == '.') classNameUTF[i] = '/';
    }
    return classNameUTF;
}
Ejemplo n.º 6
0
Object* rvmAllocateObject(Env* env, Class* clazz) {
    if (CLASS_IS_ABSTRACT(clazz) || CLASS_IS_INTERFACE(clazz)) {
        // TODO: Message
        rvmThrowNew(env, java_lang_InstantiationException, "");
        return NULL;
    }
    rvmInitialize(env, clazz);
    if (rvmExceptionOccurred(env)) return NULL;
    Object* obj = rvmAllocateMemoryForObject(env, clazz);
    if (!obj) return NULL;
    obj->clazz = clazz;
    return obj;
}
Ejemplo n.º 7
0
jboolean rvmThrowUnsatisfiedLinkError(Env* env, const char* message) {
    return rvmThrowNew(env, java_lang_UnsatisfiedLinkError, "");
}
Ejemplo n.º 8
0
jboolean rvmThrowNegativeArraySizeException(Env* env) {
    return rvmThrowNew(env, java_lang_NegativeArraySizeException, "");
}
Ejemplo n.º 9
0
jboolean rvmThrowClassNotFoundException(Env* env, const char* className) {
    char* msg = rvmToBinaryClassName(env, className);
    if (!msg) return FALSE;
    return rvmThrowNew(env, java_lang_ClassNotFoundException, msg);
}
Ejemplo n.º 10
0
jboolean rvmThrowNoClassDefFoundError(Env* env, const char* message) {
    return rvmThrowNew(env, java_lang_NoClassDefFoundError, message);
}
Ejemplo n.º 11
0
static void throwUnsupportedOperationException(Env* env, char* msg) {
    Class* clazz = rvmFindClassUsingLoader(env, "java/lang/UnsupportedOperationException", NULL);
    if (!clazz) return;
    rvmThrowNew(env, clazz, msg);
}
Ejemplo n.º 12
0
jboolean rvmThrowNewfv(Env* env, Class* clazz, const char* format, va_list ap) {
    char message[THROW_FORMAT_BUF_SIZE];
    vsnprintf(message, THROW_FORMAT_BUF_SIZE, format, ap);
    return rvmThrowNew(env, clazz, message);
}
Ejemplo n.º 13
0
jboolean rvmThrowIllegalStateException(Env* env, const char* message) {
    return rvmThrowNew(env, java_lang_IllegalStateException, message);
}
Ejemplo n.º 14
0
jboolean rvmThrowIncompatibleClassChangeErrorMethod(Env* env, Class* clazz, const char* name, const char* desc) {
    // TODO: Message should look like ?
    return rvmThrowNew(env, java_lang_IncompatibleClassChangeError, "");
}
Ejemplo n.º 15
0
jboolean rvmThrowIncompatibleClassChangeErrorInstanceField(Env* env, Class* clazz, const char* name, const char* desc) {
    // TODO: Message should look like "java.lang.ThrowIncompatibleClassChangeError: Expected non-static field a.C.x"
    return rvmThrowNew(env, java_lang_IncompatibleClassChangeError, "");
}
Ejemplo n.º 16
0
jboolean rvmThrowIncompatibleClassChangeError(Env* env, const char* message) {
    return rvmThrowNew(env, java_lang_IncompatibleClassChangeError, message);
}
Ejemplo n.º 17
0
jboolean rvmThrowNoSuchMethodError(Env* env, const char* message) {
    return rvmThrowNew(env, java_lang_NoSuchMethodError, message);
}
Ejemplo n.º 18
0
jboolean rvmThrowIllegalAccessError(Env* env, const char* message) {
    return rvmThrowNew(env, java_lang_IllegalAccessError, message);
}
Ejemplo n.º 19
0
jboolean rvmThrowLinkageError(Env* env) {
    return rvmThrowNew(env, java_lang_LinkageError, "");
}
Ejemplo n.º 20
0
jboolean rvmThrowArithmeticException(Env* env) {
    return rvmThrowNew(env, java_lang_ArithmeticException, NULL);
}
Ejemplo n.º 21
0
jboolean rvmThrowInterruptedException(Env* env) {
    return rvmThrowNew(env, java_lang_InterruptedException, NULL);
}
Ejemplo n.º 22
0
jboolean rvmThrowClassCastException(Env* env, Class* expectedClass, Class* actualClass) {
    // TODO: Message should look like "java.lang.ClassCastException: java.lang.Object cannot be cast to java.lang.String"
    return rvmThrowNew(env, java_lang_ClassCastException, "");
}
Ejemplo n.º 23
0
jboolean rvmThrowInstantiationError(Env* env, const char* message) {
    return rvmThrowNew(env, java_lang_InstantiationError, message);
}
Ejemplo n.º 24
0
static jboolean throwFormatError(Env* env, char* expectedType) {
    char msg[64];
    snprintf(msg, sizeof(msg), "Invalid format: %s expected", expectedType);
    rvmThrowNew(env, java_lang_annotation_AnnotationFormatError, msg);
    return FALSE;
}
Ejemplo n.º 25
0
static jint ThrowNew(JNIEnv* env, jclass clazz, const char* msg) {
    return rvmThrowNew((Env*) env, (Class*) clazz, msg) ? 0 : -1;
}
Ejemplo n.º 26
0
jboolean rvmThrowArrayStoreException(Env* env) {
    return rvmThrowNew(env, java_lang_ArrayStoreException, "");
}
Ejemplo n.º 27
0
jboolean rvmThrowNullPointerException(Env* env) {
    return rvmThrowNew(env, java_lang_NullPointerException, NULL);
}
Ejemplo n.º 28
0
jboolean rvmThrowOutOfMemoryError(Env* env) {
    return rvmThrowNew(env, java_lang_OutOfMemoryError, NULL);
}
Ejemplo n.º 29
0
jboolean rvmThrowAbstractMethodError(Env* env, const char* message) {
    return rvmThrowNew(env, java_lang_AbstractMethodError, message);
}
Ejemplo n.º 30
0
void rvmInitialize(Env* env, Class* clazz) {
    obtainClassLock();
    // TODO: Throw java.lang.NoClassDefFoundError if state == CLASS_ERROR?
    if (CLASS_IS_STATE_ERROR(clazz)) {
        // TODO: Add the class' binary name in the message
        rvmThrowNew(env, java_lang_NoClassDefFoundError, "Could not initialize class ??");
        releaseClassLock();
        return;
    }
    if (!CLASS_IS_STATE_INITIALIZED(clazz) && !CLASS_IS_STATE_INITIALIZING(clazz)) {
        jint oldState = clazz->flags & CLASS_STATE_MASK;
        clazz->flags = (clazz->flags & (~CLASS_STATE_MASK)) | CLASS_STATE_INITIALIZING;
        if (clazz->superclass) {
            rvmInitialize(env, clazz->superclass);
            if (rvmExceptionOccurred(env)) {
                clazz->flags = (clazz->flags & (~CLASS_STATE_MASK)) | oldState;
                releaseClassLock();
                return;
            }
        }

        TRACEF("Initializing class %s", clazz->name);
        void* initializer = clazz->initializer;
        if (!initializer) {
            if (!CLASS_IS_ARRAY(clazz) && !CLASS_IS_PROXY(clazz) && !CLASS_IS_PRIMITIVE(clazz)) {
                env->vm->options->classInitialized(env, clazz);
            }
            clazz->flags = (clazz->flags & (~CLASS_STATE_MASK)) | CLASS_STATE_INITIALIZED;
            releaseClassLock();
            return;
        }

        CallInfo* callInfo = call0AllocateCallInfo(env, initializer, 1, 0, 0, 0, 0);
        call0AddPtr(callInfo, env);
        void (*f)(CallInfo*) = (void (*)(CallInfo*)) _call0;
        rvmPushGatewayFrame(env);
        TrycatchContext tc = {0};
        tc.sel = CATCH_ALL_SEL;
        if (!rvmTrycatchEnter(env, &tc)) {
            f(callInfo);
        }
        rvmTrycatchLeave(env);
        rvmPopGatewayFrame(env);

        Object* exception = rvmExceptionClear(env);
        if (exception) {
            clazz->flags = (clazz->flags & (~CLASS_STATE_MASK)) | CLASS_STATE_ERROR;
            if (!rvmIsInstanceOf(env, exception, java_lang_Error)) {
                // If exception isn't an instance of java.lang.Error 
                // we must wrap it in a java.lang.ExceptionInInitializerError
                Method* constructor = rvmGetInstanceMethod(env, java_lang_ExceptionInInitializerError, "<init>", "(Ljava/lang/Throwable;)V");
                if (!constructor) return;
                Object* wrappedException = rvmNewObject(env, java_lang_ExceptionInInitializerError, constructor, exception);
                if (!wrappedException) return;
                exception = wrappedException;
            }
            rvmThrow(env, exception);
            releaseClassLock();
            return;
        }
        if (!CLASS_IS_ARRAY(clazz) && !CLASS_IS_PROXY(clazz) && !CLASS_IS_PRIMITIVE(clazz)) {
            env->vm->options->classInitialized(env, clazz);
        }
        clazz->flags = (clazz->flags & (~CLASS_STATE_MASK)) | CLASS_STATE_INITIALIZED;
    }
    releaseClassLock();
}