diff options
| author | Krasimir Angelov <kr.angelov@gmail.com> | 2017-08-30 08:15:59 +0200 |
|---|---|---|
| committer | Krasimir Angelov <kr.angelov@gmail.com> | 2017-08-30 08:15:59 +0200 |
| commit | d92f8f2f9e8fa2f74209d6eb0183bde2bdbe1214 (patch) | |
| tree | 908cfaf2f970259691ad44932181e0bcf597fa9d /src/runtime | |
| parent | 3e9de6ffbbe77f0ab41b62a7c7001a554f1900cf (diff) | |
added readType in Java
Diffstat (limited to 'src/runtime')
| -rw-r--r-- | src/runtime/java/jpgf.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/src/runtime/java/jpgf.c b/src/runtime/java/jpgf.c index f1396e526..52642533c 100644 --- a/src/runtime/java/jpgf.c +++ b/src/runtime/java/jpgf.c @@ -1539,6 +1539,34 @@ Java_org_grammaticalframework_pgf_Type_getHypos(JNIEnv* env, jobject self) return jhypos; } +JNIEXPORT jobject JNICALL +Java_org_grammaticalframework_pgf_Type_readType(JNIEnv* env, jclass clazz, jstring s) +{ + GuPool* pool = gu_new_pool(); + + GuPool* tmp_pool = gu_local_pool(); + GuString buf = j2gu_string(env, s, tmp_pool); + GuIn* in = gu_data_in((uint8_t*) buf, strlen(buf), tmp_pool); + GuExn* err = gu_exn(tmp_pool); + + PgfType* ty = pgf_read_type(in, pool, err); + if (!gu_ok(err)) { + throw_string_exception(env, "org/grammaticalframework/pgf/PGFError", "The type cannot be parsed"); + gu_pool_free(tmp_pool); + gu_pool_free(pool); + return NULL; + } + + gu_pool_free(tmp_pool); + + jclass pool_class = (*env)->FindClass(env, "org/grammaticalframework/pgf/Pool"); + jmethodID pool_constrId = (*env)->GetMethodID(env, pool_class, "<init>", "(J)V"); + jobject jpool = (*env)->NewObject(env, pool_class, pool_constrId, p2l(pool)); + + jmethodID constrId = (*env)->GetMethodID(env, clazz, "<init>", "(Ljava/lang/Object;J)V"); + return (*env)->NewObject(env, clazz, constrId, jpool, p2l(ty)); +} + JNIEXPORT jstring JNICALL Java_org_grammaticalframework_pgf_Type_toString(JNIEnv* env, jobject self) { |
