working on aliases

This commit is contained in:
mdev9
2024-02-18 19:06:16 +01:00
parent 98343b24c8
commit ff1f6351aa
6 changed files with 85 additions and 17 deletions

View File

@ -6,7 +6,7 @@
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/02/16 23:16:07 by marde-vr #+# #+# */
/* Updated: 2024/02/18 17:20:54 by marde-vr ### ########.fr */
/* Updated: 2024/02/18 19:05:38 by marde-vr ### ########.fr */
/* */
/* ************************************************************************** */
@ -18,10 +18,10 @@ char *get_alias_name(t_cmd *arg)
char *res;
i = 0;
while (arg->token[i] != '=')
while (arg->token[i] && arg->token[i] != '=')
i++;
i++;
res = ft_strdup("");
res = ft_calloc(i, 1);
ft_strlcpy(res, arg->token, i);
return (res);
}
@ -35,22 +35,60 @@ char *get_alias_value(t_cmd *arg)
while (arg->token[i] != '=')
i++;
i++;
res = arg->token + i;
res = ft_strdup(arg->token + i);
return (res);
}
void print_aliases(t_alias **aliases)
int unalias(t_cmd *args, t_alias **aliases)
{
(void)aliases;
t_alias *alias;
if (args->next && !ft_strcmp(args->next->token, "-a"))
{
free_alias(*aliases);
*aliases = 0;
return (0);
}
alias = *aliases;
while (alias)
{
if (alias->next && args->next && !ft_strcmp(alias->next->name, args->next->token))
{
if (alias->next->next)
alias->next = alias->next->next;
else
alias->next = 0;
alias->next = 0;
free_alias(alias);
return (0);
}
if (alias->next)
alias = alias->next;
else
alias = 0;
}
if (args->next && args->next->type == ARG)
ft_printf("minishell: unalias: %s: not found\n", args->next->token);
else
ft_printf("unalias: usage: unalias name\n");
return (1);
}
int alias(t_cmd *args, t_alias **aliases)
{
char *name;
char *value;
t_alias *cur_alias;
cur_alias = *aliases;
if (!args->next || args->next->type != ARG)
print_aliases(aliases);
{
while (cur_alias)
{
ft_printf("alias %s=%s\n", cur_alias->name, cur_alias->value);
cur_alias = cur_alias->next;
}
}
else
{
name = get_alias_name(args->next);
@ -61,7 +99,8 @@ int alias(t_cmd *args, t_alias **aliases)
}
else
{
ft_get_alias(*aliases, name);
ft_printf("alias %s=%s\n", name, ft_get_alias(*aliases, name));
free(name);
}
}
return (0);

View File

@ -6,7 +6,7 @@
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/02/07 14:12:49 by tomoron #+# #+# */
/* Updated: 2024/02/18 16:36:29 by tomoron ### ########.fr */
/* Updated: 2024/02/18 18:32:33 by marde-vr ### ########.fr */
/* */
/* ************************************************************************** */
@ -14,7 +14,6 @@
int exec_builtin(t_cmd *parsed_cmd, t_env **env, t_alias **aliases)
{
if (!ft_strcmp(parsed_cmd->token, "echo"))
g_return_code = echo(parsed_cmd->next);
else if (!ft_strcmp(parsed_cmd->token, "ret"))
@ -27,8 +26,12 @@ int exec_builtin(t_cmd *parsed_cmd, t_env **env, t_alias **aliases)
g_return_code = pwd();
else if (!ft_strcmp(parsed_cmd->token, "cd"))
g_return_code = cd(parsed_cmd);
else if (!ft_strcmp(parsed_cmd->token, "export"))
g_return_code = ft_export(parsed_cmd, env);
else if (!ft_strcmp(parsed_cmd->token, "alias"))
g_return_code = alias(parsed_cmd, aliases);
else if (!ft_strcmp(parsed_cmd->token, "unalias"))
g_return_code = unalias(parsed_cmd, aliases);
else
return (STDIN_FILENO);
return (STDOUT_FILENO);

20
srcs/export.c Normal file
View File

@ -0,0 +1,20 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* export.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/02/18 18:29:20 by marde-vr #+# #+# */
/* Updated: 2024/02/18 18:39:39 by marde-vr ### ########.fr */
/* */
/* ************************************************************************** */
#include "minishell.h"
int ft_export(t_cmd *cmd, t_env **env)
{
(void)cmd;
(void)env;
return (0);
}

View File

@ -6,7 +6,7 @@
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/02/04 17:31:38 by tomoron #+# #+# */
/* Updated: 2024/02/18 17:10:42 by marde-vr ### ########.fr */
/* Updated: 2024/02/18 18:32:24 by marde-vr ### ########.fr */
/* */
/* ************************************************************************** */
@ -79,5 +79,7 @@ int alias(t_cmd *args, t_alias **aliases);
void free_alias(t_alias *alias);
char *ft_get_alias(t_alias *alias, char *var_name);
t_alias *alias_add_back(t_alias *alias, char *name, char *value);
int unalias(t_cmd *args, t_alias **aliases);
int ft_export(t_cmd *cmd, t_env **env);
#endif

View File

@ -6,7 +6,7 @@
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/02/16 17:40:16 by marde-vr #+# #+# */
/* Updated: 2024/02/18 17:10:16 by marde-vr ### ########.fr */
/* Updated: 2024/02/18 18:01:11 by marde-vr ### ########.fr */
/* */
/* ************************************************************************** */
@ -34,9 +34,12 @@ void handle_minishellrc(t_env **env, t_alias **aliases)
line = get_next_line(fd);
while (line)
{
parsed_cmd = parse_command(line, *env);
exec_command(parsed_cmd, env, aliases);
free(parsed_cmd);
if (line[0] != '#')
{
parsed_cmd = parse_command(line, *env);
exec_command(parsed_cmd, env, aliases);
free_cmd(parsed_cmd);
}
free(line);
line = get_next_line(fd);
}