X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/aa3595ed3c903167f52eeeab8e636bec96b258dd..bc0e9c9ecdf8b93f139978e522433f0a9fdcdedd:/src/msg/msg_environment.cpp diff --git a/src/msg/msg_environment.cpp b/src/msg/msg_environment.cpp index 2fbb89def1..3c3bdf8693 100644 --- a/src/msg/msg_environment.cpp +++ b/src/msg/msg_environment.cpp @@ -1,15 +1,11 @@ -/* Copyright (c) 2004-2015. The SimGrid Team. - * All rights reserved. */ +/* Copyright (c) 2004-2016. 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 "msg_private.h" -#include "xbt/sysdep.h" -#include "xbt/log.h" - #include "simgrid/s4u/NetZone.hpp" #include "simgrid/s4u/engine.hpp" +#include "src/msg/msg_private.h" #if HAVE_LUA #include @@ -17,6 +13,8 @@ #include #endif +SG_BEGIN_DECL() + /********************************* MSG **************************************/ /** \ingroup msg_simulation @@ -50,31 +48,49 @@ void MSG_post_create_environment() { } } -msg_as_t MSG_environment_get_routing_root() { +msg_netzone_t MSG_environment_get_routing_root() +{ return simgrid::s4u::Engine::instance()->netRoot(); } -const char *MSG_environment_as_get_name(msg_as_t as) { - return as->name(); +const char* MSG_environment_as_get_name(msg_netzone_t netzone) +{ + return netzone->name(); } -msg_as_t MSG_environment_as_get_by_name(const char * name) { +msg_netzone_t MSG_environment_as_get_by_name(const char* name) +{ return simgrid::s4u::Engine::instance()->netzoneByNameOrNull(name); } -xbt_dict_t MSG_environment_as_get_routing_sons(msg_as_t as) { - return as->children(); +xbt_dict_t MSG_environment_as_get_routing_sons(msg_netzone_t netzone) +{ + xbt_dict_t res = xbt_dict_new_homogeneous(nullptr); + for (auto elem : *netzone->children()) { + xbt_dict_set(res, elem->name(), static_cast(elem), nullptr); + } + return res; } -const char *MSG_environment_as_get_property_value(msg_as_t as, const char *name) +const char* MSG_environment_as_get_property_value(msg_netzone_t netzone, const char* name) { - xbt_dict_t dict = static_cast (xbt_lib_get_or_null(as_router_lib, MSG_environment_as_get_name(as), - ROUTING_PROP_ASR_LEVEL)); - if (dict==nullptr) - return nullptr; - return static_cast(xbt_dict_get_or_null(dict, name)); + return netzone->property(name); } -xbt_dynar_t MSG_environment_as_get_hosts(msg_as_t as) { - return as->hosts(); +void MSG_environment_as_set_property_value(msg_netzone_t netzone, const char* name, char* value) +{ + netzone->setProperty(name, value); } + +xbt_dynar_t MSG_environment_as_get_hosts(msg_netzone_t netzone) +{ + xbt_dynar_t res = xbt_dynar_new(sizeof(sg_host_t), nullptr); + + for (auto host : *netzone->hosts()) { + xbt_dynar_push(res, &host); + } + + return res; +} + +SG_END_DECL()