4 This file is part of PulseAudio.
6 Copyright 2004-2006 Lennart Poettering
7 Copyright 2006 Pierre Ossman <ossman@cendio.se> for Cendio AB
9 PulseAudio is free software; you can redistribute it and/or modify
10 it under the terms of the GNU Lesser General Public License as published
11 by the Free Software Foundation; either version 2 of the License,
12 or (at your option) any later version.
14 PulseAudio is distributed in the hope that it will be useful, but
15 WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 General Public License for more details.
19 You should have received a copy of the GNU Lesser General Public License
20 along with PulseAudio; if not, write to the Free Software
21 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
29 #include <pulse/context.h>
31 #include <pulsecore/gccmacro.h>
32 #include <pulsecore/macro.h>
33 #include <pulsecore/pstream-util.h>
37 #include "introspect.h"
41 static void context_stat_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
42 pa_operation
*o
= userdata
;
43 pa_stat_info i
, *p
= &i
;
47 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
49 memset(&i
, 0, sizeof(i
));
54 if (command
!= PA_COMMAND_REPLY
) {
55 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
59 } else if (pa_tagstruct_getu32(t
, &i
.memblock_total
) < 0 ||
60 pa_tagstruct_getu32(t
, &i
.memblock_total_size
) < 0 ||
61 pa_tagstruct_getu32(t
, &i
.memblock_allocated
) < 0 ||
62 pa_tagstruct_getu32(t
, &i
.memblock_allocated_size
) < 0 ||
63 pa_tagstruct_getu32(t
, &i
.scache_size
) < 0) {
64 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
69 pa_stat_info_cb_t cb
= (pa_stat_info_cb_t
) o
->callback
;
70 cb(o
->context
, p
, o
->userdata
);
75 pa_operation_unref(o
);
78 pa_operation
* pa_context_stat(pa_context
*c
, pa_stat_info_cb_t cb
, void *userdata
) {
79 return pa_context_send_simple_command(c
, PA_COMMAND_STAT
, context_stat_callback
, (pa_operation_cb_t
) cb
, userdata
);
84 static void context_get_server_info_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
85 pa_operation
*o
= userdata
;
86 pa_server_info i
, *p
= &i
;
90 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
92 memset(&i
, 0, sizeof(i
));
97 if (command
!= PA_COMMAND_REPLY
) {
98 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
102 } else if (pa_tagstruct_gets(t
, &i
.server_name
) < 0 ||
103 pa_tagstruct_gets(t
, &i
.server_version
) < 0 ||
104 pa_tagstruct_gets(t
, &i
.user_name
) < 0 ||
105 pa_tagstruct_gets(t
, &i
.host_name
) < 0 ||
106 pa_tagstruct_get_sample_spec(t
, &i
.sample_spec
) < 0 ||
107 pa_tagstruct_gets(t
, &i
.default_sink_name
) < 0 ||
108 pa_tagstruct_gets(t
, &i
.default_source_name
) < 0 ||
109 pa_tagstruct_getu32(t
, &i
.cookie
) < 0) {
111 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
116 pa_server_info_cb_t cb
= (pa_server_info_cb_t
) o
->callback
;
117 cb(o
->context
, p
, o
->userdata
);
121 pa_operation_done(o
);
122 pa_operation_unref(o
);
125 pa_operation
* pa_context_get_server_info(pa_context
*c
, pa_server_info_cb_t cb
, void *userdata
) {
126 return pa_context_send_simple_command(c
, PA_COMMAND_GET_SERVER_INFO
, context_get_server_info_callback
, (pa_operation_cb_t
) cb
, userdata
);
131 static void context_get_sink_info_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
132 pa_operation
*o
= userdata
;
137 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
142 if (command
!= PA_COMMAND_REPLY
) {
143 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
150 while (!pa_tagstruct_eof(t
)) {
153 memset(&i
, 0, sizeof(i
));
154 i
.proplist
= pa_proplist_new();
156 if (pa_tagstruct_getu32(t
, &i
.index
) < 0 ||
157 pa_tagstruct_gets(t
, &i
.name
) < 0 ||
158 pa_tagstruct_gets(t
, &i
.description
) < 0 ||
159 pa_tagstruct_get_sample_spec(t
, &i
.sample_spec
) < 0 ||
160 pa_tagstruct_get_channel_map(t
, &i
.channel_map
) < 0 ||
161 pa_tagstruct_getu32(t
, &i
.owner_module
) < 0 ||
162 pa_tagstruct_get_cvolume(t
, &i
.volume
) < 0 ||
163 pa_tagstruct_get_boolean(t
, &i
.mute
) < 0 ||
164 pa_tagstruct_getu32(t
, &i
.monitor_source
) < 0 ||
165 pa_tagstruct_gets(t
, &i
.monitor_source_name
) < 0 ||
166 pa_tagstruct_get_usec(t
, &i
.latency
) < 0 ||
167 pa_tagstruct_gets(t
, &i
.driver
) < 0 ||
168 pa_tagstruct_getu32(t
, &flags
) < 0 ||
169 (o
->context
->version
>= 13 && pa_tagstruct_get_proplist(t
, i
.proplist
) < 0)) {
171 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
172 pa_proplist_free(i
.proplist
);
176 i
.flags
= (pa_sink_flags_t
) flags
;
179 pa_sink_info_cb_t cb
= (pa_sink_info_cb_t
) o
->callback
;
180 cb(o
->context
, &i
, 0, o
->userdata
);
183 pa_proplist_free(i
.proplist
);
188 pa_sink_info_cb_t cb
= (pa_sink_info_cb_t
) o
->callback
;
189 cb(o
->context
, NULL
, eol
, o
->userdata
);
193 pa_operation_done(o
);
194 pa_operation_unref(o
);
197 pa_operation
* pa_context_get_sink_info_list(pa_context
*c
, pa_sink_info_cb_t cb
, void *userdata
) {
198 return pa_context_send_simple_command(c
, PA_COMMAND_GET_SINK_INFO_LIST
, context_get_sink_info_callback
, (pa_operation_cb_t
) cb
, userdata
);
201 pa_operation
* pa_context_get_sink_info_by_index(pa_context
*c
, uint32_t idx
, pa_sink_info_cb_t cb
, void *userdata
) {
207 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
210 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
212 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
214 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_SINK_INFO
, &tag
);
215 pa_tagstruct_putu32(t
, idx
);
216 pa_tagstruct_puts(t
, NULL
);
217 pa_pstream_send_tagstruct(c
->pstream
, t
);
218 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_sink_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
223 pa_operation
* pa_context_get_sink_info_by_name(pa_context
*c
, const char *name
, pa_sink_info_cb_t cb
, void *userdata
) {
229 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
232 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
233 PA_CHECK_VALIDITY_RETURN_NULL(c
, !name
|| *name
, PA_ERR_INVALID
);
235 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
237 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_SINK_INFO
, &tag
);
238 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
239 pa_tagstruct_puts(t
, name
);
240 pa_pstream_send_tagstruct(c
->pstream
, t
);
241 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_sink_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
246 /*** Source info ***/
248 static void context_get_source_info_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
249 pa_operation
*o
= userdata
;
254 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
259 if (command
!= PA_COMMAND_REPLY
) {
260 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
266 while (!pa_tagstruct_eof(t
)) {
270 memset(&i
, 0, sizeof(i
));
271 i
.proplist
= pa_proplist_new();
273 if (pa_tagstruct_getu32(t
, &i
.index
) < 0 ||
274 pa_tagstruct_gets(t
, &i
.name
) < 0 ||
275 pa_tagstruct_gets(t
, &i
.description
) < 0 ||
276 pa_tagstruct_get_sample_spec(t
, &i
.sample_spec
) < 0 ||
277 pa_tagstruct_get_channel_map(t
, &i
.channel_map
) < 0 ||
278 pa_tagstruct_getu32(t
, &i
.owner_module
) < 0 ||
279 pa_tagstruct_get_cvolume(t
, &i
.volume
) < 0 ||
280 pa_tagstruct_get_boolean(t
, &i
.mute
) < 0 ||
281 pa_tagstruct_getu32(t
, &i
.monitor_of_sink
) < 0 ||
282 pa_tagstruct_gets(t
, &i
.monitor_of_sink_name
) < 0 ||
283 pa_tagstruct_get_usec(t
, &i
.latency
) < 0 ||
284 pa_tagstruct_gets(t
, &i
.driver
) < 0 ||
285 pa_tagstruct_getu32(t
, &flags
) < 0 ||
286 (o
->context
->version
>= 13 && pa_tagstruct_get_proplist(t
, i
.proplist
) < 0)) {
288 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
289 pa_proplist_free(i
.proplist
);
293 i
.flags
= (pa_source_flags_t
) flags
;
296 pa_source_info_cb_t cb
= (pa_source_info_cb_t
) o
->callback
;
297 cb(o
->context
, &i
, 0, o
->userdata
);
300 pa_proplist_free(i
.proplist
);
305 pa_source_info_cb_t cb
= (pa_source_info_cb_t
) o
->callback
;
306 cb(o
->context
, NULL
, eol
, o
->userdata
);
310 pa_operation_done(o
);
311 pa_operation_unref(o
);
314 pa_operation
* pa_context_get_source_info_list(pa_context
*c
, pa_source_info_cb_t cb
, void *userdata
) {
315 return pa_context_send_simple_command(c
, PA_COMMAND_GET_SOURCE_INFO_LIST
, context_get_source_info_callback
, (pa_operation_cb_t
) cb
, userdata
);
318 pa_operation
* pa_context_get_source_info_by_index(pa_context
*c
, uint32_t idx
, pa_source_info_cb_t cb
, void *userdata
) {
324 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
327 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
329 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
331 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_SOURCE_INFO
, &tag
);
332 pa_tagstruct_putu32(t
, idx
);
333 pa_tagstruct_puts(t
, NULL
);
334 pa_pstream_send_tagstruct(c
->pstream
, t
);
335 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_source_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
340 pa_operation
* pa_context_get_source_info_by_name(pa_context
*c
, const char *name
, pa_source_info_cb_t cb
, void *userdata
) {
346 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
349 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
350 PA_CHECK_VALIDITY_RETURN_NULL(c
, !name
|| *name
, PA_ERR_INVALID
);
352 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
354 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_SOURCE_INFO
, &tag
);
355 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
356 pa_tagstruct_puts(t
, name
);
357 pa_pstream_send_tagstruct(c
->pstream
, t
);
358 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_source_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
363 /*** Client info ***/
365 static void context_get_client_info_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
366 pa_operation
*o
= userdata
;
371 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
376 if (command
!= PA_COMMAND_REPLY
) {
377 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
383 while (!pa_tagstruct_eof(t
)) {
386 memset(&i
, 0, sizeof(i
));
387 i
.proplist
= pa_proplist_new();
389 if (pa_tagstruct_getu32(t
, &i
.index
) < 0 ||
390 pa_tagstruct_gets(t
, &i
.name
) < 0 ||
391 pa_tagstruct_getu32(t
, &i
.owner_module
) < 0 ||
392 pa_tagstruct_gets(t
, &i
.driver
) < 0 ||
393 (o
->context
->version
>= 13 && pa_tagstruct_get_proplist(t
, i
.proplist
) < 0)) {
395 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
396 pa_proplist_free(i
.proplist
);
401 pa_client_info_cb_t cb
= (pa_client_info_cb_t
) o
->callback
;
402 cb(o
->context
, &i
, 0, o
->userdata
);
405 pa_proplist_free(i
.proplist
);
410 pa_client_info_cb_t cb
= (pa_client_info_cb_t
) o
->callback
;
411 cb(o
->context
, NULL
, eol
, o
->userdata
);
415 pa_operation_done(o
);
416 pa_operation_unref(o
);
419 pa_operation
* pa_context_get_client_info(pa_context
*c
, uint32_t idx
, pa_client_info_cb_t cb
, void *userdata
) {
425 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
428 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
429 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
431 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
433 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_CLIENT_INFO
, &tag
);
434 pa_tagstruct_putu32(t
, idx
);
435 pa_pstream_send_tagstruct(c
->pstream
, t
);
436 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_client_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
441 pa_operation
* pa_context_get_client_info_list(pa_context
*c
, pa_client_info_cb_t cb
, void *userdata
) {
442 return pa_context_send_simple_command(c
, PA_COMMAND_GET_CLIENT_INFO_LIST
, context_get_client_info_callback
, (pa_operation_cb_t
) cb
, userdata
);
445 /*** Module info ***/
447 static void context_get_module_info_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
448 pa_operation
*o
= userdata
;
453 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
458 if (command
!= PA_COMMAND_REPLY
) {
459 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
465 while (!pa_tagstruct_eof(t
)) {
467 memset(&i
, 0, sizeof(i
));
469 if (pa_tagstruct_getu32(t
, &i
.index
) < 0 ||
470 pa_tagstruct_gets(t
, &i
.name
) < 0 ||
471 pa_tagstruct_gets(t
, &i
.argument
) < 0 ||
472 pa_tagstruct_getu32(t
, &i
.n_used
) < 0 ||
473 pa_tagstruct_get_boolean(t
, &i
.auto_unload
) < 0) {
474 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
479 pa_module_info_cb_t cb
= (pa_module_info_cb_t
) o
->callback
;
480 cb(o
->context
, &i
, 0, o
->userdata
);
486 pa_module_info_cb_t cb
= (pa_module_info_cb_t
) o
->callback
;
487 cb(o
->context
, NULL
, eol
, o
->userdata
);
491 pa_operation_done(o
);
492 pa_operation_unref(o
);
495 pa_operation
* pa_context_get_module_info(pa_context
*c
, uint32_t idx
, pa_module_info_cb_t cb
, void *userdata
) {
501 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
504 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
505 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
507 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
509 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_MODULE_INFO
, &tag
);
510 pa_tagstruct_putu32(t
, idx
);
511 pa_pstream_send_tagstruct(c
->pstream
, t
);
512 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_module_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
517 pa_operation
* pa_context_get_module_info_list(pa_context
*c
, pa_module_info_cb_t cb
, void *userdata
) {
518 return pa_context_send_simple_command(c
, PA_COMMAND_GET_MODULE_INFO_LIST
, context_get_module_info_callback
, (pa_operation_cb_t
) cb
, userdata
);
521 /*** Sink input info ***/
523 static void context_get_sink_input_info_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
524 pa_operation
*o
= userdata
;
529 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
534 if (command
!= PA_COMMAND_REPLY
) {
535 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
541 while (!pa_tagstruct_eof(t
)) {
542 pa_sink_input_info i
;
544 memset(&i
, 0, sizeof(i
));
545 i
.proplist
= pa_proplist_new();
547 if (pa_tagstruct_getu32(t
, &i
.index
) < 0 ||
548 pa_tagstruct_gets(t
, &i
.name
) < 0 ||
549 pa_tagstruct_getu32(t
, &i
.owner_module
) < 0 ||
550 pa_tagstruct_getu32(t
, &i
.client
) < 0 ||
551 pa_tagstruct_getu32(t
, &i
.sink
) < 0 ||
552 pa_tagstruct_get_sample_spec(t
, &i
.sample_spec
) < 0 ||
553 pa_tagstruct_get_channel_map(t
, &i
.channel_map
) < 0 ||
554 pa_tagstruct_get_cvolume(t
, &i
.volume
) < 0 ||
555 pa_tagstruct_get_usec(t
, &i
.buffer_usec
) < 0 ||
556 pa_tagstruct_get_usec(t
, &i
.sink_usec
) < 0 ||
557 pa_tagstruct_gets(t
, &i
.resample_method
) < 0 ||
558 pa_tagstruct_gets(t
, &i
.driver
) < 0 ||
559 (o
->context
->version
>= 11 && pa_tagstruct_get_boolean(t
, &i
.mute
) < 0) ||
560 (o
->context
->version
>= 13 && pa_tagstruct_get_proplist(t
, i
.proplist
) < 0)) {
562 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
563 pa_proplist_free(i
.proplist
);
568 pa_sink_input_info_cb_t cb
= (pa_sink_input_info_cb_t
) o
->callback
;
569 cb(o
->context
, &i
, 0, o
->userdata
);
572 pa_proplist_free(i
.proplist
);
577 pa_sink_input_info_cb_t cb
= (pa_sink_input_info_cb_t
) o
->callback
;
578 cb(o
->context
, NULL
, eol
, o
->userdata
);
582 pa_operation_done(o
);
583 pa_operation_unref(o
);
586 pa_operation
* pa_context_get_sink_input_info(pa_context
*c
, uint32_t idx
, pa_sink_input_info_cb_t cb
, void *userdata
) {
592 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
595 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
596 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
598 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
600 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_SINK_INPUT_INFO
, &tag
);
601 pa_tagstruct_putu32(t
, idx
);
602 pa_pstream_send_tagstruct(c
->pstream
, t
);
603 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_sink_input_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
608 pa_operation
* pa_context_get_sink_input_info_list(pa_context
*c
, void (*cb
)(pa_context
*c
, const pa_sink_input_info
*i
, int is_last
, void *userdata
), void *userdata
) {
609 return pa_context_send_simple_command(c
, PA_COMMAND_GET_SINK_INPUT_INFO_LIST
, context_get_sink_input_info_callback
, (pa_operation_cb_t
) cb
, userdata
);
612 /*** Source output info ***/
614 static void context_get_source_output_info_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
615 pa_operation
*o
= userdata
;
620 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
625 if (command
!= PA_COMMAND_REPLY
) {
626 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
632 while (!pa_tagstruct_eof(t
)) {
633 pa_source_output_info i
;
635 memset(&i
, 0, sizeof(i
));
636 i
.proplist
= pa_proplist_new();
638 if (pa_tagstruct_getu32(t
, &i
.index
) < 0 ||
639 pa_tagstruct_gets(t
, &i
.name
) < 0 ||
640 pa_tagstruct_getu32(t
, &i
.owner_module
) < 0 ||
641 pa_tagstruct_getu32(t
, &i
.client
) < 0 ||
642 pa_tagstruct_getu32(t
, &i
.source
) < 0 ||
643 pa_tagstruct_get_sample_spec(t
, &i
.sample_spec
) < 0 ||
644 pa_tagstruct_get_channel_map(t
, &i
.channel_map
) < 0 ||
645 pa_tagstruct_get_usec(t
, &i
.buffer_usec
) < 0 ||
646 pa_tagstruct_get_usec(t
, &i
.source_usec
) < 0 ||
647 pa_tagstruct_gets(t
, &i
.resample_method
) < 0 ||
648 pa_tagstruct_gets(t
, &i
.driver
) < 0 ||
649 (o
->context
->version
>= 13 && pa_tagstruct_get_proplist(t
, i
.proplist
) < 0)) {
651 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
652 pa_proplist_free(i
.proplist
);
657 pa_source_output_info_cb_t cb
= (pa_source_output_info_cb_t
) o
->callback
;
658 cb(o
->context
, &i
, 0, o
->userdata
);
661 pa_proplist_free(i
.proplist
);
666 pa_source_output_info_cb_t cb
= (pa_source_output_info_cb_t
) o
->callback
;
667 cb(o
->context
, NULL
, eol
, o
->userdata
);
671 pa_operation_done(o
);
672 pa_operation_unref(o
);
675 pa_operation
* pa_context_get_source_output_info(pa_context
*c
, uint32_t idx
, pa_source_output_info_cb_t cb
, void *userdata
) {
681 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
684 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
685 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
687 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
689 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_SOURCE_OUTPUT_INFO
, &tag
);
690 pa_tagstruct_putu32(t
, idx
);
691 pa_pstream_send_tagstruct(c
->pstream
, t
);
692 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_source_output_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
697 pa_operation
* pa_context_get_source_output_info_list(pa_context
*c
, pa_source_output_info_cb_t cb
, void *userdata
) {
698 return pa_context_send_simple_command(c
, PA_COMMAND_GET_SOURCE_OUTPUT_INFO_LIST
, context_get_source_output_info_callback
, (pa_operation_cb_t
) cb
, userdata
);
701 /*** Volume manipulation ***/
703 pa_operation
* pa_context_set_sink_volume_by_index(pa_context
*c
, uint32_t idx
, const pa_cvolume
*volume
, pa_context_success_cb_t cb
, void *userdata
) {
709 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
712 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
713 PA_CHECK_VALIDITY_RETURN_NULL(c
, pa_cvolume_valid(volume
), PA_ERR_INVALID
);
715 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
717 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SINK_VOLUME
, &tag
);
718 pa_tagstruct_putu32(t
, idx
);
719 pa_tagstruct_puts(t
, NULL
);
720 pa_tagstruct_put_cvolume(t
, volume
);
721 pa_pstream_send_tagstruct(c
->pstream
, t
);
722 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
727 pa_operation
* pa_context_set_sink_volume_by_name(pa_context
*c
, const char *name
, const pa_cvolume
*volume
, pa_context_success_cb_t cb
, void *userdata
) {
733 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
737 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
738 PA_CHECK_VALIDITY_RETURN_NULL(c
, pa_cvolume_valid(volume
), PA_ERR_INVALID
);
739 PA_CHECK_VALIDITY_RETURN_NULL(c
, !name
|| *name
, PA_ERR_INVALID
);
741 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
743 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SINK_VOLUME
, &tag
);
744 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
745 pa_tagstruct_puts(t
, name
);
746 pa_tagstruct_put_cvolume(t
, volume
);
747 pa_pstream_send_tagstruct(c
->pstream
, t
);
748 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
753 pa_operation
* pa_context_set_sink_mute_by_index(pa_context
*c
, uint32_t idx
, int mute
, pa_context_success_cb_t cb
, void *userdata
) {
759 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
761 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
763 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
765 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SINK_MUTE
, &tag
);
766 pa_tagstruct_putu32(t
, idx
);
767 pa_tagstruct_puts(t
, NULL
);
768 pa_tagstruct_put_boolean(t
, mute
);
769 pa_pstream_send_tagstruct(c
->pstream
, t
);
770 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
775 pa_operation
* pa_context_set_sink_mute_by_name(pa_context
*c
, const char *name
, int mute
, pa_context_success_cb_t cb
, void *userdata
) {
781 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
784 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
785 PA_CHECK_VALIDITY_RETURN_NULL(c
, !name
|| *name
, PA_ERR_INVALID
);
787 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
789 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SINK_MUTE
, &tag
);
790 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
791 pa_tagstruct_puts(t
, name
);
792 pa_tagstruct_put_boolean(t
, mute
);
793 pa_pstream_send_tagstruct(c
->pstream
, t
);
794 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
799 pa_operation
* pa_context_set_sink_input_volume(pa_context
*c
, uint32_t idx
, const pa_cvolume
*volume
, pa_context_success_cb_t cb
, void *userdata
) {
805 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
808 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
809 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
810 PA_CHECK_VALIDITY_RETURN_NULL(c
, pa_cvolume_valid(volume
), PA_ERR_INVALID
);
812 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
814 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SINK_INPUT_VOLUME
, &tag
);
815 pa_tagstruct_putu32(t
, idx
);
816 pa_tagstruct_put_cvolume(t
, volume
);
817 pa_pstream_send_tagstruct(c
->pstream
, t
);
818 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
823 pa_operation
* pa_context_set_sink_input_mute(pa_context
*c
, uint32_t idx
, int mute
, pa_context_success_cb_t cb
, void *userdata
) {
829 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
831 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
832 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
833 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->version
>= 11, PA_ERR_NOTSUPPORTED
);
835 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
837 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SINK_INPUT_MUTE
, &tag
);
838 pa_tagstruct_putu32(t
, idx
);
839 pa_tagstruct_put_boolean(t
, mute
);
840 pa_pstream_send_tagstruct(c
->pstream
, t
);
841 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
846 pa_operation
* pa_context_set_source_volume_by_index(pa_context
*c
, uint32_t idx
, const pa_cvolume
*volume
, pa_context_success_cb_t cb
, void *userdata
) {
852 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
855 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
856 PA_CHECK_VALIDITY_RETURN_NULL(c
, pa_cvolume_valid(volume
), PA_ERR_INVALID
);
858 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
860 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SOURCE_VOLUME
, &tag
);
861 pa_tagstruct_putu32(t
, idx
);
862 pa_tagstruct_puts(t
, NULL
);
863 pa_tagstruct_put_cvolume(t
, volume
);
864 pa_pstream_send_tagstruct(c
->pstream
, t
);
865 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
870 pa_operation
* pa_context_set_source_volume_by_name(pa_context
*c
, const char *name
, const pa_cvolume
*volume
, pa_context_success_cb_t cb
, void *userdata
) {
876 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
880 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
881 PA_CHECK_VALIDITY_RETURN_NULL(c
, pa_cvolume_valid(volume
), PA_ERR_INVALID
);
882 PA_CHECK_VALIDITY_RETURN_NULL(c
, !name
|| *name
, PA_ERR_INVALID
);
884 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
886 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SOURCE_VOLUME
, &tag
);
887 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
888 pa_tagstruct_puts(t
, name
);
889 pa_tagstruct_put_cvolume(t
, volume
);
890 pa_pstream_send_tagstruct(c
->pstream
, t
);
891 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
896 pa_operation
* pa_context_set_source_mute_by_index(pa_context
*c
, uint32_t idx
, int mute
, pa_context_success_cb_t cb
, void *userdata
) {
902 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
904 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
906 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
908 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SOURCE_MUTE
, &tag
);
909 pa_tagstruct_putu32(t
, idx
);
910 pa_tagstruct_puts(t
, NULL
);
911 pa_tagstruct_put_boolean(t
, mute
);
912 pa_pstream_send_tagstruct(c
->pstream
, t
);
913 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
918 pa_operation
* pa_context_set_source_mute_by_name(pa_context
*c
, const char *name
, int mute
, pa_context_success_cb_t cb
, void *userdata
) {
924 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
927 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
928 PA_CHECK_VALIDITY_RETURN_NULL(c
, !name
|| *name
, PA_ERR_INVALID
);
930 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
932 t
= pa_tagstruct_command(c
, PA_COMMAND_SET_SOURCE_MUTE
, &tag
);
933 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
934 pa_tagstruct_puts(t
, name
);
935 pa_tagstruct_put_boolean(t
, mute
);
936 pa_pstream_send_tagstruct(c
->pstream
, t
);
937 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
944 static void context_get_sample_info_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
945 pa_operation
*o
= userdata
;
950 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
955 if (command
!= PA_COMMAND_REPLY
) {
956 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
962 while (!pa_tagstruct_eof(t
)) {
965 memset(&i
, 0, sizeof(i
));
966 i
.proplist
= pa_proplist_new();
968 if (pa_tagstruct_getu32(t
, &i
.index
) < 0 ||
969 pa_tagstruct_gets(t
, &i
.name
) < 0 ||
970 pa_tagstruct_get_cvolume(t
, &i
.volume
) < 0 ||
971 pa_tagstruct_get_usec(t
, &i
.duration
) < 0 ||
972 pa_tagstruct_get_sample_spec(t
, &i
.sample_spec
) < 0 ||
973 pa_tagstruct_get_channel_map(t
, &i
.channel_map
) < 0 ||
974 pa_tagstruct_getu32(t
, &i
.bytes
) < 0 ||
975 pa_tagstruct_get_boolean(t
, &i
.lazy
) < 0 ||
976 pa_tagstruct_gets(t
, &i
.filename
) < 0 ||
977 (o
->context
->version
>= 13 && pa_tagstruct_get_proplist(t
, i
.proplist
) < 0)) {
979 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
984 pa_sample_info_cb_t cb
= (pa_sample_info_cb_t
) o
->callback
;
985 cb(o
->context
, &i
, 0, o
->userdata
);
988 pa_proplist_free(i
.proplist
);
993 pa_sample_info_cb_t cb
= (pa_sample_info_cb_t
) o
->callback
;
994 cb(o
->context
, NULL
, eol
, o
->userdata
);
998 pa_operation_done(o
);
999 pa_operation_unref(o
);
1002 pa_operation
* pa_context_get_sample_info_by_name(pa_context
*c
, const char *name
, pa_sample_info_cb_t cb
, void *userdata
) {
1008 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1011 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1012 PA_CHECK_VALIDITY_RETURN_NULL(c
, name
&& *name
, PA_ERR_INVALID
);
1014 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1016 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_SAMPLE_INFO
, &tag
);
1017 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
1018 pa_tagstruct_puts(t
, name
);
1019 pa_pstream_send_tagstruct(c
->pstream
, t
);
1020 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_sample_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1025 pa_operation
* pa_context_get_sample_info_by_index(pa_context
*c
, uint32_t idx
, pa_sample_info_cb_t cb
, void *userdata
) {
1031 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1034 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1035 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1037 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1039 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_SAMPLE_INFO
, &tag
);
1040 pa_tagstruct_putu32(t
, idx
);
1041 pa_tagstruct_puts(t
, NULL
);
1042 pa_pstream_send_tagstruct(c
->pstream
, t
);
1043 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_sample_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1048 pa_operation
* pa_context_get_sample_info_list(pa_context
*c
, pa_sample_info_cb_t cb
, void *userdata
) {
1049 return pa_context_send_simple_command(c
, PA_COMMAND_GET_SAMPLE_INFO_LIST
, context_get_sample_info_callback
, (pa_operation_cb_t
) cb
, userdata
);
1052 static pa_operation
* command_kill(pa_context
*c
, uint32_t command
, uint32_t idx
, pa_context_success_cb_t cb
, void *userdata
) {
1058 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1060 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1061 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1063 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1065 t
= pa_tagstruct_command(c
, command
, &tag
);
1066 pa_tagstruct_putu32(t
, idx
);
1067 pa_pstream_send_tagstruct(c
->pstream
, t
);
1068 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1073 pa_operation
* pa_context_kill_client(pa_context
*c
, uint32_t idx
, pa_context_success_cb_t cb
, void *userdata
) {
1074 return command_kill(c
, PA_COMMAND_KILL_CLIENT
, idx
, cb
, userdata
);
1077 pa_operation
* pa_context_kill_sink_input(pa_context
*c
, uint32_t idx
, pa_context_success_cb_t cb
, void *userdata
) {
1078 return command_kill(c
, PA_COMMAND_KILL_SINK_INPUT
, idx
, cb
, userdata
);
1081 pa_operation
* pa_context_kill_source_output(pa_context
*c
, uint32_t idx
, pa_context_success_cb_t cb
, void *userdata
) {
1082 return command_kill(c
, PA_COMMAND_KILL_SOURCE_OUTPUT
, idx
, cb
, userdata
);
1085 static void context_index_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
1086 pa_operation
*o
= userdata
;
1091 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
1096 if (command
!= PA_COMMAND_REPLY
) {
1097 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
1100 idx
= PA_INVALID_INDEX
;
1101 } else if (pa_tagstruct_getu32(t
, &idx
) ||
1102 !pa_tagstruct_eof(t
)) {
1103 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
1108 pa_context_index_cb_t cb
= (pa_context_index_cb_t
) o
->callback
;
1109 cb(o
->context
, idx
, o
->userdata
);
1114 pa_operation_done(o
);
1115 pa_operation_unref(o
);
1118 pa_operation
* pa_context_load_module(pa_context
*c
, const char*name
, const char *argument
, pa_context_index_cb_t cb
, void *userdata
) {
1124 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1126 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1127 PA_CHECK_VALIDITY_RETURN_NULL(c
, name
&& *name
, PA_ERR_INVALID
);
1129 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1131 t
= pa_tagstruct_command(c
, PA_COMMAND_LOAD_MODULE
, &tag
);
1132 pa_tagstruct_puts(t
, name
);
1133 pa_tagstruct_puts(t
, argument
);
1134 pa_pstream_send_tagstruct(c
->pstream
, t
);
1135 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_index_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1140 pa_operation
* pa_context_unload_module(pa_context
*c
, uint32_t idx
, pa_context_success_cb_t cb
, void *userdata
) {
1141 return command_kill(c
, PA_COMMAND_UNLOAD_MODULE
, idx
, cb
, userdata
);
1144 /*** Autoload stuff ***/
1146 static void context_get_autoload_info_callback(pa_pdispatch
*pd
, uint32_t command
, PA_GCC_UNUSED
uint32_t tag
, pa_tagstruct
*t
, void *userdata
) {
1147 pa_operation
*o
= userdata
;
1152 pa_assert(PA_REFCNT_VALUE(o
) >= 1);
1157 if (command
!= PA_COMMAND_REPLY
) {
1158 if (pa_context_handle_error(o
->context
, command
, t
) < 0)
1164 while (!pa_tagstruct_eof(t
)) {
1167 memset(&i
, 0, sizeof(i
));
1169 if (pa_tagstruct_getu32(t
, &i
.index
) < 0 ||
1170 pa_tagstruct_gets(t
, &i
.name
) < 0 ||
1171 pa_tagstruct_getu32(t
, &i
.type
) < 0 ||
1172 pa_tagstruct_gets(t
, &i
.module
) < 0 ||
1173 pa_tagstruct_gets(t
, &i
.argument
) < 0) {
1174 pa_context_fail(o
->context
, PA_ERR_PROTOCOL
);
1179 pa_autoload_info_cb_t cb
= (pa_autoload_info_cb_t
) o
->callback
;
1180 cb(o
->context
, &i
, 0, o
->userdata
);
1186 pa_autoload_info_cb_t cb
= (pa_autoload_info_cb_t
) o
->callback
;
1187 cb(o
->context
, NULL
, eol
, o
->userdata
);
1191 pa_operation_done(o
);
1192 pa_operation_unref(o
);
1195 pa_operation
* pa_context_get_autoload_info_by_name(pa_context
*c
, const char *name
, pa_autoload_type_t type
, pa_autoload_info_cb_t cb
, void *userdata
) {
1201 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1204 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1205 PA_CHECK_VALIDITY_RETURN_NULL(c
, name
&& *name
, PA_ERR_INVALID
);
1206 PA_CHECK_VALIDITY_RETURN_NULL(c
, type
== PA_AUTOLOAD_SINK
|| type
== PA_AUTOLOAD_SOURCE
, PA_ERR_INVALID
);
1208 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1210 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_AUTOLOAD_INFO
, &tag
);
1211 pa_tagstruct_puts(t
, name
);
1212 pa_tagstruct_putu32(t
, type
);
1213 pa_pstream_send_tagstruct(c
->pstream
, t
);
1214 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_autoload_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1219 pa_operation
* pa_context_get_autoload_info_by_index(pa_context
*c
, uint32_t idx
, pa_autoload_info_cb_t cb
, void *userdata
) {
1225 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1228 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1229 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1231 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1233 t
= pa_tagstruct_command(c
, PA_COMMAND_GET_AUTOLOAD_INFO
, &tag
);
1234 pa_tagstruct_putu32(t
, idx
);
1235 pa_pstream_send_tagstruct(c
->pstream
, t
);
1236 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_get_autoload_info_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1241 pa_operation
* pa_context_get_autoload_info_list(pa_context
*c
, pa_autoload_info_cb_t cb
, void *userdata
) {
1242 return pa_context_send_simple_command(c
, PA_COMMAND_GET_AUTOLOAD_INFO_LIST
, context_get_autoload_info_callback
, (pa_operation_cb_t
) cb
, userdata
);
1245 pa_operation
* pa_context_add_autoload(pa_context
*c
, const char *name
, pa_autoload_type_t type
, const char *module
, const char*argument
, pa_context_index_cb_t cb
, void* userdata
) {
1251 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1253 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1254 PA_CHECK_VALIDITY_RETURN_NULL(c
, name
&& *name
, PA_ERR_INVALID
);
1255 PA_CHECK_VALIDITY_RETURN_NULL(c
, type
== PA_AUTOLOAD_SINK
|| type
== PA_AUTOLOAD_SOURCE
, PA_ERR_INVALID
);
1256 PA_CHECK_VALIDITY_RETURN_NULL(c
, module
&& *module
, PA_ERR_INVALID
);
1258 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1260 t
= pa_tagstruct_command(c
, PA_COMMAND_ADD_AUTOLOAD
, &tag
);
1261 pa_tagstruct_puts(t
, name
);
1262 pa_tagstruct_putu32(t
, type
);
1263 pa_tagstruct_puts(t
, module
);
1264 pa_tagstruct_puts(t
, argument
);
1265 pa_pstream_send_tagstruct(c
->pstream
, t
);
1266 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, context_index_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1271 pa_operation
* pa_context_remove_autoload_by_name(pa_context
*c
, const char *name
, pa_autoload_type_t type
, pa_context_success_cb_t cb
, void* userdata
) {
1277 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1279 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1280 PA_CHECK_VALIDITY_RETURN_NULL(c
, name
&& *name
, PA_ERR_INVALID
);
1281 PA_CHECK_VALIDITY_RETURN_NULL(c
, type
== PA_AUTOLOAD_SINK
|| type
== PA_AUTOLOAD_SOURCE
, PA_ERR_INVALID
);
1283 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1285 t
= pa_tagstruct_command(c
, PA_COMMAND_REMOVE_AUTOLOAD
, &tag
);
1286 pa_tagstruct_puts(t
, name
);
1287 pa_tagstruct_putu32(t
, type
);
1288 pa_pstream_send_tagstruct(c
->pstream
, t
);
1289 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1294 pa_operation
* pa_context_remove_autoload_by_index(pa_context
*c
, uint32_t idx
, pa_context_success_cb_t cb
, void* userdata
) {
1300 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1302 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1303 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1305 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1307 t
= pa_tagstruct_command(c
, PA_COMMAND_REMOVE_AUTOLOAD
, &tag
);
1308 pa_tagstruct_putu32(t
, idx
);
1309 pa_pstream_send_tagstruct(c
->pstream
, t
);
1310 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1315 pa_operation
* pa_context_move_sink_input_by_name(pa_context
*c
, uint32_t idx
, char *sink_name
, pa_context_success_cb_t cb
, void* userdata
) {
1321 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1323 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1324 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->version
>= 10, PA_ERR_NOTSUPPORTED
);
1325 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1326 PA_CHECK_VALIDITY_RETURN_NULL(c
, sink_name
&& *sink_name
, PA_ERR_INVALID
);
1328 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1330 t
= pa_tagstruct_command(c
, PA_COMMAND_MOVE_SINK_INPUT
, &tag
);
1331 pa_tagstruct_putu32(t
, idx
);
1332 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
1333 pa_tagstruct_puts(t
, sink_name
);
1334 pa_pstream_send_tagstruct(c
->pstream
, t
);
1335 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1340 pa_operation
* pa_context_move_sink_input_by_index(pa_context
*c
, uint32_t idx
, uint32_t sink_idx
, pa_context_success_cb_t cb
, void* userdata
) {
1346 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1348 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1349 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->version
>= 10, PA_ERR_NOTSUPPORTED
);
1350 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1351 PA_CHECK_VALIDITY_RETURN_NULL(c
, sink_idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1353 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1355 t
= pa_tagstruct_command(c
, PA_COMMAND_MOVE_SINK_INPUT
, &tag
);
1356 pa_tagstruct_putu32(t
, idx
);
1357 pa_tagstruct_putu32(t
, sink_idx
);
1358 pa_tagstruct_puts(t
, NULL
);
1359 pa_pstream_send_tagstruct(c
->pstream
, t
);
1360 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1365 pa_operation
* pa_context_move_source_output_by_name(pa_context
*c
, uint32_t idx
, char *source_name
, pa_context_success_cb_t cb
, void* userdata
) {
1371 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1373 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1374 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->version
>= 10, PA_ERR_NOTSUPPORTED
);
1375 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1376 PA_CHECK_VALIDITY_RETURN_NULL(c
, source_name
&& *source_name
, PA_ERR_INVALID
);
1378 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1380 t
= pa_tagstruct_command(c
, PA_COMMAND_MOVE_SOURCE_OUTPUT
, &tag
);
1381 pa_tagstruct_putu32(t
, idx
);
1382 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
1383 pa_tagstruct_puts(t
, source_name
);
1384 pa_pstream_send_tagstruct(c
->pstream
, t
);
1385 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1390 pa_operation
* pa_context_move_source_output_by_index(pa_context
*c
, uint32_t idx
, uint32_t source_idx
, pa_context_success_cb_t cb
, void* userdata
) {
1396 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1398 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1399 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->version
>= 10, PA_ERR_NOTSUPPORTED
);
1400 PA_CHECK_VALIDITY_RETURN_NULL(c
, idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1401 PA_CHECK_VALIDITY_RETURN_NULL(c
, source_idx
!= PA_INVALID_INDEX
, PA_ERR_INVALID
);
1403 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1405 t
= pa_tagstruct_command(c
, PA_COMMAND_MOVE_SOURCE_OUTPUT
, &tag
);
1406 pa_tagstruct_putu32(t
, idx
);
1407 pa_tagstruct_putu32(t
, source_idx
);
1408 pa_tagstruct_puts(t
, NULL
);
1409 pa_pstream_send_tagstruct(c
->pstream
, t
);
1410 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1415 pa_operation
* pa_context_suspend_sink_by_name(pa_context
*c
, char *sink_name
, int suspend
, pa_context_success_cb_t cb
, void* userdata
) {
1421 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1423 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1424 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->version
>= 11, PA_ERR_NOTSUPPORTED
);
1425 PA_CHECK_VALIDITY_RETURN_NULL(c
, !sink_name
|| *sink_name
, PA_ERR_INVALID
);
1427 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1429 t
= pa_tagstruct_command(c
, PA_COMMAND_SUSPEND_SINK
, &tag
);
1430 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
1431 pa_tagstruct_puts(t
, sink_name
);
1432 pa_tagstruct_put_boolean(t
, suspend
);
1433 pa_pstream_send_tagstruct(c
->pstream
, t
);
1434 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1439 pa_operation
* pa_context_suspend_sink_by_index(pa_context
*c
, uint32_t idx
, int suspend
, pa_context_success_cb_t cb
, void* userdata
) {
1445 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1447 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1448 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->version
>= 11, PA_ERR_NOTSUPPORTED
);
1450 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1452 t
= pa_tagstruct_command(c
, PA_COMMAND_SUSPEND_SINK
, &tag
);
1453 pa_tagstruct_putu32(t
, idx
);
1454 pa_tagstruct_puts(t
, idx
== PA_INVALID_INDEX
? "" : NULL
);
1455 pa_tagstruct_put_boolean(t
, suspend
);
1456 pa_pstream_send_tagstruct(c
->pstream
, t
);
1457 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1462 pa_operation
* pa_context_suspend_source_by_name(pa_context
*c
, char *source_name
, int suspend
, pa_context_success_cb_t cb
, void* userdata
) {
1468 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1470 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1471 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->version
>= 11, PA_ERR_NOTSUPPORTED
);
1472 PA_CHECK_VALIDITY_RETURN_NULL(c
, !source_name
|| *source_name
, PA_ERR_INVALID
);
1474 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1476 t
= pa_tagstruct_command(c
, PA_COMMAND_SUSPEND_SOURCE
, &tag
);
1477 pa_tagstruct_putu32(t
, PA_INVALID_INDEX
);
1478 pa_tagstruct_puts(t
, source_name
);
1479 pa_tagstruct_put_boolean(t
, suspend
);
1480 pa_pstream_send_tagstruct(c
->pstream
, t
);
1481 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);
1486 pa_operation
* pa_context_suspend_source_by_index(pa_context
*c
, uint32_t idx
, int suspend
, pa_context_success_cb_t cb
, void* userdata
) {
1492 pa_assert(PA_REFCNT_VALUE(c
) >= 1);
1494 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->state
== PA_CONTEXT_READY
, PA_ERR_BADSTATE
);
1495 PA_CHECK_VALIDITY_RETURN_NULL(c
, c
->version
>= 11, PA_ERR_NOTSUPPORTED
);
1497 o
= pa_operation_new(c
, NULL
, (pa_operation_cb_t
) cb
, userdata
);
1499 t
= pa_tagstruct_command(c
, PA_COMMAND_SUSPEND_SOURCE
, &tag
);
1500 pa_tagstruct_putu32(t
, idx
);
1501 pa_tagstruct_puts(t
, idx
== PA_INVALID_INDEX
? "" : NULL
);
1502 pa_tagstruct_put_boolean(t
, suspend
);
1503 pa_pstream_send_tagstruct(c
->pstream
, t
);
1504 pa_pdispatch_register_reply(c
->pdispatch
, tag
, DEFAULT_TIMEOUT
, pa_context_simple_ack_callback
, pa_operation_ref(o
), (pa_free_cb_t
) pa_operation_unref
);