source: roaraudio/libroarpulse/sample.c @ 3417:4b788d82b0dd

Last change on this file since 3417:4b788d82b0dd was 3417:4b788d82b0dd, checked in by phi, 14 years ago

implemented the rest

File size: 5.3 KB
Line 
1//sample.c:
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2010
5 *  The code (may) include prototypes and comments (and maybe
6 *  other code fragements) from libpulse*. They are mostly copyrighted by:
7 *  Lennart Poettering <poettering@users.sourceforge.net> and
8 *  Pierre Ossman <drzeus@drzeus.cx>
9 *
10 *  This file is part of libroarpulse a part of RoarAudio,
11 *  a cross-platform sound system for both, home and professional use.
12 *  See README for details.
13 *
14 *  This file is free software; you can redistribute it and/or modify
15 *  it under the terms of the GNU General Public License version 3
16 *  as published by the Free Software Foundation.
17 *
18 *  RoarAudio is distributed in the hope that it will be useful,
19 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
20 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21 *  GNU General Public License for more details.
22 *
23 *  You should have received a copy of the GNU General Public License
24 *  along with this software; see the file COPYING.  If not, write to
25 *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
26 *
27 *  NOTE for everyone want's to change something and send patches:
28 *  read README and HACKING! There a addition information on
29 *  the license of this document you need to read before you send
30 *  any patches.
31 *
32 *  NOTE for uses of non-GPL (LGPL,...) software using libesd, libartsc
33 *  or libpulse*:
34 *  The libs libroaresd, libroararts and libroarpulse link this libroar
35 *  and are therefore GPL. Because of this it may be illigal to use
36 *  them with any software that uses libesd, libartsc or libpulse*.
37 */
38
39#include <libroarpulse/libroarpulse.h>
40
41/** Return the amount of bytes playback of a second of audio with the specified sample type takes */
42size_t pa_bytes_per_second(const pa_sample_spec *spec);
43
44/** Return the size of a frame with the specific sample type */
45size_t pa_frame_size(const pa_sample_spec *spec) {
46 if ( spec == NULL )
47  return 0;
48
49 return pa_sample_size(spec) * spec->channels;
50}
51
52/** Return the size of a sample with the specific sample type */
53size_t pa_sample_size(const pa_sample_spec *spec) {
54 if ( spec == NULL )
55  return -1;
56
57 switch (spec->format) {
58  case PA_SAMPLE_ALAW:
59  case PA_SAMPLE_ULAW:
60  case PA_SAMPLE_U8:
61    return 1;
62   break;
63  case PA_SAMPLE_S16LE:
64  case PA_SAMPLE_S16BE:
65    return 2;
66   break;
67  default:
68    return 0;
69   break;
70 }
71
72 return 0;
73}
74
75/** Calculate the time the specified bytes take to play with the specified sample type */
76pa_usec_t pa_bytes_to_usec(uint64_t length, const pa_sample_spec *spec) {
77 if ( spec == NULL )
78  return 0;
79
80 return (pa_usec_t) (((double) length/pa_frame_size(spec)*1000000)/spec->rate);
81}
82
83/** Calculates the number of bytes that are required for the specified time. \since 0.9 */
84size_t pa_usec_to_bytes(pa_usec_t t, const pa_sample_spec *spec) {
85 if ( spec == NULL )
86  return 0;
87
88 return (size_t) (((double) t * spec->rate / 1000000))*pa_frame_size(spec);
89}
90
91/** Return non-zero when the sample type specification is valid */
92int pa_sample_spec_valid(const pa_sample_spec *spec) {
93 if ( spec == NULL )
94  return 0;
95
96 if ( spec->channels < 1 || spec->channels > ROAR_MAX_CHANNELS )
97  return 0;
98
99 if ( spec->format < 0 || spec->format > PA_SAMPLE_MAX )
100  return 0;
101
102 return 1;
103}
104
105/** Return non-zero when the two sample type specifications match */
106int pa_sample_spec_equal(const pa_sample_spec*a, const pa_sample_spec*b) {
107 if ( a->rate != b->rate )
108  return 0;
109
110 if ( a->channels != b->channels )
111  return 0;
112
113 if ( a->format != b->format )
114  return 0;
115
116 return 1;
117}
118
119/** Return a descriptive string for the specified sample format. \since 0.8 */
120static struct {
121 pa_sample_format_t format;
122 const char * name;
123} _roar_pa_format[] = {
124 {PA_SAMPLE_U8,     "u8"   },
125 {PA_SAMPLE_ALAW,   "aLaw" },
126 {PA_SAMPLE_ULAW,   "uLaw" },
127 {PA_SAMPLE_S16LE,  "s16le"},
128 {PA_SAMPLE_S16BE,  "s16be"},
129 {PA_SAMPLE_INVALID, NULL  }
130};
131
132const char *pa_sample_format_to_string(pa_sample_format_t f) {
133 int i;
134
135 for (i = 0; _roar_pa_format[i].name != NULL; i++)
136  if ( _roar_pa_format[i].format == f )
137   return _roar_pa_format[i].name;
138
139 return NULL;
140}
141
142/** Parse a sample format text. Inverse of pa_sample_format_to_string() */
143pa_sample_format_t pa_parse_sample_format(const char *format) {
144 int i;
145
146 for (i = 0; _roar_pa_format[i].name != NULL; i++)
147  if ( !strcasecmp(_roar_pa_format[i].name, format) )
148   return _roar_pa_format[i].format;
149
150 return PA_SAMPLE_INVALID;
151}
152
153/** Maximum required string length for pa_sample_spec_snprint() */
154#define PA_SAMPLE_SPEC_SNPRINT_MAX 32
155
156/** Pretty print a sample type specification to a string */
157char* pa_sample_spec_snprint(char *s, size_t l, const pa_sample_spec *spec) {
158 if ( s == NULL || l == 0 || spec == NULL )
159  return NULL;
160
161 if ( pa_sample_spec_valid(spec) ) {
162  snprintf(s, l, "%s %uch %uHz", pa_sample_format_to_string(spec->format), spec->channels, spec->rate);
163 } else {
164  snprintf(s, l, "Invalid");
165 }
166
167 return s;
168}
169
170/** Pretty print a byte size value. (i.e. "2.5 MiB") */
171char* pa_bytes_snprint(char *s, size_t l, unsigned v) {
172 double val = v;
173 int    i;
174 const char pre[] = "KMGTP";
175
176 if ( v <= 1024 ) {
177  snprintf(s, l, "%u B", v);
178  return s;
179 }
180
181 for (i = 0; pre[i] != 0; i++) {
182  val /= 1024;
183  if ( val <= 1024 ) {
184   snprintf(s, l, "%0.1f %ciB", val, pre[i]);
185   return s;
186  }
187 }
188
189 snprintf(s, l, "%0.1f %ciB", val*1024., pre[i-1]);
190 return s;
191}
192
193//ll
Note: See TracBrowser for help on using the repository browser.