aboutsummaryrefslogtreecommitdiff
path: root/src/eval
diff options
context:
space:
mode:
authornass1pro <nass1pro@gmail.com>2020-07-20 14:55:11 +0200
committernass1pro <nass1pro@gmail.com>2020-07-20 14:55:11 +0200
commit52bb7cc0f234776cd19c7a608b06578150d4695a (patch)
tree2812f633709b12fd9a728ff587ac27b27e1b2ba4 /src/eval
parent7b9b77cbd7cfb3ffa8ac9e8ea69e01aa96179635 (diff)
downloadminishell-52bb7cc0f234776cd19c7a608b06578150d4695a.tar.gz
minishell-52bb7cc0f234776cd19c7a608b06578150d4695a.tar.bz2
minishell-52bb7cc0f234776cd19c7a608b06578150d4695a.zip
update eval_cmd
Diffstat (limited to 'src/eval')
-rw-r--r--src/eval/cmd.c16
-rw-r--r--src/eval/utils_eval.c34
2 files changed, 47 insertions, 3 deletions
diff --git a/src/eval/cmd.c b/src/eval/cmd.c
index 87c9bbf..c81c349 100644
--- a/src/eval/cmd.c
+++ b/src/eval/cmd.c
@@ -3,10 +3,10 @@
/* ::: :::::::: */
/* cmd.c :+: :+: :+: */
/* +:+ +:+ +:+ */
-/* By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ */
+/* By: charles <charles@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/06/14 10:41:31 by charles #+# #+# */
-/* Updated: 2020/07/19 19:00:54 by charles ### ########.fr */
+/* Updated: 2020/07/20 14:53:40 by nahaddac ### ########.fr */
/* */
/* ************************************************************************** */
@@ -14,6 +14,7 @@
pid_t g_child_pid = -1;
int g_last_status_code = 0;
+void token_debug(void *v);
/*
** \brief Wrap a function in a fork
@@ -91,6 +92,8 @@ int eval_cmd(int fds[2], t_env env, t_path path, t_ast *ast)
{
t_fork_param_cmd param;
char **argv;
+ char *id;
+ t_ftlst *tmp;
if (!redir_extract(ast->redirs, env, fds))
{
@@ -105,7 +108,14 @@ int eval_cmd(int fds[2], t_env env, t_path path, t_ast *ast)
&& ((t_token*)ast->cmd_argv->data)->tag & TAG_IS_STR
&& utils_start_with_valid_identifier(((t_token*)ast->cmd_argv->data)->content))
{
- if (env_export_full(param.env_local, ((t_token*)ast->cmd_argv->data)->content) == NULL)
+ id = ((t_token*)ast->cmd_argv->data)->content;
+ *ft_strchr(id, '=') = '\0';
+ ((t_token*)ast->cmd_argv->data)->content = ft_strchr(id, '\0') + 1;
+ tmp = split_token(&ast->cmd_argv, TAG_STICK);
+ preprocess(tmp, env);
+ ft_lstiter(tmp, token_debug);
+
+ if (env_export(param.env_local,id, ((t_token*)ast->cmd_argv->data)->content) == NULL)
return (-1);
ft_lstpop_front(&ast->cmd_argv, (void (*)(void*))token_destroy);
}
diff --git a/src/eval/utils_eval.c b/src/eval/utils_eval.c
new file mode 100644
index 0000000..374411e
--- /dev/null
+++ b/src/eval/utils_eval.c
@@ -0,0 +1,34 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* utils_eval.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: nahaddac <nahaddac@student.42.fr> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/07/20 13:07:25 by nahaddac #+# #+# */
+/* Updated: 2020/07/20 14:51:40 by nahaddac ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "eval.h"
+
+
+t_ftlst *split_token(t_ftlst **lst, enum e_token_tag tag)
+{
+ t_ftlst *curr;
+ t_ftlst *start;
+
+ start = *lst;
+ curr = *lst;
+ while (curr != NULL || ((t_token *)curr->data)->tag & tag)
+ {
+ if (curr->next == NULL || (!(((t_token *)curr->next->data)->tag & tag)))
+ {
+ *lst = curr->next;
+ curr->next = NULL;
+ return start;
+ }
+ curr = curr->next;
+ }
+ return start;
+}