Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branch 'master' into actor-yield
[simgrid.git] / src / surf / PropertyHolder.cpp
index 97331c6..6298706 100644 (file)
@@ -1,41 +1,39 @@
-/* Copyright (c) 2015. The SimGrid Team. All rights reserved.               */
+/* Copyright (c) 2015-2017. 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 "xbt/sysdep.h"
 #include "PropertyHolder.hpp"
 
 namespace simgrid {
 namespace surf {
 
-PropertyHolder::PropertyHolder(xbt_dict_t props)
-: properties_(props)
-{
-}
-
 PropertyHolder::~PropertyHolder() {
-  xbt_dict_free(&properties_);
+  delete properties_;
 }
 
-/** @brief Return the property associated to the provided key (or NULL if not existing) */
-const char *PropertyHolder::getProperty(const char*key) {
-  if (properties_ == NULL)
-    return NULL;
-  return (const char*) xbt_dict_get_or_null(properties_,key);
+/** @brief Return the property associated to the provided key (or nullptr if not existing) */
+const char* PropertyHolder::getProperty(std::string key)
+{
+  if (properties_ == nullptr)
+    return nullptr;
+  auto prop = properties_->find(key);
+  return prop == properties_->end() ? nullptr : prop->second.c_str();
 }
 
 /** @brief Change the value of a given key in the property set */
-void PropertyHolder::setProperty(const char*key, const char*value) {
-  if (!properties_)
-    properties_ = xbt_dict_new();
-  xbt_dict_set(properties_, key, xbt_strdup(value), &xbt_free_f);
+void PropertyHolder::setProperty(std::string key, std::string value)
+{
+  if (not properties_)
+    properties_       = new std::map<std::string, std::string>;
+  (*properties_)[key] = value;
 }
 
 /** @brief Return the whole set of properties. Don't mess with it, dude! */
-xbt_dict_t PropertyHolder::getProperties() {
-  if (!properties_)
-    properties_ = xbt_dict_new();
+std::map<std::string, std::string>* PropertyHolder::getProperties()
+{
+  if (not properties_)
+    properties_ = new std::map<std::string, std::string>;
   return properties_;
 }