fix invalid read with quotes functions
+ ft_free_cmd_arr()
This commit is contained in:
@@ -64,7 +64,7 @@ static size_t count_word(char const *s, char c)
|
||||
{
|
||||
while (quote_state_change("e_state, &s[i]))
|
||||
i++;
|
||||
if (s[i] != c || quote_state)
|
||||
if (s[i] && (s[i] != c || quote_state))
|
||||
i++;
|
||||
}
|
||||
}
|
||||
@@ -152,7 +152,7 @@ static void fill_arr(char const *s, char c, char **str_arr)
|
||||
{
|
||||
while (quote_state_change("e_state, &s[i]))
|
||||
str_arr[arr_i][char_i++] = s[i++];
|
||||
if (s[i] != c || quote_state)
|
||||
if (s[i] && (s[i] != c || quote_state))
|
||||
str_arr[arr_i][char_i++] = s[i++];
|
||||
}
|
||||
str_arr[arr_i][char_i] = '\0'; //superflu si ft_calloc
|
||||
|
||||
@@ -37,7 +37,8 @@ char *ft_strdup_quotes(const char *s)
|
||||
{
|
||||
while (quote_state_change("e_state, &s[i]))
|
||||
i++;
|
||||
dup[i_dup++] = s[i++];
|
||||
if (s[i])
|
||||
dup[i_dup++] = s[i++];
|
||||
}
|
||||
return (dup);
|
||||
}
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
/* By: lperrey <lperrey@student.42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2021/10/24 10:52:40 by lperrey #+# #+# */
|
||||
/* Updated: 2021/11/13 05:13:40 by lperrey ### ########.fr */
|
||||
/* Updated: 2021/11/14 00:35:42 by lperrey ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -39,26 +39,6 @@ void save_redirections_words(t_token *t)
|
||||
}
|
||||
}
|
||||
|
||||
void ft_free_cmd_arr(t_cmd **cmd_arr)
|
||||
{
|
||||
int i;
|
||||
|
||||
i = 0;
|
||||
while (cmd_arr[i])
|
||||
{
|
||||
if (cmd_arr[i]->argv)
|
||||
ft_free_2d_arr(cmd_arr[i]->argv);
|
||||
if (cmd_arr[i]->fd_in != STDIN_FILENO && cmd_arr[i]->fd_in > 0)
|
||||
if (close(cmd_arr[i]->fd_in) == -1)
|
||||
perror("close()");
|
||||
if (cmd_arr[i]->fd_out != STDOUT_FILENO && cmd_arr[i]->fd_out > 0)
|
||||
if (close(cmd_arr[i]->fd_out) == -1)
|
||||
perror("close()");
|
||||
i++;
|
||||
}
|
||||
ft_free_2d_arr(cmd_arr);
|
||||
}
|
||||
|
||||
t_cmd **parsing(t_token *token_list)
|
||||
{
|
||||
t_cmd **cmd_arr;
|
||||
|
||||
Reference in New Issue
Block a user