221 lines
5.5 KiB
C
221 lines
5.5 KiB
C
/* ************************************************************************** */
|
|
/* */
|
|
/* ::: :::::::: */
|
|
/* exec.h :+: :+: :+: */
|
|
/* +:+ +:+ +:+ */
|
|
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
|
|
/* +#+#+#+#+#+ +#+ */
|
|
/* Created: 2016/11/27 20:29:56 by jhalford #+# #+# */
|
|
/* Updated: 2017/03/10 13:26:16 by jhalford ### ########.fr */
|
|
/* */
|
|
/* ************************************************************************** */
|
|
|
|
#ifndef EXEC_H
|
|
# define EXEC_H
|
|
|
|
# include <sys/stat.h>
|
|
# include "minishell.h"
|
|
|
|
# define PIPE_READ 0
|
|
# define PIPE_WRITE 1
|
|
|
|
# define PROCESS_COMPLETED (1 << 0)
|
|
# define PROCESS_SUSPENDED (1 << 1)
|
|
# define PROCESS_RUNNING (1 << 2)
|
|
# define PROCESS_CONTINUED (1 << 3)
|
|
|
|
# define PROCESS_STATE_MASK ((1 << 4) - (1 << 0))
|
|
|
|
# define IS_PIPESTART(p) ((p).fdin == STDIN)
|
|
# define IS_PIPEEND(p) ((p).fdout == STDOUT)
|
|
# define IS_PIPESINGLE(p) (IS_PIPESTART(p) && IS_PIPEEND(p))
|
|
|
|
/* # define EXEC_BG (1 << 1) */
|
|
# define EXEC_AND_IF (1 << 2)
|
|
# define EXEC_OR_IF (1 << 3)
|
|
# define EXEC_IF_BRANCH (1 << 4)
|
|
# define EXEC_CASE_BRANCH (1 << 5)
|
|
|
|
# define EXEC_AOL_MASK (EXEC_AND_IF | EXEC_OR_IF)
|
|
|
|
# define EXEC_IS_BG(j) (j & EXEC_BG)
|
|
# define EXEC_IS_FG(j) (!EXEC_IS_BG(j))
|
|
# define EXEC_IS_AND_IF(j) (j & EXEC_AND_IF)
|
|
# define EXEC_IS_OR_IF(j) (j & EXEC_OR_IF)
|
|
# define EXEC_IS_IF_BRANCH(j) (j & EXEC_IF_BRANCH)
|
|
# define EXEC_IS_CASE_BRANCH(j) (j & EXEC_CASE_BRANCH)
|
|
|
|
struct s_data_cmd
|
|
{
|
|
char **av;
|
|
char *path;
|
|
t_execf *execf;
|
|
struct stat *stat;
|
|
};
|
|
|
|
struct s_data_cond
|
|
{
|
|
t_btree *condition;
|
|
t_btree *content;
|
|
};
|
|
|
|
struct s_data_list
|
|
{
|
|
t_ld *list_word;
|
|
t_btree *content;
|
|
};
|
|
|
|
struct s_data_subshell
|
|
{
|
|
t_btree *content;
|
|
};
|
|
|
|
union u_process_data
|
|
{
|
|
struct s_data_cmd cmd;
|
|
struct s_data_subshell subshell;
|
|
struct s_data_subshell function;
|
|
struct s_data_cond d_while;
|
|
struct s_data_cond d_until;
|
|
struct s_data_cond d_if;
|
|
struct s_data_list d_for;
|
|
struct s_data_list d_case;
|
|
};
|
|
|
|
enum e_process_type
|
|
{
|
|
PROCESS_FUNCTION,
|
|
PROCESS_BUILTIN,
|
|
PROCESS_FILE,
|
|
PROCESS_SUBSHELL,
|
|
PROCESS_WHILE,
|
|
PROCESS_UNTIL,
|
|
PROCESS_IF,
|
|
PROCESS_FOR,
|
|
PROCESS_CASE,
|
|
PROCESS_MAX
|
|
};
|
|
|
|
typedef enum e_process_type t_process_type;
|
|
typedef union u_process_data t_process_data;
|
|
typedef struct s_data_cond t_data_while;
|
|
typedef struct s_data_cond t_data_if;
|
|
typedef struct s_data_cond t_data_if;
|
|
|
|
struct s_process
|
|
{
|
|
t_process_type type;
|
|
t_process_data data;
|
|
pid_t pid;
|
|
int fdin;
|
|
int fdout;
|
|
int to_close;
|
|
t_list *redirs;
|
|
int status;
|
|
t_flag attrs;
|
|
};
|
|
|
|
struct s_exec
|
|
{
|
|
t_job job;
|
|
int fd_save[3];
|
|
t_flag attrs;
|
|
int fdin;
|
|
t_list *op_stack;
|
|
char **case_pattern;
|
|
int control_count;
|
|
};
|
|
|
|
|
|
extern t_itof g_execmap[];
|
|
extern t_itof g_redirmap[];
|
|
extern t_itof g_launchmap[];
|
|
|
|
|
|
int exec_reset(void);
|
|
int process_setgroup(t_process *p, pid_t pid);
|
|
void process_setsig(void);
|
|
void process_reset(t_process *p);
|
|
void process_resetfds(t_process *p);
|
|
|
|
int fd_is_valid(int fd, int flag);
|
|
int bad_fd(int fd);
|
|
int process_redirect(t_process *p);
|
|
int redirect_great(t_redir *redir);
|
|
int redirect_less(t_redir *redir);
|
|
int redirect_dgreat(t_redir *redir);
|
|
int redirect_dless(t_redir *redir);
|
|
int redirect_greatand(t_redir *redir);
|
|
int redirect_lessand(t_redir *redir);
|
|
|
|
char *ft_findexec(char *path, char *file);
|
|
|
|
void set_exitstatus(int status, int override);
|
|
|
|
void ast_free(void *data, size_t content_size);
|
|
void *node_copy(void *data);
|
|
void *redir_copy(void *data);
|
|
|
|
void redir_free(void *data, size_t content_size);
|
|
|
|
char **token_to_argv(t_ld *ld, int do_match);
|
|
|
|
int add_new_job(t_job *job);
|
|
|
|
int error_badidentifier(char *name);
|
|
t_btree *is_function(t_process *p);
|
|
|
|
/*
|
|
** Mapping pour free les process
|
|
*/
|
|
void process_free(void *content, size_t content_size);
|
|
int process_free_cmd(t_process *p);
|
|
int process_free_cond(t_process *p);
|
|
int process_free_list(t_process *p);
|
|
int process_free_subshell(t_process *p);
|
|
|
|
/*
|
|
** Mapping pour launch les process
|
|
*/
|
|
int launch_process(t_process *p);
|
|
int launch_if(t_process *p);
|
|
int launch_while(t_process *p);
|
|
int launch_until(t_process *p);
|
|
int launch_for(t_process *p);
|
|
int launch_case(t_process *p);
|
|
int launch_file(t_process *p);
|
|
int launch_builtin(t_process *p);
|
|
int launch_subshell(t_process *p);
|
|
int launch_function(t_process *p);
|
|
|
|
/*
|
|
** Mapping pour set les process
|
|
*/
|
|
|
|
int set_process(t_process *p, t_btree *ast);
|
|
int set_process_map(t_process *p, t_btree *ast);
|
|
int set_process_cmd(t_process *p, t_btree *ast);
|
|
int set_process_while(t_process *p, t_btree *ast);
|
|
int set_process_until(t_process *p, t_btree *ast);
|
|
int set_process_if(t_process *p, t_btree *ast);
|
|
int set_process_for(t_process *p, t_btree *ast);
|
|
int set_process_case(t_process *p, t_btree *ast);
|
|
int set_process_subshell(t_process *p, t_btree *ast);
|
|
|
|
/*
|
|
** Mapping pour exec les process
|
|
*/
|
|
int ft_exec(t_btree **ast);
|
|
int exec_leaf(t_btree **ast);
|
|
int exec_semi(t_btree **ast);
|
|
int exec_ampersand(t_btree **ast);
|
|
int exec_or_if(t_btree **ast);
|
|
int exec_and_if(t_btree **ast);
|
|
int exec_pipe(t_btree **ast);
|
|
int exec_elif(t_btree **ast);
|
|
int exec_else(t_btree **ast);
|
|
int exec_var(t_btree **ast);
|
|
int exec_case_branch(t_btree **ast);
|
|
int exec_math(t_btree **ast);
|
|
|
|
#endif
|