source: mainline/uspace/lib/posix/string.h@ 96606fe

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 96606fe was 7e10aee, checked in by Jiří Zárevúcky <zarevucky.jiri@…>, 14 years ago

Rewrite strstr() using Knuth-Morris-Pratt algorithm.

  • Property mode set to 100644
File size: 5.3 KB
Line 
1/*
2 * Copyright (c) 2011 Petr Koupy
3 * Copyright (c) 2011 Jiri Zarevucky
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * - Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * - 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 * - The name of the author may not be used to endorse or promote products
16 * derived from this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30/** @addtogroup libposix
31 * @{
32 */
33/** @file String manipulation.
34 */
35
36#ifndef POSIX_STRING_H_
37#define POSIX_STRING_H_
38
39#include <mem.h>
40#include <str.h>
41
42/* available in str.h
43 *
44 * char *strtok(char *restrict, const char *restrict);
45 * char *strtok_r(char *restrict, const char *restrict, char **restrict);
46 *
47 * available in mem.h
48 *
49 * void *memset(void *, int, size_t);
50 * void *memcpy(void *, const void *, size_t);
51 * void *memmove(void *, const void *, size_t);
52 *
53 * TODO: not implemented due to missing locale support
54 *
55 * int strcoll_l(const char *, const char *, locale_t);
56 * char *strerror_l(int, locale_t);
57 * size_t strxfrm_l(char *restrict, const char *restrict, size_t, locale_t);
58 */
59
60#ifndef NULL
61 #define NULL ((void *) 0)
62#endif
63
64/* Copying and Concatenation */
65extern char *posix_strcpy(char *restrict dest, const char *restrict src);
66extern char *posix_strncpy(char *restrict dest, const char *restrict src, size_t n);
67extern char *posix_stpcpy(char *restrict dest, const char *restrict src);
68extern char *posix_stpncpy(char *restrict dest, const char *restrict src, size_t n);
69extern char *posix_strcat(char *restrict dest, const char *restrict src);
70extern char *posix_strncat(char *restrict dest, const char *restrict src, size_t n);
71extern void *posix_memccpy(void *restrict dest, const void *restrict src, int c, size_t n);
72extern char *posix_strdup(const char *s);
73extern char *posix_strndup(const char *s, size_t n);
74
75/* String/Array Comparison */
76extern int posix_memcmp(const void *mem1, const void *mem2, size_t n);
77extern int posix_strcmp(const char *s1, const char *s2);
78extern int posix_strncmp(const char *s1, const char *s2, size_t n);
79
80/* Search Functions */
81extern void *posix_memchr(const void *mem, int c, size_t n);
82extern char *posix_strchr(const char *s, int c);
83extern char *posix_strrchr(const char *s, int c);
84extern char *gnu_strchrnul(const char *s, int c);
85extern char *posix_strpbrk(const char *s1, const char *s2);
86extern size_t posix_strcspn(const char *s1, const char *s2);
87extern size_t posix_strspn(const char *s1, const char *s2);
88extern char *posix_strstr(const char *haystack, const char *needle);
89
90/* Collation Functions */
91extern int posix_strcoll(const char *s1, const char *s2);
92extern size_t posix_strxfrm(char *restrict s1, const char *restrict s2, size_t n);
93
94/* Error Messages */
95extern char *posix_strerror(int errnum);
96extern int posix_strerror_r(int errnum, char *buf, size_t bufsz);
97
98/* String Length */
99extern size_t posix_strlen(const char *s);
100extern size_t posix_strnlen(const char *s, size_t n);
101
102/* Signal Messages */
103extern char *posix_strsignal(int signum);
104
105/* Legacy Declarations */
106#ifndef POSIX_STRINGS_H_
107extern int posix_ffs(int i);
108extern int posix_strcasecmp(const char *s1, const char *s2);
109extern int posix_strncasecmp(const char *s1, const char *s2, size_t n);
110#endif
111
112#ifndef LIBPOSIX_INTERNAL
113 #define strcpy posix_strcpy
114 #define strncpy posix_strncpy
115 #define stpcpy posix_stpcpy
116 #define stpncpy posix_stpncpy
117 #define strcat posix_strcat
118 #define strncat posix_strncat
119 #define memccpy posix_memccpy
120 #define strdup posix_strdup
121 #define strndup posix_strndup
122
123 #define memcmp posix_memcmp
124 #define strcmp posix_strcmp
125 #define strncmp posix_strncmp
126
127 #define memchr posix_memchr
128 #define strchr posix_strchr
129 #define strrchr posix_strrchr
130 #define strchrnul gnu_strchrnul
131 #define strpbrk posix_strpbrk
132 #define strcspn posix_strcspn
133 #define strspn posix_strspn
134 #define strstr posix_strstr
135
136 #define strcoll posix_strcoll
137 #define strxfrm posix_strxfrm
138
139 #define strerror posix_strerror
140 #define strerror_r posix_strerror_r
141
142 #define strlen posix_strlen
143 #define strnlen posix_strnlen
144
145 #define strsignal posix_strsignal
146
147 #define ffs posix_ffs
148 #define strcasecmp posix_strcasecmp
149 #define strncasecmp posix_strncasecmp
150#endif
151
152#endif // POSIX_STRING_H_
153
154/** @}
155 */
Note: See TracBrowser for help on using the repository browser.