Qpid Proton C API 0.40.0
 
Loading...
Searching...
No Matches
connection_driver.h
Go to the documentation of this file.
1#ifndef PROTON_CONNECTION_DRIVER_H
2#define PROTON_CONNECTION_DRIVER_H 1
3
4/*
5 * Licensed to the Apache Software Foundation (ASF) under one
6 * or more contributor license agreements. See the NOTICE file
7 * distributed with this work for additional information
8 * regarding copyright ownership. The ASF licenses this file
9 * to you under the Apache License, Version 2.0 (the
10 * "License"); you may not use this file except in compliance
11 * with the License. You may obtain a copy of the License at
12 *
13 * http://www.apache.org/licenses/LICENSE-2.0
14 *
15 * Unless required by applicable law or agreed to in writing,
16 * software distributed under the License is distributed on an
17 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
18 * KIND, either express or implied. See the License for the
19 * specific language governing permissions and limitations
20 * under the License.
21 */
22
77#include <proton/annotations.h>
78#include <proton/import_export.h>
79#include <proton/event.h>
80#include <proton/types.h>
81
82#include <stdarg.h>
83
84#ifdef __cplusplus
85extern "C" {
86#endif
87
91typedef struct pn_connection_driver_t {
92 pn_connection_t *connection;
93 pn_transport_t *transport;
94 pn_collector_t *collector;
96
114
122
128
140
153
163
169
174
179
189
195
200
205
210
219
224
232
242PN_EXTERN void pn_connection_driver_errorf(pn_connection_driver_t *d, const char *name, PN_PRINTF_FORMAT const char *fmt, ...)
243 PN_PRINTF_FORMAT_ATTR(3, 4);
244
248PN_EXTERN void pn_connection_driver_verrorf(pn_connection_driver_t *d, const char *name, const char *fmt, va_list);
249
254#define PN_TRANSPORT_WRITE_CLOSED PN_TRANSPORT_HEAD_CLOSED
255
260#define PN_TRANSPORT_READ_CLOSED PN_TRANSPORT_TAIL_CLOSED
261
265PN_EXTERN void pn_connection_driver_log(pn_connection_driver_t *d, const char *msg);
266
270PN_EXTERN void pn_connection_driver_logf(pn_connection_driver_t *d, PN_PRINTF_FORMAT const char *fmt, ...)
271 PN_PRINTF_FORMAT_ATTR(2, 3);
272
276PN_EXTERN void pn_connection_driver_vlogf(pn_connection_driver_t *d, const char *fmt, va_list ap);
277
290
295#ifdef __cplusplus
296}
297#endif
298
299#endif /* connection_driver.h */
Protocol and transport events.
A const byte buffer.
Definition types.h:223
A non-const byte buffer.
Definition types.h:246
bool pn_connection_driver_write_closed(pn_connection_driver_t *)
True if write side is closed.
void void pn_connection_driver_verrorf(pn_connection_driver_t *d, const char *name, const char *fmt, va_list)
Set transport error via a va_list, see pn_connection_driver_errorf()
pn_rwbytes_t pn_connection_driver_read_buffer(pn_connection_driver_t *)
Get the read buffer.
void pn_connection_driver_read_close(pn_connection_driver_t *)
Close the read side.
void pn_connection_driver_errorf(pn_connection_driver_t *d, const char *name, PN_PRINTF_FORMAT const char *fmt,...) PN_PRINTF_FORMAT_ATTR(3
Set transport error.
int pn_connection_driver_init(pn_connection_driver_t *, pn_connection_t *, pn_transport_t *)
Set connection and transport to the provided values, or create a new pn_connection_t or pn_transport_...
pn_event_t * pn_connection_driver_next_event(pn_connection_driver_t *)
Get the next event to handle.
pn_connection_t * pn_connection_driver_release_connection(pn_connection_driver_t *d)
Disassociate the driver's connection from its transport and collector and sets d->connection = NULL.
bool pn_connection_driver_finished(pn_connection_driver_t *)
Return true if the the driver is closed for reading and writing and there are no more events.
pn_bytes_t pn_connection_driver_write_buffer(pn_connection_driver_t *)
Get the write buffer.
void pn_connection_driver_destroy(pn_connection_driver_t *)
Unbind, release and free the connection and transport.
pn_rwbytes_t pn_connection_driver_read_buffer_sized(pn_connection_driver_t *, size_t n)
Try to get a read buffer with the specified size.
bool pn_connection_driver_read_closed(pn_connection_driver_t *)
True if read side is closed.
pn_connection_driver_t ** pn_connection_driver_ptr(pn_connection_t *connection)
Associate a pn_connection_t with its pn_connection_driver_t.
void pn_connection_driver_logf(pn_connection_driver_t *d, PN_PRINTF_FORMAT const char *fmt,...) PN_PRINTF_FORMAT_ATTR(2
Deprecated - Use pn_transport_logf().
void void pn_connection_driver_vlogf(pn_connection_driver_t *d, const char *fmt, va_list ap)
Deprecated - Use pn_transport_vlogf().
pn_bytes_t pn_connection_driver_write_done(pn_connection_driver_t *, size_t n)
Call when the first n bytes of pn_connection_driver_write_buffer() have been written to IO.
void pn_connection_driver_read_done(pn_connection_driver_t *, size_t n)
Process the first n bytes of data in pn_connection_driver_read_buffer() and reclaim the buffer space.
void pn_connection_driver_close(pn_connection_driver_t *c)
Close both sides.
int pn_connection_driver_bind(pn_connection_driver_t *d)
Force binding of the transport.
void pn_connection_driver_log(pn_connection_driver_t *d, const char *msg)
Deprecated - Use pn_transport_log().
bool pn_connection_driver_has_event(pn_connection_driver_t *)
True if pn_connection_driver_next_event() will return a non-NULL event.
void pn_connection_driver_write_close(pn_connection_driver_t *)
Close the write side.
The elements needed to drive AMQP IO and events.
Definition connection_driver.h:91
struct pn_connection_t pn_connection_t
An AMQP Connection object.
Definition types.h:300
struct pn_event_t pn_event_t
Notification of a state change in the protocol engine.
Definition event.h:75
struct pn_collector_t pn_collector_t
An event collector.
Definition types.h:432
struct pn_transport_t pn_transport_t
A network channel supporting an AMQP connection.
Definition types.h:450
AMQP and API data types.