SRC := main.c debug_tools.c init.c signal_handling.c repl.c new_token.c \
free_token.c new_node.c free_node.c tokenizer.c parser.c \
parse_cmd.c collect_redirs.c print_ast.c interpreter.c env.c \
- get_cmd_path.c
+ get_cmd_path.c env_to_strlst.c execute_cmd.c
OBJ_DIR := _obj
OBJ := $(addprefix $(OBJ_DIR)/, $(SRC:%.c=%.o))
/* By: chuhlig <chuhlig@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/08 16:53:39 by dkaiser #+# #+# */
-/* Updated: 2024/10/17 17:01:27 by dkaiser ### ########.fr */
+/* Updated: 2024/10/21 14:57:24 by dkaiser ### ########.fr */
/* */
/* ************************************************************************** */
void getenvlst(t_env **env, char **en);
void free_envlst(t_env **env);
char *env_get(t_env *env, char *name);
+char **env_to_strlst(t_env *env);
/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/06/22 17:14:49 by dkaiser #+# #+# */
-/* Updated: 2024/10/17 17:09:25 by dkaiser ### ########.fr */
+/* Updated: 2024/10/21 15:00:05 by dkaiser ### ########.fr */
/* */
/* ************************************************************************** */
int eval(t_node *node, t_env *env);
char *get_cmd_path(char *cmd, t_env *env);
+int execute_cmd(t_cmd *cmd, t_env *env);
#endif
/* By: chuhlig <chuhlig@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/10/17 14:31:07 by chuhlig #+# #+# */
-/* Updated: 2024/10/17 15:58:28 by dkaiser ### ########.fr */
+/* Updated: 2024/10/21 15:07:51 by dkaiser ### ########.fr */
/* */
/* ************************************************************************** */
#include "env.h"
#include "get_next_line.h"
#include "libft.h"
+#include <stdlib.h>
void getenvlst(t_env **env, char **en)
{
}
}
-char *env_get(t_env *env, char *name)
+char *env_get(t_env *env, char *name)
{
while (env != NULL)
{
--- /dev/null
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* env_to_strlst.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2024/10/21 14:52:08 by dkaiser #+# #+# */
+/* Updated: 2024/10/21 15:07:33 by dkaiser ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "libft.h"
+#include "minishell.h"
+
+static char *get_var_assign(t_env *cur);
+
+char **env_to_strlst(t_env *env)
+{
+ int size;
+ t_env *cur;
+ char **result;
+ int i;
+
+ size = 0;
+ cur = env;
+ while (cur != NULL)
+ {
+ size++;
+ cur = cur->next;
+ }
+ result = malloc(sizeof(char *) * (size + 1));
+ if (result == NULL)
+ return (NULL);
+ i = 0;
+ cur = env;
+ while (i < size)
+ {
+ result[i] = get_var_assign(cur);
+ cur = cur->next;
+ i++;
+ }
+ result[i] = NULL;
+ return (result);
+}
+
+static char *get_var_assign(t_env *cur)
+{
+ char *left_side;
+ char *result;
+
+ left_side = ft_strjoin(cur->name, "=");
+ if (left_side == NULL)
+ return (NULL);
+ result = ft_strjoin(left_side, cur->value);
+ free(left_side);
+ return (result);
+}
--- /dev/null
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* execute_cmd.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2024/10/21 13:58:56 by dkaiser #+# #+# */
+/* Updated: 2024/10/21 15:07:37 by dkaiser ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "minishell.h"
+#include <stdlib.h>
+#include <sys/_types/_pid_t.h>
+#include <unistd.h>
+
+int execute_cmd(t_cmd *cmd, t_env *env)
+{
+ int result;
+ pid_t pid;
+
+ pid = fork();
+ if (pid < 0)
+ return (EXIT_FAILURE);
+ if (pid == 0)
+ {
+ result = execve(cmd->args[0], cmd->args, env_to_strlst(env));
+ exit(result);
+ }
+ else
+ {
+ // only wait if cmd is on rightmost side of pipe?
+ // so in cmd1 | cmd2 | cmd3 | cmd4 only wait for cmd4
+ waitpid(pid, &result, 0);
+ }
+ return (result);
+}
/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/05 13:15:24 by dkaiser #+# #+# */
-/* Updated: 2024/10/17 17:05:51 by dkaiser ### ########.fr */
+/* Updated: 2024/10/21 15:07:27 by dkaiser ### ########.fr */
/* */
/* ************************************************************************** */
#include "minishell.h"
+#include <sys/wait.h>
static int eval_pipe(t_pipe *pipe, t_env *env);
static int eval_cmd(t_cmd *cmd, t_env *env);
static int eval_cmd(t_cmd *cmd, t_env *env)
{
- printf("%s\n", get_cmd_path(cmd->args[0], env));
+ char *cmd_path;
+
+ cmd_path = get_cmd_path(cmd->args[0], env);
+ if (cmd_path == NULL)
+ return (1);
+ free(cmd->args[0]);
+ cmd->args[0] = cmd_path;
+ execute_cmd(cmd, env);
return (0);
}
/* By: chuhlig <chuhlig@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/06/22 17:14:03 by dkaiser #+# #+# */
-/* Updated: 2024/10/17 17:01:45 by dkaiser ### ########.fr */
+/* Updated: 2024/10/21 15:02:56 by dkaiser ### ########.fr */
/* */
/* ************************************************************************** */
{
t_env *env;
+ env = NULL;
if (!argc && !argv)
return (1);
if (init())