simgrid::s4u::Engine *e = new simgrid::s4u::Engine(&argc,argv);
e->loadPlatform("../../platforms/two_hosts_platform.xml");
- new Worker("worker", simgrid::s4u::Host::byName("host0"), 0, NULL);
- new Master("master", simgrid::s4u::Host::byName("host1"), 0, NULL);
+ new Worker("worker", simgrid::s4u::Host::by_name("host0"), 0, NULL);
+ new Master("master", simgrid::s4u::Host::by_name("host1"), 0, NULL);
e->run();
return 0;
}
myHost(const char*procname, simgrid::s4u::Host *host,int argc, char **argv)
: simgrid::s4u::Actor(procname,host,argc,argv){}
- void show_info(boost::unordered_map <std::string, simgrid::s4u::Storage &> &mounts) {
+ void show_info(boost::unordered_map <std::string, simgrid::s4u::Storage*> &mounts) {
XBT_INFO("Storage info on %s:",
simgrid::s4u::Host::current()->name().c_str());
for (const auto&kv : mounts) {
const char* mountpoint = kv.first.c_str();
- simgrid::s4u::Storage &storage = kv.second;
+ simgrid::s4u::Storage &storage = *kv.second;
// Retrieve disk's information
sg_size_t free_size = storage.size_free();
}
int main(int argc, char **argv) {
- boost::unordered_map <std::string, simgrid::s4u::Storage &> &mounts =
+ boost::unordered_map <std::string, simgrid::s4u::Storage *>& mounts =
simgrid::s4u::Host::current()->mountedStorages();
show_info(mounts);
simgrid::s4u::Engine *e = new simgrid::s4u::Engine(&argc,argv);
e->loadPlatform("../../platforms/storage/storage.xml");
- new myHost("host", simgrid::s4u::Host::byName("denise"), 0, NULL);
+ new myHost("host", simgrid::s4u::Host::by_name("denise"), 0, NULL);
e->run();
return 0;
}
#include <simgrid/simix.h>
#include <simgrid/datatypes.h>
+#include <simgrid/s4u/forward.hpp>
namespace simgrid {
namespace s4u {
-class Actor;
-class Storage;
-class File;
-
/** @brief Simulated machine that can host some actors
*
* It represents some physical resource with computing and networking capabilities.
public: // TODO, make me private
~Host();
public:
- /** Retrieves an host from its name. */
- static s4u::Host *byName(std::string name);
- /** Retrieves the host on which the current actor is running */
- static s4u::Host *current();
static Host* by_name_or_null(const char* name);
static Host* by_name_or_create(const char* name);
+ /** Retrieves an host from its name. */
+ static s4u::Host *by_name(std::string name);
+ /** Retrieves the host on which the current actor is running */
+ static s4u::Host *current();
simgrid::xbt::string const& name() const { return name_; }
xbt_dict_t getMountedStorageList();
xbt_dynar_t getAttachedStorageList();
- /** Allows to store user data on that host */
- // TODO, use the extension stuff instead
- void set_userdata(void *data) {p_userdata = data;}
- /** Retrieves the previously stored data */
- void* userdata() {return p_userdata;}
-
/** Get an associative list [mount point]->[Storage] off all local mount points.
*
* This is defined in the platform file, and cannot be modified programatically (yet).
*
* Do not change the returned value in any way.
*/
- // TODO, do not use Storage&, this looks dangerous!
- boost::unordered_map<std::string, Storage&> &mountedStorages();
+ boost::unordered_map<std::string, Storage*> &mountedStorages();
private:
simgrid::xbt::string name_ = "noname";
- boost::unordered_map<std::string, Storage&> *mounts = NULL; // caching
- void* p_userdata = NULL;
+ boost::unordered_map<std::string, Storage*> *mounts = NULL; // caching
public:
// FIXME: these should be protected, but it leads to many errors
surf::NetCard *pimpl_netcard = nullptr;
public:
- static boost::unordered_map<std::string, s4u::Host *> *hosts;
-
/*** Called on each newly created object */
static simgrid::xbt::signal<void(Host&)> onCreation;
/*** Called just before destructing an object */
~fake_host() {}
};
fake_host foo;
- const size_t offset = (char*) &foo.host.getName() - (char*) &foo.host;
+ const size_t offset = (char*) &foo.host.name() - (char*) &foo.host;
// Read the simgrid::xbt::string in the MCed process:
mc_smx_process_info_t info = MC_smx_process_get_info(p);
}
s4u::Host *s4u::Actor::getHost() {
- return s4u::Host::byName(sg_host_get_name(simcall_process_get_host(p_smx_process)));
+ return s4u::Host::by_name(sg_host_get_name(simcall_process_get_host(p_smx_process)));
}
const char* s4u::Actor::getName() {
return simcall_process_get_name(p_smx_process);
namespace simgrid {
namespace s4u {
-boost::unordered_map<std::string, Host*> *Host::hosts
- = new boost::unordered_map<std::string, Host*>();
-
simgrid::xbt::signal<void(Host&)> Host::onCreation;
simgrid::xbt::signal<void(Host&)> Host::onDestruction;
simgrid::xbt::signal<void(Host&)> Host::onStateChange;
delete mounts;
}
-Host *Host::byName(std::string name) {
+Host *Host::by_name(std::string name) {
Host* host = Host::by_name_or_null(name.c_str());
// TODO, raise an exception instead?
if (host == nullptr)
return this->pimpl_cpu->getNbPStates();
}
-boost::unordered_map<std::string, Storage&> &Host::mountedStorages() {
+boost::unordered_map<std::string, Storage*> &Host::mountedStorages() {
if (mounts == NULL) {
- mounts = new boost::unordered_map<std::string, Storage&> ();
+ mounts = new boost::unordered_map<std::string, Storage*> ();
xbt_dict_t dict = this->getMountedStorageList();
char *mountname;
char *storagename;
xbt_dict_foreach(dict, cursor, mountname, storagename) {
- mounts->insert({mountname, Storage::byName(storagename)});
+ mounts->insert({mountname, &Storage::byName(storagename)});
}
xbt_dict_free(&dict);
}
SD_task_t taskInit;
SD_task_t taskA, taskB, taskC, taskD;
- xbt_dynar_t ret;
const SD_workstation_t *workstation;
&communication_amount1, -1.0);
- ret = SD_simulate(-1.);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.);
SD_task_destroy(taskA);
SD_task_destroy(taskB);
SD_task_destroy(taskC);
{
double time;
SD_task_t task;
- xbt_dynar_t ret;
double communication_amount[] = { 0.0, 1.0, 2.0, 3.0,
0.0, 0.0, 0.0, 0.0,
SD_task_schedule(task, 4, SD_workstation_get_list(), no_cost,
communication_amount, -1.0);
- ret = SD_simulate(-1.0);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.0);
time = SD_get_clock();
{
double time;
SD_task_t task;
- xbt_dynar_t ret;
SD_init(argc, argv);
SD_create_environment(argv[1]);
task = create_empty_cost_root();
- ret = SD_simulate(-1.0);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.0);
SD_task_destroy(task);
SD_application_reinit();
task = create_empty_cost_root();
- ret = SD_simulate(-1.0);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.0);
SD_task_destroy(task);
- ret = SD_simulate(-1.0);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.0);
time = SD_get_clock();
printf("%g\n", time);
{
double time;
SD_task_t task;
- xbt_dynar_t ret;
SD_init(argc, argv);
SD_create_environment(argv[1]);
task = create_root_with_costs();
- ret = SD_simulate(-1.0);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.0);
SD_task_destroy(task);
SD_application_reinit();
task = create_empty_cost_root();
- ret = SD_simulate(-1.0);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.0);
SD_task_destroy(task);
- ret = SD_simulate(-1.0);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.0);
time = SD_get_clock();
printf("%g\n", time);
double comp_cost[] = { 1.0, 1.0 };
SD_task_t task;
- xbt_dynar_t ret;
SD_init(&argc, argv);
SD_create_environment(argv[1]);
SD_task_schedule(task, 2, SD_workstation_get_list(), comp_cost,
comm_amount, -1.0);
- ret = SD_simulate(-1.0);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.0);
time = SD_get_clock();
double comp_cost[] = { 1.0 };
SD_task_t task;
- xbt_dynar_t ret;
SD_init(&argc, argv);
SD_create_environment(argv[1]);
SD_task_schedule(task, 1, SD_workstation_get_list(), comp_cost,
comm_amount, -1.0);
- ret = SD_simulate(-1.0);
- xbt_dynar_free(&ret);
+ SD_simulate(-1.0);
time = SD_get_clock();
include/xbt/cunit.h
include/xbt/dict.h
include/xbt/string.hpp
+ include/xbt/signal.hpp
include/xbt/dynar.h
include/xbt/ex.h
include/xbt/fifo.h