fix(lexer): edge cases where 'f' can be lexed as 'fi' for example
This commit is contained in:
parent
adc1bdc841
commit
3b538cbb79
1 changed files with 7 additions and 7 deletions
|
|
@ -60,31 +60,31 @@ static void set_token_keyword(struct token *tok, char *begin, ssize_t size)
|
|||
{
|
||||
if (tok->type != TOKEN_NULL || size == 0)
|
||||
return;
|
||||
if (strncmp(begin, "if", size) == 0)
|
||||
if (strncmp(begin, "if", size) == 0 && size == 2)
|
||||
{
|
||||
tok->type = TOKEN_IF;
|
||||
}
|
||||
else if (strncmp(begin, "fi", size) == 0)
|
||||
else if (strncmp(begin, "fi", size) == 0 && size == 2)
|
||||
{
|
||||
tok->type = TOKEN_FI;
|
||||
}
|
||||
else if (strncmp(begin, "then", size) == 0)
|
||||
else if (strncmp(begin, "then", size) == 0 && size == 4)
|
||||
{
|
||||
tok->type = TOKEN_THEN;
|
||||
}
|
||||
else if (strncmp(begin, "else", size) == 0)
|
||||
else if (strncmp(begin, "else", size) == 0 && size == 4)
|
||||
{
|
||||
tok->type = TOKEN_ELSE;
|
||||
}
|
||||
else if (strncmp(begin, "elif", size) == 0)
|
||||
else if (strncmp(begin, "elif", size) == 0 && size == 4)
|
||||
{
|
||||
tok->type = TOKEN_ELIF;
|
||||
}
|
||||
else if (strncmp(begin, "&&", size) == 0)
|
||||
else if (strncmp(begin, "&&", size) == 0 && size == 2)
|
||||
{
|
||||
tok->type = TOKEN_AND;
|
||||
}
|
||||
else if (strncmp(begin, "||", size) == 0)
|
||||
else if (strncmp(begin, "||", size) == 0 && size == 2)
|
||||
{
|
||||
tok->type = TOKEN_OR;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue