<< start working
This commit is contained in:
parent
795ad81851
commit
610073ec06
5
Makefile
5
Makefile
@ -6,7 +6,7 @@
|
|||||||
# By: apommier <apommier@student.42.fr> +#+ +:+ +#+ #
|
# By: apommier <apommier@student.42.fr> +#+ +:+ +#+ #
|
||||||
# +#+#+#+#+#+ +#+ #
|
# +#+#+#+#+#+ +#+ #
|
||||||
# Created: 2022/03/06 12:50:24 by apommier #+# #+# #
|
# 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/pipe/pipex_utils.c\
|
||||||
srcs/set_cmd/free_cmd.c\
|
srcs/set_cmd/free_cmd.c\
|
||||||
srcs/set_cmd/set_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}
|
OBJS = ${SRCS:.c=.o}
|
||||||
CC = clang
|
CC = clang
|
||||||
CFLAGS = -Wall -Wextra
|
CFLAGS = -Wall -Wextra
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/03/09 22:33:49 by apommier #+# #+# */
|
/* 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
|
//pipex_utils.c
|
||||||
char **get_path(char **env);
|
char **get_path(char **env);
|
||||||
char *get_command(char **exec, char **env);
|
char *get_command(char **exec, char **env);
|
||||||
void print_double(char **tab);
|
|
||||||
void free_double(char **tab);
|
|
||||||
|
|
||||||
//free_cmd
|
//free_cmd
|
||||||
void free_cmd(t_cmd *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 *set_redirection(t_s_cmd *cmd, char *line);
|
||||||
char next_space(char *str, int i);
|
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
|
#endif
|
||||||
@ -6,27 +6,13 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/03/08 16:58:40 by apommier #+# #+# */
|
/* 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"
|
#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)
|
char **get_path(char **env)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -6,24 +6,13 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/03/09 12:33:30 by apommier #+# #+# */
|
/* 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"
|
#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)
|
void exit_shell(t_cmd *cmd)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -6,21 +6,13 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/03/08 15:19:42 by apommier #+# #+# */
|
/* 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"
|
#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)
|
t_s_cmd *set_s_cmd(char *line, t_cmd *cmd)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/03/09 15:18:58 by apommier #+# #+# */
|
/* 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();
|
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)
|
char *set_redirection(t_s_cmd *cmd, char *line)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
@ -178,8 +220,8 @@ char *set_redirection(t_s_cmd *cmd, char *line)
|
|||||||
if(line[i] == '<')
|
if(line[i] == '<')
|
||||||
{
|
{
|
||||||
line = ft_input(line, cmd, i);
|
line = ft_input(line, cmd, i);
|
||||||
//if (cmd->in_type == 1)
|
if (cmd->in_type == 1)
|
||||||
// set_file(cmd->infile);
|
wait_prompt(cmd);
|
||||||
i = 0;
|
i = 0;
|
||||||
}
|
}
|
||||||
else if(line[i] == '>')
|
else if(line[i] == '>')
|
||||||
|
|||||||
54
srcs/set_redirection/utils.c
Normal file
54
srcs/set_redirection/utils.c
Normal 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");
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue
Block a user