]> code.delx.au - pulseaudio/blob - src/pulsecore/client.h
Merge dead branch 'lockfree'
[pulseaudio] / src / pulsecore / client.h
1 #ifndef foopulseclienthfoo
2 #define foopulseclienthfoo
3
4 /***
5 This file is part of PulseAudio.
6
7 Copyright 2004-2006 Lennart Poettering
8
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.
13
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.
18
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
22 USA.
23 ***/
24
25 #include <inttypes.h>
26
27 typedef struct pa_client pa_client;
28
29 #include <pulse/proplist.h>
30 #include <pulsecore/core.h>
31 #include <pulsecore/module.h>
32
33 /* Every connection to the server should have a pa_client
34 * attached. That way the user may generate a listing of all connected
35 * clients easily and kill them if he wants.*/
36
37 struct pa_client {
38 uint32_t index;
39 pa_core *core;
40
41 pa_proplist *proplist;
42 pa_module *module;
43 char *driver;
44
45 void (*kill)(pa_client *c);
46 void *userdata;
47 };
48
49 pa_client *pa_client_new(pa_core *c, const char *driver, const char *name);
50
51 /* This function should be called only by the code that created the client */
52 void pa_client_free(pa_client *c);
53
54 /* Code that didn't create the client should call this function to
55 * request destruction of the client */
56 void pa_client_kill(pa_client *c);
57
58 /* Rename the client */
59 void pa_client_set_name(pa_client *c, const char *name);
60
61 #endif