-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathquote_transformation.c
122 lines (113 loc) · 3.02 KB
/
quote_transformation.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
118
119
120
121
122
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* quote_transformation.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: mthiry <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/07/20 14:39:24 by mthiry #+# #+# */
/* Updated: 2022/08/09 11:56:26 by mthiry ### ########.fr */
/* */
/* ************************************************************************** */
#include "minishell.h"
t_node *delete_node(t_node *elem)
{
t_node *tmp;
if (!elem)
return (NULL);
if (!elem->next)
return (elem);
tmp = elem;
elem = elem->next;
if (!tmp->prev)
elem->prev = NULL;
else
elem->prev = tmp->prev;
if (elem->prev)
elem->prev->next = elem;
free(tmp->value);
free(tmp);
return (elem);
}
t_node *fuse_next_elem(t_node *elem, t_node *tmp, t_input *data)
{
tmp = elem;
if (!elem->prev->prev)
return (elem);
elem = elem->prev->prev;
elem->value = ms_strjoin_free(elem->value, tmp->value, data);
elem = ms_token_del(tmp);
if (elem->next)
elem = elem->next;
return (elem);
}
t_node *fuse_between_quotes(t_node *elem, t_input *data, int type)
{
t_node *tmp;
elem = elem->next;
if (elem->type == type)
{
if (elem->next)
elem = elem->next;
return (elem);
}
tmp = elem->next;
elem->type = WORD;
while (tmp && tmp->type != type)
{
elem->value = ms_strjoin_free(elem->value, tmp->value, data);
tmp = delete_node(tmp);
}
if (tmp && tmp->type == type)
elem = tmp->next;
if (elem && (elem->type == WORD || elem->type == SLASH))
elem = fuse_next_elem(elem, tmp, data);
return (elem);
}
t_node *fuse_prev_elem(t_node *elem, t_input *data, int type)
{
char *str;
char *str_2;
t_node *tmp;
tmp = elem->prev;
elem = elem->next;
if (elem->type == type)
{
if (elem->next)
elem = elem->next;
return (elem);
}
str = ms_strdup(tmp->value, data);
str_2 = elem->value;
elem->value = ms_strjoin_free(str, str_2, data);
tmp->type = 0;
free(str_2);
return (elem);
}
int quote_transformation(t_node *elem, t_input *data)
{
while (elem)
{
if (!elem->next)
break ;
if ((elem->type == QUOTE_D && elem->next
&& elem->next->type == QUOTE_D)
|| (elem->type == QUOTE && elem->next && elem->next->type == QUOTE))
{
elem->type = EMPTY_ARG;
ms_token_del(elem->next);
}
else if (elem->type == QUOTE_D || elem->type == QUOTE)
{
if (elem->prev && (elem->prev->type == WORD
|| elem->prev->type == SLASH))
fuse_prev_elem(elem, data, elem->type);
elem = fuse_between_quotes(elem, data, elem->type);
if (!elem || !elem->next)
break ;
}
else
elem = elem->next;
}
return (0);
}