X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/121e1dc6ee0462b6f6f1f1570b0f48c61ee4ff9a..b9625f82f86db0674e911887addce45dca31b57f:/src/bindings/java/jmsg_as.cpp diff --git a/src/bindings/java/jmsg_as.cpp b/src/bindings/java/jmsg_as.cpp index 9b4f7bf3ae..405df1033d 100644 --- a/src/bindings/java/jmsg_as.cpp +++ b/src/bindings/java/jmsg_as.cpp @@ -1,23 +1,21 @@ /* Java bindings of the NetZones. */ -/* Copyright (c) 2007-2017. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2007-2020. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ +#include "simgrid/kernel/routing/NetZoneImpl.hpp" #include "simgrid/s4u/Host.hpp" #include "simgrid/s4u/NetZone.hpp" -#include "src/kernel/routing/NetZoneImpl.hpp" -#include "jmsg_as.h" +#include "jmsg.hpp" +#include "jmsg_as.hpp" #include "jmsg_host.h" -#include "jxbt_utilities.h" -#include "jmsg.h" +#include "jxbt_utilities.hpp" XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(java); -SG_BEGIN_DECL() - static jmethodID jas_method_As_constructor; static jfieldID jas_field_As_bind; @@ -57,35 +55,35 @@ JNIEXPORT void JNICALL Java_org_simgrid_msg_As_nativeInit(JNIEnv* env, jclass cl } JNIEXPORT jobject JNICALL Java_org_simgrid_msg_As_getName(JNIEnv * env, jobject jas) { - simgrid::s4u::NetZone* as = jnetzone_get_native(env, jas); - return env->NewStringUTF(as->name()); + const simgrid::s4u::NetZone* as = jnetzone_get_native(env, jas); + return env->NewStringUTF(as->get_cname()); } JNIEXPORT jobjectArray JNICALL Java_org_simgrid_msg_As_getSons(JNIEnv * env, jobject jas) { int index = 0; jobjectArray jtable; - sg_netzone_t self_as = jnetzone_get_native(env, jas); + const simgrid::s4u::NetZone* self_as = jnetzone_get_native(env, jas); jclass cls = env->FindClass("org/simgrid/msg/As"); - if (!cls) + if (not cls) return nullptr; - jtable = env->NewObjectArray(static_cast(self_as->children()->size()), cls, nullptr); + jtable = env->NewObjectArray(static_cast(self_as->get_children().size()), cls, nullptr); - if (!jtable) { + if (not jtable) { jxbt_throw_jni(env, "Hosts table allocation failed"); return nullptr; } - for (auto tmp_as : *self_as->children()) { + for (auto const& tmp_as : self_as->get_children()) { jobject tmp_jas = jnetzone_new_instance(env); - if (!tmp_jas) { + if (not tmp_jas) { jxbt_throw_jni(env, "java As instantiation failed"); return nullptr; } tmp_jas = jnetzone_ref(env, tmp_jas); - if (!tmp_jas) { + if (not tmp_jas) { jxbt_throw_jni(env, "new global ref allocation failed"); return nullptr; } @@ -98,16 +96,16 @@ JNIEXPORT jobjectArray JNICALL Java_org_simgrid_msg_As_getSons(JNIEnv * env, job } JNIEXPORT jobject JNICALL Java_org_simgrid_msg_As_getProperty(JNIEnv *env, jobject jas, jobject jname) { - simgrid::s4u::NetZone* as = jnetzone_get_native(env, jas); + const simgrid::s4u::NetZone* as = jnetzone_get_native(env, jas); - if (!as) { + if (not as) { jxbt_throw_notbound(env, "as", jas); return nullptr; } const char *name = env->GetStringUTFChars(static_cast(jname), 0); - const char *property = MSG_environment_as_get_property_value(as, name); - if (!property) { + const char* property = sg_zone_get_property_value(as, name); + if (not property) { return nullptr; } @@ -123,29 +121,30 @@ JNIEXPORT jobjectArray JNICALL Java_org_simgrid_msg_As_getHosts(JNIEnv * env, jo jobjectArray jtable; jobject jhost; jstring jname; - simgrid::s4u::NetZone* as = jnetzone_get_native(env, jas); + const simgrid::s4u::NetZone* as = jnetzone_get_native(env, jas); jclass cls = jxbt_get_class(env, "org/simgrid/msg/Host"); - std::vector* table = as->hosts(); - if (!cls) + if (not cls) return nullptr; - jtable = env->NewObjectArray(static_cast(table->size()), cls, nullptr); + std::vector table = as->get_all_hosts(); + + jtable = env->NewObjectArray(static_cast(table.size()), cls, nullptr); - if (!jtable) { + if (not jtable) { jxbt_throw_jni(env, "Hosts table allocation failed"); return nullptr; } int index = 0; - for (auto host : *table) { + for (auto const& host : table) { jhost = static_cast(host->extension(JAVA_HOST_LEVEL)); - if (!jhost) { - jname = env->NewStringUTF(host->cname()); + if (not jhost) { + jname = env->NewStringUTF(host->get_cname()); jhost = Java_org_simgrid_msg_Host_getByName(env, cls, jname); - env->ReleaseStringUTFChars(static_cast(jname), host->cname()); + env->ReleaseStringUTFChars(static_cast(jname), host->get_cname()); } env->SetObjectArrayElement(jtable, index, jhost); @@ -153,5 +152,3 @@ JNIEXPORT jobjectArray JNICALL Java_org_simgrid_msg_As_getHosts(JNIEnv * env, jo } return jtable; } - -SG_END_DECL()