Typedefs | |
typedef pn_iterator_t | pn_selectables_t |
An iterator for selectables. | |
typedef struct pn_selectable_t | pn_selectable_t |
A selectable object provides an interface that can be used to incorporate proton's I/O into third party event loops. | |
Functions | |
PN_EXTERN pn_selectables_t * | pn_selectables (void) |
Construct a new selectables iterator. | |
PN_EXTERN pn_selectable_t * | pn_selectables_next (pn_selectables_t *selectables) |
Get the next selectable from an iterator. | |
PN_EXTERN void | pn_selectables_free (pn_selectables_t *selectables) |
Free a selectables iterator. | |
PN_EXTERN pn_selectable_t * | pn_selectable (void) |
PN_EXTERN void | pn_selectable_on_readable (pn_selectable_t *sel, void(*readable)(pn_selectable_t *)) |
PN_EXTERN void | pn_selectable_on_writable (pn_selectable_t *sel, void(*writable)(pn_selectable_t *)) |
PN_EXTERN void | pn_selectable_on_expired (pn_selectable_t *sel, void(*expired)(pn_selectable_t *)) |
PN_EXTERN void | pn_selectable_on_error (pn_selectable_t *sel, void(*error)(pn_selectable_t *)) |
PN_EXTERN void | pn_selectable_on_release (pn_selectable_t *sel, void(*release)(pn_selectable_t *)) |
PN_EXTERN void | pn_selectable_on_finalize (pn_selectable_t *sel, void(*finalize)(pn_selectable_t *)) |
PN_EXTERN pn_record_t * | pn_selectable_attachments (pn_selectable_t *sel) |
PN_EXTERN pn_socket_t | pn_selectable_get_fd (pn_selectable_t *selectable) |
Get the file descriptor associated with a selectable. | |
PN_EXTERN void | pn_selectable_set_fd (pn_selectable_t *selectable, pn_socket_t fd) |
Set the file descriptor associated with a selectable. | |
PN_EXTERN bool | pn_selectable_is_reading (pn_selectable_t *selectable) |
Check if a selectable is interested in readable events. | |
PN_EXTERN void | pn_selectable_set_reading (pn_selectable_t *sel, bool reading) |
PN_EXTERN bool | pn_selectable_is_writing (pn_selectable_t *selectable) |
Check if a selectable is interested in writable events. | |
PN_EXTERN void | pn_selectable_set_writing (pn_selectable_t *sel, bool writing) |
PN_EXTERN pn_timestamp_t | pn_selectable_get_deadline (pn_selectable_t *selectable) |
Get the next deadline for a selectable. | |
PN_EXTERN void | pn_selectable_set_deadline (pn_selectable_t *sel, pn_timestamp_t deadline) |
PN_EXTERN void | pn_selectable_readable (pn_selectable_t *selectable) |
Notify a selectable that the file descriptor is readable. | |
PN_EXTERN void | pn_selectable_writable (pn_selectable_t *selectable) |
Notify a selectable that the file descriptor is writable. | |
PN_EXTERN void | pn_selectable_error (pn_selectable_t *selectable) |
Notify a selectable that there is an error on the file descriptor. | |
PN_EXTERN void | pn_selectable_expired (pn_selectable_t *selectable) |
Notify a selectable that its deadline has expired. | |
PN_EXTERN bool | pn_selectable_is_registered (pn_selectable_t *selectable) |
Check if a selectable is registered. | |
PN_EXTERN void | pn_selectable_set_registered (pn_selectable_t *selectable, bool registered) |
Set the registered flag for a selectable. | |
PN_EXTERN bool | pn_selectable_is_terminal (pn_selectable_t *selectable) |
Check if a selectable is in the terminal state. | |
PN_EXTERN void | pn_selectable_terminate (pn_selectable_t *selectable) |
Terminate a selectable. | |
PN_EXTERN void | pn_selectable_release (pn_selectable_t *selectable) |
PN_EXTERN void | pn_selectable_free (pn_selectable_t *selectable) |
Free a selectable object. | |
PN_EXTERN void | pn_selectable_collect (pn_selectable_t *selectable, pn_collector_t *collector) |
Configure a selectable with a set of callbacks that emit readable, writable, and expired events into the supplied collector. |
typedef struct pn_selectable_t pn_selectable_t |
A selectable object provides an interface that can be used to incorporate proton's I/O into third party event loops.
Every selectable is associated with exactly one file descriptor. Selectables may be interested in three kinds of events, read events, write events, and timer events.
When a read, write, or timer event occurs, the selectable must be notified by calling pn_selectable_readable(), pn_selectable_writable(), and pn_selectable_expired() as appropriate.
Once a selectable reaches a terminal state (see pn_selectable_is_terminal()), it will never be interested in events of any kind. When this occurs it should be removed from the external event loop and discarded using pn_selectable_free().
typedef pn_iterator_t pn_selectables_t |
An iterator for selectables.
PN_EXTERN pn_selectable_t* pn_selectable | ( | void | ) |
PN_EXTERN pn_record_t* pn_selectable_attachments | ( | pn_selectable_t * | sel | ) |
PN_EXTERN void pn_selectable_collect | ( | pn_selectable_t * | selectable, | |
pn_collector_t * | collector | |||
) |
Configure a selectable with a set of callbacks that emit readable, writable, and expired events into the supplied collector.
[in] | selectable | a selectable objet |
[in] | collector | a collector object |
PN_EXTERN void pn_selectable_error | ( | pn_selectable_t * | selectable | ) |
Notify a selectable that there is an error on the file descriptor.
[in] | selectable | a selectable object |
PN_EXTERN void pn_selectable_expired | ( | pn_selectable_t * | selectable | ) |
Notify a selectable that its deadline has expired.
[in] | selectable | a selectable object |
PN_EXTERN void pn_selectable_free | ( | pn_selectable_t * | selectable | ) |
Free a selectable object.
[in] | selectable | a selectable object (or NULL) |
PN_EXTERN pn_timestamp_t pn_selectable_get_deadline | ( | pn_selectable_t * | selectable | ) |
Get the next deadline for a selectable.
A selectable with a deadline is interested in being notified when that deadline expires. Zero indicates there is currently no deadline.
[in] | selectable | a selectable object |
PN_EXTERN pn_socket_t pn_selectable_get_fd | ( | pn_selectable_t * | selectable | ) |
Get the file descriptor associated with a selectable.
[in] | selectable | a selectable object |
PN_EXTERN bool pn_selectable_is_reading | ( | pn_selectable_t * | selectable | ) |
Check if a selectable is interested in readable events.
[in] | selectable | a selectable object |
PN_EXTERN bool pn_selectable_is_registered | ( | pn_selectable_t * | selectable | ) |
Check if a selectable is registered.
This flag is set via pn_selectable_set_registered() and can be used for tracking whether a given selectable has been registerd with an external event loop.
[in] | selectable |
PN_EXTERN bool pn_selectable_is_terminal | ( | pn_selectable_t * | selectable | ) |
Check if a selectable is in the terminal state.
A selectable that is in the terminal state will never be interested in being notified of events of any kind ever again. Once a selectable reaches this state it should be removed from any external I/O loops and freed in order to reclaim any resources associated with it.
[in] | selectable | a selectable object |
PN_EXTERN bool pn_selectable_is_writing | ( | pn_selectable_t * | selectable | ) |
Check if a selectable is interested in writable events.
[in] | selectable | a selectable object |
PN_EXTERN void pn_selectable_on_error | ( | pn_selectable_t * | sel, | |
void(*)(pn_selectable_t *) | error | |||
) |
PN_EXTERN void pn_selectable_on_expired | ( | pn_selectable_t * | sel, | |
void(*)(pn_selectable_t *) | expired | |||
) |
PN_EXTERN void pn_selectable_on_finalize | ( | pn_selectable_t * | sel, | |
void(*)(pn_selectable_t *) | finalize | |||
) |
PN_EXTERN void pn_selectable_on_readable | ( | pn_selectable_t * | sel, | |
void(*)(pn_selectable_t *) | readable | |||
) |
PN_EXTERN void pn_selectable_on_release | ( | pn_selectable_t * | sel, | |
void(*)(pn_selectable_t *) | release | |||
) |
PN_EXTERN void pn_selectable_on_writable | ( | pn_selectable_t * | sel, | |
void(*)(pn_selectable_t *) | writable | |||
) |
PN_EXTERN void pn_selectable_readable | ( | pn_selectable_t * | selectable | ) |
Notify a selectable that the file descriptor is readable.
[in] | selectable | a selectable object |
PN_EXTERN void pn_selectable_release | ( | pn_selectable_t * | selectable | ) |
PN_EXTERN void pn_selectable_set_deadline | ( | pn_selectable_t * | sel, | |
pn_timestamp_t | deadline | |||
) |
PN_EXTERN void pn_selectable_set_fd | ( | pn_selectable_t * | selectable, | |
pn_socket_t | fd | |||
) |
Set the file descriptor associated with a selectable.
[in] | selectable | a selectable object |
[in] | fd | the file descriptor |
PN_EXTERN void pn_selectable_set_reading | ( | pn_selectable_t * | sel, | |
bool | reading | |||
) |
PN_EXTERN void pn_selectable_set_registered | ( | pn_selectable_t * | selectable, | |
bool | registered | |||
) |
Set the registered flag for a selectable.
See pn_selectable_is_registered() for details.
[in] | selectable | a selectable object |
[in] | registered | the registered flag |
PN_EXTERN void pn_selectable_set_writing | ( | pn_selectable_t * | sel, | |
bool | writing | |||
) |
PN_EXTERN void pn_selectable_terminate | ( | pn_selectable_t * | selectable | ) |
Terminate a selectable.
[in] | selectable | a selectable object |
PN_EXTERN void pn_selectable_writable | ( | pn_selectable_t * | selectable | ) |
Notify a selectable that the file descriptor is writable.
[in] | selectable | a selectable object |
PN_EXTERN pn_selectables_t* pn_selectables | ( | void | ) |
Construct a new selectables iterator.
PN_EXTERN void pn_selectables_free | ( | pn_selectables_t * | selectables | ) |
Free a selectables iterator.
[in] | selectables | a selectables iterator (or NULL) |
PN_EXTERN pn_selectable_t* pn_selectables_next | ( | pn_selectables_t * | selectables | ) |
Get the next selectable from an iterator.
[in] | selectables | a selectable iterator |