exit error

This commit is contained in:
Loic Deridder
2025-02-03 14:22:33 +01:00
parent 45dc502424
commit dbb7506a31
5 changed files with 15 additions and 13 deletions

View File

@@ -6,7 +6,7 @@
/* By: lderidde <lderidde@student.s19.be> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/01/24 14:32:13 by lderidde #+# #+# */
/* Updated: 2025/01/28 10:39:44 by lderidde ### ########.fr */
/* Updated: 2025/02/03 14:17:14 by lderidde ### ########.fr */
/* */
/* ************************************************************************** */
@@ -49,23 +49,24 @@ int bash_exiterrorcount(void)
return (2);
}
int builtin_exit(char **arg, bool depth)
int builtin_exit(char **arg, bool depth, t_ast_n *node)
{
long res;
if (ft_isnumeric(arg[1]))
res = node->msh->ex_code;
if (arg[1] && ft_isnumeric(arg[1]))
res = ft_atol(arg[1]);
if (depth == true)
{
if (count_args(arg) > 2 && ft_isnumeric(arg[1]))
return (err_msg_cmd("exit", NULL, "too many arguments", 1));
else if (!ft_isnumeric(arg[1]) || errno == ERANGE)
else if (arg[1] && (!ft_isnumeric(arg[1]) || errno == ERANGE))
return (err_msg_cmd("exit", arg[1], "numeric argument required", 2));
return (res % 256);
}
if (count_args(arg) > 2 && ft_isnumeric(arg[1]))
return (bash_exiterrorcount());
else if (!ft_isnumeric(arg[1]) || errno == ERANGE)
else if (arg[1] && (!ft_isnumeric(arg[1]) || errno == ERANGE))
bash_exit_errornum(arg[1]);
else
bash_exit(res % 256);

View File

@@ -6,7 +6,7 @@
/* By: lderidde <lderidde@student.s19.be> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/01/27 11:22:33 by lderidde #+# #+# */
/* Updated: 2025/02/03 13:15:41 by lderidde ### ########.fr */
/* Updated: 2025/02/03 14:05:14 by lderidde ### ########.fr */
/* */
/* ************************************************************************** */
@@ -80,7 +80,7 @@ int exec_builtin(t_ast_n *node)
{
handle_redir(node);
if (ft_strncmp(node->cmd, "exit", 4) == 0)
return (builtin_exit(node->args, true));
return (builtin_exit(node->args, false, node));
else if (ft_strncmp(node->cmd, "pwd", 3) == 0)
return (builtin_pwd(node->args));
else if (ft_strncmp(node->cmd, "echo", 4) == 0)

View File

@@ -6,7 +6,7 @@
/* By: lderidde <lderidde@student.s19.be> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/01/27 14:16:52 by lderidde #+# #+# */
/* Updated: 2025/02/03 13:19:31 by lderidde ### ########.fr */
/* Updated: 2025/02/03 14:19:09 by lderidde ### ########.fr */
/* */
/* ************************************************************************** */
@@ -57,6 +57,7 @@ t_msh *init_msh(char **envp)
t_msh *msh;
msh = malloc(sizeof(t_msh) * 1);
msh->ex_code = 0;
if (!msh)
return (NULL);
if (!envp[0])
@@ -80,7 +81,7 @@ int main(int ac, char **av, char **envp)
{
input = powerline();
msh->head = parser(input, msh);
execute_command(msh->head);
msh->ex_code = execute_command(msh->head);
free(input);
}
}