unstick update && syntax check

This commit is contained in:
gazhonsepaskwa
2025-02-08 12:37:48 +01:00
parent d3849d196f
commit 373e240e85
6 changed files with 124 additions and 20 deletions

View File

@@ -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");

View File

@@ -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);
} }

View File

@@ -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;

View File

@@ -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);
} }

View File

@@ -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);
} }

View File

@@ -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);