X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/4dc2608f9460271cc08c6218fcbf9c1bfd7cf641..ffd004a13acd17db31f5d5df1bc2fc2dc696b9a9:/src/kernel/EngineImpl.hpp diff --git a/src/kernel/EngineImpl.hpp b/src/kernel/EngineImpl.hpp index 1a12c38a9c..69963c84db 100644 --- a/src/kernel/EngineImpl.hpp +++ b/src/kernel/EngineImpl.hpp @@ -24,8 +24,9 @@ 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_; + std::unordered_map> models_prio_; + routing::NetZoneImpl* netzone_root_ = nullptr; friend s4u::Engine; @@ -43,31 +44,15 @@ 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 Add a model (specific for ptask) - * - * Ptask is special. The CPU and NETWORK models need to be in the managed - * resources by surf_solve (model_by_type) but cannot be in the list of - * all models (old all_existing_models global variable) - * - * This methods does this job while we cannot handle ptask as the remaining models - */ - void add_model_ptask(resource::Model::Type type, resource::Model* model, bool is_default); - /** @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, + const 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_; } - routing::NetZoneImpl* netzone_root_ = nullptr; static EngineImpl* get_instance() { return simgrid::s4u::Engine::get_instance()->pimpl; } actor::ActorCodeFactory get_function(const std::string& name) {