50 lines
1.2 KiB
C
50 lines
1.2 KiB
C
#ifndef UMUMBLE_UMUMBLE_H
|
|
#define UMUMBLE_UMUMBLE_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif /* __cplusplus */
|
|
|
|
#include "constants.h"
|
|
|
|
#include <uv.h>
|
|
#include <tlsuv/tlsuv.h>
|
|
|
|
typedef struct mumble_ctx_s {
|
|
int status;
|
|
int error;
|
|
uv_loop_t uv_loop;
|
|
uv_getaddrinfo_t uv_resolver;
|
|
uv_connect_t uv_connect_req;
|
|
tlsuv_stream_t tls_stream;
|
|
uv_tcp_t uv_tcp_socket;
|
|
} mumble_ctx_t;
|
|
|
|
/* Initializes a mumble context object.
|
|
* This function will allocate initial memory needed for storing e.g. the channel layout.
|
|
* Make sure to call mumble_ctx_close() when you're done!
|
|
*
|
|
* \param ctx pointer to the context object to initialize
|
|
* \return int indicating success
|
|
* \retval 1 error
|
|
*/
|
|
int mumble_ctx_init(mumble_ctx_t *ctx);
|
|
|
|
/* Closes a mumble context, deallocating internal objects used by the context.
|
|
* This function does not free the memory possibly used to allocate the ctx object.
|
|
* If you stored ctx in dynamic memory, make sure to call free(ctx) after calling this function.
|
|
*
|
|
* \param ctx pointer to the context object to close
|
|
*/
|
|
void mumble_ctx_close(mumble_ctx_t *ctx);
|
|
|
|
int mumble_connect(mumble_ctx_t *ctx, const char *host, int port);
|
|
|
|
int mumble_run(mumble_ctx_t *ctx);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif /* __cplusplus */
|
|
|
|
#endif /* UMUMBLE_UMUMBLE_H */
|