Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
create a singleton for s4u::Engine
authorMartin Quinson <martin.quinson@loria.fr>
Tue, 1 Mar 2016 15:52:57 +0000 (16:52 +0100)
committerMartin Quinson <martin.quinson@loria.fr>
Tue, 1 Mar 2016 15:52:57 +0000 (16:52 +0100)
include/simgrid/s4u/engine.hpp
src/s4u/s4u_engine.cpp

index b81a57f..2c9fa3c 100644 (file)
@@ -47,6 +47,10 @@ public:
   /** @brief Retrieve the simulation time */
   static double getClock();
   
+  /** @brief Retrieve the engine singleton */
+  static s4u::Engine *instance();
+private:
+  static s4u::Engine *instance_;
 };
 }} // namespace simgrid::sgo
 
index ca3415a..ce3cc47 100644 (file)
 XBT_LOG_NEW_CATEGORY(s4u,"Log channels of the S4U (Simgrid for you) interface");
 using namespace simgrid;
 
-double s4u::Engine::getClock() {
-  return SIMIX_get_clock();
-}
+s4u::Engine *s4u::Engine::instance_ = nullptr; /* That singleton is awful, but I don't see no other solution right now. */
+
 
 s4u::Engine::Engine(int *argc, char **argv) {
+  xbt_assert(s4u::Engine::instance_ == nullptr, "It is currently forbidden to create more than one instance of s4u::Engine");
+  s4u::Engine::instance_ = this;
+
   SIMIX_global_init(argc, argv);
 }
 
+s4u::Engine *s4u::Engine::instance() {
+  if (s4u::Engine::instance_ == nullptr)
+    new Engine(0,nullptr);
+  return s4u::Engine::instance_;
+}
+
+double s4u::Engine::getClock() {
+  return SIMIX_get_clock();
+}
+
 void s4u::Engine::loadPlatform(const char *platf) {
   SIMIX_create_environment(platf);
 }