diff options
Diffstat (limited to '')
-rw-r--r-- | Makefile | 1 | ||||
-rw-r--r-- | src/f_fail.h | 1 | ||||
-rw-r--r-- | src/f_parse.c | 22 | ||||
-rw-r--r-- | src/f_parse.h | 18 | ||||
-rw-r--r-- | src/m_loop.c | 1 | ||||
-rw-r--r-- | src/m_minishell.c | 3 | ||||
-rw-r--r-- | src/p_line.c | 3 | ||||
-rw-r--r-- | src/p_split.c | 42 | ||||
-rw-r--r-- | src/u_parse.c | 7 | ||||
-rw-r--r-- | src/u_parse.h | 4 |
10 files changed, 82 insertions, 20 deletions
@@ -43,6 +43,7 @@ SRCS_NAME += f_errno SRCS_NAME += f_exec SRCS_NAME += f_fail SRCS_NAME += f_file +SRCS_NAME += f_parse SRCS_NAME += f_redir SRCS_NAME += f_shlvl SRCS_NAME += m_argv diff --git a/src/f_fail.h b/src/f_fail.h index 2e432e2..0046814 100644 --- a/src/f_fail.h +++ b/src/f_fail.h @@ -19,6 +19,7 @@ #include "f_errno.h" #include "f_exec.h" #include "f_file.h" +#include "f_parse.h" #include "f_redir.h" #include "f_shlvl.h" #include "s_struct.h" diff --git a/src/f_parse.c b/src/f_parse.c new file mode 100644 index 0000000..67a7bf1 --- /dev/null +++ b/src/f_parse.c @@ -0,0 +1,22 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* f_parse.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include <libft.h> +#include <unistd.h> + +void + f_parse_token(char c) +{ + ft_dprintf(STDERR_FILENO, + "minishell: syntax error near unexpected token `%c'", + c); +} diff --git a/src/f_parse.h b/src/f_parse.h new file mode 100644 index 0000000..f6ac496 --- /dev/null +++ b/src/f_parse.h @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* f_parse.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef F_PARSE_H +#define F_PARSE_H + +void f_parse_token(char c); + +#endif diff --git a/src/m_loop.c b/src/m_loop.c index b3c06d0..5641686 100644 --- a/src/m_loop.c +++ b/src/m_loop.c @@ -34,7 +34,6 @@ static void uint8_t previf; p_line(line, msh); - ft_memdel((void*)&line); previf = 0; ptr = msh->curr; while (ptr != NULL) diff --git a/src/m_minishell.c b/src/m_minishell.c index a538041..6be605a 100644 --- a/src/m_minishell.c +++ b/src/m_minishell.c @@ -14,6 +14,7 @@ #include <stdint.h> #include <unistd.h> #include <string.h> +#include <unistd.h> #include <errno.h> #include "f_fail.h" @@ -32,7 +33,7 @@ int if ((msh = init_msh(argv, envp)) == NULL) { - ft_dprintf(2, "%s\n", strerror(errno)); + ft_dprintf(STDERR_FILENO, "%s\n", strerror(errno)); return (FT_RET_ALLOC); } ret = m_argv(argc, argv, msh); diff --git a/src/p_line.c b/src/p_line.c index d839154..cdb2fd4 100644 --- a/src/p_line.c +++ b/src/p_line.c @@ -59,8 +59,7 @@ static t_bool } void - p_line(char line[], - t_msh *msh) + p_line(char line[], t_msh *msh) { p_delete_comments(line); if (p_check_whitespaces_only(line) == TRUE) diff --git a/src/p_split.c b/src/p_split.c index 7e2260d..25f1cc7 100644 --- a/src/p_split.c +++ b/src/p_split.c @@ -14,7 +14,9 @@ #include <stdlib.h> #include <limits.h> +#include "f_fail.h" #include "d_define.h" +#include "s_struct.h" #include "u_parse.h" #include "u_utils.h" @@ -156,16 +158,31 @@ typedef struct s_split } t_split; static void - p_meet_splitter(char *ptr, char line[], t_split sp, t_quote_mode mode) + p_meet_splitter(char *ptr, + const char line[], + t_split *sp, + t_quote_mode mode) { - const char c = *ptr; - - if (c == C_SEMIC && *ptr + 1 != C_SEMIC && *ptr + 1 != C_NUL && + if (mode == Q_NONE && *ptr == C_SEMIC && *(ptr + 1) != C_SEMIC && u_is_not_escaped(line, ptr) == TRUE) { - sp.pos[sp.count] = (ptr - line); - sp.nextif[sp.count] = 0; - sp.count += 1; + sp->pos[sp->count] = (ptr - line); + sp->nextif[sp->count] = 0; + sp->count += 1; + } + else if (mode == Q_NONE && *ptr == C_AMP && *(ptr + 1) == C_AMP && + (*ptr + 2) != C_PIPE && u_is_not_escaped(line, ptr) == TRUE) + { + sp->pos[sp->count] = (ptr - line); + sp->nextif[sp->count] = 1; + sp->count += 1; + } + else if (mode == Q_NONE && *ptr == C_PIPE && *(ptr + 1) == C_PIPE && + *(ptr + 2) != C_PIPE && u_is_not_escaped(line, ptr) == TRUE) + { + sp->pos[sp->count] = (ptr - line); + sp->nextif[sp->count] = 2; + sp->count += 1; } } @@ -180,27 +197,28 @@ static t_split sp.nextif[0] = 0; sp.count = 0; mode = Q_NONE; - ptr = line; + ptr = (char*)line; while (*ptr != C_NUL) { if (*ptr == C_SQUOTE) - mode = u_meet_squote(ptr, line, mode); + mode = u_meet_squote(line, ptr, mode); else if (*ptr == C_DQUOTE) - mode = u_meet_dquote(ptr, line, mode); + mode = u_meet_dquote(line, ptr, mode); else if (*ptr == C_SEMIC || *ptr == C_AMP || *ptr == C_PIPE) - p_meet_splitter(ptr, line, sp, mode); + p_meet_splitter(ptr, line, &sp, mode); ptr++; } return (sp); } char - **p_split_line(const char line[]) + **p_split_line(char line[]) { t_split sp; char **words; words = NULL; sp = p_fill_sp(line); + ft_memdel((void*)&line); return (words); } diff --git a/src/u_parse.c b/src/u_parse.c index ade8dd7..b49e6ba 100644 --- a/src/u_parse.c +++ b/src/u_parse.c @@ -10,10 +10,13 @@ /* */ /* ************************************************************************** */ +#include <libft.h> + +#include "u_utils.h" #include "d_define.h" t_quote_mode - u_meet_dquote(char *head, char *ptr, t_quote_mode mode) + u_meet_dquote(const char *head, char *ptr, t_quote_mode mode) { if (mode == Q_NONE) { @@ -34,7 +37,7 @@ t_quote_mode } t_quote_mode - u_meet_squote(char *head, char *ptr, t_quote_mode mode) + u_meet_squote(const char *head, char *ptr, t_quote_mode mode) { if (mode == Q_NONE) { diff --git a/src/u_parse.h b/src/u_parse.h index 631468e..8542f80 100644 --- a/src/u_parse.h +++ b/src/u_parse.h @@ -15,7 +15,7 @@ #include "d_define.h" -t_quote_mode u_meet_dquote(char *head, char *ptr, t_quote_mode mode); -t_quote_mode u_meet_squote(char *head, char *ptr, t_quote_mode mode); +t_quote_mode u_meet_dquote(const char *head, char *ptr, t_quote_mode mode); +t_quote_mode u_meet_squote(const char *head, char *ptr, t_quote_mode mode); #endif |