heredoc fix

This commit is contained in:
Loic Deridder
2025-02-14 13:15:52 +01:00
parent bf6877e18c
commit bc365a1796
5 changed files with 31 additions and 26 deletions

View File

@@ -12,49 +12,51 @@
#include "../../../includes/minishell.h"
static void remove_quote(char **str, char c)
static void remove_quote(char **new, char *limiter, char c)
{
char *new;
// char *new;
int i;
int k;
int len;
i = 0;
k = 0;
len = ft_strlen(*str);
new = ft_calloc(len - 1, sizeof(char));
len = ft_strlen(limiter);
*(new) = ft_calloc(len - 1, sizeof(char));
while (i < len - 2)
{
if ((&((*str)[k]) == ft_strchr(*str, c))
|| (&((*str)[k]) == ft_strrchr(*str, c)))
if ((&(limiter[k]) == ft_strchr(limiter, c))
|| (&(limiter[k]) == ft_strrchr(limiter, c)))
{
k++;
}
else
new[i++] = (*str)[k++];
(*new)[i++] = limiter[k++];
}
ft_free(str);
*str = new;
// ft_free(str);
// *str = new;
}
static int ifremove_quote(char **str)
static int ifremove_quote(char **new, char *limiter)
{
char c;
int ret;
ret = 0;
if (!ft_strchr(*str, '\'') && !ft_strchr(*str, '\"'))
if (!ft_strchr(limiter, '\'') && !ft_strchr(limiter, '\"'))
c = 0;
else if (!ft_strchr(*str, '\"'))
else if (!ft_strchr(limiter, '\"'))
c = '\'';
else if (!ft_strchr(*str, '\''))
else if (!ft_strchr(limiter, '\''))
c = '\"';
else if (ft_strchr(*str, '\'') < ft_strchr(*str, '\"'))
else if (ft_strchr(limiter, '\'') < ft_strchr(limiter, '\"'))
c = '\'';
else
c = '\"';
if (c && (ft_strchr(*str, c) != ft_strrchr(*str, c)))
remove_quote(str, c);
if (c && (ft_strchr(limiter, c) != ft_strrchr(limiter, c)))
remove_quote(new, limiter, c);
else
*new = ft_strdup(limiter);
if (c)
ret = 1;
return (ret);
@@ -80,8 +82,8 @@ void read_hereinput(char *limiter, t_node *lst, t_msh *msh)
r = read(0, &c, 1);
}
buf[i] = '\0';
if (ft_strncmp(buf, limiter, ft_strlen(limiter)) == 0)
end_heredoc(buf, msh, lst);
if (ft_strncmp(buf, limiter, -1) == 0)
end_heredoc(buf, msh, lst, limiter);
buf[i++] = '\n';
buf[i] = '\0';
ft_fprintf(1, "%s", buf);
@@ -91,16 +93,17 @@ void parse_heredoc(char *limiter, t_node *lst, t_msh *msh)
{
int fd;
pid_t pid;
char *new;
fd = open(".heredoc", O_WRONLY | O_CREAT | O_APPEND, 0666);
pid = fork();
if (pid == 0)
{
ifremove_quote(&limiter);
ifremove_quote(&new, limiter);
dup2(fd, STDOUT_FILENO);
close(fd);
while (1)
read_hereinput(limiter, lst, msh);
read_hereinput(new, lst, msh);
}
else if (pid > 0)
{

View File

@@ -18,13 +18,15 @@ void exit_heredoc(char *limiter, t_msh *msh, t_node *lst)
ft_fprintf(1, "%s\n", limiter);
free_linked_list(lst);
free_msh(msh);
ft_free(&limiter);
exit(EXIT_SUCCESS);
}
void end_heredoc(char *buf, t_msh *msh, t_node *lst)
void end_heredoc(char *buf, t_msh *msh, t_node *lst, char *limiter)
{
ft_fprintf(1, "%s\n", buf);
free_msh(msh);
free_linked_list(lst);
ft_free(&limiter);
exit(EXIT_SUCCESS);
}

View File

@@ -59,7 +59,7 @@ void free_linked_list(t_node *head)
while (tmp)
{
next = tmp->next;
free(tmp->val);
ft_free(&tmp->val);
free(tmp);
tmp = next;
}