X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/bad4812e36b65cbfa8f5d14b56cd7fad34f1792b..b9d349f4e630752232d93f23b5cb3c33e02e0d05:/src/kernel/EngineImpl.hpp diff --git a/src/kernel/EngineImpl.hpp b/src/kernel/EngineImpl.hpp index 951418fea8..3e1585dff6 100644 --- a/src/kernel/EngineImpl.hpp +++ b/src/kernel/EngineImpl.hpp @@ -24,8 +24,12 @@ class EngineImpl { std::unordered_map netpoints_; std::unordered_map registered_functions; // Maps function names to actor code actor::ActorCodeFactory default_function; // Function to use as a fallback when the provided name matches nothing - std::vector> models_; - std::unordered_map> models_by_type_; + std::vector models_; + struct ModelStruct { + int prio; + std::shared_ptr ptr; + }; + std::unordered_map models_prio_; routing::NetZoneImpl* netzone_root_ = nullptr; friend s4u::Engine; @@ -44,19 +48,13 @@ public: /** * @brief Add a model to engine list * - * @param type Model type (network, disk, etc) * @param model Pointer to model - * @param is_default Is this the default model for this type of resource in this exp + * @param list List of dependencies for this model */ - void add_model(resource::Model::Type type, std::shared_ptr model, bool is_default = false); - /** @brief Get current default model for a resource type */ - resource::Model* get_default_model(resource::Model::Type type) const; - - /** @brief Get list of models created for a resource type */ - const std::vector& get_model_list(resource::Model::Type type); + void add_model(std::shared_ptr model, std::vector&& dep_models); /** @brief Get list of all models managed by this engine */ - const std::vector>& get_all_models() const { return models_; } + const std::vector& get_all_models() const { return models_; } static EngineImpl* get_instance() { return simgrid::s4u::Engine::get_instance()->pimpl; } actor::ActorCodeFactory get_function(const std::string& name)