PulseAudio  5.0
ext-device-manager.h
Go to the documentation of this file.
1 #ifndef foopulseextdevicemanagerhfoo
2 #define foopulseextdevicemanagerhfoo
3 
4 /***
5  This file is part of PulseAudio.
6 
7  Copyright 2008 Lennart Poettering
8  Copyright 2009 Colin Guthrie
9 
10  PulseAudio is free software; you can redistribute it and/or modify
11  it under the terms of the GNU Lesser General Public License as published
12  by the Free Software Foundation; either version 2.1 of the License,
13  or (at your option) any later version.
14 
15  PulseAudio is distributed in the hope that it will be useful, but
16  WITHOUT ANY WARRANTY; without even the implied warranty of
17  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18  General Public License for more details.
19 
20  You should have received a copy of the GNU Lesser General Public License
21  along with PulseAudio; if not, write to the Free Software
22  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
23  USA.
24 ***/
25 
26 #include <pulse/cdecl.h>
27 #include <pulse/context.h>
28 #include <pulse/version.h>
29 
35 PA_C_DECL_BEGIN
36 
38  const char *role;
39  uint32_t priority;
41 
45  const char *name;
46  const char *description;
47  const char *icon;
48  uint32_t index;
49  uint32_t n_role_priorities;
52 
55  pa_context *c,
56  uint32_t version,
57  void *userdata);
58 
61  pa_context *c,
63  void *userdata);
64 
67  pa_context *c,
68  const pa_ext_device_manager_info *info,
69  int eol,
70  void *userdata);
71 
74  pa_context *c,
76  void *userdata);
77 
80  pa_context *c,
81  const char* device,
82  const char* description,
84  void *userdata);
85 
88  pa_context *c,
89  const char *const s[],
91  void *userdata);
92 
95  pa_context *c,
96  int enable,
98  void *userdata);
99 
102  pa_context *c,
103  const char* role,
104  const char** devices,
106  void *userdata);
107 
110  pa_context *c,
111  int enable,
113  void *userdata);
114 
117  pa_context *c,
118  void *userdata);
119 
123  pa_context *c,
125  void *userdata);
126 
127 PA_C_DECL_END
128 
129 #endif
pa_operation * pa_ext_device_manager_set_device_description(pa_context *c, const char *device, const char *description, pa_context_success_cb_t cb, void *userdata)
Sets the description for a device.
struct pa_context pa_context
An opaque connection context to a daemon.
Definition: context.h:156
uint32_t index
The device index if it is currently available or PA_INVALID_INDEX.
Definition: ext-device-manager.h:48
Connection contexts for asynchronous communication with a server.
struct pa_ext_device_manager_info pa_ext_device_manager_info
Stores information about one device in the device database that is maintained by module-device-manage...
pa_operation * pa_ext_device_manager_test(pa_context *c, pa_ext_device_manager_test_cb_t cb, void *userdata)
Test if this extension module is available in the server.
struct pa_operation pa_operation
An asynchronous operation object.
Definition: operation.h:35
void(* pa_ext_device_manager_test_cb_t)(pa_context *c, uint32_t version, void *userdata)
Callback prototype for pa_ext_device_manager_test().
Definition: ext-device-manager.h:54
const char * description
The description of the device when it was last seen, if applicable and saved.
Definition: ext-device-manager.h:46
pa_operation * pa_ext_device_manager_subscribe(pa_context *c, int enable, pa_context_success_cb_t cb, void *userdata)
Subscribe to changes in the device database.
void(* pa_context_success_cb_t)(pa_context *c, int success, void *userdata)
A generic callback for operation completion.
Definition: context.h:162
pa_operation * pa_ext_device_manager_enable_role_device_priority_routing(pa_context *c, int enable, pa_context_success_cb_t cb, void *userdata)
Enable the role-based device-priority routing mode.
pa_operation * pa_ext_device_manager_read(pa_context *c, pa_ext_device_manager_read_cb_t cb, void *userdata)
Read all entries from the device database.
pa_operation * pa_ext_device_manager_delete(pa_context *c, const char *const s[], pa_context_success_cb_t cb, void *userdata)
Delete entries from the device database.
const char * icon
The icon given to the device.
Definition: ext-device-manager.h:47
struct pa_ext_device_manager_role_priority_info pa_ext_device_manager_role_priority_info
Stores information about one device in the device database that is maintained by module-device-manage...
Definition: ext-device-manager.h:44
const char * role
Definition: ext-device-manager.h:38
Definition: ext-device-manager.h:37
Define header version.
void(* pa_ext_device_manager_read_cb_t)(pa_context *c, const pa_ext_device_manager_info *info, int eol, void *userdata)
Callback prototype for pa_ext_device_manager_read().
Definition: ext-device-manager.h:66
void(* pa_ext_device_manager_subscribe_cb_t)(pa_context *c, void *userdata)
Callback prototype for pa_ext_device_manager_set_subscribe_cb().
Definition: ext-device-manager.h:116
uint32_t n_role_priorities
How many role priorities do we have?
Definition: ext-device-manager.h:49
uint32_t priority
Definition: ext-device-manager.h:39
pa_ext_device_manager_role_priority_info * role_priorities
An array of role priority structures or NULL.
Definition: ext-device-manager.h:50
void pa_ext_device_manager_set_subscribe_cb(pa_context *c, pa_ext_device_manager_subscribe_cb_t cb, void *userdata)
Set the subscription callback that is called when pa_ext_device_manager_subscribe() was called...
pa_operation * pa_ext_device_manager_reorder_devices_for_role(pa_context *c, const char *role, const char **devices, pa_context_success_cb_t cb, void *userdata)
Prefer a given device in the priority list.
const char * name
Identifier string of the device.
Definition: ext-device-manager.h:45