7 # pragma warning(disable:4101)
8 # pragma warning(disable:4065)
21 template<
typename T,
typename A>
22 void doParsimPacking(omnetpp::cCommBuffer *buffer,
const std::vector<T,A>& v)
26 for (
int i = 0; i < n; i++)
30 template<
typename T,
typename A>
36 for (
int i = 0; i < n; i++)
41 template<
typename T,
typename A>
42 void doParsimPacking(omnetpp::cCommBuffer *buffer,
const std::list<T,A>& l)
45 for (
typename std::list<T,A>::const_iterator it = l.begin(); it != l.end(); ++it)
49 template<
typename T,
typename A>
54 for (
int i=0; i<n; i++) {
61 template<
typename T,
typename Tr,
typename A>
62 void doParsimPacking(omnetpp::cCommBuffer *buffer,
const std::set<T,Tr,A>& s)
65 for (
typename std::set<T,Tr,A>::const_iterator it = s.begin(); it != s.end(); ++it)
69 template<
typename T,
typename Tr,
typename A>
74 for (
int i=0; i<n; i++) {
82 template<
typename K,
typename V,
typename Tr,
typename A>
83 void doParsimPacking(omnetpp::cCommBuffer *buffer,
const std::map<K,V,Tr,A>& m)
86 for (
typename std::map<K,V,Tr,A>::const_iterator it = m.begin(); it != m.end(); ++it) {
92 template<
typename K,
typename V,
typename Tr,
typename A>
97 for (
int i=0; i<n; i++) {
109 for (
int i = 0; i < n; i++)
116 for (
int i = 0; i < n; i++)
124 throw omnetpp::cRuntimeError(
"Parsim error: no doParsimPacking() function for type %s", omnetpp::opp_typename(
typeid(t)));
130 throw omnetpp::cRuntimeError(
"Parsim error: no doParsimUnpacking() function for type %s", omnetpp::opp_typename(
typeid(t)));
137 template<
typename T,
typename A>
138 std::ostream& operator<<(std::ostream& out, const std::vector<T,A>& vec);
142 inline std::ostream&
operator<<(std::ostream& out,
const T&) {
return out;}
145 template<
typename T,
typename A>
146 inline std::ostream& operator<<(std::ostream& out, const std::vector<T,A>& vec)
149 for(
typename std::vector<T,A>::const_iterator it = vec.begin(); it != vec.end(); ++it)
151 if (it != vec.begin()) {
152 out.put(
','); out.put(
' ');
159 sprintf(buf,
" (size=%u)", (
unsigned int)vec.size());
160 out.write(buf, strlen(buf));
183 if (
this==&other)
return *
this;
184 ::omnetpp::cPacket::operator=(other);
199 ::omnetpp::cPacket::parsimPack(b);
208 ::omnetpp::cPacket::parsimUnpack(b);
263 virtual bool doesSupport(omnetpp::cObject *obj)
const override;
265 virtual const char *
getProperty(
const char *propertyname)
const override;
267 virtual const char *
getFieldName(
int field)
const override;
268 virtual int findField(
const char *fieldName)
const override;
272 virtual const char *
getFieldProperty(
int field,
const char *propertyname)
const override;
276 virtual bool setFieldValueAsString(
void *
object,
int field,
int i,
const char *value)
const override;
302 static const char *names[] = {
"customize",
nullptr };
303 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
304 const char **basenames = basedesc ? basedesc->getPropertyNames() :
nullptr;
312 if (!strcmp(propertyname,
"customize"))
return "true";
313 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
314 return basedesc ? basedesc->getProperty(propertyname) :
nullptr;
319 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
320 return basedesc ? 4+basedesc->getFieldCount() : 4;
325 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
328 return basedesc->getFieldTypeFlags(field);
329 field -= basedesc->getFieldCount();
331 static unsigned int fieldTypeFlags[] = {
337 return (field>=0 && field<4) ? fieldTypeFlags[field] : 0;
342 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
345 return basedesc->getFieldName(field);
346 field -= basedesc->getFieldCount();
348 static const char *fieldNames[] = {
354 return (field>=0 && field<4) ? fieldNames[field] :
nullptr;
359 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
360 int base = basedesc ? basedesc->getFieldCount() : 0;
361 if (fieldName[0]==
'm' && strcmp(fieldName,
"midFragment")==0)
return base+0;
362 if (fieldName[0]==
'f' && strcmp(fieldName,
"firstFragment")==0)
return base+1;
363 if (fieldName[0]==
'l' && strcmp(fieldName,
"lastFragment")==0)
return base+2;
364 if (fieldName[0]==
'c' && strcmp(fieldName,
"completeSDU")==0)
return base+3;
365 return basedesc ? basedesc->findField(fieldName) : -1;
370 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
373 return basedesc->getFieldTypeString(field);
374 field -= basedesc->getFieldCount();
376 static const char *fieldTypeStrings[] = {
382 return (field>=0 && field<4) ? fieldTypeStrings[field] :
nullptr;
387 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
390 return basedesc->getFieldPropertyNames(field);
391 field -= basedesc->getFieldCount();
394 default:
return nullptr;
400 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
403 return basedesc->getFieldProperty(field, propertyname);
404 field -= basedesc->getFieldCount();
407 default:
return nullptr;
413 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
416 return basedesc->getFieldArraySize(
object, field);
417 field -= basedesc->getFieldCount();
427 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
430 return basedesc->getFieldValueAsString(
object,field,i);
431 field -= basedesc->getFieldCount();
445 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
448 return basedesc->setFieldValueAsString(
object,field,i,value);
449 field -= basedesc->getFieldCount();
457 default:
return false;
463 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
466 return basedesc->getFieldStructName(field);
467 field -= basedesc->getFieldCount();
470 default:
return nullptr;
476 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
479 return basedesc->getFieldStructValuePointer(
object, field, i);
480 field -= basedesc->getFieldCount();
484 default:
return nullptr;
virtual const char * getFieldProperty(int field, const char *propertyname) const override
virtual void setCompleteSDU(bool completeSDU)
virtual int getFieldCount() const override
Register_ClassDescriptor(PDUDataDescriptor)
virtual const char * getProperty(const char *propertyname) const override
virtual bool getMidFragment() const
virtual std::string getFieldValueAsString(void *object, int field, int i) const override
virtual void setLastFragment(bool lastFragment)
virtual unsigned int getFieldTypeFlags(int field) const override
virtual void setMidFragment(bool midFragment)
virtual int getFieldArraySize(void *object, int field) const override
virtual bool getCompleteSDU() const
virtual const char * getFieldName(int field) const override
PDUData_Base(const char *name=nullptr, int kind=0)
const char ** propertynames
void doParsimPacking(omnetpp::cCommBuffer *buffer, const std::vector< T, A > &v)
virtual void parsimPack(omnetpp::cCommBuffer *b) const
virtual void parsimUnpack(omnetpp::cCommBuffer *b)
void doParsimUnpacking(omnetpp::cCommBuffer *buffer, std::vector< T, A > &v)
virtual bool setFieldValueAsString(void *object, int field, int i, const char *value) const override
virtual bool getLastFragment() const
void doParsimArrayUnpacking(omnetpp::cCommBuffer *b, T *t, int n)
virtual bool doesSupport(omnetpp::cObject *obj) const override
virtual const char * getFieldStructName(int field) const override
std::ostream & operator<<(std::ostream &out, const std::vector< T, A > &vec)
virtual int findField(const char *fieldName) const override
void copy(const PDUData_Base &other)
virtual void setFirstFragment(bool firstFragment)
virtual void * getFieldStructValuePointer(void *object, int field, int i) const override
virtual ~PDUDataDescriptor()
virtual const char * getFieldTypeString(int field) const override
PDUData_Base & operator=(const PDUData_Base &other)
virtual const char ** getFieldPropertyNames(int field) const override
virtual const char ** getPropertyNames() const override
void doParsimArrayPacking(omnetpp::cCommBuffer *b, const T *t, int n)
virtual bool getFirstFragment() const