/* ************************************************************************** */ /* */ /* ::: :::::::: */ /* launch_process.c :+: :+: :+: */ /* +:+ +:+ +:+ */ /* By: jhalford +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2016/12/13 14:20:45 by jhalford #+# #+# */ /* Updated: 2017/03/02 20:29:33 by jhalford ### ########.fr */ /* */ /* ************************************************************************** */ #include "minishell.h" int launch_process(t_process *p) { t_exec *exec; int pid; exec = &data_singleton()->exec; if (p->attributes & PROCESS_UNKNOWN) { ft_dprintf(2, "{red}%s: command not found: %s{eoc}\n", SHELL_NAME, p->av[0]); set_exitstatus(127, 1); } else if (p->attributes & PROCESS_BUILTIN && IS_PIPESINGLE(p)) { if (process_redirect(p)) return (1); set_exitstatus((*p->execf)(p->path, p->av, data_singleton()->env), 1); } else { p->attributes &= ~PROCESS_STATE_MASK; p->attributes |= PROCESS_RUNNING; if (p->attributes & (PROCESS_BINARY | PROCESS_SCRIPT) && access(p->path, X_OK) == -1) { ft_dprintf(2, "{red}%s: permission denied: %s{eoc}\n", SHELL_NAME, p->av[0]); set_exitstatus(126, 1); return (1); } pid = fork(); if (pid == 0) { process_setgroup(p, 0); process_setsig(); if (process_redirect(p)) exit (1); (*p->execf)(p->path, p->av, data_singleton()->env); exit(43); } else if (pid > 0) { p->pid = pid; process_setgroup(p, pid); return (0); } else if (pid == -1) ft_dprintf(2, "{red}%s: internal fork error{eoc}\n", SHELL_NAME); } return (1); }