dRonin
adbada4
dRonin firmware
Main Page
Related Pages
Modules
Namespaces
Data Structures
Files
File List
Globals
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Groups
Pages
dronin-strsep.h
Go to the documentation of this file.
1
#ifndef _DRONIN_STRSEP_H
2
#define _DRONIN_STRSEP_H
3
/*-
4
* Copyright (c) 1990, 1993
5
* The Regents of the University of California. All rights reserved.
6
*
7
* Redistribution and use in source and binary forms, with or without
8
* modification, are permitted provided that the following conditions
9
* are met:
10
* 1. Redistributions of source code must retain the above copyright
11
* notice, this list of conditions and the following disclaimer.
12
* 2. Redistributions in binary form must reproduce the above copyright
13
* notice, this list of conditions and the following disclaimer in the
14
* documentation and/or other materials provided with the distribution.
15
* 3. Neither the name of the University nor the names of its contributors
16
* may be used to endorse or promote products derived from this software
17
* without specific prior written permission.
18
*
19
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29
* SUCH DAMAGE.
30
*/
31
32
/*
33
* Get next token from string *stringp, where tokens are possibly-empty
34
* strings separated by characters from delim.
35
*
36
* Writes NULs into the string at *stringp to end tokens.
37
* delim need not remain constant from call to call.
38
* On return, *stringp points past the last NUL written (if there might
39
* be further tokens), or is NULL (if there are definitely no more tokens).
40
*
41
* If *stringp is NULL, strsep returns NULL.
42
*/
43
static
inline
char
*
44
strsep
(
char
**stringp,
const
char
*delim)
45
{
46
char
*s;
47
const
char
*spanp;
48
int
c, sc;
49
char
*tok;
50
51
if
((s = *stringp) == NULL)
52
return
(NULL);
53
for
(tok = s;;) {
54
c = *s++;
55
spanp = delim;
56
do
{
57
if
((sc = *spanp++) == c) {
58
if
(c == 0)
59
s = NULL;
60
else
61
s[-1] = 0;
62
*stringp = s;
63
return
(tok);
64
}
65
}
while
(sc != 0);
66
}
67
/* NOTREACHED */
68
}
69
#endif
/* _DRONIN_STRSEP_H */
strsep
static char * strsep(char **stringp, const char *delim)
Definition:
dronin-strsep.h:44
flight
PiOS
posix
inc
dronin-strsep.h
Generated by
1.8.6