/******************************************************************************** * Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH * * * * This software is distributed under the terms of the * * GNU Lesser General Public Licence (LGPL) version 3, * * copied verbatim in the file "LICENSE" * ********************************************************************************/ /** * FairMQTransportFactoryZMQ.h * * @since 2014-01-20 * @author: A. Rybalchenko */ #ifndef FAIRMQTRANSPORTFACTORYZMQ_H_ #define FAIRMQTRANSPORTFACTORYZMQ_H_ #include "FairMQTransportFactory.h" #include "FairMQMessageZMQ.h" #include "FairMQSocketZMQ.h" #include "FairMQPollerZMQ.h" #include "FairMQUnmanagedRegionZMQ.h" #include #include #include #include #include #include #include #include class FairMQTransportFactoryZMQ final : public FairMQTransportFactory { public: FairMQTransportFactoryZMQ(const std::string& id = "", const fair::mq::ProgOptions* config = nullptr); FairMQTransportFactoryZMQ(const FairMQTransportFactoryZMQ&) = delete; FairMQTransportFactoryZMQ operator=(const FairMQTransportFactoryZMQ&) = delete; FairMQMessagePtr CreateMessage() override; FairMQMessagePtr CreateMessage(const size_t size) override; FairMQMessagePtr CreateMessage(void* data, const size_t size, fairmq_free_fn* ffn, void* hint = nullptr) override; FairMQMessagePtr CreateMessage(FairMQUnmanagedRegionPtr& region, void* data, const size_t size, void* hint = 0) override; FairMQSocketPtr CreateSocket(const std::string& type, const std::string& name) override; FairMQPollerPtr CreatePoller(const std::vector& channels) const override; FairMQPollerPtr CreatePoller(const std::vector& channels) const override; FairMQPollerPtr CreatePoller(const std::unordered_map>& channelsMap, const std::vector& channelList) const override; FairMQUnmanagedRegionPtr CreateUnmanagedRegion(const size_t size, FairMQRegionCallback callback, const std::string& path = "", int flags = 0) override; FairMQUnmanagedRegionPtr CreateUnmanagedRegion(const size_t size, const int64_t userFlags, FairMQRegionCallback callback, const std::string& path = "", int flags = 0) override; void SubscribeToRegionEvents(FairMQRegionEventCallback callback) override; void UnsubscribeFromRegionEvents() override; void RegionEventsSubscription(); std::vector GetRegionInfo() override; void RemoveRegion(uint64_t id); fair::mq::Transport GetType() const override; void Interrupt() override { FairMQSocketZMQ::Interrupt(); } void Resume() override { FairMQSocketZMQ::Resume(); } void Reset() override {} ~FairMQTransportFactoryZMQ() override; private: static fair::mq::Transport fTransportType; void* fContext; std::mutex fMtx; uint64_t fRegionCounter; std::condition_variable fRegionEventsCV; std::vector fRegionInfos; std::queue fRegionEvents; std::thread fRegionEventThread; std::function fRegionEventCallback; bool fRegionEventsSubscriptionActive; }; #endif /* FAIRMQTRANSPORTFACTORYZMQ_H_ */