EMANE  1.2.1
timestampcontrolmessage.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2014 - Adjacent Link LLC, Bridgewater, New Jersey
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  * * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in
13  * the documentation and/or other materials provided with the
14  * distribution.
15  * * Neither the name of Adjacent Link LLC nor the names of its
16  * contributors may be used to endorse or promote products derived
17  * from this software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30  * POSSIBILITY OF SUCH DAMAGE.
31  */
32 
33 #ifndef EMANECONTROLSTIMESTAMPMESSAGE_HEADER_
34 #define EMANECONTROLSTIMESTAMPMESSAGE_HEADER_
35 
36 #include "emane/controlmessage.h"
38 
39 #include <memory>
40 
41 namespace EMANE
42 {
43  namespace Controls
44  {
61  {
62  public:
77  static
78  TimeStampControlMessage * create(const TimePoint & timestamp);
79 
87  TimeStampControlMessage * clone() const override;
88 
93 
99  TimePoint getTimeStamp() const;
100 
102 
103  private:
104  class Implementation;
105  std::unique_ptr<Implementation> pImpl_;
106 
107  TimeStampControlMessage(const TimePoint & timestamp);
108 
110 
112  operator=(const TimeStampControlMessage &) = delete;
113  };
114  }
115 }
116 
117 #endif // EMANECONTROLSTIMESTAMPMESSAGE_HEADER_
TimeStampControlMessage * clone() const override
static TimeStampControlMessage * create(const TimePoint &timestamp)
#define EMANE_CONTROL_MEASSGE_TIME_STAMP
ControlMessage interface is the base for all control messages.
Time Stamp Control Message is sent to the emulator physical layer to specify the time that should be ...
Clock::time_point TimePoint
Definition: types.h:50
Definition: agent.h:43