]> code.delx.au - pulseaudio/blob - src/pulsecore/tokenizer.c
remap: Change remapping function argument type from void to int16_t / float as approp...
[pulseaudio] / src / pulsecore / tokenizer.c
1 /***
2 This file is part of PulseAudio.
3
4 Copyright 2004-2006 Lennart Poettering
5
6 PulseAudio is free software; you can redistribute it and/or modify
7 it under the terms of the GNU Lesser General Public License as published
8 by the Free Software Foundation; either version 2.1 of the License,
9 or (at your option) any later version.
10
11 PulseAudio 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 Lesser General Public License
17 along with PulseAudio; 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 <string.h>
27 #include <stdlib.h>
28
29 #include <pulse/xmalloc.h>
30
31 #include <pulsecore/dynarray.h>
32 #include <pulsecore/macro.h>
33
34 #include "tokenizer.h"
35
36 static void parse(pa_dynarray*a, const char *s, unsigned args) {
37 int infty = 0;
38 const char delimiter[] = " \t\n\r";
39 const char *p;
40
41 pa_assert(a);
42 pa_assert(s);
43
44 if (args == 0)
45 infty = 1;
46
47 p = s+strspn(s, delimiter);
48 while (*p && (infty || args >= 2)) {
49 size_t l = strcspn(p, delimiter);
50 char *n = pa_xstrndup(p, l);
51 pa_dynarray_append(a, n);
52 p += l;
53 p += strspn(p, delimiter);
54 args--;
55 }
56
57 if (args && *p) {
58 char *n = pa_xstrdup(p);
59 pa_dynarray_append(a, n);
60 }
61 }
62
63 pa_tokenizer* pa_tokenizer_new(const char *s, unsigned args) {
64 pa_dynarray *a;
65
66 a = pa_dynarray_new(pa_xfree);
67 parse(a, s, args);
68 return (pa_tokenizer*) a;
69 }
70
71 void pa_tokenizer_free(pa_tokenizer *t) {
72 pa_dynarray *a = (pa_dynarray*) t;
73
74 pa_assert(a);
75 pa_dynarray_free(a);
76 }
77
78 const char *pa_tokenizer_get(pa_tokenizer *t, unsigned i) {
79 pa_dynarray *a = (pa_dynarray*) t;
80
81 pa_assert(a);
82
83 if (i >= pa_dynarray_size(a))
84 return NULL;
85
86 return pa_dynarray_get(a, i);
87 }