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> +#+ +:+ +#+ # # By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ #
# +#+#+#+#+#+ +#+ # # +#+#+#+#+#+ +#+ #
# Created: 2023/07/28 00:35:01 by tomoron #+# #+# # # Created: 2023/07/28 00:35:01 by tomoron #+# #+# #
# Updated: 2024/02/18 15:45:58 by tomoron ### ########.fr # # Updated: 2024/02/18 18:33:00 by marde-vr ### ########.fr #
# # # #
# **************************************************************************** # # **************************************************************************** #
@ -26,7 +26,8 @@ SRCS_RAW = main.c\
parsing_var.c\ parsing_var.c\
handle_alias.c\ handle_alias.c\
lst_alias.c\ lst_alias.c\
minishellrc.c minishellrc.c\
export.c
OBJS_DIR = objs/ OBJS_DIR = objs/
SRCS_DIR = srcs/ SRCS_DIR = srcs/

View File

@ -6,7 +6,7 @@
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */ /* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/02/16 23:16:07 by marde-vr #+# #+# */ /* 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; char *res;
i = 0; i = 0;
while (arg->token[i] != '=') while (arg->token[i] && arg->token[i] != '=')
i++; i++;
i++; i++;
res = ft_strdup(""); res = ft_calloc(i, 1);
ft_strlcpy(res, arg->token, i); ft_strlcpy(res, arg->token, i);
return (res); return (res);
} }
@ -35,22 +35,60 @@ char *get_alias_value(t_cmd *arg)
while (arg->token[i] != '=') while (arg->token[i] != '=')
i++; i++;
i++; i++;
res = arg->token + i; res = ft_strdup(arg->token + i);
return (res); 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) int alias(t_cmd *args, t_alias **aliases)
{ {
char *name; char *name;
char *value; char *value;
t_alias *cur_alias;
cur_alias = *aliases;
if (!args->next || args->next->type != ARG) 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 else
{ {
name = get_alias_name(args->next); name = get_alias_name(args->next);
@ -61,7 +99,8 @@ int alias(t_cmd *args, t_alias **aliases)
} }
else else
{ {
ft_get_alias(*aliases, name); ft_printf("alias %s=%s\n", name, ft_get_alias(*aliases, name));
free(name);
} }
} }
return (0); return (0);

View File

@ -6,7 +6,7 @@
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */ /* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/02/07 14:12:49 by tomoron #+# #+# */ /* 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) int exec_builtin(t_cmd *parsed_cmd, t_env **env, t_alias **aliases)
{ {
if (!ft_strcmp(parsed_cmd->token, "echo")) if (!ft_strcmp(parsed_cmd->token, "echo"))
g_return_code = echo(parsed_cmd->next); g_return_code = echo(parsed_cmd->next);
else if (!ft_strcmp(parsed_cmd->token, "ret")) 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(); g_return_code = pwd();
else if (!ft_strcmp(parsed_cmd->token, "cd")) else if (!ft_strcmp(parsed_cmd->token, "cd"))
g_return_code = cd(parsed_cmd); 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")) else if (!ft_strcmp(parsed_cmd->token, "alias"))
g_return_code = alias(parsed_cmd, aliases); g_return_code = alias(parsed_cmd, aliases);
else if (!ft_strcmp(parsed_cmd->token, "unalias"))
g_return_code = unalias(parsed_cmd, aliases);
else else
return (STDIN_FILENO); return (STDIN_FILENO);
return (STDOUT_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> +#+ +:+ +#+ */ /* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/02/04 17:31:38 by tomoron #+# #+# */ /* 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); void free_alias(t_alias *alias);
char *ft_get_alias(t_alias *alias, char *var_name); char *ft_get_alias(t_alias *alias, char *var_name);
t_alias *alias_add_back(t_alias *alias, char *name, char *value); 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 #endif

View File

@ -6,7 +6,7 @@
/* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */ /* By: marde-vr <marde-vr@42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/02/16 17:40:16 by marde-vr #+# #+# */ /* 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); line = get_next_line(fd);
while (line) while (line)
{ {
parsed_cmd = parse_command(line, *env); if (line[0] != '#')
exec_command(parsed_cmd, env, aliases); {
free(parsed_cmd); parsed_cmd = parse_command(line, *env);
exec_command(parsed_cmd, env, aliases);
free_cmd(parsed_cmd);
}
free(line); free(line);
line = get_next_line(fd); line = get_next_line(fd);
} }