-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathms_export.c
117 lines (106 loc) · 2.49 KB
/
ms_export.c
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
116
117
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ms_export.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: obeedril <obeedril@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/03/11 21:00:33 by dlana #+# #+# */
/* Updated: 2022/03/11 21:08:13 by obeedril ### ########.fr */
/* */
/* ************************************************************************** */
#include "minishell.h"
int ft_strncmp_by_env(const char *s1, const char *s2)
{
int i;
unsigned char *t1;
unsigned char *t2;
t1 = (unsigned char *) s1;
t2 = (unsigned char *) s2;
i = 0;
while ((t1[i] != '\0' || t2[i] != '\0') && t2[i] != '=' && t1[i] != '=')
{
if (t1[i] != t2[i])
return (t1[i] - t2[i]);
i++;
}
if ((t1[i] != '\0' || t2[i] != '\0') && t2[i] != '=' && t1[i] != '=')
return (t1[i] - t2[i]);
return (0);
}
void ms_sort_env(t_data *data, int y, int **sort)
{
int i;
int difference;
int first;
i = 0;
difference = 0;
first = YES;
i = 0;
while (i < data->num_env)
{
if ((*sort)[i] != YES)
{
difference = ft_strncmp_by_env(data->our_env[y], data->our_env[i]);
if (difference > 0)
first = NO;
}
i++;
}
if (first == YES && (*sort)[y] != YES)
{
(*sort)[y] = YES;
ms_print_sort_export(data, y);
}
}
int ms_check_sorted(int **sort, t_data *data)
{
int i;
i = 0;
while (i < data->num_env)
{
if ((*sort)[i] == NO)
return (NO);
i++;
}
return (YES);
}
void ms_recurs_sort(t_data *data, int **sort)
{
int end;
int y;
y = 0;
end = 0;
while (y < data->num_env)
{
ms_sort_env(data, y, sort);
y++;
if (y == data->num_env)
{
end = ms_check_sorted(sort, data);
if (end == NO)
ms_recurs_sort(data, sort);
}
}
}
void ms_export(t_data *data, int i)
{
int y;
int *sort;
y = 0;
if (data->cmd[i].array_arg[1] != NULL)
{
if (i == 0)
ms_add_env_variable(data, i);
return ;
}
ms_malloc_arr_int(&sort, data->num_env);
while (y < data->num_env)
{
sort[y] = NO;
y++;
}
sort[y] = 0;
ms_recurs_sort(data, &sort);
ms_free_int_arr(&sort);
}