mirror of
https://github.com/FairRootGroup/FairMQ.git
synced 2025-10-15 17:41:45 +00:00
add serialization API
This commit is contained in:
committed by
Mohammad Al-Turany
parent
e818174126
commit
5f365c84c7
@@ -17,6 +17,51 @@
|
||||
|
||||
#include "FairMQDevice.h"
|
||||
|
||||
|
||||
struct Ex8Header {
|
||||
int32_t stopFlag;
|
||||
};
|
||||
|
||||
|
||||
struct MyPoint
|
||||
{
|
||||
/* data */
|
||||
double x=1;
|
||||
double y=1;
|
||||
double z=1;
|
||||
};
|
||||
|
||||
|
||||
struct MyPointSerializer
|
||||
{
|
||||
void Serialize(std::unique_ptr<FairMQMessage>& msg, MyPoint* input)
|
||||
{
|
||||
int DataSize = sizeof(MyPoint);
|
||||
msg->Rebuild(DataSize);
|
||||
MyPoint* digiptr = reinterpret_cast<MyPoint*>(msg->GetData());
|
||||
digiptr->x=input->x;
|
||||
digiptr->y=input->y;
|
||||
digiptr->z=input->z;
|
||||
}
|
||||
|
||||
void Deserialize(std::unique_ptr<FairMQMessage>& msg, MyPoint* input)
|
||||
{
|
||||
MyPoint* digiptr = static_cast<MyPoint*>(msg->GetData());
|
||||
input->x=digiptr->x;
|
||||
input->y=digiptr->y;
|
||||
input->z=digiptr->z;
|
||||
}
|
||||
|
||||
void Deserialize(FairMQMessage& msg, MyPoint* input)
|
||||
{
|
||||
MyPoint* digiptr = static_cast<MyPoint*>(msg.GetData());
|
||||
input->x=digiptr->x;
|
||||
input->y=digiptr->y;
|
||||
input->z=digiptr->z;
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
class FairMQExample8Sink : public FairMQDevice
|
||||
{
|
||||
public:
|
||||
|
Reference in New Issue
Block a user