X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/ce9cbf0e2aea0198cb08a735a3ad36c6471f5468..69b64311b67fddc105da16faded6fecec9db45d3:/src/bindings/java/jmsg_as.cpp diff --git a/src/bindings/java/jmsg_as.cpp b/src/bindings/java/jmsg_as.cpp index 8124ac4a15..d814976a69 100644 --- a/src/bindings/java/jmsg_as.cpp +++ b/src/bindings/java/jmsg_as.cpp @@ -13,7 +13,7 @@ #include "jxbt_utilities.h" #include "jmsg.h" -XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(jmsg); +XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(java); SG_BEGIN_DECL() @@ -129,27 +129,22 @@ JNIEXPORT jobjectArray JNICALL Java_org_simgrid_msg_As_getHosts(JNIEnv * env, jo jobjectArray jtable; jobject jhost; jstring jname; - msg_host_t host; simgrid::s4u::NetZone* as = jnetzone_get_native(env, jas); - xbt_dynar_t table = as->hosts(); - int count = xbt_dynar_length(table); - jclass cls = jxbt_get_class(env, "org/simgrid/msg/Host"); - + std::vector* table = as->hosts(); if (!cls) return nullptr; - jtable = env->NewObjectArray(static_cast(count), cls, nullptr); + jtable = env->NewObjectArray(static_cast(table->size()), cls, nullptr); if (!jtable) { jxbt_throw_jni(env, "Hosts table allocation failed"); return nullptr; } - for (int index = 0; index < count; index++) { - host = xbt_dynar_get_as(table,index,msg_host_t); - + int index = 0; + for (auto host : *table) { jhost = static_cast(host->extension(JAVA_HOST_LEVEL)); if (!jhost) { jname = env->NewStringUTF(host->cname()); @@ -160,8 +155,8 @@ JNIEXPORT jobjectArray JNICALL Java_org_simgrid_msg_As_getHosts(JNIEnv * env, jo } env->SetObjectArrayElement(jtable, index, jhost); + index++; } - xbt_dynar_free(&table); return jtable; }