unstick update && syntax check
This commit is contained in:
@@ -46,8 +46,6 @@ t_ast_n *parser(char *input, t_msh *msh)
|
|||||||
lst = tokenize(input);
|
lst = tokenize(input);
|
||||||
if (!lst)
|
if (!lst)
|
||||||
return (NULL);
|
return (NULL);
|
||||||
if (syntax_error(lst))
|
|
||||||
return (NULL);
|
|
||||||
if (DEBUG)
|
if (DEBUG)
|
||||||
{
|
{
|
||||||
dio = drawio_init("ast.xml");
|
dio = drawio_init("ast.xml");
|
||||||
|
|||||||
@@ -19,35 +19,96 @@ int only_operator(t_node *head)
|
|||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int syntax_err_mess(char *token)
|
int syntax_err_mess(char *token_base, int selected)
|
||||||
{
|
{
|
||||||
ft_fprintf(2, "minishell : syntax error near unexpected token `%s'\n",
|
char *token;
|
||||||
|
|
||||||
|
token = ft_strdup(token_base);
|
||||||
|
if (selected == 0)
|
||||||
|
ft_fprintf(2, "minishell : syntax error : unexpected token `%s'\n",
|
||||||
token);
|
token);
|
||||||
|
if (selected == 2)
|
||||||
|
ft_fprintf(2, "minishell : syntax error : unoppened token `%s'\n",
|
||||||
|
&token[1]);
|
||||||
|
token[1] = 0;
|
||||||
|
if (selected == 1)
|
||||||
|
ft_fprintf(2, "minishell : syntax error : unclosed token `%s'\n",
|
||||||
|
token);
|
||||||
|
free(token);
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
int unexpected_token(t_node *node)
|
int unexpected_token(t_node *node)
|
||||||
{
|
{
|
||||||
if (!ft_strncmp(node->val, "%", 1) || (!ft_strncmp(node->val, "&", 1)
|
if ((!ft_strncmp(node->val, "&", 1) && ft_strncmp(node->val, "&&", 2))
|
||||||
&& ft_strncmp(node->val, "&&", 2)) || !ft_strncmp(node->val, ";", 1)
|
|| !ft_strncmp(node->val, ";", 1) || !ft_strncmp(node->val, "[", 1)
|
||||||
|| !ft_strncmp(node->val, "[", 1) || !ft_strncmp(node->val, "]", 1)
|
|| !ft_strncmp(node->val, "]", 1) || !ft_strncmp(node->val, "{", 1)
|
||||||
|| !ft_strncmp(node->val, "{", 1) || !ft_strncmp(node->val, "}", 1))
|
|| !ft_strncmp(node->val, "}", 1))
|
||||||
return (1);
|
return (1);
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int check_unclosed(char *c, t_node *node)
|
||||||
|
{
|
||||||
|
t_node *cpy;
|
||||||
|
int count;
|
||||||
|
|
||||||
|
cpy = node;
|
||||||
|
count = 0;
|
||||||
|
while (cpy)
|
||||||
|
{
|
||||||
|
if (!ft_strncmp(&c[0], cpy->val, 1))
|
||||||
|
count++;
|
||||||
|
if (!ft_strncmp(&c[1], cpy->val, 1))
|
||||||
|
count--;
|
||||||
|
cpy = cpy->next;
|
||||||
|
}
|
||||||
|
if (count > 0)
|
||||||
|
return (1);
|
||||||
|
if (count < 0)
|
||||||
|
return (2);
|
||||||
|
return (0);
|
||||||
|
}
|
||||||
|
|
||||||
|
int check_unclosed_quote(char *c, t_node *node)
|
||||||
|
{
|
||||||
|
t_node *cpy;
|
||||||
|
int count;
|
||||||
|
int len;
|
||||||
|
|
||||||
|
cpy = node;
|
||||||
|
count = 0;
|
||||||
|
while (cpy)
|
||||||
|
{
|
||||||
|
len = ft_strlen(cpy->val);
|
||||||
|
if (len > 0 && cpy->val[0] == c[0])
|
||||||
|
{
|
||||||
|
if (len == 1 || cpy->val[len - 1] != c[0])
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
cpy = cpy->next;
|
||||||
|
}
|
||||||
|
return (count % 2);
|
||||||
|
}
|
||||||
|
|
||||||
int syntax_error(t_node *head)
|
int syntax_error(t_node *head)
|
||||||
{
|
{
|
||||||
t_node *cpy;
|
t_node *cpy;
|
||||||
|
|
||||||
if (only_operator(head))
|
if (only_operator(head))
|
||||||
return (syntax_err_mess(head->val));
|
return (syntax_err_mess(head->val, 0));
|
||||||
cpy = head;
|
cpy = head;
|
||||||
while (cpy)
|
while (cpy)
|
||||||
{
|
{
|
||||||
if (unexpected_token(cpy))
|
if (unexpected_token(cpy))
|
||||||
return (syntax_err_mess(cpy->val));
|
return (syntax_err_mess(cpy->val, 0));
|
||||||
cpy = cpy->next;
|
cpy = cpy->next;
|
||||||
}
|
}
|
||||||
|
if (check_unclosed("()", head) != 0)
|
||||||
|
return (syntax_err_mess("()", check_unclosed("()", head)));
|
||||||
|
if (check_unclosed_quote("\"", head) != 0)
|
||||||
|
return (syntax_err_mess("\"\"", 1));
|
||||||
|
if (check_unclosed_quote("'", head) != 0)
|
||||||
|
return (syntax_err_mess("'", 1));
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -39,9 +39,9 @@ t_token get_token(char *str)
|
|||||||
{
|
{
|
||||||
t_token token;
|
t_token token;
|
||||||
|
|
||||||
if (!ft_strncmp(str, "&", 1) || !ft_strncmp(str, "|", 1) || !ft_strncmp(str,
|
if (!ft_strncmp(str, "&", 1) || !ft_strncmp(str, "|", 1)
|
||||||
"(", 1) || !ft_strncmp(str, ")", 1) || !ft_strncmp(str, "<", 1)
|
|| !ft_strncmp(str, "(", 1) || !ft_strncmp(str, ")", 1)
|
||||||
|| !ft_strncmp(str, ">", 1))
|
|| !ft_strncmp(str, "<", 1) || !ft_strncmp(str, ">", 1))
|
||||||
token = OPERATOR;
|
token = OPERATOR;
|
||||||
else
|
else
|
||||||
token = WORD;
|
token = WORD;
|
||||||
|
|||||||
@@ -103,6 +103,23 @@ static int stick_quote_node(t_node *head, char q)
|
|||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void debug_token_list(t_node* lst, char *msg)
|
||||||
|
{
|
||||||
|
t_node *cpy;
|
||||||
|
|
||||||
|
cpy = lst;
|
||||||
|
if (DEBUG)
|
||||||
|
{
|
||||||
|
ft_debug("========================={%s}\n", msg);
|
||||||
|
while (cpy)
|
||||||
|
{
|
||||||
|
ft_debug("|%s|\n", cpy->val);
|
||||||
|
cpy = cpy->next;
|
||||||
|
}
|
||||||
|
ft_debug("=========================\n\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
t_node *tokenize(char *str)
|
t_node *tokenize(char *str)
|
||||||
{
|
{
|
||||||
t_node *head;
|
t_node *head;
|
||||||
@@ -110,12 +127,18 @@ t_node *tokenize(char *str)
|
|||||||
head = tokenize_base(str);
|
head = tokenize_base(str);
|
||||||
if (!head)
|
if (!head)
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
// debug_token_list(head, "tokenize_base");
|
||||||
if (!trim_nodes(head))
|
if (!trim_nodes(head))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
// debug_token_list(head, "trim_nodes");
|
||||||
if (!unstick_nodes(head))
|
if (!unstick_nodes(head))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
// debug_token_list(head, "unstick_nodes");
|
||||||
stick_quote_node(head, 39);
|
stick_quote_node(head, 39);
|
||||||
stick_quote_node(head, '"');
|
stick_quote_node(head, '"');
|
||||||
|
debug_token_list(head, "tokenizer");
|
||||||
set_token(head);
|
set_token(head);
|
||||||
|
if (syntax_error(head))
|
||||||
|
return (NULL);
|
||||||
return (head);
|
return (head);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,29 +15,49 @@
|
|||||||
int is_meta(char c)
|
int is_meta(char c)
|
||||||
{
|
{
|
||||||
if (c == '&' || c == '|' || c == '<' || c == '>' || c == '(' || c == ')'
|
if (c == '&' || c == '|' || c == '<' || c == '>' || c == '(' || c == ')'
|
||||||
|| c == '"' || c == 39)
|
|| c == '"' || c == 39 || c == ';' || c == '{' || c == '}' || c == '['
|
||||||
|
|| c == ']')
|
||||||
return (1);
|
return (1);
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int unic(int *meta)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int ref_meta;
|
||||||
|
|
||||||
|
i = -1;
|
||||||
|
ref_meta = meta[0];
|
||||||
|
while (meta[++i] != -1)
|
||||||
|
if (meta[i] != ref_meta)
|
||||||
|
return (0);
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
|
||||||
int is_sticked(char *val)
|
int is_sticked(char *val)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int meta;
|
int meta[100];
|
||||||
|
int meta_it;
|
||||||
int unmeta;
|
int unmeta;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
meta = 0;
|
meta_it = 0;
|
||||||
|
meta[0] = -1;
|
||||||
unmeta = 0;
|
unmeta = 0;
|
||||||
while (val[i])
|
while (val[i])
|
||||||
{
|
{
|
||||||
if (is_meta(val[i]))
|
if (is_meta(val[i]))
|
||||||
meta = 1;
|
{
|
||||||
|
meta[meta_it] = val[i];
|
||||||
|
meta_it++;
|
||||||
|
}
|
||||||
if (!is_meta(val[i]))
|
if (!is_meta(val[i]))
|
||||||
unmeta = 1;
|
unmeta = 1;
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
if (meta && unmeta)
|
meta[meta_it] = -1;
|
||||||
|
if ((meta[0] != -1 && unmeta) || !unic(meta))
|
||||||
return (1);
|
return (1);
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,9 +17,11 @@ char *copy_meta_xor(char *val, int *copied, int rev)
|
|||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
char *out;
|
char *out;
|
||||||
|
char ref;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
while (is_meta(val[i]) ^ rev)
|
ref = val[0];
|
||||||
|
while ((is_meta(val[i]) && val[i] == ref) ^ rev)
|
||||||
i++;
|
i++;
|
||||||
*copied = i;
|
*copied = i;
|
||||||
out = malloc(i + 1);
|
out = malloc(i + 1);
|
||||||
|
|||||||
Reference in New Issue
Block a user