13#ifndef IOX2_PENDING_RESPONSE_HPP
14#define IOX2_PENDING_RESPONSE_HPP
25template <ServiceType,
typename,
typename,
typename,
typename>
35 typename RequestPayload,
36 typename RequestUserHeader,
37 typename ResponsePayload,
38 typename ResponseUserHeader>
60 template <
typename T = RequestUserHeader,
61 typename = std::enable_if_t<!std::is_same<void, RequestUserHeader>::value, T>>
66 template <typename T = RequestPayload, typename = std::enable_if_t<!bb::IsSlice<T>::VALUE,
void>>
67 auto payload() const -> const T&;
71 template <typename T = RequestPayload, typename = std::enable_if_t<bb::IsSlice<T>::VALUE,
void>>
72 auto
payload() const -> bb::ImmutableSlice<ValueType>;
95 template <
ServiceType, typename, typename, typename, typename>
98 typename RequestPayloadT,
99 typename RequestUserHeaderT,
100 typename ResponsePayloadT,
101 typename ResponseUserHeaderT>
103 send(
RequestMut<S, RequestPayloadT, RequestUserHeaderT, ResponsePayloadT, ResponseUserHeaderT>&& request)
104 -> bb::Expected<
PendingResponse<S, RequestPayloadT, RequestUserHeaderT, ResponsePayloadT, ResponseUserHeaderT>,
111 iox2_pending_response_h m_handle =
nullptr;
115 typename RequestPayload,
116 typename RequestUserHeader,
117 typename ResponsePayload,
118 typename ResponseUserHeader>
121 *
this = std::move(rhs);
125 typename RequestPayload,
126 typename RequestUserHeader,
127 typename ResponsePayload,
128 typename ResponseUserHeader>
133 m_handle = rhs.m_handle;
134 rhs.m_handle =
nullptr;
141 typename RequestPayload,
142 typename RequestUserHeader,
143 typename ResponsePayload,
144 typename ResponseUserHeader>
151 typename RequestPayload,
152 typename RequestUserHeader,
153 typename ResponsePayload,
154 typename ResponseUserHeader>
157 iox2_response_h response_handle {};
158 auto result = iox2_pending_response_receive(&m_handle,
nullptr, &response_handle);
160 if (result == IOX2_OK) {
161 if (response_handle !=
nullptr) {
167 return bb::err(bb::into<ReceiveError>(result));
171 typename RequestPayload,
172 typename RequestUserHeader,
173 typename ResponsePayload,
174 typename ResponseUserHeader>
177 iox2_request_header_h header_handle =
nullptr;
178 iox2_pending_response_header(&m_handle,
nullptr, &header_handle);
183 typename RequestPayload,
184 typename RequestUserHeader,
185 typename ResponsePayload,
186 typename ResponseUserHeader>
187template <
typename T,
typename>
191 const void* ptr =
nullptr;
192 iox2_pending_response_user_header(&m_handle, &ptr);
193 return *
static_cast<const T*
>(ptr);
197 typename RequestPayload,
198 typename RequestUserHeader,
199 typename ResponsePayload,
200 typename ResponseUserHeader>
201template <
typename T,
typename>
205 const void* ptr =
nullptr;
206 iox2_pending_response_payload(&m_handle, &ptr,
nullptr);
207 return *
static_cast<const T*
>(ptr);
211 typename RequestPayload,
212 typename RequestUserHeader,
213 typename ResponsePayload,
214 typename ResponseUserHeader>
215template <
typename T,
typename>
218 -> bb::ImmutableSlice<ValueType> {
219 const void* ptr =
nullptr;
220 size_t number_of_elements = 0;
222 iox2_pending_response_payload(&m_handle, &ptr, &number_of_elements);
228 typename RequestPayload,
229 typename RequestUserHeader,
230 typename ResponsePayload,
231 typename ResponseUserHeader>
234 return iox2_pending_response_number_of_server_connections(&m_handle);
238 typename RequestPayload,
239 typename RequestUserHeader,
240 typename ResponsePayload,
241 typename ResponseUserHeader>
245 return iox2_pending_response_has_response(&m_handle);
249 typename RequestPayload,
250 typename RequestUserHeader,
251 typename ResponsePayload,
252 typename ResponseUserHeader>
256 return iox2_pending_response_is_connected(&m_handle);
260 typename RequestPayload,
261 typename RequestUserHeader,
262 typename ResponsePayload,
263 typename ResponseUserHeader>
266 iox2_pending_response_set_disconnect_hint(&m_handle);
270 typename RequestPayload,
271 typename RequestUserHeader,
272 typename ResponsePayload,
273 typename ResponseUserHeader>
276 : m_handle { handle } {
280 typename RequestPayload,
281 typename RequestUserHeader,
282 typename ResponsePayload,
283 typename ResponseUserHeader>
284inline void PendingResponse<Service, RequestPayload, RequestUserHeader, ResponsePayload, ResponseUserHeader>::drop() {
285 if (m_handle !=
nullptr) {
286 iox2_pending_response_drop(m_handle);
Sends [RequestMut]s to a [Server] in a request-response based communication.
auto operator=(PendingResponse &&rhs) noexcept -> PendingResponse &
auto number_of_server_connections() const -> size_t
auto user_header() -> const T &
auto payload() const -> const T &
auto has_response() -> bool
PendingResponse(const PendingResponse &)=delete
~PendingResponse() noexcept
PendingResponse(PendingResponse &&rhs) noexcept
friend auto send(RequestMut< S, RequestPayloadT, RequestUserHeaderT, ResponsePayloadT, ResponseUserHeaderT > &&request) -> bb::Expected< PendingResponse< S, RequestPayloadT, RequestUserHeaderT, ResponsePayloadT, ResponseUserHeaderT >, RequestSendError >
auto header() -> RequestHeader
void set_disconnect_hint()
auto is_connected() const -> bool
auto receive() -> bb::Expected< bb::Optional< Response< Service, ResponsePayload, ResponseUserHeader > >, ReceiveError >
auto operator=(const PendingResponse &) -> PendingResponse &=delete
A class representing a slice of contiguous elements of type T.
constexpr NulloptT NULLOPT
constexpr auto err(const E &error) -> Unexpected< E >
iox2::bb::variation::Optional< T > Optional
iox2::bb::variation::Expected< T, E > Expected
RequestSendError
Failure that can be emitted when a [RequestMut] is sent.