12024
|
1 /*
|
|
2 The mediastreamer library aims at providing modular media processing and I/O
|
|
3 for linphone, but also for any telephony application.
|
|
4 Copyright (C) 2001 Simon MORLAT simon.morlat@linphone.org
|
|
5
|
|
6 This library is free software; you can redistribute it and/or
|
|
7 modify it under the terms of the GNU Lesser General Public
|
|
8 License as published by the Free Software Foundation; either
|
|
9 version 2.1 of the License, or (at your option) any later version.
|
|
10
|
|
11 This library is distributed in the hope that it will be useful,
|
|
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
14 Lesser General Public License for more details.
|
|
15
|
|
16 You should have received a copy of the GNU Lesser General Public
|
|
17 License along with this library; if not, write to the Free Software
|
|
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
19 */
|
|
20 #ifndef MSSOUNDREAD_H
|
|
21 #define MSSOUNDREAD_H
|
|
22
|
|
23 #include "msfilter.h"
|
|
24 #include "mssync.h"
|
|
25
|
|
26
|
|
27
|
|
28 struct _MSSoundRead
|
|
29 {
|
|
30 /* the MSOssRead derivates from MSFilter, so the MSFilter object MUST be the first of the MSOssRead object
|
|
31 in order to the object mechanism to work*/
|
|
32 MSFilter filter;
|
|
33 };
|
|
34
|
|
35 typedef struct _MSSoundRead MSSoundRead;
|
|
36
|
|
37 struct _MSSoundReadClass
|
|
38 {
|
|
39 /* the MSOssRead derivates from MSFilter, so the MSFilter class MUST be the first of the MSOssRead class
|
|
40 in order to the class mechanism to work*/
|
|
41 MSFilterClass parent_class;
|
|
42 gint (*set_device)(MSSoundRead *, gint devid);
|
|
43 void (*start)(MSSoundRead *);
|
|
44 void (*stop)(MSSoundRead*);
|
|
45 void (*set_level)(MSSoundRead *, gint a);
|
|
46 };
|
|
47
|
|
48 typedef struct _MSSoundReadClass MSSoundReadClass;
|
|
49
|
|
50 /* PUBLIC */
|
|
51 #define MS_SOUND_READ(filter) ((MSSoundRead*)(filter))
|
|
52 #define MS_SOUND_READ_CLASS(klass) ((MSSoundReadClass*)(klass))
|
|
53
|
|
54 static inline int ms_sound_read_set_device(MSSoundRead *r,gint devid)
|
|
55 {
|
|
56 return MS_SOUND_READ_CLASS( MS_FILTER(r)->klass )->set_device(r,devid);
|
|
57 }
|
|
58
|
|
59 static inline void ms_sound_read_start(MSSoundRead *r)
|
|
60 {
|
|
61 MS_SOUND_READ_CLASS( MS_FILTER(r)->klass )->start(r);
|
|
62 }
|
|
63
|
|
64 static inline void ms_sound_read_stop(MSSoundRead *w)
|
|
65 {
|
|
66 MS_SOUND_READ_CLASS( MS_FILTER(w)->klass )->stop(w);
|
|
67 }
|
|
68
|
|
69 static inline void ms_sound_read_set_level(MSSoundRead *w,gint a)
|
|
70 {
|
|
71 MS_SOUND_READ_CLASS( MS_FILTER(w)->klass )->set_level(w,a);
|
|
72 }
|
|
73
|
|
74 /* FOR INTERNAL USE*/
|
|
75 void ms_sound_read_init(MSSoundRead *r);
|
|
76 void ms_sound_read_class_init(MSSoundReadClass *klass);
|
|
77
|
|
78
|
|
79 #endif
|
|
80
|