mirror of
https://github.com/FairRootGroup/FairMQ.git
synced 2025-10-13 08:41:16 +00:00
git-svn-id: https://subversion.gsi.de/fairroot/fairbase/trunk@22451 0381ead4-6506-0410-b988-94b70fbc4730
79 lines
1.4 KiB
C++
79 lines
1.4 KiB
C++
/*
|
|
* FairMQProcessor.cxx
|
|
*
|
|
* Created on: Dec 6, 2012
|
|
* Author: dklein
|
|
*/
|
|
|
|
#include <boost/thread.hpp>
|
|
#include <boost/bind.hpp>
|
|
|
|
#include "FairMQProcessor.h"
|
|
#include "FairMQLogger.h"
|
|
|
|
FairMQProcessor::FairMQProcessor() :
|
|
fTask(NULL)
|
|
{
|
|
}
|
|
|
|
FairMQProcessor::~FairMQProcessor()
|
|
{
|
|
delete fTask;
|
|
}
|
|
|
|
void FairMQProcessor::SetTask(FairMQProcessorTask* task)
|
|
{
|
|
fTask = task;
|
|
}
|
|
|
|
void FairMQProcessor::Init()
|
|
{
|
|
FairMQDevice::Init();
|
|
|
|
fTask->InitTask();
|
|
}
|
|
|
|
void FairMQProcessor::Run()
|
|
{
|
|
FairMQLogger::GetInstance()->Log(FairMQLogger::INFO, ">>>>>>> Run <<<<<<<");
|
|
|
|
boost::thread rateLogger(boost::bind(&FairMQDevice::LogSocketRates, this));
|
|
|
|
// Initialize poll set
|
|
zmq_pollitem_t items[] = {
|
|
{ *(fPayloadInputs->at(0)->GetSocket()), 0, ZMQ_POLLIN, 0 }
|
|
};
|
|
|
|
int receivedMsgs = 0;
|
|
int sentMsgs = 0;
|
|
|
|
Bool_t received = false;
|
|
|
|
while ( fState == RUNNING ) {
|
|
FairMQMessage msg;
|
|
|
|
zmq_poll(items, 1, 100);
|
|
|
|
if (items[0].revents & ZMQ_POLLIN) {
|
|
received = fPayloadInputs->at(0)->Receive(&msg);
|
|
receivedMsgs++;
|
|
}
|
|
|
|
if (received) {
|
|
fTask->Exec(&msg, NULL);
|
|
|
|
fPayloadOutputs->at(0)->Send(&msg);
|
|
sentMsgs++;
|
|
received = false;
|
|
}
|
|
}
|
|
|
|
std::cout << "I've received " << receivedMsgs << " and sent " << sentMsgs << " messages!" << std::endl;
|
|
|
|
boost::this_thread::sleep(boost::posix_time::milliseconds(5000));
|
|
|
|
rateLogger.interrupt();
|
|
rateLogger.join();
|
|
}
|
|
|