/******************************************************************************** * 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" * ********************************************************************************/ #ifndef FAIRMQPOLLERSHM_H_ #define FAIRMQPOLLERSHM_H_ #include #include #include #include #include "FairMQPoller.h" #include "FairMQChannel.h" #include "FairMQTransportFactorySHM.h" class FairMQChannel; class FairMQPollerSHM : public FairMQPoller { friend class FairMQChannel; friend class FairMQTransportFactorySHM; public: FairMQPollerSHM(const std::vector& channels); FairMQPollerSHM(const std::vector& channels); FairMQPollerSHM(const std::unordered_map>& channelsMap, const std::vector& channelList); FairMQPollerSHM(const FairMQPollerSHM&) = delete; FairMQPollerSHM operator=(const FairMQPollerSHM&) = delete; void SetItemEvents(zmq_pollitem_t& item, const int type); virtual void Poll(const int timeout); virtual bool CheckInput(const int index); virtual bool CheckOutput(const int index); virtual bool CheckInput(const std::string channelKey, const int index); virtual bool CheckOutput(const std::string channelKey, const int index); virtual ~FairMQPollerSHM(); private: FairMQPollerSHM(const FairMQSocket& cmdSocket, const FairMQSocket& dataSocket); zmq_pollitem_t* fItems; int fNumItems; std::unordered_map fOffsetMap; }; #endif /* FAIRMQPOLLERSHM_H_ */