/******************************************************************************** * 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" * ********************************************************************************/ #ifndef FAIR_MQ_ZMQ_TRANSPORTFACTORY_H #define FAIR_MQ_ZMQ_TRANSPORTFACTORY_H #include #include #include #include #include #include #include #include #include // unique_ptr #include #include namespace fair { namespace mq { namespace zmq { class TransportFactory final : public FairMQTransportFactory { public: TransportFactory(const std::string& id = "", const ProgOptions* config = nullptr) : FairMQTransportFactory(id) , fCtx(nullptr) { int major, minor, patch; zmq_version(&major, &minor, &patch); LOG(debug) << "Transport: Using ZeroMQ library, version: " << major << "." << minor << "." << patch; if (config) { fCtx = tools::make_unique(config->GetProperty("io-threads", 1)); } else { LOG(debug) << "fair::mq::ProgOptions not available! Using defaults."; fCtx = tools::make_unique(1); } } TransportFactory(const TransportFactory&) = delete; TransportFactory operator=(const TransportFactory&) = delete; MessagePtr CreateMessage() override { return tools::make_unique(this); } MessagePtr CreateMessage(const size_t size) override { return tools::make_unique(size, this); } MessagePtr CreateMessage(void* data, const size_t size, fairmq_free_fn* ffn, void* hint = nullptr) override { return tools::make_unique(data, size, ffn, hint, this); } MessagePtr CreateMessage(UnmanagedRegionPtr& region, void* data, const size_t size, void* hint = 0) override { return tools::make_unique(region, data, size, hint, this); } SocketPtr CreateSocket(const std::string& type, const std::string& name) override { return tools::make_unique(*fCtx, type, name, GetId(), this); } PollerPtr CreatePoller(const std::vector& channels) const override { return tools::make_unique(channels); } PollerPtr CreatePoller(const std::vector& channels) const override { return tools::make_unique(channels); } PollerPtr CreatePoller(const std::unordered_map>& channelsMap, const std::vector& channelList) const override { return tools::make_unique(channelsMap, channelList); } UnmanagedRegionPtr CreateUnmanagedRegion(const size_t size, RegionCallback callback, const std::string& path = "", int flags = 0) override { return CreateUnmanagedRegion(size, 0, callback, nullptr, path, flags); } UnmanagedRegionPtr CreateUnmanagedRegion(const size_t size, RegionBulkCallback bulkCallback, const std::string& path = "", int flags = 0) override { return CreateUnmanagedRegion(size, 0, nullptr, bulkCallback, path, flags); } UnmanagedRegionPtr CreateUnmanagedRegion(const size_t size, const int64_t userFlags, RegionCallback callback, const std::string& path = "", int flags = 0) override { return CreateUnmanagedRegion(size, userFlags, callback, nullptr, path, flags); } UnmanagedRegionPtr CreateUnmanagedRegion(const size_t size, const int64_t userFlags, RegionBulkCallback bulkCallback, const std::string& path = "", int flags = 0) override { return CreateUnmanagedRegion(size, userFlags, nullptr, bulkCallback, path, flags); } UnmanagedRegionPtr CreateUnmanagedRegion(const size_t size, const int64_t userFlags, RegionCallback callback, RegionBulkCallback bulkCallback, const std::string& path = "", int flags = 0) { UnmanagedRegionPtr ptr = tools::make_unique(*fCtx, size, userFlags, callback, bulkCallback, path, flags, this); auto zPtr = static_cast(ptr.get()); fCtx->AddRegion(zPtr->GetId(), zPtr->GetData(), zPtr->GetSize(), zPtr->GetUserFlags(), RegionEvent::created); return ptr; } void SubscribeToRegionEvents(RegionEventCallback callback) override { fCtx->SubscribeToRegionEvents(callback); } bool SubscribedToRegionEvents() override { return fCtx->SubscribedToRegionEvents(); } void UnsubscribeFromRegionEvents() override { fCtx->UnsubscribeFromRegionEvents(); } std::vector GetRegionInfo() override { return fCtx->GetRegionInfo(); } Transport GetType() const override { return Transport::ZMQ; } void Interrupt() override { fCtx->Interrupt(); } void Resume() override { fCtx->Resume(); } void Reset() override { fCtx->Reset(); } ~TransportFactory() override { LOG(debug) << "Destroying ZeroMQ transport..."; } private: std::unique_ptr fCtx; }; } // namespace zmq } // namespace mq } // namespace fair #endif /* FAIR_MQ_ZMQ_TRANSPORTFACTORY_H */