diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/p_args_quotes.c | 50 | 
1 files changed, 31 insertions, 19 deletions
| diff --git a/src/p_args_quotes.c b/src/p_args_quotes.c index a63ce38..6ecbb90 100644 --- a/src/p_args_quotes.c +++ b/src/p_args_quotes.c @@ -15,35 +15,35 @@  #include "d_define.h" -static void -	p_arg_squotes(char word[]) -{ -	char	*ptr; +/* static void */ +/* 	p_arg_squotes(char word[]) */ +/* { */ +/* 	char	*ptr; */ -	ptr = word; -	while ((ptr = ft_strchr(ptr, C_SQUOTE)) != NULL) -	{ -		ft_memmove(word + (ptr - word), ptr + 1, ft_strlen(ptr + 1) + 1); -	} -} +/* 	ptr = word; */ +/* 	while ((ptr = ft_strchr(ptr, C_SQUOTE)) != NULL) */ +/* 	{ */ +/* 		ft_memmove(word + (ptr - word), ptr + 1, ft_strlen(ptr + 1) + 1); */ +/* 	} */ +/* } */  static void  	p_arg_dquotes(char word[])  {  	char	*ptr; -	ft_memmove(word, word + 1, ft_strlen(word));  	ptr = word;  	while ((ptr = ft_strchr(ptr, C_DQUOTE)) != NULL)  	{ -		if (*(ptr - 1) == C_BACKSLASH && *(ptr - 2) != C_BACKSLASH) -		{ +		if (ptr - word == 0) +			ft_memmove(word, word + 1, ft_strlen(word)); +		else if (ptr - word == 1 && *(ptr - 1) == C_BACKSLASH) +			ptr++; +		else if (ptr - word > 1 && *(ptr - 1) == C_BACKSLASH && +			*(ptr - 2) != C_BACKSLASH)  			ptr++; -		}  		else -		{  			ft_memmove(word + (ptr - word), ptr + 1, ft_strlen(ptr + 1) + 1); -		}  	}  } @@ -55,11 +55,23 @@ void  	char	*sq_ptr;  	ptr = words; +	dq_ptr = NULL; +	sq_ptr = NULL;  	while (*ptr != NULL)  	{ -		p_arg_squotes(*ptr); -		else if (**ptr == C_DQUOTE) -			p_arg_dquotes(*ptr); +		dq_ptr = ft_strchr(*ptr, C_DQUOTE); +		sq_ptr = ft_strchr(*ptr, C_SQUOTE); +		if (dq_ptr != NULL && sq_ptr != NULL) +		{ +			if (dq_ptr < sq_ptr) +				p_arg_dquotes(*ptr); +		} +		/* if (**ptr == C_SQUOTE) */ +			/* p_arg_squotes(*ptr); */ +		/* else if (**ptr == C_DQUOTE) */ +			/* p_arg_dquotes(*ptr); */  		ptr++; +		dq_ptr = NULL; +		sq_ptr = NULL;  	}  } | 
