summaryrefslogtreecommitdiff
path: root/node_modules/sucrase/dist/esm/parser/traverser/base.js
diff options
context:
space:
mode:
authorPhilipp Tanlak <philipp.tanlak@gmail.com>2025-11-24 20:54:57 +0100
committerPhilipp Tanlak <philipp.tanlak@gmail.com>2025-11-24 20:57:48 +0100
commitb1e2c8fd5cb5dfa46bc440a12eafaf56cd844b1c (patch)
tree49d360fd6cbc6a2754efe93524ac47ff0fbe0f7d /node_modules/sucrase/dist/esm/parser/traverser/base.js
Docs
Diffstat (limited to 'node_modules/sucrase/dist/esm/parser/traverser/base.js')
-rw-r--r--node_modules/sucrase/dist/esm/parser/traverser/base.js60
1 files changed, 60 insertions, 0 deletions
diff --git a/node_modules/sucrase/dist/esm/parser/traverser/base.js b/node_modules/sucrase/dist/esm/parser/traverser/base.js
new file mode 100644
index 0000000..df24ff7
--- /dev/null
+++ b/node_modules/sucrase/dist/esm/parser/traverser/base.js
@@ -0,0 +1,60 @@
+import State from "../tokenizer/state";
+import {charCodes} from "../util/charcodes";
+
+export let isJSXEnabled;
+export let isTypeScriptEnabled;
+export let isFlowEnabled;
+export let state;
+export let input;
+export let nextContextId;
+
+export function getNextContextId() {
+ return nextContextId++;
+}
+
+// eslint-disable-next-line @typescript-eslint/no-explicit-any
+export function augmentError(error) {
+ if ("pos" in error) {
+ const loc = locationForIndex(error.pos);
+ error.message += ` (${loc.line}:${loc.column})`;
+ error.loc = loc;
+ }
+ return error;
+}
+
+export class Loc {
+
+
+ constructor(line, column) {
+ this.line = line;
+ this.column = column;
+ }
+}
+
+export function locationForIndex(pos) {
+ let line = 1;
+ let column = 1;
+ for (let i = 0; i < pos; i++) {
+ if (input.charCodeAt(i) === charCodes.lineFeed) {
+ line++;
+ column = 1;
+ } else {
+ column++;
+ }
+ }
+ return new Loc(line, column);
+}
+
+export function initParser(
+ inputCode,
+ isJSXEnabledArg,
+ isTypeScriptEnabledArg,
+ isFlowEnabledArg,
+) {
+ input = inputCode;
+ state = new State();
+ nextContextId = 1;
+ isJSXEnabled = isJSXEnabledArg;
+ isTypeScriptEnabled = isTypeScriptEnabledArg;
+ isFlowEnabled = isFlowEnabledArg;
+}