blob: dd7d1512ea1119ef129a1062fbf480cdf6fcb2c2 [file] [log] [blame]
Martin Rothfb8876d2022-08-07 15:12:12 -06001/* SPDX-License-Identifier: GPL-2.0-only */
2
Julius Wernera66c9b82019-05-20 14:53:47 -07003#include <assert.h>
Joel Kitching393c71c2019-06-16 16:09:42 +08004#include <ctype.h>
Thomas Heijligen92043552019-01-29 12:48:01 +01005#include <string.h>
6#include <stddef.h>
7#include <stdlib.h>
8
9char *strdup(const char *s)
10{
Julius Wernera66c9b82019-05-20 14:53:47 -070011 if (!ENV_RAMSTAGE)
12 dead_code(); /* This can't be used without malloc(). */
13
Thomas Heijligen92043552019-01-29 12:48:01 +010014 size_t sz = strlen(s) + 1;
15 char *d = malloc(sz);
Thejaswani Putta6f5225c2019-04-11 18:36:08 -070016 if (d)
17 memcpy(d, s, sz);
Thomas Heijligen92043552019-01-29 12:48:01 +010018 return d;
19}
20
21char *strconcat(const char *s1, const char *s2)
22{
Julius Wernera66c9b82019-05-20 14:53:47 -070023 if (!ENV_RAMSTAGE)
24 dead_code(); /* This can't be used without malloc(). */
25
Thomas Heijligen92043552019-01-29 12:48:01 +010026 size_t sz_1 = strlen(s1);
27 size_t sz_2 = strlen(s2);
28 char *d = malloc(sz_1 + sz_2 + 1);
Thejaswani Putta6f5225c2019-04-11 18:36:08 -070029 if (d) {
30 memcpy(d, s1, sz_1);
31 memcpy(d + sz_1, s2, sz_2 + 1);
32 }
Thomas Heijligen92043552019-01-29 12:48:01 +010033 return d;
34}
Julius Wernera66c9b82019-05-20 14:53:47 -070035
36size_t strnlen(const char *src, size_t max)
37{
38 size_t i = 0;
39 while ((*src++) && (i < max))
40 i++;
41 return i;
42}
43
44size_t strlen(const char *src)
45{
46 size_t i = 0;
47 while (*src++)
48 i++;
49 return i;
50}
51
52char *strchr(const char *s, int c)
53{
54 do {
55 if (*s == c)
56 return (char *)s;
57 } while (*s++);
58
59 return NULL;
60}
61
62char *strrchr(const char *s, int c)
63{
64 char *p = NULL;
65
66 do {
67 if (*s == c)
68 p = (char *)s;
69 } while (*s++);
70
71 return p;
72}
73
74char *strncpy(char *to, const char *from, int count)
75{
76 char *ret = to;
77 char data;
78
79 while (count > 0) {
80 count--;
81 data = *from++;
82 *to++ = data;
83 if (data == '\0')
84 break;
85 }
86
87 while (count > 0) {
88 count--;
89 *to++ = '\0';
90 }
91 return ret;
92}
93
94char *strcpy(char *dst, const char *src)
95{
96 char *ptr = dst;
97
98 while (*src)
99 *dst++ = *src++;
100 *dst = '\0';
101
102 return ptr;
103}
104
105int strcmp(const char *s1, const char *s2)
106{
107 int r;
108
109 while ((r = (*s1 - *s2)) == 0 && *s1) {
110 s1++;
111 s2++;
112 }
113 return r;
114}
115
116int strncmp(const char *s1, const char *s2, int maxlen)
117{
118 int i;
119
120 for (i = 0; i < maxlen; i++) {
121 if ((s1[i] != s2[i]) || (s1[i] == '\0'))
122 return s1[i] - s2[i];
123 }
124
125 return 0;
126}
127
128unsigned int skip_atoi(char **s)
129{
130 unsigned int i = 0;
131
132 while (isdigit(**s))
133 i = i*10 + *((*s)++) - '0';
134 return i;
135}
Yuji Sasaki6b212d82019-06-12 17:42:19 -0700136
137int strspn(const char *str, const char *spn)
138{
139 int ret = 0;
140
141 while (*str != 0) {
142 const char *p;
143 for (p = spn; *str != *p; p++)
144 if (*p == '\0')
145 return ret;
146 ret++;
147 str++;
148 }
149 return ret;
150}
151
152int strcspn(const char *str, const char *spn)
153{
154 int ret = 0;
155
156 while (*str != 0) {
157 const char *p;
158 for (p = spn; *p != '\0'; p++)
159 if (*p == *str)
160 return ret;
161 ret++;
162 str++;
163 }
164 return ret;
165}
166
Jes Klinke683ac6f2020-07-31 09:58:49 -0700167char *strstr(const char *haystack, const char *needle)
168{
169 size_t needle_len = strlen(needle);
170 for (; *haystack; haystack++) {
171 if (!strncmp(haystack, needle, needle_len))
172 return (char *)haystack;
173 }
174 return NULL;
175}
176
harshit7a6f27c2020-05-15 10:40:02 +0530177char *strtok_r(char *str, const char *delim, char **ptr)
178{
179 char *start;
180 char *end;
181
182 if (str == NULL)
183 str = *ptr;
184 start = str + strspn(str, delim);
185 if (start[0] == '\0')
186 return NULL;
187
188 end = start + strcspn(start, delim);
189 *ptr = end;
190 if (end[0] != '\0')
191 *(*ptr)++ = '\0';
192 return start;
193}
194
195char *strtok(char *str, const char *delim)
196{
197 static char *strtok_ptr;
198
199 return strtok_r(str, delim, &strtok_ptr);
200}
201
Yuji Sasaki6b212d82019-06-12 17:42:19 -0700202long atol(const char *str)
203{
204 long ret = 0;
205 long sign = 1;
206
207 str += strspn(str, " \t\n\r\f\v");
208
209 if (*str == '+') {
210 sign = 1;
211 str++;
212 } else if (*str == '-') {
213 sign = -1;
214 str++;
215 }
216
217 while (isdigit(*str)) {
218 ret *= 10;
219 ret += *str++ - '0';
220 }
221 return ret * sign;
222}