diff options
Diffstat (limited to '')
-rw-r--r-- | Makefile | 1 | ||||
-rw-r--r-- | src/d_define.h | 9 | ||||
-rw-r--r-- | src/p_args.c | 47 | ||||
-rw-r--r-- | src/p_split.c | 271 | ||||
-rw-r--r-- | src/u_parse.c | 55 | ||||
-rw-r--r-- | src/u_parse.h | 21 | ||||
-rw-r--r-- | src/u_utils.c | 2 | ||||
-rw-r--r-- | src/u_utils.h | 2 |
8 files changed, 253 insertions, 155 deletions
@@ -69,6 +69,7 @@ SRCS_NAME += p_line SRCS_NAME += p_lblock SRCS_NAME += p_lblock_next SRCS_NAME += p_split +SRCS_NAME += u_parse SRCS_NAME += u_utils SRCS_NAME += u_vars SRCS_NAME += u_vars_next diff --git a/src/d_define.h b/src/d_define.h index 5c10526..8e73668 100644 --- a/src/d_define.h +++ b/src/d_define.h @@ -66,11 +66,14 @@ ** ====== UTILS ====== */ -#define C_SQUOTE 0x27 -#define C_DQUOTE 0x22 -#define C_BACKS 0x5c #define C_NUL 0x00 #define C_SUB 0x1a +#define C_DQUOTE 0x22 +#define C_SQUOTE 0x27 +#define C_AMP 0x26 +#define C_SEMIC 0x3b +#define C_BACKS 0x5c +#define C_PIPE 0x7c /* ** ====== FILES ====== diff --git a/src/p_args.c b/src/p_args.c index 78cfc06..a4b3d02 100644 --- a/src/p_args.c +++ b/src/p_args.c @@ -18,6 +18,7 @@ #include "p_args.h" #include "p_args_next.h" #include "p_args_escape.h" +#include "u_parse.h" #include "u_utils.h" static void @@ -33,48 +34,6 @@ static void } } -static t_quote_mode - p_meet_dquote(char *head, char *ptr, t_quote_mode mode) -{ - if (mode == Q_NONE) - { - if (u_is_not_escaped(head, ptr) == TRUE) - { - return (Q_DOUBLE); - } - else - { - return (Q_NONE); - } - } - else if (mode == Q_DOUBLE && u_is_not_escaped(head, ptr) == TRUE) - { - return (Q_NONE); - } - return (mode); -} - -static t_quote_mode - p_meet_squote(char *head, char *ptr, t_quote_mode mode) -{ - if (mode == Q_NONE) - { - if (u_is_not_escaped(head, ptr) == TRUE) - { - return (Q_SINGLE); - } - else - { - return (Q_NONE); - } - } - else if (mode == Q_SINGLE) - { - return (Q_NONE); - } - return (mode); -} - static t_bool p_meet_whitespace(char *head, char *ptr, t_quote_mode mode) { @@ -110,9 +69,9 @@ static uint16_t if (*ptr == C_BACKS) p_meet_bs(ptr, mode); if (*ptr == C_DQUOTE) - mode = p_meet_dquote((char*)word, ptr, mode); + mode = u_meet_dquote((char*)word, ptr, mode); else if (*ptr == C_SQUOTE) - mode = p_meet_squote((char*)word, ptr, mode); + mode = u_meet_squote((char*)word, ptr, mode); if (ft_iswhitespace(*ptr) && p_meet_whitespace((char*)word, ptr, mode) == TRUE) { diff --git a/src/p_split.c b/src/p_split.c index 998fda5..f3f3e27 100644 --- a/src/p_split.c +++ b/src/p_split.c @@ -12,134 +12,193 @@ #include <libft.h> #include <stdlib.h> +#include <limits.h> +#include "d_define.h" +#include "u_parse.h" #include "u_utils.h" -static size_t - p_count_semi_words(const char line[]) -{ - size_t count; - size_t i; +/* static size_t */ +/* p_count_semi_words(const char line[]) */ +/* { */ +/* size_t count; */ +/* size_t i; */ - count = 0; - i = 0; - while (line[i] != '\0') - { - if (line[i] == ';' && line[i + 1] != ';' && line[i + 1] != '\0') - count += 1; - i++; - } - return (count); -} +/* count = 0; */ +/* i = 0; */ +/* while (line[i] != '\0') */ +/* { */ +/* if (line[i] == ';' && line[i + 1] != ';' && line[i + 1] != '\0' && */ +/* u_is_not_escaped(line, line + i) == TRUE) */ +/* count += 1; */ +/* i++; */ +/* } */ +/* return (count); */ +/* } */ -static size_t - p_count_and_or_words(const char line[], const char c) -{ - size_t count; - size_t i; +/* static size_t */ +/* p_count_and_or_words(const char line[], const char c) */ +/* { */ +/* size_t count; */ +/* size_t i; */ - count = 0; - i = 0; - while (line[i] != '\0') - { - if (line[i] == c && line[i + 1] == c && - line[i + 2] != c && line[i + 2] != '\0') - count += 1; - i++; - } - return (count); -} +/* count = 0; */ +/* i = 0; */ +/* while (line[i] != '\0') */ +/* { */ +/* if (line[i] == c && line[i + 1] == c && */ +/* line[i + 2] != c && line[i + 2] != '\0') */ +/* count += 1; */ +/* i++; */ +/* } */ +/* return (count); */ +/* } */ + +/* static char */ +/* *p_get_first_occur(const char *line_ptr) */ +/* { */ +/* char *ptr[3]; */ +/* size_t len[3]; */ + +/* ptr[0] = ft_strnstr(line_ptr, ";", ft_strlen(line_ptr) + 1); */ +/* ptr[1] = ft_strnstr(line_ptr, "&&", ft_strlen(line_ptr) + 1); */ +/* ptr[2] = ft_strnstr(line_ptr, "||", ft_strlen(line_ptr) + 1); */ +/* len[0] = ft_strlen(ptr[0]); */ +/* len[1] = ft_strlen(ptr[1]); */ +/* len[2] = ft_strlen(ptr[2]); */ +/* if (len[0] > len[1] && len[0] > len[2]) */ +/* return (ptr[0]); */ +/* else if (len[1] > len[0] && len[1] > len[2]) */ +/* return (ptr[1]); */ +/* else if (len[2] > len[0] && len[2] > len[1]) */ +/* return (ptr[2]); */ +/* return ((char*)line_ptr); */ +/* } */ + +/* static char */ +/* **p_split_destroy(char **words, */ +/* size_t i) */ +/* { */ +/* while (i > 0) */ +/* { */ +/* ft_memdel((void*)&words[i]); */ +/* } */ +/* ft_memdel((void*)&words); */ +/* return (NULL); */ +/* } */ -static char - *p_get_first_occur(const char *line_ptr) +/* static char */ +/* **p_split_to_stuff(const char line[], */ +/* const size_t count) */ +/* { */ +/* char **words; */ +/* char *line_ptr; */ +/* char *need_ptr; */ +/* size_t i; */ +/* char c; */ + +/* if ((words = (char**)malloc((count + 1) * sizeof(char*))) == NULL) */ +/* return (NULL); */ +/* line_ptr = (char*)line; */ +/* i = 0; */ +/* while (i < count) */ +/* { */ +/* need_ptr = p_get_first_occur(line_ptr); */ +/* c = need_ptr[0]; */ +/* need_ptr += (c == ';') ? (1) : (0); */ +/* need_ptr += (c == '&') ? (2) : (0); */ +/* need_ptr += (c == '|') ? (2) : (0); */ +/* if (need_ptr - line_ptr == 0) */ +/* { */ +/* if ((words[i] = (char*)malloc(((ft_strlen(line_ptr) + 2) * */ +/* sizeof(char)))) == NULL) */ +/* return (p_split_destroy(words, i)); */ +/* ft_memcpy(words[i], line_ptr, ft_strlen(line_ptr)); */ +/* words[i][ft_strlen(line_ptr)] = ';'; */ +/* words[i][ft_strlen(line_ptr) + 1] = '\0'; */ +/* } */ +/* else */ +/* { */ +/* if ((words[i] = (char*)malloc(((need_ptr - line_ptr) + 1) * */ +/* sizeof(char))) == NULL) */ +/* return (p_split_destroy(words, i)); */ +/* ft_memcpy(words[i], line_ptr, (need_ptr - line_ptr) - 1); */ +/* words[i][(need_ptr - line_ptr) - ((c == ';') ? (1) : (2))] = c; */ +/* words[i][(need_ptr - line_ptr) - ((c == ';') ? (0) : (1))] = '\0'; */ +/* line_ptr = need_ptr; */ +/* } */ +/* i++; */ +/* } */ +/* words[i] = NULL; */ +/* return (words); */ +/* } */ + +/* char */ +/* **p_split_line(const char line[]) */ +/* { */ +/* char **words; */ +/* size_t count; */ + +/* count = p_count_semi_words(line); */ +/* count += p_count_and_or_words(line, '&'); */ +/* count += p_count_and_or_words(line, '|'); */ +/* count += 1; */ +/* if ((words = p_split_to_stuff(line, count)) == NULL) */ +/* return (NULL); */ +/* return (words); */ +/* } */ + +typedef struct s_split { - char *ptr[3]; - size_t len[3]; - - ptr[0] = ft_strnstr(line_ptr, ";", ft_strlen(line_ptr) + 1); - ptr[1] = ft_strnstr(line_ptr, "&&", ft_strlen(line_ptr) + 1); - ptr[2] = ft_strnstr(line_ptr, "||", ft_strlen(line_ptr) + 1); - len[0] = ft_strlen(ptr[0]); - len[1] = ft_strlen(ptr[1]); - len[2] = ft_strlen(ptr[2]); - if (len[0] > len[1] && len[0] > len[2]) - return (ptr[0]); - else if (len[1] > len[0] && len[1] > len[2]) - return (ptr[1]); - else if (len[2] > len[0] && len[2] > len[1]) - return (ptr[2]); - return ((char*)line_ptr); -} + size_t pos[ARG_MAX / 2]; + int8_t nextif[ARG_MAX / 2]; + int16_t count; +} t_split; -static char - **p_split_destroy(char **words, - size_t i) +static void + p_meet_splitter(char *ptr, char line[], t_split sp, t_quote_mode mode) { - while (i > 0) + const char c = *ptr; + + if (c == C_SEMIC && *ptr + 1 != C_SEMIC && *ptr + 1 != C_NUL && + u_is_not_escaped(line, ptr) == TRUE) { - ft_memdel((void*)&words[i]); + sp.pos[sp.count] = (ptr - line); } - ft_memdel((void*)&words); - return (NULL); } -static char - **p_split_to_stuff(const char line[], - const size_t count) +static t_split + p_fill_sp(const char line[]) { - char **words; - char *line_ptr; - char *need_ptr; - size_t i; - char c; - - if ((words = (char**)malloc((count + 1) * sizeof(char*))) == NULL) - return (NULL); - line_ptr = (char*)line; - i = 0; - while (i < count) + t_split sp; + char *ptr; + t_quote_mode mode; + + sp.pos[0] = 0; + sp.nextif[0] = 0; + sp.count = 0; + mode = Q_NONE; + ptr = line; + while (*ptr != C_NUL) { - need_ptr = p_get_first_occur(line_ptr); - c = need_ptr[0]; - need_ptr += (c == ';') ? (1) : (0); - need_ptr += (c == '&') ? (2) : (0); - need_ptr += (c == '|') ? (2) : (0); - if (need_ptr - line_ptr == 0) - { - if ((words[i] = (char*)malloc(((ft_strlen(line_ptr) + 2) * - sizeof(char)))) == NULL) - return (p_split_destroy(words, i)); - ft_memcpy(words[i], line_ptr, ft_strlen(line_ptr)); - words[i][ft_strlen(line_ptr)] = ';'; - words[i][ft_strlen(line_ptr) + 1] = '\0'; - } - else - { - if ((words[i] = (char*)malloc(((need_ptr - line_ptr) + 1) * - sizeof(char))) == NULL) - return (p_split_destroy(words, i)); - ft_memcpy(words[i], line_ptr, (need_ptr - line_ptr) - 1); - words[i][(need_ptr - line_ptr) - ((c == ';') ? (1) : (2))] = c; - words[i][(need_ptr - line_ptr) - ((c == ';') ? (0) : (1))] = '\0'; - line_ptr = need_ptr; - } - i++; + if (*ptr == C_SQUOTE) + mode = u_meet_squote(ptr, line, mode); + else if (*ptr == C_DQUOTE) + mode = u_meet_dquote(ptr, line, mode); + else if (*ptr == C_SEMIC || *ptr == C_AMP || *ptr == C_PIPE) + p_meet_splitter(ptr, line, sp, mode); + ptr++; } - words[i] = NULL; - return (words); + return (sp); } char **p_split_line(const char line[]) { + t_split sp; char **words; - size_t count; - - count = p_count_semi_words(line); - count += p_count_and_or_words(line, '&'); - count += p_count_and_or_words(line, '|'); - count += 1; - if ((words = p_split_to_stuff(line, count)) == NULL) - return (NULL); + + words = NULL; + sp = p_fill_sp(line); return (words); } diff --git a/src/u_parse.c b/src/u_parse.c new file mode 100644 index 0000000..ade8dd7 --- /dev/null +++ b/src/u_parse.c @@ -0,0 +1,55 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* u_parse.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include "d_define.h" + +t_quote_mode + u_meet_dquote(char *head, char *ptr, t_quote_mode mode) +{ + if (mode == Q_NONE) + { + if (u_is_not_escaped(head, ptr) == TRUE) + { + return (Q_DOUBLE); + } + else + { + return (Q_NONE); + } + } + else if (mode == Q_DOUBLE && u_is_not_escaped(head, ptr) == TRUE) + { + return (Q_NONE); + } + return (mode); +} + +t_quote_mode + u_meet_squote(char *head, char *ptr, t_quote_mode mode) +{ + if (mode == Q_NONE) + { + if (u_is_not_escaped(head, ptr) == TRUE) + { + return (Q_SINGLE); + } + else + { + return (Q_NONE); + } + } + else if (mode == Q_SINGLE) + { + return (Q_NONE); + } + return (mode); +} diff --git a/src/u_parse.h b/src/u_parse.h new file mode 100644 index 0000000..631468e --- /dev/null +++ b/src/u_parse.h @@ -0,0 +1,21 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* u_parse.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef U_PARSE_H +#define U_PARSE_H + +#include "d_define.h" + +t_quote_mode u_meet_dquote(char *head, char *ptr, t_quote_mode mode); +t_quote_mode u_meet_squote(char *head, char *ptr, t_quote_mode mode); + +#endif diff --git a/src/u_utils.c b/src/u_utils.c index 7f75c4d..dd1634b 100644 --- a/src/u_utils.c +++ b/src/u_utils.c @@ -20,7 +20,7 @@ #include "s_struct.h" t_bool - u_is_not_escaped(char *head, char *ptr) + u_is_not_escaped(const char *head, const char *ptr) { if (((ptr - head) == 0) || ((ptr - head) >= 1 && *(ptr - 1) != C_BACKS) || diff --git a/src/u_utils.h b/src/u_utils.h index 2aa2c72..12606b7 100644 --- a/src/u_utils.h +++ b/src/u_utils.h @@ -18,7 +18,7 @@ #include "s_struct.h" -t_bool u_is_not_escaped(char *head, char *ptr); +t_bool u_is_not_escaped(const char *head, const char *ptr); void u_eof_fd(int32_t fd); uint64_t u_builtins_get_argc(const char *args[]); char **u_get_env_var_names(t_msh *msh); |