FairMQ  1.4.14
C++ Message Queuing Library and Framework
FairMQTransportFactory.h
1 /********************************************************************************
2  * Copyright (C) 2014-2018 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
3  * *
4  * This software is distributed under the terms of the *
5  * GNU Lesser General Public Licence (LGPL) version 3, *
6  * copied verbatim in the file "LICENSE" *
7  ********************************************************************************/
8 
9 #ifndef FAIRMQTRANSPORTFACTORY_H_
10 #define FAIRMQTRANSPORTFACTORY_H_
11 
12 #include <FairMQLogger.h>
13 #include <FairMQMessage.h>
14 #include <FairMQPoller.h>
15 #include <FairMQSocket.h>
16 #include <FairMQUnmanagedRegion.h>
17 #include <fairmq/MemoryResources.h>
18 #include <fairmq/Transports.h>
19 
20 #include <string>
21 #include <memory>
22 #include <vector>
23 #include <unordered_map>
24 #include <stdexcept>
25 #include <cstddef> // size_t
26 
27 class FairMQChannel;
28 namespace fair { namespace mq { class ProgOptions; } }
29 
31 {
32  private:
34  const std::string fkId;
35 
37  fair::mq::ChannelResource fMemoryResource{this};
38 
39  public:
42  FairMQTransportFactory(const std::string& id);
43 
44  auto GetId() const -> const std::string { return fkId; };
45 
47  fair::mq::ChannelResource* GetMemoryResource() { return &fMemoryResource; }
48  operator fair::mq::ChannelResource*() { return &fMemoryResource; }
49 
52  virtual FairMQMessagePtr CreateMessage() = 0;
56  virtual FairMQMessagePtr CreateMessage(const size_t size) = 0;
63  virtual FairMQMessagePtr CreateMessage(void* data, const size_t size, fairmq_free_fn* ffn, void* hint = nullptr) = 0;
69  virtual FairMQMessagePtr CreateMessage(FairMQUnmanagedRegionPtr& unmanagedRegion, void* data, const size_t size, void* hint = 0) = 0;
70 
72  virtual FairMQSocketPtr CreateSocket(const std::string& type, const std::string& name) = 0;
73 
75  virtual FairMQPollerPtr CreatePoller(const std::vector<FairMQChannel>& channels) const = 0;
77  virtual FairMQPollerPtr CreatePoller(const std::vector<FairMQChannel*>& channels) const = 0;
79  virtual FairMQPollerPtr CreatePoller(const std::unordered_map<std::string, std::vector<FairMQChannel>>& channelsMap, const std::vector<std::string>& channelList) const = 0;
80 
87  virtual FairMQUnmanagedRegionPtr CreateUnmanagedRegion(const size_t size, FairMQRegionCallback callback = nullptr, const std::string& path = "", int flags = 0) const = 0;
95  virtual FairMQUnmanagedRegionPtr CreateUnmanagedRegion(const size_t size, const int64_t userFlags, FairMQRegionCallback callback = nullptr, const std::string& path = "", int flags = 0) const = 0;
96 
99  virtual void SubscribeToRegionEvents(FairMQRegionEventCallback callback) = 0;
101  virtual void UnsubscribeFromRegionEvents() = 0;
102 
103  virtual std::vector<FairMQRegionInfo> GetRegionInfo() = 0;
104 
106  virtual fair::mq::Transport GetType() const = 0;
107 
108  virtual void Interrupt() = 0;
109  virtual void Resume() = 0;
110  virtual void Reset() = 0;
111 
112  virtual ~FairMQTransportFactory() {};
113 
114  static auto CreateTransportFactory(const std::string& type, const std::string& id = "", const fair::mq::ProgOptions* config = nullptr) -> std::shared_ptr<FairMQTransportFactory>;
115 
116  static void FairMQNoCleanup(void* /*data*/, void* /*obj*/)
117  {
118  }
119 
120  template<typename T>
121  static void FairMQSimpleMsgCleanup(void* /*data*/, void* obj)
122  {
123  delete static_cast<T*>(obj);
124  }
125 
126  template<typename T>
127  FairMQMessagePtr NewSimpleMessage(const T& data)
128  {
129  // todo: is_trivially_copyable not available on gcc < 5, workaround?
130  // static_assert(std::is_trivially_copyable<T>::value, "The argument type for NewSimpleMessage has to be trivially copyable!");
131  T* dataCopy = new T(data);
132  return CreateMessage(dataCopy, sizeof(T), FairMQSimpleMsgCleanup<T>, dataCopy);
133  }
134 
135  template<std::size_t N>
136  FairMQMessagePtr NewSimpleMessage(const char(&data)[N])
137  {
138  std::string* msgStr = new std::string(data);
139  return CreateMessage(const_cast<char*>(msgStr->c_str()), msgStr->length(), FairMQSimpleMsgCleanup<std::string>, msgStr);
140  }
141 
142  FairMQMessagePtr NewSimpleMessage(const std::string& str)
143  {
144 
145  std::string* msgStr = new std::string(str);
146  return CreateMessage(const_cast<char*>(msgStr->c_str()), msgStr->length(), FairMQSimpleMsgCleanup<std::string>, msgStr);
147  }
148 
149  template<typename T>
150  FairMQMessagePtr NewStaticMessage(const T& data)
151  {
152  return CreateMessage(data, sizeof(T), FairMQNoCleanup, nullptr);
153  }
154 
155  FairMQMessagePtr NewStaticMessage(const std::string& str)
156  {
157  return CreateMessage(const_cast<char*>(str.c_str()), str.length(), FairMQNoCleanup, nullptr);
158  }
159 };
160 
161 namespace fair
162 {
163 namespace mq
164 {
165 
166 using TransportFactory = FairMQTransportFactory;
167 struct TransportFactoryError : std::runtime_error { using std::runtime_error::runtime_error; };
168 
169 } /* namespace mq */
170 } /* namespace fair */
171 
172 #endif /* FAIRMQTRANSPORTFACTORY_H_ */
Definition: FairMQTransportFactory.h:167
Definition: FairMQTransportFactory.h:30
Definition: FairMQChannel.h:30
Definition: ProgOptions.h:36
fair::mq::ChannelResource * GetMemoryResource()
Get a pointer to the associated polymorphic memory resource.
Definition: FairMQTransportFactory.h:47
Definition: MemoryResources.h:56
Tools for interfacing containers to the transport via polymorphic allocators.
Definition: DeviceRunner.h:23

privacy