summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2015-10-03 08:43:41 -0700
committerPaul Sokolovsky <pfalcon@users.sourceforge.net>2015-10-03 08:58:46 -0700
commitf22be4ebd9cb301ec02257588e693647e6a01404 (patch)
treec054aef603d695b26c354baed1abaeaabf32e9ef
parent34f26ea862d18c61a66f36f44277bb954bf36cd1 (diff)
downloadmicropython-f22be4ebd9cb301ec02257588e693647e6a01404.tar.gz
micropython-f22be4ebd9cb301ec02257588e693647e6a01404.zip
unix/modjni: jobject.__str__/__repr__: Return Java .toString() value.
-rw-r--r--unix/modjni.c23
1 files changed, 16 insertions, 7 deletions
diff --git a/unix/modjni.c b/unix/modjni.c
index fa1fd8ce99..6847990532 100644
--- a/unix/modjni.c
+++ b/unix/modjni.c
@@ -48,7 +48,7 @@ static jmethodID Class_getField_mid;
static jmethodID Class_getMethods_mid;
static jmethodID Class_getConstructors_mid;
static jmethodID Method_getName_mid;
-static jmethodID Method_toString_mid;
+static jmethodID Object_toString_mid;
static jclass List_class;
static jmethodID List_get_mid;
@@ -180,10 +180,17 @@ STATIC mp_obj_t new_jclass(jclass jc) {
// jobject
STATIC void jobject_print(const mp_print_t *print, mp_obj_t self_in, mp_print_kind_t kind) {
- (void)kind;
mp_obj_jobject_t *self = self_in;
- // Variable value printed as cast to int
- mp_printf(print, "<jobject @%p>", self->obj);
+ if (kind == PRINT_REPR) {
+ mp_printf(print, "<jobject @%p \"", self->obj);
+ }
+ jobject str_o = JJ(CallObjectMethod, self->obj, Object_toString_mid);
+ const char *str = JJ(GetStringUTFChars, str_o, NULL);
+ mp_printf(print, str);
+ JJ(ReleaseStringUTFChars, str_o, str);
+ if (kind == PRINT_REPR) {
+ mp_printf(print, "\">");
+ }
}
STATIC void jobject_attr(mp_obj_t self_in, qstr attr_in, mp_obj_t *dest) {
@@ -358,7 +365,7 @@ STATIC mp_obj_t call_method(jobject obj, const char *name, jarray methods, bool
jsize num_methods = JJ(GetArrayLength, methods);
for (int i = 0; i < num_methods; i++) {
jobject meth = JJ(GetObjectArrayElement, methods, i);
- jobject name_o = JJ(CallObjectMethod, meth, Method_toString_mid);
+ jobject name_o = JJ(CallObjectMethod, meth, Object_toString_mid);
const char *decl = JJ(GetStringUTFChars, name_o, NULL);
const char *arg_types = strchr(decl, '(') + 1;
//const char *arg_types_end = strchr(arg_types, ')');
@@ -500,6 +507,10 @@ STATIC void create_jvm() {
jclass method_class = JJ(FindClass, "java/lang/reflect/Method");
String_class = JJ(FindClass, "java/lang/String");
+ jclass Object_class = JJ(FindClass, "java/lang/Object");
+ Object_toString_mid = JJ(GetMethodID, Object_class, "toString",
+ "()Ljava/lang/String;");
+
Class_getField_mid = (*env)->GetMethodID(env, Class_class, "getField",
"(Ljava/lang/String;)Ljava/lang/reflect/Field;");
Class_getMethods_mid = (*env)->GetMethodID(env, Class_class, "getMethods",
@@ -508,8 +519,6 @@ STATIC void create_jvm() {
"()[Ljava/lang/reflect/Constructor;");
Method_getName_mid = (*env)->GetMethodID(env, method_class, "getName",
"()Ljava/lang/String;");
- Method_toString_mid = (*env)->GetMethodID(env, method_class, "toString",
- "()Ljava/lang/String;");
List_class = JJ(FindClass, "java/util/List");
List_get_mid = JJ(GetMethodID, List_class, "get",