35 lines
1.2 KiB
JavaScript
35 lines
1.2 KiB
JavaScript
|
import {charCodes} from "./charcodes";
|
||
|
import {WHITESPACE_CHARS} from "./whitespace";
|
||
|
|
||
|
function computeIsIdentifierChar(code) {
|
||
|
if (code < 48) return code === 36;
|
||
|
if (code < 58) return true;
|
||
|
if (code < 65) return false;
|
||
|
if (code < 91) return true;
|
||
|
if (code < 97) return code === 95;
|
||
|
if (code < 123) return true;
|
||
|
if (code < 128) return false;
|
||
|
throw new Error("Should not be called with non-ASCII char code.");
|
||
|
}
|
||
|
|
||
|
export const IS_IDENTIFIER_CHAR = new Uint8Array(65536);
|
||
|
for (let i = 0; i < 128; i++) {
|
||
|
IS_IDENTIFIER_CHAR[i] = computeIsIdentifierChar(i) ? 1 : 0;
|
||
|
}
|
||
|
for (let i = 128; i < 65536; i++) {
|
||
|
IS_IDENTIFIER_CHAR[i] = 1;
|
||
|
}
|
||
|
// Aside from whitespace and newlines, all characters outside the ASCII space are either
|
||
|
// identifier characters or invalid. Since we're not performing code validation, we can just
|
||
|
// treat all invalid characters as identifier characters.
|
||
|
for (const whitespaceChar of WHITESPACE_CHARS) {
|
||
|
IS_IDENTIFIER_CHAR[whitespaceChar] = 0;
|
||
|
}
|
||
|
IS_IDENTIFIER_CHAR[0x2028] = 0;
|
||
|
IS_IDENTIFIER_CHAR[0x2029] = 0;
|
||
|
|
||
|
export const IS_IDENTIFIER_START = IS_IDENTIFIER_CHAR.slice();
|
||
|
for (let numChar = charCodes.digit0; numChar <= charCodes.digit9; numChar++) {
|
||
|
IS_IDENTIFIER_START[numChar] = 0;
|
||
|
}
|