summaryrefslogtreecommitdiffstats
path: root/src/pulsecore/strlist.h
blob: e57203c5901337c48ceb2039298708088cb63fe1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#ifndef foostrlisthfoo
#define foostrlisthfoo

/***
  This file is part of PulseAudio.

  Copyright 2004-2006 Lennart Poettering

  PulseAudio is free software; you can redistribute it and/or modify
  it under the terms of the GNU Lesser General Public License as published
  by the Free Software Foundation; either version 2.1 of the License,
  or (at your option) any later version.

  PulseAudio is distributed in the hope that it will be useful, but
  WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  General Public License for more details.

  You should have received a copy of the GNU Lesser General Public License
  along with PulseAudio; if not, write to the Free Software
  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
  USA.
***/

typedef struct pa_strlist pa_strlist;

/* Add the specified server string to the list, return the new linked list head */
pa_strlist* pa_strlist_prepend(pa_strlist *l, const char *s);

/* Remove the specified string from the list, return the new linked list head */
pa_strlist* pa_strlist_remove(pa_strlist *l, const char *s);

/* Make a whitespace separated string of all server stringes. Returned memory has to be freed with pa_xfree() */
char *pa_strlist_tostring(pa_strlist *l);

/* Free the entire list */
void pa_strlist_free(pa_strlist *l);

/* Return the next entry in the list in *string and remove it from
 * the list. Returns the new list head. The memory *string points to
 * has to be freed with pa_xfree() */
pa_strlist* pa_strlist_pop(pa_strlist *l, char **s);

/* Parse a whitespace separated server list */
pa_strlist* pa_strlist_parse(const char *s);

/* Reverse string list */
pa_strlist *pa_strlist_reverse(pa_strlist *l);

/* Return the next item in the list */
pa_strlist *pa_strlist_next(pa_strlist *s);

/* Return the string associated to the current item */
const char *pa_strlist_data(pa_strlist *s);

#endif