/* ************************************************************************** */ /* */ /* ::: :::::::: */ /* env.c :+: :+: :+: */ /* +:+ +:+ +:+ */ /* By: narnaud +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2022/02/16 09:41:29 by narnaud #+# #+# */ /* Updated: 2022/05/05 09:30:51 by narnaud ### ########.fr */ /* */ /* ************************************************************************** */ #include "minishell.h" int is_valid_identifier(char *ident) { if (ft_isalpha(ident[0]) || ident[0] == '_') { while (*ident) { if (!ft_isalpha(*ident) && !ft_isdigit(*ident) && *ident != '_') return (0); ident++; } return (1); } return (0); } int ft_unset(t_datas *datas, t_command *cmd) { (void)datas; if (!cmd->argv[1]) { //read(input_fd, PIPE_MAX_SIZE); return (1); } return (0); } int ft_env(t_datas *datas) { int i; i = 0; while (datas->envp[i]) { printf("%s\n", datas->envp[i]); i++; } return (0); } int ft_export(t_datas *datas, t_command *cmd) { char **new; char **env; int i; i = 0; new = ft_split(cmd->argv[1], '='); if (!is_valid_identifier(new[0])) { printf ("export: not an identifier: %s\n", new[0]); return (0); } while (datas->envp[i]) { env = ft_split(datas->envp[i], '='); if (!ft_strncmp(new[0], env[0], ft_strlen(new[0]) + 1)) { datas->envp[i] = cmd->argv[1]; return (1); } i++; } datas->envp[i] = cmd->argv[1]; datas->envp[i + 1] = NULL; return (1); }