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));
165 omnetpp::cEnum *e = omnetpp::cEnum::find(
"DataType");
166 if (!e) omnetpp::enums.getInstance()->add(e =
new omnetpp::cEnum(
"DataType"));
190 if (
this==&other)
return *
this;
191 ::omnetpp::cPacket::operator=(other);
204 ::omnetpp::cPacket::parsimPack(b);
211 ::omnetpp::cPacket::parsimUnpack(b);
244 virtual bool doesSupport(omnetpp::cObject *obj)
const override;
246 virtual const char *
getProperty(
const char *propertyname)
const override;
248 virtual const char *
getFieldName(
int field)
const override;
249 virtual int findField(
const char *fieldName)
const override;
253 virtual const char *
getFieldProperty(
int field,
const char *propertyname)
const override;
257 virtual bool setFieldValueAsString(
void *
object,
int field,
int i,
const char *value)
const override;
277 return dynamic_cast<Data_Base *
>(obj)!=
nullptr;
283 static const char *names[] = {
"customize",
nullptr };
284 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
285 const char **basenames = basedesc ? basedesc->getPropertyNames() :
nullptr;
293 if (!strcmp(propertyname,
"customize"))
return "true";
294 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
295 return basedesc ? basedesc->getProperty(propertyname) :
nullptr;
300 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
301 return basedesc ? 2+basedesc->getFieldCount() : 2;
306 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
309 return basedesc->getFieldTypeFlags(field);
310 field -= basedesc->getFieldCount();
312 static unsigned int fieldTypeFlags[] = {
316 return (field>=0 && field<2) ? fieldTypeFlags[field] : 0;
321 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
324 return basedesc->getFieldName(field);
325 field -= basedesc->getFieldCount();
327 static const char *fieldNames[] = {
331 return (field>=0 && field<2) ? fieldNames[field] :
nullptr;
336 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
337 int base = basedesc ? basedesc->getFieldCount() : 0;
338 if (fieldName[0]==
'd' && strcmp(fieldName,
"dataType")==0)
return base+0;
339 if (fieldName[0]==
'e' && strcmp(fieldName,
"encapMsgLength")==0)
return base+1;
340 return basedesc ? basedesc->findField(fieldName) : -1;
345 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
348 return basedesc->getFieldTypeString(field);
349 field -= basedesc->getFieldCount();
351 static const char *fieldTypeStrings[] = {
355 return (field>=0 && field<2) ? fieldTypeStrings[field] :
nullptr;
360 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
363 return basedesc->getFieldPropertyNames(field);
364 field -= basedesc->getFieldCount();
368 static const char *names[] = {
"enum",
nullptr };
371 default:
return nullptr;
377 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
380 return basedesc->getFieldProperty(field, propertyname);
381 field -= basedesc->getFieldCount();
385 if (!strcmp(propertyname,
"enum"))
return "DataType";
387 default:
return nullptr;
393 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
396 return basedesc->getFieldArraySize(
object, field);
397 field -= basedesc->getFieldCount();
407 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
410 return basedesc->getFieldValueAsString(
object,field,i);
411 field -= basedesc->getFieldCount();
415 case 0:
return enum2string(pp->
getDataType(),
"DataType");
423 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
426 return basedesc->setFieldValueAsString(
object,field,i,value);
427 field -= basedesc->getFieldCount();
433 default:
return false;
439 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
442 return basedesc->getFieldStructName(field);
443 field -= basedesc->getFieldCount();
446 default:
return nullptr;
452 omnetpp::cClassDescriptor *basedesc = getBaseClassDescriptor();
455 return basedesc->getFieldStructValuePointer(
object, field, i);
456 field -= basedesc->getFieldCount();
460 default:
return nullptr;
const char ** propertynames
virtual const char ** getPropertyNames() const override
Register_ClassDescriptor(DataDescriptor)
virtual void setEncapMsgLength(int64_t encapMsgLength)
virtual unsigned int getFieldTypeFlags(int field) const override
Data_Base(const char *name=nullptr, int kind=0)
virtual int findField(const char *fieldName) const override
virtual void parsimPack(omnetpp::cCommBuffer *b) const
void doParsimPacking(omnetpp::cCommBuffer *buffer, const std::vector< T, A > &v)
EXECUTE_ON_STARTUP(omnetpp::cEnum *e=omnetpp::cEnum::find("DataType");if(!e) omnetpp::enums.getInstance() ->add(e=new omnetpp::cEnum("DataType"));e->insert(DATA_SDU_COMPLETE,"DATA_SDU_COMPLETE");e->insert(DATA_FIRST_FRAG,"DATA_FIRST_FRAG");e->insert(DATA_MIDDLE_FRAG,"DATA_MIDDLE_FRAG");e->insert(DATA_LAST_FRAG,"DATA_LAST_FRAG");)
virtual int64_t getEncapMsgLength() const
virtual bool doesSupport(omnetpp::cObject *obj) const override
virtual const char * getFieldProperty(int field, const char *propertyname) const override
virtual int getFieldArraySize(void *object, int field) const override
void doParsimUnpacking(omnetpp::cCommBuffer *buffer, std::vector< T, A > &v)
virtual const char * getFieldTypeString(int field) const override
virtual void setDataType(int dataType)
void doParsimArrayUnpacking(omnetpp::cCommBuffer *b, T *t, int n)
virtual const char * getFieldName(int field) const override
virtual std::string getFieldValueAsString(void *object, int field, int i) const override
virtual void parsimUnpack(omnetpp::cCommBuffer *b)
Data_Base & operator=(const Data_Base &other)
virtual ~DataDescriptor()
std::ostream & operator<<(std::ostream &out, const std::vector< T, A > &vec)
virtual int getDataType() const
virtual const char ** getFieldPropertyNames(int field) const override
virtual bool setFieldValueAsString(void *object, int field, int i, const char *value) const override
virtual const char * getProperty(const char *propertyname) const override
void copy(const Data_Base &other)
virtual void * getFieldStructValuePointer(void *object, int field, int i) const override
virtual const char * getFieldStructName(int field) const override
void doParsimArrayPacking(omnetpp::cCommBuffer *b, const T *t, int n)
virtual int getFieldCount() const override