OMNeT++ Simulation Library  5.6.1
cmessage.h
1 //==========================================================================
2 // CMESSAGE.H - header for
3 // OMNeT++/OMNEST
4 // Discrete System Simulation in C++
5 //
6 //==========================================================================
7 
8 /*--------------------------------------------------------------*
9  Copyright (C) 1992-2017 Andras Varga
10  Copyright (C) 2006-2017 OpenSim Ltd.
11 
12  This file is distributed WITHOUT ANY WARRANTY. See the file
13  `license' for details on this and other legal matters.
14 *--------------------------------------------------------------*/
15 
16 #ifndef __OMNETPP_CMESSAGE_H
17 #define __OMNETPP_CMESSAGE_H
18 
19 #include <vector>
20 #include "cevent.h"
21 #include "carray.h"
22 #include "cmsgpar.h"
23 #include "csimulation.h"
24 
25 namespace omnetpp {
26 
27 class cMsgPar;
28 class cGate;
29 class cChannel;
30 class cModule;
31 class cSimpleModule;
32 class cSimulation;
33 
42 enum eMessageKind
43 {
44  MK_STARTER = -1,
45  MK_TIMEOUT = -2,
46  MK_PARSIM_BEGIN = -1000
47 };
48 
55 // Note: it cannot go to cparsimcomm.h, without causing unwanted dependency on sim/parsim
56 #define MAX_PARSIM_PARTITIONS 32768 // srcprocid in cMessage
57 
58 
95 class SIM_API cMessage : public cEvent
96 {
97  private:
98  enum {
99  FL_ISPRIVATECOPY = 4,
100  };
101  // note: fields are in an order that maximizes packing (minimizes sizeof(cMessage))
102  short messageKind; // message kind -- 0>= user-defined meaning, <0 reserved
103  short srcProcId; // reserved for use by parallel execution: id of source partition
104  cArray *parList; // ptr to list of parameters
105  cObject *controlInfo; // ptr to "control info"
106  void *contextPointer; // a stored pointer -- user-defined meaning, used with self-messages
107 
108  int senderModuleId; // sender module ID -- set internally
109  int senderGateId; // source gate ID -- set internally
110  int targetModuleId; // destination module ID -- set internally
111  int targetGateId; // destination gate ID -- set internally
112  simtime_t creationTime; // creation time -- set be constructor
113  simtime_t sendTime; // time of sending -- set internally
114  simtime_t timestamp; // time stamp -- user-defined meaning
115 
116  long messageId; // a unique message identifier assigned upon message creation
117  long messageTreeId; // a message identifier that is inherited by dup, if non dupped it is msgid
118  static long nextMessageId; // the next unique message identifier to be assigned upon message creation
119 
120  // global variables for statistics
121  static long totalMsgCount;
122  static long liveMsgCount;
123 
124  private:
125  // internal: create parlist
126  void _createparlist();
127 
128  void copy(const cMessage& msg);
129 
130  // internal: used by LogBuffer for creating an *exact* copy of a message
131  void setId(long id) {messageId = id;}
132 
133  public:
134  // internal: create an exact clone (including msgid) that doesn't show up in the statistics
135  cMessage *privateDup() const;
136 
137  // internal: called by the simulation kernel as part of the send(),
138  // scheduleAt() calls to set the values returned by the
139  // getSenderModuleId(), getSenderGate(), getSendingTime() methods.
140  void setSentFrom(cModule *module, int gateId, simtime_t_cref t);
141 
142  // internal: used by the parallel simulation kernel.
143  void setSrcProcId(int procId) {srcProcId = (short)procId;}
144 
145  // internal: used by the parallel simulation kernel.
146  virtual int getSrcProcId() const override {return srcProcId;}
147 
148  // internal: returns the parameter list object, or nullptr if it hasn't been used yet
149  cArray *getParListPtr() {return parList;}
150 
151  private: // hide cEvent methods from the cMessage API
152 
153  // overridden from cEvent: return true
154  virtual bool isMessage() const override {return true;}
155 
156  // overridden from cEvent: return true of the target module is still alive and well
157  virtual bool isStale() override;
158 
159  // overridden from cEvent: return the arrival module
160  virtual cObject *getTargetObject() const override;
161 
162  // overridden from cEvent
163  virtual void execute() override;
164 
165  public:
168 
172  cMessage(const cMessage& msg);
173 
177  explicit cMessage(const char *name=nullptr, short kind=0);
178 
182  virtual ~cMessage();
183 
190  cMessage& operator=(const cMessage& msg);
192 
197  virtual bool isPacket() const {return false;}
198 
201 
208  virtual cMessage *dup() const override {return new cMessage(*this);}
209 
214  virtual std::string str() const override;
215 
220  virtual void forEachChild(cVisitor *v) override;
221 
227  virtual void parsimPack(cCommBuffer *buffer) const override;
228 
234  virtual void parsimUnpack(cCommBuffer *buffer) override;
236 
244  void setKind(short k) {messageKind=k;}
245 
249  void setTimestamp() {timestamp=getSimulation()->getSimTime();}
250 
254  void setTimestamp(simtime_t t) {timestamp=t;}
255 
264  void setContextPointer(void *p) {contextPointer=p;}
265 
281  virtual void setControlInfo(cObject *p);
282 
288  cObject *removeControlInfo();
289 
293  short getKind() const {return messageKind;}
294 
298  simtime_t_cref getTimestamp() const {return timestamp;}
299 
303  void *getContextPointer() const {return contextPointer;}
304 
308  cObject *getControlInfo() const {return controlInfo;}
310 
313 
327  virtual cArray& getParList() {if (!parList) _createparlist(); return *parList;}
328 
339  virtual cMsgPar& addPar(const char *name) {cMsgPar *p=new cMsgPar(name);getParList().add(p);return *p;}
340 
350  virtual cMsgPar& addPar(cMsgPar *par) {getParList().add(par); return *par;}
351 
363  virtual cMsgPar& par(int index);
364 
377  virtual cMsgPar& par(const char *name);
378 
389  virtual int findPar(const char *name) const;
390 
401  virtual bool hasPar(const char *name) const {return findPar(name)>=0;}
402 
412  virtual cObject *addObject(cObject *par) {getParList().add(par); return par;}
413 
424  virtual cObject *getObject(const char *name) {return getParList().get(name);}
425 
435  virtual bool hasObject(const char *name) {return !parList ? false : parList->find(name)>=0;}
436 
447  virtual cObject *removeObject(const char *name) {return getParList().remove(name);}
448 
459  virtual cObject *removeObject(cObject *par) {return getParList().remove(par);}
461 
464 
468  bool isSelfMessage() const {return targetGateId==-1;}
469 
475  cModule *getSenderModule() const {return getSimulation()->getModule(senderModuleId);}
476 
482  cGate *getSenderGate() const;
483 
489  cModule *getArrivalModule() const {return getSimulation()->getModule(targetModuleId);}
490 
496  cGate *getArrivalGate() const;
497 
504  int getSenderModuleId() const {return senderModuleId;}
505 
513  int getSenderGateId() const {return senderGateId;}
514 
521  int getArrivalModuleId() const {return targetModuleId;}
522 
530  int getArrivalGateId() const {return targetGateId;}
531 
537  simtime_t_cref getCreationTime() const {return creationTime;}
538 
543  simtime_t_cref getSendingTime() const {return sendTime;}
544 
559  // note: overridden to provide more specific documentation
560  simtime_t_cref getArrivalTime() const {return arrivalTime;}
561 
565  bool arrivedOn(int gateId) const {return gateId==targetGateId;}
566 
572  bool arrivedOn(const char *gateName) const;
573 
578  bool arrivedOn(const char *gateName, int gateIndex) const;
579 
583  long getId() const {return messageId;}
584 
589  long getTreeId() const {return messageTreeId;}
591 
599  virtual const char *getDisplayString() const;
600 
607  void setArrival(int moduleId, int gateId) {targetModuleId = moduleId; targetGateId = gateId;}
608 
613  void setArrival(int moduleId, int gateId, simtime_t_cref t) {targetModuleId = moduleId; targetGateId = gateId; setArrivalTime(t);}
615 
626  static long getTotalMessageCount() {return totalMsgCount;}
627 
635  static long getLiveMessageCount() {return liveMsgCount;}
636 
640  static void resetMessageCounters() {totalMsgCount=liveMsgCount=0;}
642 };
643 
644 } // namespace omnetpp
645 
646 #endif
647 
648 
int getSenderGateId() const
Definition: cmessage.h:513
The message class in OMNeT++. cMessage objects may represent events, messages, jobs or other entities...
Definition: cmessage.h:95
Represents a module gate.
Definition: cgate.h:63
Root of the OMNeT++ class hierarchy. cObject is a lightweight class without any data members...
Definition: cobject.h:58
int64_t-based, base-10 fixed-point simulation time.
Definition: simtime.h:66
static long getTotalMessageCount()
Definition: cmessage.h:626
cModule * getModule(int id) const
Definition: csimulation.h:215
int getArrivalGateId() const
Definition: cmessage.h:530
void setArrival(int moduleId, int gateId)
Definition: cmessage.h:607
virtual cMsgPar & addPar(const char *name)
Definition: cmessage.h:339
virtual cObject * removeObject(cObject *par)
Definition: cmessage.h:459
Represents an event in the discrete event simulator.
Definition: cevent.h:43
static void resetMessageCounters()
Definition: cmessage.h:640
cObject * getControlInfo() const
Definition: cmessage.h:308
int getArrivalModuleId() const
Definition: cmessage.h:521
Vector-like container for objects derived from cObject.
Definition: carray.h:38
virtual cObject * getObject(const char *name)
Definition: cmessage.h:424
virtual bool hasPar(const char *name) const
Definition: cmessage.h:401
long getTreeId() const
Definition: cmessage.h:589
long getId() const
Definition: cmessage.h:583
Allows a value (string, bool, double, etc) to be attached to a cMessage object.
Definition: cmsgpar.h:52
simtime_t_cref getSendingTime() const
Definition: cmessage.h:543
This class represents modules in the simulation.
Definition: cmodule.h:47
simtime_t_cref getTimestamp() const
Definition: cmessage.h:298
short getKind() const
Definition: cmessage.h:293
void setTimestamp()
Definition: cmessage.h:249
Buffer for the communications layer of parallel simulation.
Definition: ccommbuffer.h:41
virtual cMessage * dup() const override
Definition: cmessage.h:208
simtime_t_cref getSimTime() const
Definition: csimulation.h:377
simtime_t_cref getCreationTime() const
Definition: cmessage.h:537
virtual cObject * removeObject(const char *name)
Definition: cmessage.h:447
virtual cObject * addObject(cObject *par)
Definition: cmessage.h:412
void setTimestamp(simtime_t t)
Definition: cmessage.h:254
static long getLiveMessageCount()
Definition: cmessage.h:635
virtual bool isPacket() const
Definition: cmessage.h:197
void setContextPointer(void *p)
Definition: cmessage.h:264
Enables traversing the tree of (cObject-rooted) simulation objects.
Definition: cvisitor.h:56
virtual bool hasObject(const char *name)
Definition: cmessage.h:435
virtual int find(cObject *obj) const
virtual cArray & getParList()
Definition: cmessage.h:327
Definition: cabstracthistogram.h:21
cModule * getArrivalModule() const
Definition: cmessage.h:489
void setKind(short k)
Definition: cmessage.h:244
cModule * getSenderModule() const
Definition: cmessage.h:475
void setArrival(int moduleId, int gateId, simtime_t_cref t)
Definition: cmessage.h:613
int getSenderModuleId() const
Definition: cmessage.h:504
virtual cMsgPar & addPar(cMsgPar *par)
Definition: cmessage.h:350
bool arrivedOn(int gateId) const
Definition: cmessage.h:565
cSimulation * getSimulation()
Returns the currently active simulation, or nullptr if there is none.
Definition: csimulation.h:575
bool isSelfMessage() const
Definition: cmessage.h:468
simtime_t_cref getArrivalTime() const
Definition: cmessage.h:560
void * getContextPointer() const
Definition: cmessage.h:303