PulseAudio  16.0
simple.h
Go to the documentation of this file.
1 #ifndef foosimplehfoo
2 #define foosimplehfoo
3 
4 /***
5  This file is part of PulseAudio.
6 
7  Copyright 2004-2006 Lennart Poettering
8  Copyright 2006 Pierre Ossman <ossman@cendio.se> for Cendio AB
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, see <http://www.gnu.org/licenses/>.
22 ***/
23 
24 #include <sys/types.h>
25 
26 #include <pulse/sample.h>
27 #include <pulse/channelmap.h>
28 #include <pulse/def.h>
29 #include <pulse/cdecl.h>
30 #include <pulse/version.h>
31 
111 PA_C_DECL_BEGIN
112 
115 typedef struct pa_simple pa_simple;
116 
119  const char *server,
120  const char *name,
122  const char *dev,
123  const char *stream_name,
124  const pa_sample_spec *ss,
125  const pa_channel_map *map,
126  const pa_buffer_attr *attr,
127  int *error
128  );
129 
132 
134 int pa_simple_write(pa_simple *s, const void *data, size_t bytes, int *error);
135 
138 int pa_simple_drain(pa_simple *s, int *error);
139 
144  pa_simple *s,
145  void *data,
146  size_t bytes,
147  int *error
150  );
151 
154 
157 int pa_simple_flush(pa_simple *s, int *error);
158 
159 PA_C_DECL_END
160 
161 #endif
Constants and routines for channel mapping handling.
Global definitions.
enum pa_stream_direction pa_stream_direction_t
The direction of a pa_stream object.
Constants and routines for sample type handling.
uint64_t pa_usec_t
Type for usec specifications (unsigned).
Definition: sample.h:264
int pa_simple_drain(pa_simple *s, int *error)
Wait until all data already written is played by the daemon.
pa_usec_t pa_simple_get_latency(pa_simple *s, int *error)
Return the playback or record latency.
int pa_simple_read(pa_simple *s, void *data, size_t bytes, int *error)
Read some data from the server.
int pa_simple_flush(pa_simple *s, int *error)
Flush the playback or record buffer.
void pa_simple_free(pa_simple *s)
Close and free the connection to the server.
pa_simple * pa_simple_new(const char *server, const char *name, pa_stream_direction_t dir, const char *dev, const char *stream_name, const pa_sample_spec *ss, const pa_channel_map *map, const pa_buffer_attr *attr, int *error)
Create a new connection to the server.
int pa_simple_write(pa_simple *s, const void *data, size_t bytes, int *error)
Write some data to the server.
Playback and record buffer metrics.
Definition: def.h:389
A channel map which can be used to attach labels to specific channels of a stream.
Definition: channelmap.h:264
A sample format and attribute specification.
Definition: sample.h:252
An opaque simple connection object.