X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/39c935d6d5ee86d153f6f7e6a10d723ae7c57f6f..2e7129924068cc550bffddb396bc236f66360735:/src/instr/instr_paje_containers.hpp?ds=sidebyside diff --git a/src/instr/instr_paje_containers.hpp b/src/instr/instr_paje_containers.hpp index 3ab8fe8579..06e6219cc2 100644 --- a/src/instr/instr_paje_containers.hpp +++ b/src/instr/instr_paje_containers.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2010-2021. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2010-2022. 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. */ @@ -17,27 +17,32 @@ class StateType; class VariableType; class Container { + friend class NetZoneContainer; static Container* root_container_; static std::map> all_containers_; long long int id_; std::string name_; /* Unique name of this container */ + Type* type_; /* Type of this container */ + Container* parent_; + std::map> children_; protected: static void set_root(Container* root) { root_container_ = root; } -public: +private: static xbt::signal on_creation; static xbt::signal on_destruction; - explicit Container(const std::string& name, const std::string& type_name, Container* father); +public: + static void on_creation_cb(const std::function& cb) { on_creation.connect(cb); } + static void on_destruction_cb(const std::function& cb) { on_destruction.connect(cb); } + + explicit Container(const std::string& name, const std::string& type_name, Container* parent); Container(const Container&) = delete; Container& operator=(const Container&) = delete; virtual ~Container(); - Type* type_; /* Type of this container */ - Container* father_; - std::map> children_; static Container* by_name_or_null(const std::string& name); static Container* by_name(const std::string& name); @@ -46,26 +51,29 @@ public: long long int get_id() const { return id_; } void remove_from_parent(); + Container* get_parent() const { return parent_; } + Type* get_type() const { return type_; } StateType* get_state(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); + Container* get_child_by_name(const std::string& name) const { return children_.at(name); } static Container* get_root() { return root_container_; } }; class NetZoneContainer : public Container { public: - NetZoneContainer(const std::string& name, unsigned int level, NetZoneContainer* father); + NetZoneContainer(const std::string& name, unsigned int level, NetZoneContainer* parent); }; class RouterContainer : public Container { public: - RouterContainer(const std::string& name, Container* father); + RouterContainer(const std::string& name, Container* parent); }; class HostContainer : public Container { public: - HostContainer(s4u::Host const& host, NetZoneContainer* father); + HostContainer(s4u::Host const& host, NetZoneContainer* parent); }; } // namespace instr } // namespace simgrid