mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 11:38:11 +00:00
LibJS: Syntax error for a unary expression followed by exponentiation
This change makes LibJS correctly report a syntax error when a unary expression is followed by exponentiation, as the spec requires. Apparently this is due to that expression being ambiguous ordering. Strangely this check does not seem to apply in the same way for '++' and '--' for reasons that I don't fully understand. For example ``` let x = 5; ++x ** 2 ``` Since `--5` and `++5` on it's own results in a syntax error anyway, it seems we do not need to perform this exponentiation check in those places. Diff Tests: +6 ✅ -6 ❌
This commit is contained in:
parent
5e7a82a853
commit
2d8b2328fd
3 changed files with 50 additions and 2 deletions
|
@ -0,0 +1,9 @@
|
|||
test("syntax error for an unary expression before exponentiation", () => {
|
||||
expect(`!5 ** 2`).not.toEval();
|
||||
expect(`~5 ** 2`).not.toEval();
|
||||
expect(`+5 ** 2`).not.toEval();
|
||||
expect(`-5 ** 2`).not.toEval();
|
||||
expect(`typeof 5 ** 2`).not.toEval();
|
||||
expect(`void 5 ** 2`).not.toEval();
|
||||
expect(`delete 5 ** 2`).not.toEval();
|
||||
});
|
Loading…
Add table
Add a link
Reference in a new issue