-/* Copyright (c) 2010-2020. The SimGrid Team. All rights reserved. */
+/* Copyright (c) 2010-2021. 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. */
class VariableType;
class Container {
+ static Container* root_container_;
+ static std::map<std::string, Container*, std::less<>> all_containers_;
+
long long int id_;
std::string name_; /* Unique name of this container */
+protected:
+ static void set_root(Container* root) { root_container_ = root; }
+
public:
- static xbt::signal<void(Container&)> on_creation;
- static xbt::signal<void(Container&)> on_destruction;
+ static xbt::signal<void(Container const&)> on_creation;
+ static xbt::signal<void(Container const&)> on_destruction;
explicit Container(const std::string& name, const std::string& type_name, Container* father);
Container(const Container&) = delete;
Type* type_; /* Type of this container */
Container* father_;
- std::map<std::string, Container*> children_;
- kernel::routing::NetPoint* netpoint_ = nullptr;
+ std::map<std::string, Container*, std::less<>> children_;
static Container* by_name_or_null(const std::string& name);
static Container* by_name(const std::string& name);
LinkType* get_link(const std::string& name);
VariableType* get_variable(const std::string& name);
void create_child(const std::string& name, const std::string& type_name);
- static Container* get_root();
+ static Container* get_root() { return root_container_; }
};
class NetZoneContainer : public Container {
class HostContainer : public Container {
public:
- HostContainer(simgrid::s4u::Host const& host, NetZoneContainer* father);
+ HostContainer(s4u::Host const& host, NetZoneContainer* father);
};
-}
-}
+} // namespace instr
+} // namespace simgrid
#endif