]> code.delx.au - pulseaudio/blob - src/pulsecore/client.h
6d09b999640d3257c3ecd2e8e48e23f588e71d1d
[pulseaudio] / src / pulsecore / client.h
1 #ifndef foopulseclienthfoo
2 #define foopulseclienthfoo
3
4 /* $Id$ */
5
6 /***
7 This file is part of PulseAudio.
8
9 Copyright 2004-2006 Lennart Poettering
10
11 PulseAudio is free software; you can redistribute it and/or modify
12 it under the terms of the GNU Lesser General Public License as published
13 by the Free Software Foundation; either version 2 of the License,
14 or (at your option) any later version.
15
16 PulseAudio is distributed in the hope that it will be useful, but
17 WITHOUT ANY WARRANTY; without even the implied warranty of
18 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 General Public License for more details.
20
21 You should have received a copy of the GNU Lesser General Public License
22 along with PulseAudio; if not, write to the Free Software
23 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
24 USA.
25 ***/
26
27 #include <inttypes.h>
28
29 typedef struct pa_client pa_client;
30
31 #include <pulsecore/core.h>
32 #include <pulsecore/module.h>
33
34 /* Every connection to the server should have a pa_client
35 * attached. That way the user may generate a listing of all connected
36 * clients easily and kill them if he wants.*/
37
38 struct pa_client {
39 uint32_t index;
40
41 pa_module *owner;
42 char *name, *driver;
43 pa_core *core;
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