136 lines
2.8 KiB
C
136 lines
2.8 KiB
C
/* ************************************************************************** */
|
|
/* */
|
|
/* ::: :::::::: */
|
|
/* export.c :+: :+: :+: */
|
|
/* +:+ +:+ +:+ */
|
|
/* By: lderidde <lderidde@student.s19.be> +#+ +:+ +#+ */
|
|
/* +#+#+#+#+#+ +#+ */
|
|
/* Created: 2025/01/24 14:32:20 by lderidde #+# #+# */
|
|
/* Updated: 2025/02/03 13:11:35 by lderidde ### ########.fr */
|
|
/* */
|
|
/* ************************************************************************** */
|
|
|
|
#include "../../includes/minishell.h"
|
|
|
|
int is_export_valid(char *str)
|
|
{
|
|
char *equal;
|
|
|
|
if (!ft_isalpha(*str) && str[0] != '_')
|
|
return (0);
|
|
equal = ft_strchr(str, '=');
|
|
if(!equal)
|
|
{
|
|
while (*(++str))
|
|
{
|
|
if (!ft_isalnum(*str) && *str != '_')
|
|
return (0);
|
|
}
|
|
return (1);
|
|
}
|
|
else
|
|
{
|
|
while (++str < equal)
|
|
{
|
|
if (!ft_isalnum(*str) && *str != '_')
|
|
return (0);
|
|
}
|
|
return (1);
|
|
}
|
|
}
|
|
|
|
char **key_value(char *str)
|
|
{
|
|
char **tmp;
|
|
char *equal;
|
|
|
|
tmp = malloc(sizeof(char *) * (2 + 1));
|
|
if (!tmp)
|
|
return (NULL);
|
|
equal = ft_strchr(str, '=');
|
|
tmp[0] = ft_substr(str, 0, equal - str);
|
|
if (equal - str == 0)
|
|
tmp[1] = ft_strdup("");
|
|
else
|
|
tmp[1] = ft_substr(equal, 1, ft_strlen(equal));
|
|
tmp[2] = NULL;
|
|
return (tmp);
|
|
}
|
|
|
|
void print_arr(char **envp)
|
|
{
|
|
int i;
|
|
char *equal;
|
|
char **print;
|
|
|
|
(void)equal;
|
|
i = -1;
|
|
while (envp[++i])
|
|
{
|
|
print = key_value(envp[i]);
|
|
if (print[1])
|
|
ft_printf("declare -x %s=\"%s\"\n", print[0], print[1]);
|
|
else
|
|
ft_printf("declare -x %s\n", print[0]);
|
|
free_tab(print);
|
|
}
|
|
}
|
|
|
|
int print_export(char **envp)
|
|
{
|
|
int i;
|
|
int j;
|
|
char *tmp;
|
|
int len;
|
|
|
|
i = -1;
|
|
len = 0;
|
|
while (envp[len])
|
|
len++;
|
|
while (++i < len - 1)
|
|
{
|
|
j = 0;
|
|
while (j < len - i - 1)
|
|
{
|
|
if (ft_strncmp(envp[j], envp[j + 1], ft_strchr(envp[j], '=') - envp[j]) > 0)
|
|
{
|
|
tmp = envp[j];
|
|
envp[j] = envp[j + 1];
|
|
envp[j + 1] = tmp;
|
|
}
|
|
j++;
|
|
}
|
|
}
|
|
print_arr(envp);
|
|
return (0);
|
|
}
|
|
|
|
int builtin_export(char **arg, t_ast_n *head)
|
|
{
|
|
int i;
|
|
char **tmp;
|
|
|
|
i = 0;
|
|
if (count_args(arg) == 1)
|
|
return (print_export(head->msh->env));
|
|
while (++i < count_args(arg))
|
|
{
|
|
if (is_export_valid(arg[i]))
|
|
{
|
|
if (ft_strchr(arg[i], '=') != NULL)
|
|
{
|
|
tmp = key_value(arg[i]);
|
|
if (!tmp)
|
|
return (1);
|
|
set_var_env(tmp[0], tmp[1], head->msh);
|
|
free_tab(tmp);
|
|
}
|
|
else
|
|
set_var_env(arg[i], NULL, head->msh);
|
|
}
|
|
else
|
|
return (err_msg_cmd("export", arg[i], EXPRT_INV, 1));
|
|
}
|
|
return (0);
|
|
}
|