Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Update copyright lines for 2022.
[simgrid.git] / src / surf / network_constant.hpp
index 6f88d3a..2a8c70f 100644 (file)
@@ -1,5 +1,4 @@
-/* Copyright (c) 2013-2015. The SimGrid Team.
- * All rights reserved.                                                     */
+/* Copyright (c) 2013-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. */
@@ -7,46 +6,31 @@
 #ifndef NETWORK_CONSTANT_HPP_
 #define NETWORK_CONSTANT_HPP_
 
-#include <xbt/base.h>
-
-#include "network_interface.hpp"
+#include "src/kernel/resource/LinkImpl.hpp"
 
 namespace simgrid {
-  namespace surf {
-
-    /***********
-     * Classes *
-     ***********/
-
-    class XBT_PRIVATE NetworkConstantModel;
-    class XBT_PRIVATE NetworkConstantAction;
-
-    /*********
-     * Model *
-     *********/
-    class NetworkConstantModel : public NetworkModel {
-    public:
-      NetworkConstantModel()  : NetworkModel() { };
-      ~NetworkConstantModel() { }
-
-      Action *communicate(NetCard *src, NetCard *dst, double size, double rate) override;
-      double next_occuring_event(double now) override;
-      bool next_occuring_event_isIdempotent() override {return true;}
-      void updateActionsState(double now, double delta) override;
-
-      Link* createLink(const char *name, double bw, double lat, e_surf_link_sharing_policy_t policy, xbt_dict_t properties) override;
-    };
-
-    /**********
-     * Action *
-     **********/
-    class NetworkConstantAction : public NetworkAction {
-    public:
-      NetworkConstantAction(NetworkConstantModel *model_, double size, double latency);
-      double initialLatency_;
-    };
-
-  }
-}
+namespace kernel {
+namespace resource {
+
+class NetworkConstantModel : public NetworkModel {
+public:
+  using NetworkModel::NetworkModel;
+  Action* communicate(s4u::Host* src, s4u::Host* dst, double size, double rate) override;
+  double next_occurring_event(double now) override;
+  void update_actions_state(double now, double delta) override;
+
+  StandardLinkImpl* create_link(const std::string& name, const std::vector<double>& bws) override;
+  StandardLinkImpl* create_wifi_link(const std::string& name, const std::vector<double>& bws) override;
+};
+
+class NetworkConstantAction final : public NetworkAction {
+public:
+  NetworkConstantAction(NetworkConstantModel* model_, s4u::Host& src, s4u::Host& dst, double size);
+  void update_remains_lazy(double now) override;
+};
+
+} // namespace resource
+} // namespace kernel
+} // namespace simgrid
 
 #endif /* NETWORK_CONSTANT_HPP_ */