1 #ifndef PROTON_PROACTOR_H
2 #define PROTON_PROACTOR_H 1
25 #include <proton/import_export.h>
74 #define PN_MAX_ADDR 1060
86 PNP_EXTERN
int pn_proactor_addr(
char *addr,
size_t size,
const char *host,
const char *port);
Protocol and transport events.
uint32_t pn_millis_t
A span of time in milliseconds.
Definition: types.h:149
struct pn_condition_t pn_condition_t
An AMQP Condition object.
Definition: condition.h:64
struct pn_connection_t pn_connection_t
An AMQP Connection object.
Definition: types.h:285
struct pn_event_t pn_event_t
Notification of a state change in the protocol engine.
Definition: event.h:75
struct pn_listener_t pn_listener_t
A listener for incoming connections.
Definition: types.h:424
PNP_EXTERN int64_t pn_proactor_now_64(void)
Get the real elapsed time since an arbitrary point in the past in milliseconds.
PNP_EXTERN void pn_connection_wake(pn_connection_t *connection)
Return a PN_CONNECTION_WAKE event for connection as soon as possible.
PNP_EXTERN void pn_proactor_release_connection(pn_connection_t *connection)
Release ownership of connection, disassociate it from its proactor.
PNP_EXTERN pn_event_batch_t * pn_proactor_wait(pn_proactor_t *proactor)
Wait until there are Proactor events to handle.
PNP_EXTERN pn_proactor_t * pn_connection_proactor(pn_connection_t *connection)
Return the proactor associated with a connection.
PNP_EXTERN void pn_proactor_free(pn_proactor_t *proactor)
Free the proactor.
struct pn_event_batch_t pn_event_batch_t
A batch of events that must be handled in sequence.
Definition: types.h:462
PNP_EXTERN pn_event_t * pn_event_batch_next(pn_event_batch_t *batch)
Remove the next event from the batch and return it.
PNP_EXTERN pn_event_batch_t * pn_proactor_get(pn_proactor_t *proactor)
Return Proactor events if any are available immediately.
PNP_EXTERN void pn_proactor_connect(pn_proactor_t *proactor, pn_connection_t *connection, const char *addr)
Deprecated - Use pn_proactor_connect2()
PNP_EXTERN void pn_proactor_interrupt(pn_proactor_t *proactor)
Return a PN_PROACTOR_INTERRUPT event as soon as possible.
PNP_EXTERN void pn_proactor_connect2(pn_proactor_t *proactor, pn_connection_t *connection, pn_transport_t *transport, const char *addr)
Connect transport to addr and bind to connection.
struct pn_proactor_t pn_proactor_t
A harness for multithreaded IO.
Definition: types.h:442
PNP_EXTERN void pn_proactor_cancel_timeout(pn_proactor_t *proactor)
Cancel the pending timeout set by pn_proactor_set_timeout().
PNP_EXTERN pn_proactor_t * pn_proactor(void)
Create a proactor.
PNP_EXTERN pn_proactor_t * pn_event_proactor(pn_event_t *event)
Return the proactor associated with an event.
PNP_EXTERN void pn_proactor_disconnect(pn_proactor_t *proactor, pn_condition_t *condition)
Disconnect all connections and listeners belonging to the proactor.
PNP_EXTERN void pn_proactor_listen(pn_proactor_t *proactor, pn_listener_t *listener, const char *addr, int backlog)
Start listening for incoming connections.
PNP_EXTERN pn_millis_t pn_proactor_now(void)
PNP_EXTERN void pn_proactor_set_timeout(pn_proactor_t *proactor, pn_millis_t timeout)
Return a PN_PROACTOR_TIMEOUT after timeout milliseconds elapse.
PNP_EXTERN void pn_proactor_done(pn_proactor_t *proactor, pn_event_batch_t *events)
Call when finished handling a batch of events.
PNP_EXTERN int pn_proactor_addr(char *addr, size_t size, const char *host, const char *port)
Format a host:port address string for pn_proactor_connect() or pn_proactor_listen()
PNP_EXTERN void pn_connection_write_flush(pn_connection_t *connection)
Unsettled API Send available AMQP protocol frames to the remote peer.
PNP_EXTERN void pn_proactor_raw_connect(pn_proactor_t *proactor, pn_raw_connection_t *raw_connection, const char *addr)
Connect addr and bind to raw_connection.
struct pn_raw_connection_t pn_raw_connection_t
A raw network connection used with the proactor.
Definition: types.h:449
struct pn_transport_t pn_transport_t
A network channel supporting an AMQP connection.
Definition: types.h:435