/******************************************************************************** * Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH * * * * This software is distributed under the terms of the * * GNU Lesser General Public Licence version 3 (LGPL) version 3, * * copied verbatim in the file "LICENSE" * ********************************************************************************/ /** * FairMQPollerNN.cxx * * @since 2014-01-23 * @author A. Rybalchenko */ #include #include "FairMQPollerNN.h" #include "FairMQLogger.h" using namespace std; FairMQPollerNN::FairMQPollerNN(const vector& channels) : items() , fNumItems() { fNumItems = channels.size(); items = new nn_pollfd[fNumItems]; for (int i = 0; i < fNumItems; ++i) { items[i].fd = channels.at(i).fSocket->GetSocket(1); items[i].events = NN_POLLIN; } } void FairMQPollerNN::Poll(int timeout) { if (nn_poll(items, fNumItems, timeout) < 0) { LOG(ERROR) << "polling failed, reason: " << nn_strerror(errno); } } bool FairMQPollerNN::CheckInput(int index) { if (items[index].revents & NN_POLLIN) { return true; } return false; } bool FairMQPollerNN::CheckOutput(int index) { if (items[index].revents & NN_POLLOUT) { return true; } return false; } FairMQPollerNN::~FairMQPollerNN() { if (items != NULL) { delete[] items; } }