]> code.delx.au - pulseaudio/blob - polyp/module-native-protocol-fd.c
implement proper logging
[pulseaudio] / polyp / module-native-protocol-fd.c
1 /* $Id$ */
2
3 /***
4 This file is part of polypaudio.
5
6 polypaudio is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published
8 by the Free Software Foundation; either version 2 of the License,
9 or (at your option) any later version.
10
11 polypaudio is distributed in the hope that it will be useful, but
12 WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with polypaudio; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19 USA.
20 ***/
21
22 #ifdef HAVE_CONFIG_H
23 #include <config.h>
24 #endif
25
26 #include <stdio.h>
27 #include <assert.h>
28 #include <unistd.h>
29
30 #include "module.h"
31 #include "iochannel.h"
32 #include "modargs.h"
33 #include "protocol-native.h"
34 #include "log.h"
35
36 static const char* const valid_modargs[] = {
37 "fd",
38 "public",
39 "cookie",
40 NULL,
41 };
42
43 int pa_module_init(struct pa_core *c, struct pa_module*m) {
44 struct pa_iochannel *io;
45 struct pa_modargs *ma;
46 int fd, r = -1;
47 assert(c && m);
48
49 if (!(ma = pa_modargs_new(m->argument, valid_modargs))) {
50 pa_log(__FILE__": failed to parse module arguments.\n");
51 goto finish;
52 }
53
54 if (pa_modargs_get_value_s32(ma, "fd", &fd) < 0) {
55 pa_log(__FILE__": invalid file descriptor.\n");
56 goto finish;
57 }
58
59 io = pa_iochannel_new(c->mainloop, fd, fd);
60
61 if (!(m->userdata = pa_protocol_native_new_iochannel(c, io, m, ma))) {
62 pa_iochannel_free(io);
63 goto finish;
64 }
65
66 r = 0;
67
68 finish:
69 if (ma)
70 pa_modargs_free(ma);
71
72 return r;
73 }
74
75 void pa_module_done(struct pa_core *c, struct pa_module*m) {
76 assert(c && m);
77
78 pa_protocol_native_free(m->userdata);
79 }