1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
|
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* main.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: cacharle <cacharle@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/02/28 11:45:44 by cacharle #+# #+# */
/* Updated: 2020/10/09 15:51:00 by cacharle ### ########.fr */
/* */
/* ************************************************************************** */
/*
** \file main.c
** \brief Minishell entrypoint
*/
#include "minishell.h"
#include "lexer.h"
#include "parser.h"
#include "eval.h"
int debug_lexer(char *input);
int debug_parser(char *input);
t_state g_state;
int run_eval(t_env env, t_parsed *parser_out)
{
int status;
int fds[2];
fds[0] = FD_NONE;
fds[1] = FD_NONE;
status = eval(fds, env, parser_out->ast);
ast_destroy(parser_out->ast);
free(parser_out);
if (status == EVAL_FATAL)
exit(1);
g_state.last_status = status;
return (status);
}
int execute(t_env env, char *input)
{
t_tok_lst *lexer_out;
int status;
t_parsed *parser_out;
if (utils_strisblank(input))
return (0);
status = lexer(input, &lexer_out);
if (status != 0)
{
tok_lst_destroy(&lexer_out, free);
return (status);
}
parser_out = parse(lexer_out);
if (parser_out == NULL || parser_out->syntax_error)
{
free(parser_out);
return (2);
}
return (run_eval(env, parser_out));
}
int repl(t_env env)
{
int ret;
char *line;
print_prompt();
while ((ret = ft_getline(STDIN_FILENO, &line)) == FTGL_OK)
{
g_state.killed = false;
if (execute(env, line) == EVAL_FATAL)
return (2);
g_child_pid = -1;
print_prompt();
free(line);
}
free(line);
if (ret != FTGL_EOF)
return (2);
return (0);
}
#ifndef MINISHELL_TEST
int main(int argc, char **argv, char **envp)
{
t_env env;
if (argc != 1)
{
ft_putendl_fd("minishell doesn't accept any arguments", STDERR_FILENO);
return (1);
}
if ((env = env_from_array(envp)) == NULL)
return (1);
setup(argv[0], env);
g_state.child_pid = -1;
repl(env);
ft_vecdestroy(env, free);
return (g_state.last_status);
}
#else
int main(int argc, char **argv, char **envp)
{
t_env env;
if ((env = env_from_array(envp)) == NULL)
return (1);
setup(argv[0], env);
g_state.last_status = 0;
if (argc == 3 && ft_strcmp(argv[1], "-l") == 0)
g_state.last_status = debug_lexer(argv[2]);
else if (argc == 3 && ft_strcmp(argv[1], "-p") == 0)
g_state.last_status = debug_parser(argv[2]);
else if (argc == 3 && ft_strcmp(argv[1], "-c") == 0)
g_state.last_status = execute(env, argv[2]);
else
repl(env);
ft_vecdestroy(env, free);
return (g_state.last_status);
}
#endif
|