save commit
This commit is contained in:
@@ -6,28 +6,29 @@
|
||||
/* By: sede-san <sede-san@student.42madrid.com +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/12/01 17:04:57 by sede-san #+# #+# */
|
||||
/* Updated: 2025/12/01 17:54:26 by sede-san ### ########.fr */
|
||||
/* Updated: 2026/02/08 19:51:38 by sede-san ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include "minishell.h"
|
||||
#include "builtins.h"
|
||||
|
||||
u_int8_t set_builtins(
|
||||
t_minishell *msh
|
||||
t_minishell *minishell
|
||||
) {
|
||||
msh->builtins = ft_hashmap_new(4, ft_hashmap_hashstr, ft_hashmap_strcmp);
|
||||
if (msh->builtins == NULL)
|
||||
minishell->builtins
|
||||
= ft_hashmap_new(4, ft_hashmap_hashstr, ft_hashmap_strcmp);
|
||||
if (minishell->builtins == NULL)
|
||||
return (0);
|
||||
ft_hashmap_put(msh->builtins, ft_strdup("cd"), builtin_cd);
|
||||
ft_hashmap_put(msh->builtins, ft_strdup("echo"), builtin_echo);
|
||||
ft_hashmap_put(msh->builtins, ft_strdup("exit"), builtin_exit);
|
||||
ft_hashmap_put(msh->builtins, ft_strdup("pwd"), builtin_pwd);
|
||||
ft_hashmap_put(minishell->builtins, ft_strdup("cd"), builtin_cd);
|
||||
ft_hashmap_put(minishell->builtins, ft_strdup("echo"), builtin_echo);
|
||||
ft_hashmap_put(minishell->builtins, ft_strdup("exit"), builtin_exit);
|
||||
ft_hashmap_put(minishell->builtins, ft_strdup("pwd"), builtin_pwd);
|
||||
return (1);
|
||||
}
|
||||
|
||||
u_int8_t is_builtin(
|
||||
const char *command_name,
|
||||
t_minishell *msh
|
||||
t_minishell *minishell
|
||||
) {
|
||||
return (ft_hashmap_contains_key(msh->builtins, command_name));
|
||||
return (ft_hashmap_contains_key(minishell->builtins, command_name));
|
||||
}
|
||||
|
||||
@@ -6,28 +6,28 @@
|
||||
/* By: sede-san <sede-san@student.42madrid.com +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/10/30 01:20:48 by sede-san #+# #+# */
|
||||
/* Updated: 2025/12/01 19:15:08 by sede-san ### ########.fr */
|
||||
/* Updated: 2026/02/08 21:16:18 by sede-san ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include "builtins.h"
|
||||
#include <stdint.h>
|
||||
|
||||
u_int8_t builtin_exit(
|
||||
uint8_t builtin_exit(
|
||||
t_command cmd,
|
||||
t_minishell *msh
|
||||
){
|
||||
)
|
||||
{
|
||||
uint8_t exit_status;
|
||||
|
||||
ft_eputendl("exit");
|
||||
if (cmd.argc == 1)
|
||||
{
|
||||
msh->exit = 1;
|
||||
// return the last exit_status, if none 0 is returned
|
||||
return (msh->exit_status);
|
||||
}
|
||||
exit_status = msh->exit_status;
|
||||
else if (!ft_strisnum(cmd.argv[1]))
|
||||
{
|
||||
ft_eputstr("exit: ");
|
||||
ft_eputendl(cmd.argv[1]);
|
||||
ft_eputendl(": numeric argument required");
|
||||
ft_eprintf(
|
||||
"minishell: exit: %s: numeric argument required\n",
|
||||
cmd.argv[1]);
|
||||
return (2);
|
||||
}
|
||||
else if (cmd.argc > 2)
|
||||
@@ -36,9 +36,11 @@ u_int8_t builtin_exit(
|
||||
return (2);
|
||||
}
|
||||
else
|
||||
{
|
||||
msh->exit = 1;
|
||||
// cast to u_int8_t causes to return a value between 0 and 255
|
||||
return ((u_int8_t)ft_atol(cmd.argv[1]));
|
||||
}
|
||||
exit_status = (uint8_t)ft_atol(cmd.argv[1]);
|
||||
|
||||
printf("builtin_exit: exit_status=%d\n", exit_status); // Debug print
|
||||
|
||||
msh->exit = 1;
|
||||
msh->exit_status = exit_status;
|
||||
return (exit_status);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user