summaryrefslogtreecommitdiffstats
path: root/src/b_export_next.c
blob: 975a579d52c2f05716931369b9ba78f6108c55b1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/* ************************************************************************** */
/*                                                                            */
/*                                                        :::      ::::::::   */
/*   b_export_next.c                                    :+:      :+:    :+:   */
/*                                                    +:+ +:+         +:+     */
/*   By: rbousset <marvin@42.fr>                    +#+  +:+       +#+        */
/*                                                +#+#+#+#+#+   +#+           */
/*   Created: 2020/02/14 17:19:27 by rbousset          #+#    #+#             */
/*   Updated: 2020/02/14 17:19:29 by rbousset         ###   ########lyon.fr   */
/*                                                                            */
/* ************************************************************************** */

#include <libft.h>
#include <stdlib.h>

#include "d_define.h"
#include "b_export_next.h"
#include "f_fail.h"
#include "s_lvars.h"
#include "s_struct.h"
#include "u_utils.h"
#include "u_vars.h"

static char	**b_get_var(const char arg[], t_msh *msh)
{
	size_t	len;
	char	**var;

	if ((var = (char**)malloc(3 * sizeof(char*))) == NULL)
		f_alloc_and_destroy_msh(msh);
	len = 0;
	while (arg[len] != '=' && arg[len] != '\0')
		len++;
	len += 1;
	if ((var[B_VAR_NAME] = (char*)malloc((len + 1) * sizeof(char))) == NULL)
		f_alloc_and_destroy_msh(msh);
	var[B_VAR_NAME][0] = '$';
	ft_strlcpy(var[B_VAR_NAME] + 1, arg, len);
	if ((var[B_VAR_VAL] = ft_strdup(arg + len)) == NULL)
		f_alloc_and_destroy_msh(msh);
	var[B_VAR_NULL] = NULL;
	return (var);
}

static long	b_is_it_in_env(const char varname[], t_msh *msh)
{
	char	**env_dup;
	size_t	i;

	env_dup = u_get_env_var_names(msh);
	i = 0;
	while (env_dup[i] != NULL)
	{
		if (ft_strncmp(varname, env_dup[i], ft_strlen(env_dup[i]) + 1) == 0)
		{
			ft_delwords(env_dup);
			return (i);
		}
		i++;
	}
	ft_delwords(env_dup);
	return (-1);
}

static void	b_add_to_env(const char arg[], t_msh *msh)
{
	size_t	i;
	char	**nenvp;

	i = 0;
	while (msh->envp[i] != NULL)
		i++;
	if (!(nenvp = (char**)malloc((i + 2) * sizeof(char*))))
		f_alloc_and_destroy_msh(msh);
	i = 0;
	while (msh->envp[i] != NULL)
	{
		if (!(nenvp[i] = ft_strdup(msh->envp[i])))
			f_alloc_and_destroy_msh(msh);
		i++;
	}
	if (!(nenvp[i] = ft_strdup(arg)))
		f_alloc_and_destroy_msh(msh);
	nenvp[i + 1] = 0;
	ft_delwords(msh->envp);
	msh->envp = nenvp;
}

void		b_export_with_equals(const char arg[], t_msh *msh)
{
	char	varval[4096];
	char	**var;
	long	env_i;

	varval[0] = C_NUL;
	var = b_get_var(arg, msh);
	if ((env_i = b_is_it_in_env(var[B_VAR_NAME] + 1, msh)) != -1)
	{
		ft_memdel((void*)&msh->envp[env_i]);
		if ((msh->envp[env_i] = ft_strdup(arg)) == NULL)
			f_alloc_and_destroy_msh(msh);
		return ;
	}
	u_get_custom_var(varval, var[B_VAR_NAME], 4096, msh);
	if (varval[0] != C_NUL)
	{
		b_add_to_env(arg, msh);
		lvars_delone(&msh->vars, var[B_VAR_NAME] + 1);
	}
	else
	{
		b_add_to_env(arg, msh);
	}
	ft_delwords(var);
}