Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
I'm glad: this prototype was not used
[simgrid.git] / src / surf / network_constant.hpp
1 /* Copyright (c) 2013-2015. The SimGrid Team.
2  * All rights reserved.                                                     */
3
4 /* This program is free software; you can redistribute it and/or modify it
5  * under the terms of the license (GNU LGPL) which comes with this package. */
6
7 #ifndef NETWORK_CONSTANT_HPP_
8 #define NETWORK_CONSTANT_HPP_
9
10 #include <xbt/base.h>
11
12 #include "network_interface.hpp"
13
14 namespace simgrid {
15   namespace surf {
16
17     /***********
18      * Classes *
19      ***********/
20
21     class XBT_PRIVATE NetworkConstantModel;
22     class XBT_PRIVATE NetworkConstantAction;
23
24     /*********
25      * Model *
26      *********/
27     class NetworkConstantModel : public NetworkModel {
28     public:
29       NetworkConstantModel()  : NetworkModel() { };
30       ~NetworkConstantModel() { }
31
32       Action *communicate(NetCard *src, NetCard *dst, double size, double rate) override;
33       double next_occuring_event(double now) override;
34       bool next_occuring_event_isIdempotent() override {return true;}
35       void updateActionsState(double now, double delta) override;
36
37       Link*
38       createLink(const char *name,
39           double bw_initial, tmgr_trace_t bw_trace,
40           double lat_initial, tmgr_trace_t lat_trace,
41           tmgr_trace_t state_trace,
42           e_surf_link_sharing_policy_t policy,
43           xbt_dict_t properties)          override { DIE_IMPOSSIBLE; }
44     };
45
46     /**********
47      * Action *
48      **********/
49     class NetworkConstantAction : public NetworkAction {
50     public:
51       NetworkConstantAction(NetworkConstantModel *model_, double size, double latency)
52     : NetworkAction(model_, size, false)
53     , m_latInit(latency)
54     {
55         m_latency = latency;
56         if (m_latency <= 0.0) {
57           p_stateSet = getModel()->getDoneActionSet();
58           p_stateSet->push_back(*this);
59         }
60         p_variable = NULL;
61     };
62       int unref() override;
63       void cancel() override;
64       double m_latInit;
65     };
66
67   }
68 }
69
70 #endif /* NETWORK_CONSTANT_HPP_ */