summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/p_split.c42
1 files changed, 39 insertions, 3 deletions
diff --git a/src/p_split.c b/src/p_split.c
index 482bc58..d39a4cb 100644
--- a/src/p_split.c
+++ b/src/p_split.c
@@ -154,7 +154,7 @@ typedef struct s_split
{
size_t pos[ARG_MAX / 2];
int8_t nextif[ARG_MAX / 2];
- int16_t count;
+ uint32_t count;
} t_split;
static void
@@ -208,15 +208,51 @@ static t_split
p_meet_splitter(ptr, line, &sp, mode);
ptr++;
}
+ sp.pos[sp.count] = ptr - line;
+ sp.nextif[sp.count] = 0;
+ sp.count += 1;
return (sp);
}
+static void
+ *p_del_split(char *words[], size_t todel)
+{
+ size_t i;
+
+ i = 0;
+ while (i < todel)
+ {
+ ft_memdel((void*)&words[i]);
+ }
+ ft_memdel((void*)&words);
+ return (NULL);
+}
+
static char
-**p_get_words(const char line[], const t_split sp)
+ **p_get_words(const char line[], const t_split sp)
{
char **words;
+ size_t i;
+ size_t oldpos;
+ int8_t oldif;
- words = NULL;
+ if ((words = (char**)malloc((sp.count + 1) * sizeof(char*))) == NULL)
+ return (NULL);
+ oldpos = 0;
+ oldif = -1;
+ i = 0;
+ while (i < sp.count)
+ {
+ if ((words[i] =
+ (char*)malloc(((sp.pos[i] - oldpos) + 1) * sizeof(char))) == NULL)
+ return ((char**)p_del_split(words, i));
+ ft_strlcpy(words[i], line + oldpos + ((oldif > 0) ? (2) : (oldif) + 1), sp.pos[i] - oldpos);
+ ft_printf("[%s]\n", words[i]);
+ oldpos = sp.pos[i];
+ oldif = sp.nextif[i];
+ i++;
+ }
+ words[i] = NULL;
return (words);
}