-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtokenizer.c
More file actions
102 lines (90 loc) · 2.41 KB
/
tokenizer.c
File metadata and controls
102 lines (90 loc) · 2.41 KB
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
#include "shell.h"
/**
* strtow - splits a string into words. Repeat delimiters are ignored
* @str: the input string
* @d: the delimiter string
* Return: a pointer to an array of strings, or NULL on failure
*/
char **strtow(char *str, char *d)
{
int i, num_words = 0;
char **s;
if (!str || !*str)
return (NULL);
if (!d)
d = " ";
for (i = 0; str[i]; i++)
if (!is_delim(str[i], d) && (is_delim(str[i + 1], d) || !str[i + 1]))
num_words++;
if (num_words == 0)
return (NULL);
s = malloc((num_words + 1) * sizeof(char *));
if (!s)
return (NULL);
for (i = 0, num_words = 0; *str; str++)
{
while (is_delim(*str, d))
str++;
int word_len = 0;
while (*str && !is_delim(*str, d))
word_len++, str++;
s[num_words] = malloc((word_len + 1) * sizeof(char));
if (!s[num_words])
{
for (i = 0; i < num_words; i++)
free(s[i]);
free(s);
return (NULL);
}
for (int j = 0; j < word_len; j++)
s[num_words][j] = *(str - word_len + j);
s[num_words][word_len] = 0;
num_words++;
}
s[num_words] = NULL;
return (s);
}
/**
* strtow2 - splits a string into words
* @str: the input string
* @d: the delimiter
* Return: a pointer to an array of strings, or NULL on failure
*/
char **strtow2(char *str, char d)
{
int i, num_words = 0;
char **s;
if (!str || !*str)
return (NULL);
for (i = 0; str[i]; i++)
if ((str[i] != d && str[i + 1] == d) ||
(str[i] != d && !str[i + 1]) || str[i + 1] == d)
num_words++;
if (num_words == 0)
return (NULL);
s = malloc((num_words + 1) * sizeof(char *));
if (!s)
return (NULL);
for (i = 0, num_words = 0; *str; str++)
{
while (*str == d)
str++;
int word_len = 0;
while (*str && *str != d)
word_len++, str++;
s[num_words] = malloc((word_len + 1) * sizeof(char));
if (!s[num_words])
{
for (i = 0; i < num_words; i++)
free(s[i]);
free(s);
return (NULL);
}
for (int j = 0; j < word_len; j++)
s[num_words][j] = *(str - word_len + j);
s[num_words][word_len] = 0;
num_words++;
}
s[num_words] = NULL;
return (s);
}