mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 13:28:11 +00:00
LibJS: Parse slashes after reserved identifiers correctly
Previously we were unable to parse code like `yield/2` because `/2` was parsed as a regex. At the same time `for (a in / b/)` was parsed as a division. This is solved by defaulting to division in the lexer, but calling `force_slash_as_regex()` from the parser whenever an IdentifierName is parsed as a ReservedWord.
This commit is contained in:
parent
b0bd1e5eb5
commit
a2efecac03
6 changed files with 65 additions and 25 deletions
|
@ -19,7 +19,30 @@ test("slash token resolution in lexer", () => {
|
|||
expect("a.instanceof / b").toEval();
|
||||
expect("class A { #name; d = a.#name / b; }").toEval();
|
||||
|
||||
// FIXME: Even more 'reserved' words are valid however the cases below do still need to pass.
|
||||
//expect("a.void / b").toEval();
|
||||
expect("async / b").toEval();
|
||||
expect("a.delete / b").toEval();
|
||||
expect("delete / b/").toEval();
|
||||
expect("a.in / b").toEval();
|
||||
expect("for (a in / b/) {}").toEval();
|
||||
expect("a.instanceof / b").toEval();
|
||||
expect("a instanceof / b/").toEval();
|
||||
expect("new / b/").toEval();
|
||||
expect("null / b").toEval();
|
||||
expect("for (a of / b/) {}").toEval();
|
||||
expect("a.return / b").toEval();
|
||||
expect("function foo() { return / b/ }").toEval();
|
||||
expect("throw / b/").toEval();
|
||||
expect("a.typeof / b").toEval();
|
||||
expect("a.void / b").toEval();
|
||||
expect("void / b/").toEval();
|
||||
|
||||
expect("await / b").toEval();
|
||||
expect("await / b/").not.toEval();
|
||||
expect("async function foo() { await / b }").not.toEval();
|
||||
expect("async function foo() { await / b/ }").toEval();
|
||||
|
||||
expect("yield / b").toEval();
|
||||
expect("yield / b/").not.toEval();
|
||||
expect("function* foo() { yield / b }").not.toEval();
|
||||
expect("function* foo() { yield / b/ }").toEval();
|
||||
});
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue