xref: /illumos-gate/usr/src/head/string.h (revision faadcf7e)
17c478bd9Sstevel@tonic-gate /*
27c478bd9Sstevel@tonic-gate  * CDDL HEADER START
37c478bd9Sstevel@tonic-gate  *
47c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
59acbbeafSnn  * Common Development and Distribution License (the "License").
69acbbeafSnn  * You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate  *
87c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate  * and limitations under the License.
127c478bd9Sstevel@tonic-gate  *
137c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate  *
197c478bd9Sstevel@tonic-gate  * CDDL HEADER END
207c478bd9Sstevel@tonic-gate  */
217c478bd9Sstevel@tonic-gate 
227c478bd9Sstevel@tonic-gate /*
232d08521bSGarrett D'Amore  * Copyright 2014 Garrett D'Amore <garrett@damore.org>
2423a1cceaSRoger A. Faulkner  * Copyright (c) 1989, 2010, Oracle and/or its affiliates. All rights reserved.
25c8907381SJohn Levon  * Copyright 2020 Joyent, Inc.
26*faadcf7eSRobert Mustacchi  * Copyright 2024 Oxide Computer company
277c478bd9Sstevel@tonic-gate  */
287c478bd9Sstevel@tonic-gate 
2923a1cceaSRoger A. Faulkner /*	Copyright (c) 1988 AT&T	*/
30b4203d75SMarcel Telka /*	  All Rights Reserved	*/
3123a1cceaSRoger A. Faulkner 
327c478bd9Sstevel@tonic-gate #ifndef _STRING_H
337c478bd9Sstevel@tonic-gate #define	_STRING_H
347c478bd9Sstevel@tonic-gate 
357c478bd9Sstevel@tonic-gate #include <iso/string_iso.h>
367c478bd9Sstevel@tonic-gate 
377c478bd9Sstevel@tonic-gate /*
387c478bd9Sstevel@tonic-gate  * Allow global visibility for symbols defined in
397c478bd9Sstevel@tonic-gate  * C++ "std" namespace in <iso/string_iso.h>.
407c478bd9Sstevel@tonic-gate  */
417c478bd9Sstevel@tonic-gate #if __cplusplus >= 199711L
427c478bd9Sstevel@tonic-gate using std::size_t;
437c478bd9Sstevel@tonic-gate using std::memchr;
447c478bd9Sstevel@tonic-gate using std::memcmp;
457c478bd9Sstevel@tonic-gate using std::memcpy;
467c478bd9Sstevel@tonic-gate using std::memmove;
477c478bd9Sstevel@tonic-gate using std::memset;
487c478bd9Sstevel@tonic-gate using std::strcat;
497c478bd9Sstevel@tonic-gate using std::strchr;
507c478bd9Sstevel@tonic-gate using std::strcmp;
517c478bd9Sstevel@tonic-gate using std::strcoll;
527c478bd9Sstevel@tonic-gate using std::strcpy;
537c478bd9Sstevel@tonic-gate using std::strcspn;
547c478bd9Sstevel@tonic-gate using std::strerror;
557c478bd9Sstevel@tonic-gate using std::strlen;
567c478bd9Sstevel@tonic-gate using std::strncat;
577c478bd9Sstevel@tonic-gate using std::strncmp;
587c478bd9Sstevel@tonic-gate using std::strncpy;
597c478bd9Sstevel@tonic-gate using std::strpbrk;
607c478bd9Sstevel@tonic-gate using std::strrchr;
617c478bd9Sstevel@tonic-gate using std::strspn;
627c478bd9Sstevel@tonic-gate using std::strstr;
637c478bd9Sstevel@tonic-gate using std::strtok;
647c478bd9Sstevel@tonic-gate using std::strxfrm;
657c478bd9Sstevel@tonic-gate #endif
667c478bd9Sstevel@tonic-gate 
677c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
687c478bd9Sstevel@tonic-gate extern "C" {
697c478bd9Sstevel@tonic-gate #endif
707c478bd9Sstevel@tonic-gate 
717c478bd9Sstevel@tonic-gate #if defined(__EXTENSIONS__) || \
727c478bd9Sstevel@tonic-gate 	(!defined(_STRICT_STDC) && !defined(__XOPEN_OR_POSIX)) || \
737c478bd9Sstevel@tonic-gate 	defined(_XPG6) || defined(_REENTRANT)
747c478bd9Sstevel@tonic-gate extern int strerror_r(int, char *, size_t);
757c478bd9Sstevel@tonic-gate #endif
767c478bd9Sstevel@tonic-gate 
777c478bd9Sstevel@tonic-gate #if defined(__EXTENSIONS__) || \
787c478bd9Sstevel@tonic-gate 	(!defined(_STRICT_STDC) && !defined(__XOPEN_OR_POSIX)) || \
797c478bd9Sstevel@tonic-gate 	(_POSIX_C_SOURCE - 0 >= 199506L) || defined(_REENTRANT)
807c478bd9Sstevel@tonic-gate extern char *strtok_r(char *_RESTRICT_KYWD, const char *_RESTRICT_KYWD,
817c478bd9Sstevel@tonic-gate 	char **_RESTRICT_KYWD);
827c478bd9Sstevel@tonic-gate #endif
837c478bd9Sstevel@tonic-gate 
847c478bd9Sstevel@tonic-gate #if defined(__EXTENSIONS__) || !defined(_STRICT_STDC) || \
857c478bd9Sstevel@tonic-gate 	defined(__XOPEN_OR_POSIX)
867c478bd9Sstevel@tonic-gate extern void *memccpy(void *_RESTRICT_KYWD, const void *_RESTRICT_KYWD,
877c478bd9Sstevel@tonic-gate 		int, size_t);
887c478bd9Sstevel@tonic-gate #endif
897c478bd9Sstevel@tonic-gate 
902d08521bSGarrett D'Amore #if !defined(_STRICT_SYMBOLS) || defined(_XPG7)
912d08521bSGarrett D'Amore 
9223a1cceaSRoger A. Faulkner extern char *stpcpy(char *_RESTRICT_KYWD, const char *_RESTRICT_KYWD);
9323a1cceaSRoger A. Faulkner extern char *stpncpy(char *_RESTRICT_KYWD, const char *_RESTRICT_KYWD, size_t);
9423a1cceaSRoger A. Faulkner extern char *strndup(const char *, size_t);
9523a1cceaSRoger A. Faulkner extern size_t strnlen(const char *, size_t);
9623a1cceaSRoger A. Faulkner extern char *strsignal(int);
972d08521bSGarrett D'Amore 
982d08521bSGarrett D'Amore #ifndef	_LOCALE_T
992d08521bSGarrett D'Amore #define	_LOCALE_T
100732efd55SDan McDonald typedef struct _locale *locale_t;
10123a1cceaSRoger A. Faulkner #endif
10223a1cceaSRoger A. Faulkner 
1032d08521bSGarrett D'Amore extern int strcoll_l(const char *, const char *, locale_t);
1042d08521bSGarrett D'Amore extern size_t strxfrm_l(char *_RESTRICT_KYWD, const char *_RESTRICT_KYWD,
1052d08521bSGarrett D'Amore     size_t, locale_t);
1062d08521bSGarrett D'Amore extern int strcasecmp_l(const char *, const char *, locale_t);
1072d08521bSGarrett D'Amore extern int strncasecmp_l(const char *, const char *, size_t, locale_t);
108b599bd93SRobert Mustacchi extern char *strerror_l(int, locale_t);
1092d08521bSGarrett D'Amore 
1102d08521bSGarrett D'Amore #endif /* defined(_STRICT_SYMBOLS) || defined(_XPG7) */
1112d08521bSGarrett D'Amore 
1122d08521bSGarrett D'Amore #if !defined(_STRICT_SYMBOLS)
1132d08521bSGarrett D'Amore 
1142d08521bSGarrett D'Amore /* Note that some of these are also declared in strings.h for XPG4_2+ */
1159d12795fSRobert Mustacchi extern void explicit_bzero(void *, size_t);
1162401904dSnn extern int uucopy(const void *_RESTRICT_KYWD, void *_RESTRICT_KYWD, size_t);
1172401904dSnn extern int uucopystr(const void *_RESTRICT_KYWD, void *_RESTRICT_KYWD, size_t);
1187c478bd9Sstevel@tonic-gate extern int ffs(int);
11923a1cceaSRoger A. Faulkner extern int ffsl(long);
12023a1cceaSRoger A. Faulkner extern int ffsll(long long);
12123a1cceaSRoger A. Faulkner extern int fls(int);
12223a1cceaSRoger A. Faulkner extern int flsl(long);
12323a1cceaSRoger A. Faulkner extern int flsll(long long);
12423a1cceaSRoger A. Faulkner extern void *memmem(const void *, size_t, const void *, size_t);
125d6bf1708SRobert Mustacchi extern void *memrchr(const void *, int, size_t);
12623a1cceaSRoger A. Faulkner extern char *strcasestr(const char *, const char *);
12723a1cceaSRoger A. Faulkner extern char *strnstr(const char *, const char *, size_t);
1287c478bd9Sstevel@tonic-gate extern size_t strlcpy(char *, const char *, size_t);
1297c478bd9Sstevel@tonic-gate extern size_t strlcat(char *, const char *, size_t);
130b811a51aSVladimir Kotal extern char *strsep(char **stringp, const char *delim);
13123a1cceaSRoger A. Faulkner extern char *strchrnul(const char *, int);
1322d08521bSGarrett D'Amore extern char *strcasestr_l(const char *, const char *, locale_t);
1332d08521bSGarrett D'Amore extern int strcasecmp(const char *, const char *);
1342d08521bSGarrett D'Amore extern int strncasecmp(const char *, const char *, size_t);
135*faadcf7eSRobert Mustacchi extern const char *strerrorname_np(int);
136*faadcf7eSRobert Mustacchi extern const char *strerrordesc_np(int);
137d6bf1708SRobert Mustacchi #endif /* !defined(__STRICT_SYMBOLS) */
1387c478bd9Sstevel@tonic-gate 
1397c478bd9Sstevel@tonic-gate #if defined(__EXTENSIONS__) || \
1407c478bd9Sstevel@tonic-gate 	(!defined(_STRICT_STDC) && !defined(__XOPEN_OR_POSIX)) || \
1417c478bd9Sstevel@tonic-gate 	defined(_XPG4_2)
1427c478bd9Sstevel@tonic-gate extern char *strdup(const char *);
1437c478bd9Sstevel@tonic-gate #endif
1447c478bd9Sstevel@tonic-gate 
14523a1cceaSRoger A. Faulkner #if defined(__EXTENSIONS__) || \
14623a1cceaSRoger A. Faulkner 	(!defined(_STRICT_STDC) && !defined(__XOPEN_OR_POSIX))
14723a1cceaSRoger A. Faulkner 
148c8907381SJohn Levon #if defined(__GNUC__)
14923a1cceaSRoger A. Faulkner 
15023a1cceaSRoger A. Faulkner #define	strdupa(s)							\
15123a1cceaSRoger A. Faulkner 	(__extension__(							\
15223a1cceaSRoger A. Faulkner 	{								\
15323a1cceaSRoger A. Faulkner 	char *__str = (char *)(s);					\
1548285fe28SToomas Soome 	(__str = strcpy((char *)__builtin_alloca(strlen(__str) + 1),	\
1558285fe28SToomas Soome 	    __str), __str);						\
15623a1cceaSRoger A. Faulkner 	}))
15723a1cceaSRoger A. Faulkner 
15823a1cceaSRoger A. Faulkner #define	strndupa(s, n)							\
15923a1cceaSRoger A. Faulkner 	(__extension__(							\
16023a1cceaSRoger A. Faulkner 	{								\
16123a1cceaSRoger A. Faulkner 	char *__str = (char *)(s);					\
16223a1cceaSRoger A. Faulkner 	size_t __len = strnlen(__str, (n));				\
16323a1cceaSRoger A. Faulkner 	(__str = strncpy((char *)__builtin_alloca(__len + 1),		\
16423a1cceaSRoger A. Faulkner 	    __str, __len),						\
16523a1cceaSRoger A. Faulkner 	__str[__len] = '\0', __str);					\
16623a1cceaSRoger A. Faulkner 	}))
16723a1cceaSRoger A. Faulkner 
16823a1cceaSRoger A. Faulkner #else	/* __GNUC__ */
16923a1cceaSRoger A. Faulkner 
17023a1cceaSRoger A. Faulkner #if defined(unix)	/* excludes c99 */
17123a1cceaSRoger A. Faulkner /*
17223a1cceaSRoger A. Faulkner  * Studio C currently can't do the gcc-style inlining,
17323a1cceaSRoger A. Faulkner  * so we use thread-local storage instead.
17423a1cceaSRoger A. Faulkner  */
17523a1cceaSRoger A. Faulkner extern void *__builtin_alloca(size_t);
17623a1cceaSRoger A. Faulkner extern __thread char *__strdupa_str;
17723a1cceaSRoger A. Faulkner extern __thread size_t __strdupa_len;
17823a1cceaSRoger A. Faulkner 
17923a1cceaSRoger A. Faulkner #define	strdupa(s)							\
1806e270ca8SMarcel Telka 	(__strdupa_str = (char *)(s),					\
18123a1cceaSRoger A. Faulkner 	strcpy((char *)__builtin_alloca(strlen(__strdupa_str) + 1),	\
18223a1cceaSRoger A. Faulkner 	    __strdupa_str))
18323a1cceaSRoger A. Faulkner 
18423a1cceaSRoger A. Faulkner #define	strndupa(s, n)							\
18523a1cceaSRoger A. Faulkner 	(__strdupa_str = (char *)(s),					\
18623a1cceaSRoger A. Faulkner 	__strdupa_len = strnlen(__strdupa_str, (n)),			\
18723a1cceaSRoger A. Faulkner 	__strdupa_str = strncpy((char *)__builtin_alloca(__strdupa_len + 1), \
18823a1cceaSRoger A. Faulkner 	    __strdupa_str, __strdupa_len),				\
18923a1cceaSRoger A. Faulkner 	__strdupa_str[__strdupa_len] = '\0', __strdupa_str)
19023a1cceaSRoger A. Faulkner #endif	/* unix */
19123a1cceaSRoger A. Faulkner 
19223a1cceaSRoger A. Faulkner #endif	/* __GNUC__ */
19323a1cceaSRoger A. Faulkner #endif	/* __EXTENSIONS__ ... */
19423a1cceaSRoger A. Faulkner 
1957c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
1967c478bd9Sstevel@tonic-gate }
1977c478bd9Sstevel@tonic-gate #endif
1987c478bd9Sstevel@tonic-gate 
1997c478bd9Sstevel@tonic-gate #endif	/* _STRING_H */
200