summaryrefslogtreecommitdiffstats
path: root/src/pdispatch.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/pdispatch.h')
-rw-r--r--src/pdispatch.h10
1 files changed, 8 insertions, 2 deletions
diff --git a/src/pdispatch.h b/src/pdispatch.h
index 73686700..35e93829 100644
--- a/src/pdispatch.h
+++ b/src/pdispatch.h
@@ -8,8 +8,10 @@
struct pa_pdispatch;
+/* It is safe to destroy the calling pdispatch object from all callbacks */
+
struct pa_pdispatch_command {
- int (*proc)(struct pa_pdispatch *pd, uint32_t command, uint32_t tag, struct pa_tagstruct *t, void *userdata);
+ void (*proc)(struct pa_pdispatch *pd, uint32_t command, uint32_t tag, struct pa_tagstruct *t, void *userdata);
};
struct pa_pdispatch* pa_pdispatch_new(struct pa_mainloop_api *m, const struct pa_pdispatch_command*table, unsigned entries);
@@ -17,6 +19,10 @@ void pa_pdispatch_free(struct pa_pdispatch *pd);
int pa_pdispatch_run(struct pa_pdispatch *pd, struct pa_packet*p, void *userdata);
-void pa_pdispatch_register_reply(struct pa_pdispatch *pd, uint32_t tag, int timeout, int (*cb)(struct pa_pdispatch *pd, uint32_t command, uint32_t tag, struct pa_tagstruct *t, void *userdata), void *userdata);
+void pa_pdispatch_register_reply(struct pa_pdispatch *pd, uint32_t tag, int timeout, void (*cb)(struct pa_pdispatch *pd, uint32_t command, uint32_t tag, struct pa_tagstruct *t, void *userdata), void *userdata);
+
+int pa_pdispatch_is_pending(struct pa_pdispatch *pd);
+
+void pa_pdispatch_set_drain_callback(struct pa_pdispatch *pd, void (*cb)(struct pa_pdispatch *pd, void *userdata), void *userdata);
#endif