FairMQ/fairmq/FairMQMerger.cxx
Alexey Rybalchenko 3803a3d155 a little clean up
2014-01-28 11:56:08 +01:00

60 lines
1.1 KiB
C++

/**
* FairMQMerger.cxx
*
* @since 2012-12-06
* @author D. Klein, A. Rybalchenko
*/
#include <boost/thread.hpp>
#include <boost/bind.hpp>
#include "FairMQLogger.h"
#include "FairMQMerger.h"
FairMQMerger::FairMQMerger()
{
}
FairMQMerger::~FairMQMerger()
{
}
void FairMQMerger::Run()
{
FairMQLogger::GetInstance()->Log(FairMQLogger::INFO, ">>>>>>> Run <<<<<<<");
boost::thread rateLogger(boost::bind(&FairMQDevice::LogSocketRates, this));
zmq_pollitem_t items[fNumInputs];
for (int i = 0; i < fNumInputs; i++) {
items[i].socket = fPayloadInputs->at(i)->GetSocket();
items[i].fd = 0;
items[i].events = ZMQ_POLLIN;
items[i].revents = 0;
}
Bool_t received = false;
while ( fState == RUNNING ) {
FairMQMessage msg;
zmq_poll(items, fNumInputs, 100);
for(int i = 0; i < fNumInputs; i++) {
if (items[i].revents & ZMQ_POLLIN) {
received = fPayloadInputs->at(i)->Receive(&msg);
}
if (received) {
fPayloadOutputs->at(0)->Send(&msg);
received = false;
}
}
}
rateLogger.interrupt();
rateLogger.join();
}