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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
/* extstring.c
* SPDX-License-Identifier: BSD-3-Clause
*/
#define USE_SECURE_MEM
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include "extlib.h"
char *
strlwr (char *s)
{
unsigned char *p = (unsigned char *) s;
while (*p)
{
*p = tolower ((unsigned char) *p);
p++;
}
return s;
}
char *
strupr (char *s)
{
unsigned char *p = (unsigned char *) s;
while (*p)
{
*p = toupper ((unsigned char) *p);
p++;
}
return s;
}
char *
trim (char *s, int *rem_front, int *rem_back)
{
char *result = strdup (s);
char *end;
while (isspace ((unsigned char) *result))
{
result++;
if (rem_front)
*rem_front += 1;
}
if (*result == 0)
return result;
end = result + strlen (result) - 1;
while (end > result && isspace ((unsigned char) *end))
{
end--;
if (rem_back)
*rem_back += 1;
}
end[1] = '\0';
return result;
}
char *
replace_str (char *s, char *old, char *replace)
{
char *result;
int i, cnt = 0;
size_t new_size = strlen (replace);
size_t old_size = strlen (old);
for (i = 0; s[i] != '\0'; i++)
{
if (strstr (&s[i], old) == &s[i])
{
cnt++;
i += old_size - 1;
}
}
result = (char *) malloc (i + cnt * (new_size - old_size) + 1);
i = 0;
while (*s)
{
if (strstr (s, old) == s)
{
strcpy (&result[i], replace);
i += new_size;
s += old_size;
}
else
result[i++] = *s++;
}
result[i] = '\0';
return result;
};
char *
join_str (char **s, size_t len, char delim)
{
char *ret = strdup (s[0]);
size_t ret_len = sizeof (char) * len + strlen (ret);
for (int i = 1; i < len; i++)
{
char *ret_tmp = realloc (ret, ret_len + strlen (s[i]) + 1);
ret_len += strlen (s[i]) + 1;
if (ret_tmp != NULL)
ret = ret_tmp;
sprintf (ret, "%s%c%s", ret, delim, s[i]);
}
return ret;
}
|