EMANE  1.2.1
timestampcontrolmessage.cc
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 
34 
35 class EMANE::Controls::TimeStampControlMessage::Implementation
36 {
37 public:
38  Implementation(const TimePoint & timeStamp):
39  timeStamp_{timeStamp}{}
40 
41  TimePoint getTimeStamp() const
42  {
43  return timeStamp_;
44  }
45 
46 private:
47  const TimePoint timeStamp_;
48 };
49 
50 EMANE::Controls::TimeStampControlMessage::
51 TimeStampControlMessage(const TimeStampControlMessage & msg):
52  ControlMessage{IDENTIFIER},
53  pImpl_{new Implementation{*msg.pImpl_}}
54 {}
55 
56 EMANE::Controls::TimeStampControlMessage::TimeStampControlMessage(const TimePoint & timeStamp):
57  ControlMessage{IDENTIFIER},
58  pImpl_{new Implementation{timeStamp}}{}
59 
61 
62 
65 {
66  return new TimeStampControlMessage{timeStamp};
67 }
68 
70 {
71  return pImpl_->getTimeStamp();
72 }
73 
76 {
77  return new TimeStampControlMessage{*this};
78 }
TimeStampControlMessage * clone() const override
static TimeStampControlMessage * create(const TimePoint &timestamp)
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
ControlMessage(ControlMessageId id)