add hooks for connection creation/deletion, for that export pa_native_connection

This commit is contained in:
Lennart Poettering 2008-08-04 18:58:29 +02:00
parent c01f0bc01f
commit eec623a23b
3 changed files with 248 additions and 206 deletions

View file

@ -152,7 +152,7 @@ int pa__init(pa_module*m) {
u->x11_client = NULL;
u->x11_wrapper = NULL;
u->hook_slot = pa_hook_connect(pa_native_protocol_servers_changed(u->protocol), PA_HOOK_NORMAL, servers_changed_cb, u);
u->hook_slot = pa_hook_connect(&pa_native_protocol_hooks(u->protocol)[PA_NATIVE_HOOK_SERVERS_CHANGED], PA_HOOK_NORMAL, servers_changed_cb, u);
if (!(u->auth_cookie = pa_auth_cookie_get(m->core, pa_modargs_get_value(ma, "cookie", PA_NATIVE_COOKIE_FILE), PA_NATIVE_COOKIE_LENGTH)))
goto fail;

File diff suppressed because it is too large Load diff

View file

@ -36,6 +36,8 @@
typedef struct pa_native_protocol pa_native_protocol;
typedef struct pa_native_connection pa_native_connection;
typedef struct pa_native_options {
PA_REFCNT_DECLARE;
@ -48,22 +50,37 @@ typedef struct pa_native_options {
} pa_native_options;
typedef enum pa_native_hook {
PA_NATIVE_HOOK_SERVERS_CHANGED,
PA_NATIVE_HOOK_CONNECTION_PUT,
PA_NATIVE_HOOK_CONNECTION_UNLINK,
PA_NATIVE_HOOK_MAX
} pa_native_hook_t;
pa_native_protocol* pa_native_protocol_get(pa_core *core);
pa_native_protocol* pa_native_protocol_ref(pa_native_protocol *p);
void pa_native_protocol_unref(pa_native_protocol *p);
void pa_native_protocol_connect(pa_native_protocol *p, pa_iochannel *io, pa_native_options *a);
void pa_native_protocol_disconnect(pa_native_protocol *p, pa_module *m);
pa_hook *pa_native_protocol_hooks(pa_native_protocol *p);
void pa_native_protocol_add_server_string(pa_native_protocol *p, const char *name);
void pa_native_protocol_remove_server_string(pa_native_protocol *p, const char *name);
pa_hook *pa_native_protocol_servers_changed(pa_native_protocol *p);
pa_strlist *pa_native_protocol_servers(pa_native_protocol *p);
typedef void (*pa_native_protocol_ext_cb_t)(pa_native_protocol *p, pa_module *m, pa_pstream *ps, uint32_t tag, pa_tagstruct *t);
typedef int (*pa_native_protocol_ext_cb_t)(
pa_native_protocol *p,
pa_module *m,
pa_native_connection *c,
uint32_t tag,
pa_tagstruct *t);
int pa_native_protocol_install_ext(pa_native_protocol *p, pa_module *m, pa_native_protocol_ext_cb_t cb);
void pa_native_protocol_remove_ext(pa_native_protocol *p, pa_module *m);
pa_pstream* pa_native_connection_get_pstream(pa_native_connection *c);
pa_native_options* pa_native_options_new(void);
pa_native_options* pa_native_options_ref(pa_native_options *o);
void pa_native_options_unref(pa_native_options *o);