-/* Copyright (c) 2010-2014. The SimGrid Team.
+/* Copyright (c) 2010-2019. 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 <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-
-#include "xbt/dict.h"
-#include "xbt/dynar.h"
+#include "simgrid/jedule/jedule.hpp"
+#include "simgrid/s4u/NetZone.hpp"
#include "xbt/asserts.h"
-#include "simgrid/jedule/jedule_events.h"
-#include "simgrid/jedule/jedule_platform.h"
-
-#ifdef HAVE_JEDULE
-
-void jed_event_add_resources(jed_event_t event, xbt_dynar_t host_selection) {
- xbt_dynar_t resource_subset_list;
- jed_res_subset_t res_set;
- unsigned int i;
-
- resource_subset_list = xbt_dynar_new(sizeof(jed_res_subset_t), NULL);
+#if SIMGRID_HAVE_JEDULE
+namespace simgrid{
+namespace jedule{
- jed_simgrid_get_resource_selection_by_hosts(resource_subset_list, host_selection);
- xbt_dynar_foreach(resource_subset_list, i, res_set) {
- xbt_dynar_push(event->resource_subsets, &res_set);
- }
-
- xbt_dynar_free(&resource_subset_list);
+void Event::add_resources(const std::vector<sg_host_t>& host_selection)
+{
+ get_resource_selection_by_hosts(this->resource_subsets_, host_selection);
}
-void jed_event_add_characteristic(jed_event_t event, char *characteristic) {
- xbt_assert( characteristic != NULL );
- xbt_dynar_push(event->characteristics_list, &characteristic);
+void Event::add_characteristic(char* characteristic)
+{
+ xbt_assert( characteristic != nullptr );
+ this->characteristics_list_.push_back(characteristic);
}
-void jed_event_add_info(jed_event_t event, char *key, char *value) {
- char *val_cp;
-
- xbt_assert(key != NULL);
- xbt_assert(value != NULL);
-
- val_cp = strdup(value);
- xbt_dict_set(event->info_hash, key, val_cp, NULL);
+void Event::add_info(char* key, char* value)
+{
+ xbt_assert((key != nullptr) && value != nullptr);
+ this->info_map_.insert({key, value});
}
-void create_jed_event(jed_event_t *event, char *name, double start_time,
- double end_time, const char *type) {
-
- *event = xbt_new0(s_jed_event_t,1);
- (*event)->name = xbt_strdup(name);
+void Event::print(FILE* jed_file) const
+{
+ fprintf(jed_file, " <event>\n");
+ fprintf(jed_file, " <prop key=\"name\" value=\"%s\" />\n", this->name_.c_str());
+ fprintf(jed_file, " <prop key=\"start\" value=\"%g\" />\n", this->start_time_);
+ fprintf(jed_file, " <prop key=\"end\" value=\"%g\" />\n", this->end_time_);
+ fprintf(jed_file, " <prop key=\"type\" value=\"%s\" />\n", this->type_.c_str());
+
+ xbt_assert(not this->resource_subsets_.empty());
+ fprintf(jed_file, " <res_util>\n");
+ for (auto const& subset : this->resource_subsets_) {
+ fprintf(jed_file, " <select resources=\"");
+ fprintf(jed_file, "%s", subset.parent->get_hierarchy_as_string().c_str());
+ fprintf(jed_file, ".[%d-%d]", subset.start_idx, subset.start_idx + subset.nres - 1);
+ fprintf(jed_file, "\" />\n");
+ }
+ fprintf(jed_file, " </res_util>\n");
- (*event)->start_time = start_time;
- (*event)->end_time = end_time;
+ if (not this->characteristics_list_.empty()) {
+ fprintf(jed_file, " <characteristics>\n");
+ for (auto const& ch : this->characteristics_list_)
+ fprintf(jed_file, " <characteristic name=\"%s\" />\n", ch.c_str());
+ fprintf(jed_file, " </characteristics>\n");
+ }
- (*event)->type = xbt_strdup(type);
+ if (not this->info_map_.empty()) {
+ fprintf(jed_file, " <info>\n");
+ for (auto const& elm : this->info_map_)
+ fprintf(jed_file, " <prop key=\"%s\" value=\"%s\" />\n", elm.first.c_str(), elm.second.c_str());
+ fprintf(jed_file, " </info>\n");
+ }
- (*event)->resource_subsets = xbt_dynar_new(sizeof(jed_res_subset_t), xbt_free_ref);
- (*event)->characteristics_list = xbt_dynar_new(sizeof(char*), NULL);
- (*event)->info_hash = xbt_dict_new_homogeneous(NULL);
+ fprintf(jed_file, " </event>\n");
}
-void jed_event_free(jed_event_t event) {
- free(event->name);
- free(event->type);
-
- xbt_dynar_free(&event->resource_subsets);
-
- xbt_dynar_free(&event->characteristics_list);
- xbt_dict_free(&event->info_hash);
-
- free(event);
+}
}
#endif