Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 16 additions & 1 deletion compiler/ext/js_reserved_map.ml
Original file line number Diff line number Diff line change
Expand Up @@ -80,12 +80,15 @@ let js_keywords = STbl.of_array [|
"void";
"while";
"with";

(* The following are also reserved in strict context, including ESM *)
"let";
"static";
"yield";

(* `await` is reserved in async context, including ESM *)
"await";

(* Future reserved words *)
"enum";
"implements";
Expand All @@ -94,6 +97,18 @@ let js_keywords = STbl.of_array [|
"private";
"protected";
"public";

(* Special identifiers

`arguments` and `eval` is not real *keywords*

However, they cannot be as identifiers in the strict mode,
and the compiler output is always in strict mode.

See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Lexical_grammar#identifiers_with_special_meanings
*)
"arguments";
"eval";
|]

let is_js_keyword s = STbl.mem js_keywords s
Expand All @@ -104,7 +119,7 @@ let is_js_keyword s = STbl.mem js_keywords s

See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Lexical_grammar#identifiers_with_special_meanings

However, these names are actually used with no problems today. Preventing this can be annoying.
However, these names are actually used with no problems today. (Except `arguments` and `eval`)
*)
let js_special_words = STbl.of_array [|
"arguments";
Expand Down
3 changes: 0 additions & 3 deletions tests/tests/src/global_mangles.res

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,6 +1,14 @@
// Generated by ReScript, PLEASE EDIT WITH CARE


function fn1($$arguments) {
console.log($$arguments);
}

function fn2($$eval) {
console.log($$eval);
}

let $$__dirname = 1;

let $$__filename = 2;
Expand All @@ -14,5 +22,7 @@ export {
$$__filename,
$$exports,
$$require,
fn1,
fn2,
}
/* No side effect */
10 changes: 10 additions & 0 deletions tests/tests/src/ident_mangles.res
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
/* Reserved in CommonJS */
let (__dirname, __filename, exports, require) = (1, 2, 3, 4)

let fn1 = arguments => {
Console.log(arguments)
}

let fn2 = eval => {
Console.log(eval)
}
4 changes: 2 additions & 2 deletions tests/tests/src/key_word_property_plus_test.mjs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// Generated by ReScript, PLEASE EDIT WITH CARE

import * as Mt from "./mt.mjs";
import * as Global_mangles from "./global_mangles.mjs";
import * as Ident_mangles from "./ident_mangles.mjs";

let suites = {
contents: /* [] */0
Expand Down Expand Up @@ -31,7 +31,7 @@ eq("File \"key_word_property_plus_test.res\", line 13, characters 2-9", [
2,
3,
4
].reduce((prim0, prim1) => prim0 + prim1 | 0, 0), ((Global_mangles.$$__dirname + Global_mangles.$$__filename | 0) + Global_mangles.$$exports | 0) + Global_mangles.$$require | 0);
].reduce((prim0, prim1) => prim0 + prim1 | 0, 0), ((Ident_mangles.$$__dirname + Ident_mangles.$$__filename | 0) + Ident_mangles.$$exports | 0) + Ident_mangles.$$require | 0);

Mt.from_pair_suites("Key_word_property_plus_test", suites.contents);

Expand Down
2 changes: 1 addition & 1 deletion tests/tests/src/key_word_property_plus_test.res
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ let () = eq(
__LOC__,
Js.Array2.reduce([1, 2, 3, 4], \"+", 0),
{
open Global_mangles
open Ident_mangles
__dirname + __filename + exports + require
},
)
Expand Down
Loading