blob: 7df4955f56aec50cb5b6e5908e69457755d3ee26 (
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
|
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* utils.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: nahaddac <nahaddac@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/07/16 08:18:15 by nahaddac #+# #+# */
/* Updated: 2020/09/13 17:23:29 by charles ### ########.fr */
/* */
/* ************************************************************************** */
#include "lexer.h"
// return token tag corresponding to string id
enum e_tok tok_assign_tag(char *content)
{
if (content[0] == ';')
return (TAG_END);
if (ft_strncmp(content, "&&", 2) == 0)
return (TAG_AND);
if (ft_strncmp(content, "||", 2) == 0)
return (TAG_OR);
if(content[0] == '|')
return (TAG_PIPE);
if (content[0] == '>')
return (TAG_REDIR_OUT);
if (content[0] == '<')
return (TAG_REDIR_IN);
if (ft_strncmp(content, ">>", 2) == 0)
return (TAG_REDIR_APPEND);
if (content[0] == '(')
return (TAG_PARENT_OPEN);
if (content[0] == ')')
return (TAG_PARENT_CLOSE);
return (0);
}
enum e_tok tok_assign_stick(t_tok_lst *tok)
{
int i;
i = ft_strlen(tok->content);
if (i > 0)
if (ft_isblank(tok->content[i - 1]))
return (tok->tag);
return (tok->tag | TAG_STICK);
}
enum e_tok tok_assign_str(t_tok_lst *tok)
{
int i;
// could use strchr to search ' or "
i = 0;
while (tok->content[i] != '\0')
{
if (tok->content[i] == '\'')
{
tok->tag = TAG_STR_SINGLE;
return (tok_assign_stick(tok));
}
if (tok->content[i] == '"')
{
tok->tag = TAG_STR_DOUBLE;
return (tok_assign_stick(tok));
}
else
{
tok->tag = TAG_STR;
return (tok_assign_stick(tok));
}
i++;
}
return (0);
}
// check is char is separator
// & alone could be considered a separator
int lexer_sep(char c)
{
return (ft_strchr(";&|><()", c) != NULL);
}
// number of starting space character
int lexer_space(char *input)
{
return (ft_strspn(input, " \t"));
}
int quote_len(char *input, int i)
{
char quote_type;
quote_type = input[i];
i++;
while (input[i] != quote_type && input[i] != '\0')
{
if (input[i] == '\\')
i++;
i++;
}
while (ft_isblank(input[i + 1]))
i++;
return (i + 1);
}
|