diff options
| author | Bob Jamison <ishmalius@gmail.com> | 2008-03-12 19:55:00 +0000 |
|---|---|---|
| committer | ishmal <ishmal@users.sourceforge.net> | 2008-03-12 19:55:00 +0000 |
| commit | 13f26e9ea37387adce6567fbacf8fc062b29f959 (patch) | |
| tree | ca9cb5e26cd41bc56ac0a715e26654c9badcb79f /src/bind/javabind.cpp | |
| parent | Better test (diff) | |
| download | inkscape-13f26e9ea37387adce6567fbacf8fc062b29f959.tar.gz inkscape-13f26e9ea37387adce6567fbacf8fc062b29f959.zip | |
Split getException into method and function, so it can be used in native functions.
(bzr r5069)
Diffstat (limited to 'src/bind/javabind.cpp')
| -rw-r--r-- | src/bind/javabind.cpp | 29 |
1 files changed, 17 insertions, 12 deletions
diff --git a/src/bind/javabind.cpp b/src/bind/javabind.cpp index b03d562ce..1424a527b 100644 --- a/src/bind/javabind.cpp +++ b/src/bind/javabind.cpp @@ -102,6 +102,21 @@ String normalizePath(const String &str) return buf; } +String getExceptionString(JNIEnv *env) +{ + String buf; + jthrowable exc = env->ExceptionOccurred(); + if (!exc) + return buf; + jclass cls = env->GetObjectClass(exc); + jmethodID mid = env->GetMethodID(cls, "toString", "()Ljava/lang/String;"); + jstring jstr = (jstring) env->CallObjectMethod(exc, mid); + const char *str = env->GetStringUTFChars(jstr, JNI_FALSE); + buf.append(str); + env->ReleaseStringUTFChars(jstr, str); + env->ExceptionClear(); + return buf; +} jint getInt(JNIEnv *env, jobject obj, const char *name) { @@ -901,6 +916,7 @@ bool JavaBinderyImpl::callStatic(int type, + /** * Fetch the last exception from the JVM, if any. Clear it to * continue processing @@ -909,18 +925,7 @@ bool JavaBinderyImpl::callStatic(int type, */ String JavaBinderyImpl::getException() { - String buf; - jthrowable exc = env->ExceptionOccurred(); - if (!exc) - return buf; - jclass cls = env->GetObjectClass(exc); - jmethodID mid = env->GetMethodID(cls, "toString", "()Ljava/lang/String;"); - jstring jstr = (jstring) env->CallObjectMethod(exc, mid); - const char *str = env->GetStringUTFChars(jstr, JNI_FALSE); - buf.append(str); - env->ReleaseStringUTFChars(jstr, str); - env->ExceptionClear(); - return buf; + return getExceptionString(env); } |
