FairMQ/fairmq/FairMQStandaloneMerger.cxx
Mohammad Al-Turany 5bc4746cbc correct struct initialization
git-svn-id: https://subversion.gsi.de/fairroot/fairbase/trunk@22608 0381ead4-6506-0410-b988-94b70fbc4730
2013-11-01 13:03:47 +00:00

56 lines
1.2 KiB
C++

/*
* FairMQStandaloneMerger.cxx
*
* Created on: Dec 6, 2012
* Author: dklein
*/
#include <boost/thread.hpp>
#include <boost/bind.hpp>
#include "FairMQLogger.h"
#include "FairMQStandaloneMerger.h"
FairMQStandaloneMerger::FairMQStandaloneMerger()
{
}
FairMQStandaloneMerger::~FairMQStandaloneMerger()
{
}
void FairMQStandaloneMerger::Run()
{
FairMQLogger::GetInstance()->Log(FairMQLogger::INFO, ">>>>>>> Run <<<<<<<");
boost::thread rateLogger(boost::bind(&FairMQDevice::LogSocketRates, this));
zmq_pollitem_t items[fNumInputs];
for (Int_t iInput = 0; iInput < fNumInputs; iInput++) {
zmq_pollitem_t tempitem= {*(fPayloadInputs->at(iInput)->GetSocket()), 0, ZMQ_POLLIN, 0};
items[iInput] = tempitem;
}
Bool_t received = false;
while ( fState == RUNNING ) {
FairMQMessage msg;
zmq_poll(items, fNumInputs, 100);
for(Int_t iItem = 0; iItem < fNumInputs; iItem++) {
if (items[iItem].revents & ZMQ_POLLIN) {
received = fPayloadInputs->at(iItem)->Receive(&msg);
}
if (received) {
fPayloadOutputs->at(0)->Send(&msg);
received = false;
}
}
}
rateLogger.interrupt();
rateLogger.join();
}