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); | 
