<< start working

This commit is contained in:
kinou-p 2022-03-11 17:07:48 +01:00
parent 795ad81851
commit 610073ec06
7 changed files with 113 additions and 44 deletions

View File

@ -6,7 +6,7 @@
# By: apommier <apommier@student.42.fr> +#+ +:+ +#+ #
# +#+#+#+#+#+ +#+ #
# Created: 2022/03/06 12:50:24 by apommier #+# #+# #
# Updated: 2022/03/09 23:29:16 by apommier ### ########.fr #
# Updated: 2022/03/11 16:35:32 by apommier ### ########.fr #
# #
# **************************************************************************** #
@ -16,7 +16,8 @@ SRCS = srcs/main.c\
srcs/pipe/pipex_utils.c\
srcs/set_cmd/free_cmd.c\
srcs/set_cmd/set_cmd.c\
srcs/set_redirection/redirection.c
srcs/set_redirection/redirection.c\
srcs/set_redirection/utils.c
OBJS = ${SRCS:.c=.o}
CC = clang
CFLAGS = -Wall -Wextra

View File

@ -6,7 +6,7 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/03/09 22:33:49 by apommier #+# #+# */
/* Updated: 2022/03/10 11:39:08 by apommier ### ########.fr */
/* Updated: 2022/03/11 17:04:09 by apommier ### ########.fr */
/* */
/* ************************************************************************** */
@ -64,8 +64,8 @@ t_cmd *set_cmd(char *input, char **path);
//pipex_utils.c
char **get_path(char **env);
char *get_command(char **exec, char **env);
void print_double(char **tab);
void free_double(char **tab);
//free_cmd
void free_cmd(t_cmd *cmd);
@ -75,4 +75,9 @@ void exit_shell(t_cmd *cmd);
char *set_redirection(t_s_cmd *cmd, char *line);
char next_space(char *str, int i);
//uitls redirection
int double_size(char **tab);
void print_double(char **tab);
void free_double(char **tab);
#endif

View File

@ -6,27 +6,13 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/03/08 16:58:40 by apommier #+# #+# */
/* Updated: 2022/03/09 20:43:42 by apommier ### ########.fr */
/* Updated: 2022/03/11 16:57:52 by apommier ### ########.fr */
/* */
/* ************************************************************************** */
#include "../../includes/minishell.h"
void print_double(char **tab)
{
int i;
i = 0;
if (tab)
{
while (tab[i])
{
printf("%d -%s-\n", i, tab[i]);
i++;
}
printf("end double\n");
}
}
char **get_path(char **env)
{

View File

@ -6,24 +6,13 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/03/09 12:33:30 by apommier #+# #+# */
/* Updated: 2022/03/10 01:32:44 by apommier ### ########.fr */
/* Updated: 2022/03/11 17:05:20 by apommier ### ########.fr */
/* */
/* ************************************************************************** */
#include "../../includes/minishell.h"
void free_double(char **tab)
{
int i;
i = 0;
if (tab)
{
while (tab[i])
free(tab[i++]);
free(tab);
}
}
void exit_shell(t_cmd *cmd)
{

View File

@ -6,21 +6,13 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/03/08 15:19:42 by apommier #+# #+# */
/* Updated: 2022/03/10 01:27:01 by apommier ### ########.fr */
/* Updated: 2022/03/11 16:39:15 by apommier ### ########.fr */
/* */
/* ************************************************************************** */
#include "../../includes/minishell.h"
int double_size(char **tab)
{
int i;
i = 0;
while (tab[i])
i++;
return (i);
}
t_s_cmd *set_s_cmd(char *line, t_cmd *cmd)
{

View File

@ -6,7 +6,7 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/03/09 15:18:58 by apommier #+# #+# */
/* Updated: 2022/03/10 11:47:21 by apommier ### ########.fr */
/* Updated: 2022/03/11 16:57:53 by apommier ### ########.fr */
/* */
/* ************************************************************************** */
@ -167,6 +167,48 @@ void set_file(char *file)
error_redirect();
}
char **add_line(char **tab, char *line)
{
int size;
char **ret;
int i;
i = 0;
size = double_size(tab);
ret = malloc(sizeof(char *) * size + 2);
if (!ret)
{
if (tab)
free_double(tab);
return (0);
}
while (tab && tab[i])
{
ret[i] == tab[i];
i++;
}
ret[i] = line;
ret[i + 1] = 0;
if (tab)
free_double(tab);
return(ret);
}
void wait_prompt(t_s_cmd *cmd)
{
char *input;
char **history;
history = 0;
input = 0;
while (ft_strcmp(input, cmd->infile))
{
input = readline("> ");
history = add_line(history, input);
}
free(input);
}
char *set_redirection(t_s_cmd *cmd, char *line)
{
int i;
@ -178,8 +220,8 @@ char *set_redirection(t_s_cmd *cmd, char *line)
if(line[i] == '<')
{
line = ft_input(line, cmd, i);
//if (cmd->in_type == 1)
// set_file(cmd->infile);
if (cmd->in_type == 1)
wait_prompt(cmd);
i = 0;
}
else if(line[i] == '>')

View File

@ -0,0 +1,54 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* utils.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/03/11 16:35:37 by apommier #+# #+# */
/* Updated: 2022/03/11 17:04:07 by apommier ### ########.fr */
/* */
/* ************************************************************************** */
#include "../../includes/minishell.h"
int double_size(char **tab)
{
int i;
i = 0;
if (tab == 0)
return (0);
while (tab[i])
i++;
return (i);
}
void free_double(char **tab)
{
int i;
i = 0;
if (tab)
{
while (tab[i])
free(tab[i++]);
free(tab);
}
}
void print_double(char **tab)
{
int i;
i = 0;
if (tab)
{
while (tab[i])
{
printf("%d -%s-\n", i, tab[i]);
i++;
}
printf("end double\n");
}
}