diff --git a/README.md b/README.md
new file mode 100644
index 0000000..1ed6fc7
--- /dev/null
+++ b/README.md
@@ -0,0 +1,38 @@
+# How to update tree-sitter
+
+Tree-sitter is packaged in a way that makes it difficult to load it up with `wds`, it is packaged as a CommonJS module (modifying a `module.exports` object) and as such does not play well with es modules.
+
+The simplest solution I have found is to turn the CommonJS module into an ES module by adding the following at the end of the file:
+
+```js
+await TreeSitter.init({
+ locateFile(scriptName, scriptDirectory) {
+ return "/assets/tree-sitter.wasm";
+ }
+});
+export const Parser = TreeSitter;
+```
+
+This also calls `init` once, with the proper location of the wasm file.
+
+So to update `tree-sitter`:
+
+- run `npm install --no-save web-tree-sitter` (check if that’s the correct version)
+- `cp node_modules/web-tree-sitter/tree-sitter.wasm assets/`
+- `cp node_modules/web-tree-sitter/tree-sitter-web.d.ts ./tree-sitter.d.ts`
+- edit `tree-sitter.d.ts`
+ - remove the `declare module` scope
+ - remove the `export = Parser`
+ - add `export ` in front of `class Parser`
+ - add `export ` in front of `namespace Parser`
+- `cp node_modules/web-tree-sitter/tree-sitter.js ./`
+- ```bash
+cat << 'EOF' >> tree-sitter.js
+await TreeSitter.init({
+ locateFile(scriptName, scriptDirectory) {
+ return "/assets/tree-sitter.wasm";
+ }
+});
+export const Parser = TreeSitter;
+EOF
+```
diff --git a/assets/tree-sitter-biscuit.wasm b/assets/tree-sitter-biscuit.wasm
index 6ef2259..46cf26b 100755
Binary files a/assets/tree-sitter-biscuit.wasm and b/assets/tree-sitter-biscuit.wasm differ
diff --git a/assets/tree-sitter.wasm b/assets/tree-sitter.wasm
index e9ac537..8f61567 100755
Binary files a/assets/tree-sitter.wasm and b/assets/tree-sitter.wasm differ
diff --git a/demo-rollup/package-lock.json b/demo-rollup/package-lock.json
index 2a9bbfb..a4aedb2 100644
--- a/demo-rollup/package-lock.json
+++ b/demo-rollup/package-lock.json
@@ -21,23 +21,15 @@
},
"..": {
"name": "@biscuit-auth/web-components",
- "version": "0.5.0-alpha1",
+ "version": "0.7.0-alpha.1",
"license": "Apache-2.0",
"dependencies": {
- "@biscuit-auth/biscuit-wasm-support": "^0.4.0-beta1",
- "@codemirror/basic-setup": "^0.19.0",
- "@codemirror/gutter": "^0.19.5",
- "@codemirror/highlight": "^0.19.6",
- "@codemirror/legacy-modes": "^0.19.0",
- "@codemirror/rangeset": "^0.19.2",
- "@codemirror/stream-parser": "^0.19.2",
- "@codemirror/theme-one-dark": "^0.19.1",
+ "@biscuit-auth/biscuit-wasm-support": "0.6.0-alpha.1",
"@typescript-eslint/eslint-plugin": "^5.7.0",
"@typescript-eslint/parser": "^5.7.0",
"lit": "^2.0.0",
"lit-analyzer": "^1.2.1",
- "tslib": "2.3.1",
- "web-tree-sitter": "^0.20.7"
+ "tslib": "2.3.1"
},
"devDependencies": {
"@rollup/plugin-node-resolve": "^13.0.6",
@@ -47,7 +39,7 @@
"eslint": "^8.4.1",
"prettier": "^2.5.1",
"tslib": "2.3.1",
- "typescript": "4.5.2",
+ "typescript": "4.9.5",
"typescript-language-server": "^3.3.1"
}
},
@@ -97,239 +89,6 @@
"version": "0.4.0-beta1",
"license": "Apache-2.0"
},
- "../node_modules/@codemirror/autocomplete": {
- "version": "0.19.15",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/state": "^0.19.4",
- "@codemirror/text": "^0.19.2",
- "@codemirror/tooltip": "^0.19.12",
- "@codemirror/view": "^0.19.0",
- "@lezer/common": "^0.15.0"
- }
- },
- "../node_modules/@codemirror/basic-setup": {
- "version": "0.19.3",
- "license": "MIT",
- "dependencies": {
- "@codemirror/autocomplete": "^0.19.0",
- "@codemirror/closebrackets": "^0.19.0",
- "@codemirror/commands": "^0.19.0",
- "@codemirror/comment": "^0.19.0",
- "@codemirror/fold": "^0.19.0",
- "@codemirror/gutter": "^0.19.0",
- "@codemirror/highlight": "^0.19.0",
- "@codemirror/history": "^0.19.0",
- "@codemirror/language": "^0.19.0",
- "@codemirror/lint": "^0.19.0",
- "@codemirror/matchbrackets": "^0.19.0",
- "@codemirror/rectangular-selection": "^0.19.2",
- "@codemirror/search": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.31"
- }
- },
- "../node_modules/@codemirror/closebrackets": {
- "version": "0.19.2",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.2",
- "@codemirror/text": "^0.19.0",
- "@codemirror/view": "^0.19.44"
- }
- },
- "../node_modules/@codemirror/commands": {
- "version": "0.19.8",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/matchbrackets": "^0.19.0",
- "@codemirror/state": "^0.19.2",
- "@codemirror/text": "^0.19.6",
- "@codemirror/view": "^0.19.22",
- "@lezer/common": "^0.15.0"
- }
- },
- "../node_modules/@codemirror/comment": {
- "version": "0.19.1",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.9",
- "@codemirror/text": "^0.19.0",
- "@codemirror/view": "^0.19.0"
- }
- },
- "../node_modules/@codemirror/fold": {
- "version": "0.19.4",
- "license": "MIT",
- "dependencies": {
- "@codemirror/gutter": "^0.19.0",
- "@codemirror/language": "^0.19.0",
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.22"
- }
- },
- "../node_modules/@codemirror/gutter": {
- "version": "0.19.9",
- "license": "MIT",
- "dependencies": {
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.23"
- }
- },
- "../node_modules/@codemirror/highlight": {
- "version": "0.19.8",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.3",
- "@codemirror/view": "^0.19.39",
- "@lezer/common": "^0.15.0",
- "style-mod": "^4.0.0"
- }
- },
- "../node_modules/@codemirror/history": {
- "version": "0.19.2",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.2",
- "@codemirror/view": "^0.19.0"
- }
- },
- "../node_modules/@codemirror/language": {
- "version": "0.19.10",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0",
- "@codemirror/text": "^0.19.0",
- "@codemirror/view": "^0.19.0",
- "@lezer/common": "^0.15.5",
- "@lezer/lr": "^0.15.0"
- }
- },
- "../node_modules/@codemirror/legacy-modes": {
- "version": "0.19.1",
- "license": "MIT",
- "dependencies": {
- "@codemirror/stream-parser": "^0.19.0"
- }
- },
- "../node_modules/@codemirror/lint": {
- "version": "0.19.6",
- "license": "MIT",
- "dependencies": {
- "@codemirror/gutter": "^0.19.4",
- "@codemirror/panel": "^0.19.0",
- "@codemirror/rangeset": "^0.19.1",
- "@codemirror/state": "^0.19.4",
- "@codemirror/tooltip": "^0.19.16",
- "@codemirror/view": "^0.19.22",
- "crelt": "^1.0.5"
- }
- },
- "../node_modules/@codemirror/matchbrackets": {
- "version": "0.19.4",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.0",
- "@lezer/common": "^0.15.0"
- }
- },
- "../node_modules/@codemirror/panel": {
- "version": "0.19.1",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.0"
- }
- },
- "../node_modules/@codemirror/rangeset": {
- "version": "0.19.9",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0"
- }
- },
- "../node_modules/@codemirror/rectangular-selection": {
- "version": "0.19.2",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0",
- "@codemirror/text": "^0.19.4",
- "@codemirror/view": "^0.19.48"
- }
- },
- "../node_modules/@codemirror/search": {
- "version": "0.19.10",
- "license": "MIT",
- "dependencies": {
- "@codemirror/panel": "^0.19.0",
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.3",
- "@codemirror/text": "^0.19.0",
- "@codemirror/view": "^0.19.34",
- "crelt": "^1.0.5"
- }
- },
- "../node_modules/@codemirror/state": {
- "version": "0.19.9",
- "license": "MIT",
- "dependencies": {
- "@codemirror/text": "^0.19.0"
- }
- },
- "../node_modules/@codemirror/stream-parser": {
- "version": "0.19.9",
- "license": "MIT",
- "dependencies": {
- "@codemirror/highlight": "^0.19.0",
- "@codemirror/language": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/text": "^0.19.0",
- "@lezer/common": "^0.15.0",
- "@lezer/lr": "^0.15.0"
- }
- },
- "../node_modules/@codemirror/text": {
- "version": "0.19.6",
- "license": "MIT"
- },
- "../node_modules/@codemirror/theme-one-dark": {
- "version": "0.19.1",
- "license": "MIT",
- "dependencies": {
- "@codemirror/highlight": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.0"
- }
- },
- "../node_modules/@codemirror/tooltip": {
- "version": "0.19.16",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.0"
- }
- },
- "../node_modules/@codemirror/view": {
- "version": "0.19.48",
- "license": "MIT",
- "dependencies": {
- "@codemirror/rangeset": "^0.19.5",
- "@codemirror/state": "^0.19.3",
- "@codemirror/text": "^0.19.0",
- "style-mod": "^4.0.0",
- "w3c-keyname": "^2.2.4"
- }
- },
"../node_modules/@eslint/eslintrc": {
"version": "1.0.5",
"license": "MIT",
@@ -371,17 +130,6 @@
"version": "1.2.1",
"license": "BSD-3-Clause"
},
- "../node_modules/@lezer/common": {
- "version": "0.15.12",
- "license": "MIT"
- },
- "../node_modules/@lezer/lr": {
- "version": "0.15.8",
- "license": "MIT",
- "dependencies": {
- "@lezer/common": "^0.15.0"
- }
- },
"../node_modules/@lit/reactive-element": {
"version": "1.4.1",
"license": "BSD-3-Clause"
@@ -1834,10 +1582,6 @@
"node": ">=0.10.0"
}
},
- "../node_modules/crelt": {
- "version": "1.0.5",
- "license": "MIT"
- },
"../node_modules/cross-fetch": {
"version": "3.1.5",
"dev": true,
@@ -5187,10 +4931,6 @@
"url": "https://github.com/sponsors/sindresorhus"
}
},
- "../node_modules/style-mod": {
- "version": "4.0.0",
- "license": "MIT"
- },
"../node_modules/supports-color": {
"version": "5.5.0",
"license": "MIT",
@@ -5604,10 +5344,6 @@
"version": "2.1.2",
"license": "MIT"
},
- "../node_modules/w3c-keyname": {
- "version": "2.2.6",
- "license": "MIT"
- },
"../node_modules/web-component-analyzer": {
"version": "1.1.6",
"license": "MIT",
diff --git a/demo/token-generator.html b/demo/token-generator.html
index f99bd45..e7256ee 100644
--- a/demo/token-generator.html
+++ b/demo/token-generator.html
@@ -11,7 +11,7 @@
demo biscuit
-
+
diff --git a/package-lock.json b/package-lock.json
index abafbb3..e662705 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1,28 +1,20 @@
{
"name": "@biscuit-auth/web-components",
- "version": "0.6.1",
+ "version": "0.7.0-beta.1",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"name": "@biscuit-auth/web-components",
- "version": "0.6.1",
+ "version": "0.7.0-beta.1",
"license": "Apache-2.0",
"dependencies": {
- "@biscuit-auth/biscuit-wasm-support": "0.5.1",
- "@codemirror/basic-setup": "^0.19.0",
- "@codemirror/gutter": "^0.19.5",
- "@codemirror/highlight": "^0.19.6",
- "@codemirror/legacy-modes": "^0.19.0",
- "@codemirror/rangeset": "^0.19.2",
- "@codemirror/stream-parser": "^0.19.2",
- "@codemirror/theme-one-dark": "^0.19.1",
+ "@biscuit-auth/biscuit-wasm-support": "0.6.0-beta.1",
"@typescript-eslint/eslint-plugin": "^5.7.0",
"@typescript-eslint/parser": "^5.7.0",
"lit": "^2.0.0",
"lit-analyzer": "^1.2.1",
- "tslib": "2.3.1",
- "web-tree-sitter": "^0.20.7"
+ "tslib": "2.3.1"
},
"devDependencies": {
"@rollup/plugin-node-resolve": "^13.0.6",
@@ -101,244 +93,11 @@
}
},
"node_modules/@biscuit-auth/biscuit-wasm-support": {
- "version": "0.5.1",
- "resolved": "https://registry.npmjs.org/@biscuit-auth/biscuit-wasm-support/-/biscuit-wasm-support-0.5.1.tgz",
- "integrity": "sha512-wjGcgsU57nZ/jOJsKLf373YFUNqES2cCmnlhU86F7E4UDsrWsJPo0YMlAOyFHoIKrlYfGjNFHb0yLl4os1n9dA==",
+ "version": "0.6.0-beta.1",
+ "resolved": "https://registry.npmjs.org/@biscuit-auth/biscuit-wasm-support/-/biscuit-wasm-support-0.6.0-beta.1.tgz",
+ "integrity": "sha512-AnY0t9qfPrN9pvXW696d5WU6Rtrum1w7FMZFbY2/pa3ECppm5t+vCO/yLvOJ3YvvNCMq4f9O7YcorOx3ogNQ3w==",
"license": "Apache-2.0"
},
- "node_modules/@codemirror/autocomplete": {
- "version": "0.19.15",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/state": "^0.19.4",
- "@codemirror/text": "^0.19.2",
- "@codemirror/tooltip": "^0.19.12",
- "@codemirror/view": "^0.19.0",
- "@lezer/common": "^0.15.0"
- }
- },
- "node_modules/@codemirror/basic-setup": {
- "version": "0.19.3",
- "license": "MIT",
- "dependencies": {
- "@codemirror/autocomplete": "^0.19.0",
- "@codemirror/closebrackets": "^0.19.0",
- "@codemirror/commands": "^0.19.0",
- "@codemirror/comment": "^0.19.0",
- "@codemirror/fold": "^0.19.0",
- "@codemirror/gutter": "^0.19.0",
- "@codemirror/highlight": "^0.19.0",
- "@codemirror/history": "^0.19.0",
- "@codemirror/language": "^0.19.0",
- "@codemirror/lint": "^0.19.0",
- "@codemirror/matchbrackets": "^0.19.0",
- "@codemirror/rectangular-selection": "^0.19.2",
- "@codemirror/search": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.31"
- }
- },
- "node_modules/@codemirror/closebrackets": {
- "version": "0.19.2",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.2",
- "@codemirror/text": "^0.19.0",
- "@codemirror/view": "^0.19.44"
- }
- },
- "node_modules/@codemirror/commands": {
- "version": "0.19.8",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/matchbrackets": "^0.19.0",
- "@codemirror/state": "^0.19.2",
- "@codemirror/text": "^0.19.6",
- "@codemirror/view": "^0.19.22",
- "@lezer/common": "^0.15.0"
- }
- },
- "node_modules/@codemirror/comment": {
- "version": "0.19.1",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.9",
- "@codemirror/text": "^0.19.0",
- "@codemirror/view": "^0.19.0"
- }
- },
- "node_modules/@codemirror/fold": {
- "version": "0.19.4",
- "license": "MIT",
- "dependencies": {
- "@codemirror/gutter": "^0.19.0",
- "@codemirror/language": "^0.19.0",
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.22"
- }
- },
- "node_modules/@codemirror/gutter": {
- "version": "0.19.9",
- "license": "MIT",
- "dependencies": {
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.23"
- }
- },
- "node_modules/@codemirror/highlight": {
- "version": "0.19.8",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.3",
- "@codemirror/view": "^0.19.39",
- "@lezer/common": "^0.15.0",
- "style-mod": "^4.0.0"
- }
- },
- "node_modules/@codemirror/history": {
- "version": "0.19.2",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.2",
- "@codemirror/view": "^0.19.0"
- }
- },
- "node_modules/@codemirror/language": {
- "version": "0.19.10",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0",
- "@codemirror/text": "^0.19.0",
- "@codemirror/view": "^0.19.0",
- "@lezer/common": "^0.15.5",
- "@lezer/lr": "^0.15.0"
- }
- },
- "node_modules/@codemirror/legacy-modes": {
- "version": "0.19.1",
- "license": "MIT",
- "dependencies": {
- "@codemirror/stream-parser": "^0.19.0"
- }
- },
- "node_modules/@codemirror/lint": {
- "version": "0.19.6",
- "license": "MIT",
- "dependencies": {
- "@codemirror/gutter": "^0.19.4",
- "@codemirror/panel": "^0.19.0",
- "@codemirror/rangeset": "^0.19.1",
- "@codemirror/state": "^0.19.4",
- "@codemirror/tooltip": "^0.19.16",
- "@codemirror/view": "^0.19.22",
- "crelt": "^1.0.5"
- }
- },
- "node_modules/@codemirror/matchbrackets": {
- "version": "0.19.4",
- "license": "MIT",
- "dependencies": {
- "@codemirror/language": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.0",
- "@lezer/common": "^0.15.0"
- }
- },
- "node_modules/@codemirror/panel": {
- "version": "0.19.1",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.0"
- }
- },
- "node_modules/@codemirror/rangeset": {
- "version": "0.19.9",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0"
- }
- },
- "node_modules/@codemirror/rectangular-selection": {
- "version": "0.19.2",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0",
- "@codemirror/text": "^0.19.4",
- "@codemirror/view": "^0.19.48"
- }
- },
- "node_modules/@codemirror/search": {
- "version": "0.19.10",
- "license": "MIT",
- "dependencies": {
- "@codemirror/panel": "^0.19.0",
- "@codemirror/rangeset": "^0.19.0",
- "@codemirror/state": "^0.19.3",
- "@codemirror/text": "^0.19.0",
- "@codemirror/view": "^0.19.34",
- "crelt": "^1.0.5"
- }
- },
- "node_modules/@codemirror/state": {
- "version": "0.19.9",
- "license": "MIT",
- "dependencies": {
- "@codemirror/text": "^0.19.0"
- }
- },
- "node_modules/@codemirror/stream-parser": {
- "version": "0.19.9",
- "license": "MIT",
- "dependencies": {
- "@codemirror/highlight": "^0.19.0",
- "@codemirror/language": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/text": "^0.19.0",
- "@lezer/common": "^0.15.0",
- "@lezer/lr": "^0.15.0"
- }
- },
- "node_modules/@codemirror/text": {
- "version": "0.19.6",
- "license": "MIT"
- },
- "node_modules/@codemirror/theme-one-dark": {
- "version": "0.19.1",
- "license": "MIT",
- "dependencies": {
- "@codemirror/highlight": "^0.19.0",
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.0"
- }
- },
- "node_modules/@codemirror/tooltip": {
- "version": "0.19.16",
- "license": "MIT",
- "dependencies": {
- "@codemirror/state": "^0.19.0",
- "@codemirror/view": "^0.19.0"
- }
- },
- "node_modules/@codemirror/view": {
- "version": "0.19.48",
- "license": "MIT",
- "dependencies": {
- "@codemirror/rangeset": "^0.19.5",
- "@codemirror/state": "^0.19.3",
- "@codemirror/text": "^0.19.0",
- "style-mod": "^4.0.0",
- "w3c-keyname": "^2.2.4"
- }
- },
"node_modules/@eslint-community/eslint-utils": {
"version": "4.4.0",
"license": "MIT",
@@ -419,17 +178,6 @@
"version": "2.0.3",
"license": "BSD-3-Clause"
},
- "node_modules/@lezer/common": {
- "version": "0.15.12",
- "license": "MIT"
- },
- "node_modules/@lezer/lr": {
- "version": "0.15.8",
- "license": "MIT",
- "dependencies": {
- "@lezer/common": "^0.15.0"
- }
- },
"node_modules/@lit-labs/ssr-dom-shim": {
"version": "1.2.0",
"license": "BSD-3-Clause"
@@ -2029,10 +1777,6 @@
"node": ">=0.10.0"
}
},
- "node_modules/crelt": {
- "version": "1.0.6",
- "license": "MIT"
- },
"node_modules/cross-fetch": {
"version": "3.1.5",
"dev": true,
@@ -5356,10 +5100,6 @@
"url": "https://github.com/sponsors/sindresorhus"
}
},
- "node_modules/style-mod": {
- "version": "4.1.2",
- "license": "MIT"
- },
"node_modules/supports-color": {
"version": "5.5.0",
"license": "MIT",
@@ -5779,10 +5519,6 @@
"version": "2.1.2",
"license": "MIT"
},
- "node_modules/w3c-keyname": {
- "version": "2.2.8",
- "license": "MIT"
- },
"node_modules/web-component-analyzer": {
"version": "1.1.7",
"license": "MIT",
@@ -5808,10 +5544,6 @@
"node": ">=4.2.0"
}
},
- "node_modules/web-tree-sitter": {
- "version": "0.20.8",
- "license": "MIT"
- },
"node_modules/webidl-conversions": {
"version": "7.0.0",
"dev": true,
diff --git a/package.json b/package.json
index cca9114..0f111da 100644
--- a/package.json
+++ b/package.json
@@ -8,7 +8,7 @@
"dist/"
],
"author": "Geoffroy Couprie",
- "version": "0.6.1",
+ "version": "0.7.0-beta.1",
"scripts": {
"start": "wds --node-resolve --open demo/",
"serve": "wds --node-resolve --open demo/ --watch",
@@ -21,20 +21,12 @@
"lint-fix": "eslint src --ext .ts --fix"
},
"dependencies": {
- "@biscuit-auth/biscuit-wasm-support": "0.5.1",
- "@codemirror/basic-setup": "^0.19.0",
- "@codemirror/gutter": "^0.19.5",
- "@codemirror/highlight": "^0.19.6",
- "@codemirror/legacy-modes": "^0.19.0",
- "@codemirror/rangeset": "^0.19.2",
- "@codemirror/stream-parser": "^0.19.2",
- "@codemirror/theme-one-dark": "^0.19.1",
+ "@biscuit-auth/biscuit-wasm-support": "0.6.0-beta.1",
"@typescript-eslint/eslint-plugin": "^5.7.0",
"@typescript-eslint/parser": "^5.7.0",
"lit": "^2.0.0",
"lit-analyzer": "^1.2.1",
- "tslib": "2.3.1",
- "web-tree-sitter": "^0.20.7"
+ "tslib": "2.3.1"
},
"devDependencies": {
"@rollup/plugin-node-resolve": "^13.0.6",
diff --git a/src/bc-datalog-editor-legacy.js b/src/bc-datalog-editor-legacy.js
deleted file mode 100644
index cbaa484..0000000
--- a/src/bc-datalog-editor-legacy.js
+++ /dev/null
@@ -1,326 +0,0 @@
-import { css, html, LitElement } from "lit";
-import { dispatchCustomEvent } from "../src/lib/events.js";
-
-import { keymap, EditorView, Range, Decoration } from "@codemirror/view";
-import { EditorState, StateField, StateEffect } from "@codemirror/state";
-import { basicSetup } from "@codemirror/basic-setup";
-import { history, historyKeymap } from "@codemirror/history";
-import { defaultKeymap } from "@codemirror/commands";
-import { StreamLanguage } from "@codemirror/stream-parser";
-import { simpleMode } from "@codemirror/legacy-modes/mode/simple-mode";
-import { lineNumbers, GutterMarker, gutter } from "@codemirror/gutter";
-import { classHighlightStyle } from "@codemirror/highlight";
-import { RangeSet } from "@codemirror/rangeset";
-
-let biscuit_mode = simpleMode({
- // The start state contains the rules that are initially used
- start: [
- {
- regex: /(allow if|deny if|check if|or|and|<-)\b/,
- token: "keyword",
- },
- { regex: /\/\/.*/, token: "comment" },
- { regex: /\/\*/, token: "comment", next: "comment" },
-
- // predicate name
- { regex: /([A-Za-z_][\w]*)/, token: "keyword", next: "terms" },
-
- { regex: /,/, token: "operator" },
- { regex: /"(?:[^\\]|\\.)*?(?:"|$)/, token: "string" },
- { regex: /\$[A-Za-z_][\w]*/, token: "variable" },
- { regex: /#[A-Za-z_][\w]*/, token: "symbol" },
- { regex: /true|false/, token: "atom" },
- // RFC 3339 date
- {
- regex:
- /(\d+)-(0[1-9]|1[012])-(0[1-9]|[12]\d|3[01])T([01]\d|2[0-3]):([0-5]\d):([0-5]\d|60)(\.\d+)?(([Zz])|([\+|\-]([01]\d|2[0-3]):([0-5]\d)))/,
- token: "atom",
- },
- { regex: /[-+]?\d+/i, token: "number" },
-
- // A next property will cause the mode to move to a different state
- { regex: /[-+*\/=<>!]+/, token: "operator" },
- { regex: /&&|\|\|/, token: "operator" },
- // indent and dedent properties guide autoindentation
- { regex: /[\{\[\(]/, indent: true },
- { regex: /[\}\]\)]/, dedent: true },
- ],
- // The multi-line comment state.
- comment: [
- { regex: /.*?\*\//, token: "comment", next: "start" },
- { regex: /.*/, token: "comment" },
- ],
- terms: [
- { regex: /,/, token: "operator" },
- // The regex matches the token, the token property contains the type
- { regex: /"(?:[^\\]|\\.)*?(?:"|$)/, token: "string" },
- { regex: /\$[A-Za-z_][\w]*/, token: "variable" },
- { regex: /#[A-Za-z_][\w]*/, token: "symbol" },
- { regex: /true|false/, token: "atom" },
- // RFC 3339 date
- {
- regex:
- /(\d+)-(0[1-9]|1[012])-(0[1-9]|[12]\d|3[01])T([01]\d|2[0-3]):([0-5]\d):([0-5]\d|60)(\.\d+)?(([Zz])|([\+|\-]([01]\d|2[0-3]):([0-5]\d)))/,
- token: "atom",
- },
- { regex: /[-+]?\d+/i, token: "number" },
- { regex: /\)/, next: "start" },
- ],
- // The meta property contains global information about the mode. It
- // can contain properties like lineComment, which are supported by
- // all modes, and also directives like dontIndentStates, which are
- // specific to simple modes.
- meta: {
- dontIndentStates: ["comment"],
- lineComment: "//",
- },
-});
-
-// Effects can be attached to transactions to communicate with the extension
-const addSuccessMarks = StateEffect.define(),
- addFailureMarks = StateEffect.define(),
- addParseErrorMarks = StateEffect.define(),
- resetMarks = StateEffect.define();
-
-// This value must be added to the set of extensions to enable this
-const markField = StateField.define({
- // Start with an empty set of decorations
- create() {
- return Decoration.none;
- },
- // This is called whenever the editor updates—it computes the new set
- update(value, tr) {
- // Move the decorations to account for document changes
- value = value.map(tr.changes);
- // If this transaction adds or removes decorations, apply those changes
- for (let effect of tr.effects) {
- if (effect.is(addSuccessMarks))
- value = value.update({ add: effect.value, sort: true });
- else if (effect.is(addFailureMarks))
- value = value.update({ add: effect.value, sort: true });
- else if (effect.is(addParseErrorMarks))
- value = value.update({ add: effect.value, sort: true });
- else if (effect.is(resetMarks))
- value = value.update({ filter: (from, to) => false });
- }
- return value;
- },
- // Indicate that this field provides a set of decorations
- provide: (f) => EditorView.decorations.from(f),
-});
-
-const successMark = Decoration.mark({
- attributes: { style: "background: var(--success-background);" },
-});
-
-const failureMark = Decoration.mark({
- attributes: { style: "background: var(--failure-background);" },
-});
-
-const parseErrorMark = Decoration.mark({
- attributes: { style: "text-decoration: underline red wavy" },
-});
-
-function resetAllMarks(view) {
- view.dispatch({
- effects: resetMarks.of({}),
- });
-}
-
-function setSuccessMark(view, start, end) {
- view.dispatch({
- effects: addSuccessMarks.of([successMark.range(start, end)]),
- });
-}
-
-function setFailureMark(view, start, end) {
- view.dispatch({
- effects: addFailureMarks.of([failureMark.range(start, end)]),
- });
-}
-
-function setParseErrorMark(view, start, end) {
- view.dispatch({
- effects: addParseErrorMarks.of([parseErrorMark.range(start, end)]),
- });
-}
-
-/**
- * TODO DOCS
- */
-export class BcDatalogEditorLegacy extends LitElement {
- static get properties() {
- return {
- readonly: { type: Boolean },
- datalog: { type: String },
- parseErrors: { type: Array },
- markers: { type: Array },
- };
- }
-
- constructor() {
- super();
- this.readonly = this.readonly === true;
- this.parseErrors = [];
- this.markers = [];
- }
-
- _onText(code) {
- this.datalog = code;
- dispatchCustomEvent(this, "update", { code: code });
- }
-
- firstUpdated() {
- const textarea = this.shadowRoot.querySelector("textarea");
-
- let updateListenerExtension = EditorView.updateListener.of((update) => {
- if (update.docChanged) {
- this._onText(htmlEntities(this._cm.state.doc.toString()));
- }
- });
-
- this._cm = new EditorView({
- root: this.renderRoot,
- state: EditorState.create({
- doc: textarea.value,
- extensions: [
- basicSetup,
- lineNumbers(),
- history(),
- EditorView.editable.of(!this.readonly),
- keymap.of([...defaultKeymap, ...historyKeymap]),
- updateListenerExtension,
- StreamLanguage.define(biscuit_mode),
- markField,
- ],
- }),
- });
-
- textarea.parentNode.insertBefore(this._cm.dom, textarea);
- textarea.style.display = "none";
- if (textarea.form)
- textarea.form.addEventListener("submit", () => {
- textarea.value = view.state.doc.toString();
- });
- }
-
- updated(changedProperties) {
- console.log("updated");
- console.log(changedProperties);
- super.updated(changedProperties);
- if (changedProperties.has("datalog")) {
- if (this.datalog != this._cm.state.doc.toString()) {
- this._cm.dispatch({
- changes: {
- from: 0,
- to: this._cm.state.doc.length,
- insert: this.datalog,
- },
- });
- }
- }
-
- resetAllMarks(this._cm);
- if (changedProperties.has("parseErrors")) {
- for (let error of this.parseErrors) {
- setParseErrorMark(this._cm, error.start, error.end);
- }
- }
-
- if (changedProperties.has("markers")) {
- for (let mark of this.markers) {
- if (mark.ok) {
- setSuccessMark(this._cm, mark.start, mark.end);
- } else {
- setFailureMark(this._cm, mark.start, mark.end);
- }
- }
- }
- }
-
- render() {
- return html`
-
-
-
- `;
- }
-
- static get styles() {
- return [
- // language=CSS
- css`
- :host {
- display: block;
- font-size: var(--editor-font, 13px);
- }
-
- @media (prefers-color-scheme: dark) {
- :host {
- background: #131314;
- color: #dee2e6;
- --success-background: rgba(0, 255, 0, 0.3);
- --failure-background: rgba(255, 0, 0, 0.5);
- }
-
- .ͼ2 .cm-gutters {
- background-color: rgb(21 21 21);
- color: rgb(216 216 216);
- border-right: 1px solid rgb(221, 221, 221);
- }
-
- .ͼ2 .cm-activeLineGutter {
- background-color: rgb(71 77 82);
- }
-
- .cm-activeLine {
- background: rgb(69 69 69);
- }
-
- .ͼ2 .cm-activeLine {
- background: rgb(69 69 69);
- }
-
- .ͼa {
- color: rgb(9 161 219);
- }
-
- .ͼd {
- color: rgb(235 23 23);
- }
-
- .ͼc {
- color: rgb(31 178 119);
- }
-
- .ͼl {
- color: rgb(227 101 0);
- }
-
- .cm-line ::selection {
- background: #00000094;
- }
- }
-
- @media (prefers-color-scheme: light) {
- :host {
- background: #fff;
- color: #1d2d35;
- --success-background: rgb(193, 241, 193);
- --failure-background: rgb(255, 162, 162);
- }
- }
- `,
- ];
- }
-}
-
-function htmlEntities(str) {
- return String(str)
- .replace(/&/g, "&")
- .replace(/</g, "<")
- .replace(/>/g, ">")
- .replace(/"/g, '"');
-}
-
-window.customElements.define("bc-datalog-editor-legacy", BcDatalogEditorLegacy);
diff --git a/src/bc-datalog-editor.ts b/src/bc-datalog-editor.ts
index 5e2cedd..a251132 100644
--- a/src/bc-datalog-editor.ts
+++ b/src/bc-datalog-editor.ts
@@ -2,7 +2,7 @@ import { css, html, LitElement, PropertyValues } from "lit";
import { customElement, property, state } from "lit/decorators.js";
import { unsafeHTML } from "lit/directives/unsafe-html.js";
import { ifDefined } from "lit/directives/if-defined.js";
-import { Parser, Language, Query, QueryCapture, Tree } from "../tree-sitter.js";
+import { Parser } from "../tree-sitter.js";
import { dispatchCustomEvent } from "./lib/events.js";
const QUERY = `
@@ -34,6 +34,7 @@ const QUERY = `
"trusting"
"check if"
"check all"
+ "reject if"
"allow if"
"deny if"
] @keyword
@@ -86,15 +87,15 @@ export class BcDatalogEditor extends LitElement {
@property()
readonly = false;
@state()
- _tree: Tree | null = null;
+ _tree: Parser.Tree | null = null;
@state()
- _captures: QueryCapture[] = [];
+ _captures: Parser.QueryCapture[] = [];
@state()
_parser: Parser | null = null;
@state()
- _query: Query | null = null;
+ _query: Parser.Query | null = null;
constructor() {
super();
@@ -109,15 +110,17 @@ export class BcDatalogEditor extends LitElement {
super.connectedCallback();
console.log("connected callback");
console.log("Parser initialized");
- console.log(Language);
- Language.load("/assets/tree-sitter-biscuit.wasm").then((BiscuitDatalog) => {
- console.log("Language initialized");
- const p = new Parser();
- p.setLanguage(BiscuitDatalog);
- this._query = BiscuitDatalog.query(QUERY);
- this._parser = p;
- this.handleInput(this.code);
- });
+ console.log(Parser.Language);
+ Parser.Language.load("/assets/tree-sitter-biscuit.wasm").then(
+ (BiscuitDatalog) => {
+ console.log("Language initialized");
+ const p = new Parser();
+ p.setLanguage(BiscuitDatalog);
+ this._query = BiscuitDatalog.query(QUERY);
+ this._parser = p;
+ this.handleInput(this.code);
+ }
+ );
}
firstUpdated(values: PropertyValues) {
diff --git a/src/bc-snapshot-printer.ts b/src/bc-snapshot-printer.ts
index 01d9d3c..5235375 100644
--- a/src/bc-snapshot-printer.ts
+++ b/src/bc-snapshot-printer.ts
@@ -24,9 +24,6 @@ export class BcSnapshotPrinter extends LitElement {
@property()
readonly = false;
- @property()
- showAuthorizer = false;
-
@property()
showQuery = false;
@@ -61,11 +58,6 @@ export class BcSnapshotPrinter extends LitElement {
this.query = e.detail.code;
}
- _onUpdatedAuthorizer(e: { detail: { code: string } }) {
- if (!this.showAuthorizer) return;
- this.authorizer = e.detail.code;
- }
-
renderSnapshotInput() {
if (this.readonly) {
return html`
@@ -134,12 +126,11 @@ export class BcSnapshotPrinter extends LitElement {
return html`
${this.renderSnapshotInput()}
-
Elapsed time: ${elapsed_micros.toString()}μs
+
Elapsed time: ${this.renderDuration(elapsed_micros)}
Iterations: ${iterations}
Snapshot contents
- ${this.renderAuthorizerInput()}
${this.renderQueryInput()}
${query_result && this.renderQueryResult(query_result)}
@@ -147,17 +138,12 @@ export class BcSnapshotPrinter extends LitElement {
`;
}
- renderAuthorizerInput() {
- if (!this.showAuthorizer) return;
+ renderDuration(micros?: bigint) {
+ if (micros === undefined) {
+ return "n/a";
+ }
- return html`
-
Extra authorizer code
-
- this._onUpdatedAuthorizer(e)}
- >
-
- `;
+ return `${micros}μs`;
}
renderQueryInput() {
diff --git a/src/bc-token-generator.ts b/src/bc-token-generator.ts
index 456dea5..ad4acdf 100644
--- a/src/bc-token-generator.ts
+++ b/src/bc-token-generator.ts
@@ -5,6 +5,7 @@ import { initialize } from "./wasm.js";
import {
generate_token,
generate_keypair,
+ generate_ecdsa_keypair,
get_public_key,
} from "@biscuit-auth/biscuit-wasm-support";
import {
@@ -23,6 +24,9 @@ export class BcTokenGenerator extends LitElement {
@property()
privateKey = "";
+ @state()
+ _alg = "ed25519";
+
@state()
_blocks: Array<{ code: string; externalKey: string | null }> = [];
@@ -53,6 +57,13 @@ export class BcTokenGenerator extends LitElement {
initialize().then(() => (this._started = true));
}
+ _onUpdatedAlg(e: { target: HTMLSelectElement }) {
+ const alg = e.target.selectedOptions[0]?.value;
+ if (alg) {
+ this._alg = alg;
+ }
+ }
+
_onUpdatedBlock(blockId: number, e: { detail: { code: string } }) {
const newBlocks = [...this._blocks];
newBlocks[blockId] = {
@@ -72,8 +83,13 @@ export class BcTokenGenerator extends LitElement {
}
generateKey() {
- const { private_key } = generate_keypair();
- this.privateKey = private_key;
+ if (this._alg == "secp256r1") {
+ const { private_key } = generate_ecdsa_keypair();
+ this.privateKey = private_key;
+ } else {
+ const { private_key } = generate_keypair();
+ this.privateKey = private_key;
+ }
}
addBlock() {
@@ -100,6 +116,10 @@ export class BcTokenGenerator extends LitElement {
+
`;
diff --git a/src/imp.js b/src/imp.js
deleted file mode 100644
index 6717a52..0000000
--- a/src/imp.js
+++ /dev/null
@@ -1,2 +0,0 @@
-//import CodeMirror from "codemirror/src/codemirror.js";
-//window.CodeMirror = CodeMirror;
diff --git a/src/index.ts b/src/index.ts
index ffd5dbb..3b8a548 100644
--- a/src/index.ts
+++ b/src/index.ts
@@ -1,4 +1,3 @@
-import "./imp.js";
import "./bc-token-editor.js";
import "./bc-token-content.js";
import "./bc-authorizer-editor.js";
diff --git a/src/lib/adapters.ts b/src/lib/adapters.ts
index a27c42a..f9f4579 100644
--- a/src/lib/adapters.ts
+++ b/src/lib/adapters.ts
@@ -149,7 +149,7 @@ export type SnapshotInspectionResult = {
export type SnapshotData = {
code: string;
iterations: number;
- elapsed_micros: bigint;
+ elapsed_micros?: bigint;
authorization_result: Result;
query_result?: Result, LogicError>;
};
diff --git a/src/lint.css.js b/src/lint.css.js
deleted file mode 100644
index 8cee6fc..0000000
--- a/src/lint.css.js
+++ /dev/null
@@ -1,79 +0,0 @@
-// language=CSS
-import { css } from "lit";
-
-export const codemirrorLinkStyles = css`
- /* The lint marker gutter */
- .CodeMirror-lint-markers {
- width: 16px;
- }
-
- .CodeMirror-lint-tooltip {
- background-color: #ffd;
- border: 1px solid black;
- border-radius: 4px 4px 4px 4px;
- color: black;
- font-family: monospace;
- font-size: 10pt;
- overflow: hidden;
- padding: 2px 5px;
- position: fixed;
- white-space: pre;
- white-space: pre-wrap;
- z-index: 100;
- max-width: 600px;
- opacity: 0;
- transition: opacity 0.4s;
- -moz-transition: opacity 0.4s;
- -webkit-transition: opacity 0.4s;
- -o-transition: opacity 0.4s;
- -ms-transition: opacity 0.4s;
- }
-
- .CodeMirror-lint-mark {
- background-position: left bottom;
- background-repeat: repeat-x;
- }
-
- .CodeMirror-lint-mark-warning {
- background-image: url("");
- }
-
- .CodeMirror-lint-mark-error {
- background-image: url("");
- }
-
- .CodeMirror-lint-marker {
- background-position: center center;
- background-repeat: no-repeat;
- cursor: pointer;
- display: inline-block;
- height: 16px;
- width: 16px;
- vertical-align: middle;
- position: relative;
- }
-
- .CodeMirror-lint-message {
- padding-left: 18px;
- background-position: top left;
- background-repeat: no-repeat;
- }
-
- .CodeMirror-lint-marker-warning,
- .CodeMirror-lint-message-warning {
- background-image: url("");
- }
-
- .CodeMirror-lint-marker-error,
- .CodeMirror-lint-message-error {
- background-image: url("");
- }
-
- .CodeMirror-lint-marker-multiple {
- background-image: url("");
- background-repeat: no-repeat;
- background-position: right bottom;
- width: 100%;
- height: 100%;
- }
-`;
diff --git a/tree-sitter-biscuit.wasm b/tree-sitter-biscuit.wasm
deleted file mode 100755
index 6ef2259..0000000
Binary files a/tree-sitter-biscuit.wasm and /dev/null differ
diff --git a/tree-sitter.d.ts b/tree-sitter.d.ts
index c5a2ee8..ad41434 100644
--- a/tree-sitter.d.ts
+++ b/tree-sitter.d.ts
@@ -1,20 +1,22 @@
-export class Parser {
+ export class Parser {
/**
- *
+ *
* @param moduleOptions Optional emscripten module-object, see https://emscripten.org/docs/api_reference/module.html
*/
static init(moduleOptions?: object): Promise;
delete(): void;
- parse(input: string | Input, previousTree?: Tree, options?: Options): Tree;
- reset(): void;
- getLanguage(): Language;
- setLanguage(language?: Language | undefined | null): void;
- getLogger(): Logger;
- setLogger(logFunc?: Logger | undefined | null): void;
- setTimeoutMicros(value: number): void;
+ parse(input: string | Parser.Input, oldTree?: Parser.Tree, options?: Parser.Options): Parser.Tree;
+ getIncludedRanges(): Parser.Range[];
getTimeoutMicros(): number;
+ setTimeoutMicros(timeout: number): void;
+ reset(): void;
+ getLanguage(): Parser.Language;
+ setLanguage(language?: Parser.Language | null): void;
+ getLogger(): Parser.Logger;
+ setLogger(logFunc?: Parser.Logger | false | null): void;
}
+ export namespace Parser {
export type Options = {
includedRanges?: Range[];
};
@@ -25,10 +27,10 @@ export class Parser {
};
export type Range = {
- startPosition: Point;
- endPosition: Point;
- startIndex: number;
- endIndex: number;
+ startIndex: number,
+ endIndex: number,
+ startPosition: Point,
+ endPosition: Point
};
export type Edit = {
@@ -46,17 +48,26 @@ export class Parser {
type: "parse" | "lex"
) => void;
- export type Input = (
- startIndex: number,
- startPoint?: Point,
- endIndex?: number,
- ) => string | null;
+ export interface Input {
+ (index: number, position?: Point): string | null;
+ }
export interface SyntaxNode {
- id: number;
tree: Tree;
+ id: number;
+ typeId: number;
+ grammarId: number;
type: string;
+ grammarType: string;
+ isNamed: boolean;
+ isMissing: boolean;
+ isExtra: boolean;
+ hasChanges: boolean;
+ hasError: boolean;
+ isError: boolean;
text: string;
+ parseState: number;
+ nextParseState: number;
startPosition: Point;
endPosition: Point;
startIndex: number;
@@ -74,27 +85,29 @@ export class Parser {
nextNamedSibling: SyntaxNode | null;
previousSibling: SyntaxNode | null;
previousNamedSibling: SyntaxNode | null;
+ descendantCount: number;
- hasChanges(): boolean;
- hasError(): boolean;
equals(other: SyntaxNode): boolean;
- isMissing(): boolean;
- isNamed(): boolean;
toString(): string;
child(index: number): SyntaxNode | null;
namedChild(index: number): SyntaxNode | null;
- childForFieldId(fieldId: number): SyntaxNode | null;
childForFieldName(fieldName: string): SyntaxNode | null;
+ childForFieldId(fieldId: number): SyntaxNode | null;
+ fieldNameForChild(childIndex: number): string | null;
+ childrenForFieldName(fieldName: string): Array;
+ childrenForFieldId(fieldId: number): Array;
+ firstChildForIndex(index: number): SyntaxNode | null;
+ firstNamedChildForIndex(index: number): SyntaxNode | null;
descendantForIndex(index: number): SyntaxNode;
descendantForIndex(startIndex: number, endIndex: number): SyntaxNode;
- descendantsOfType(type: string | Array, startPosition?: Point, endPosition?: Point): Array;
namedDescendantForIndex(index: number): SyntaxNode;
namedDescendantForIndex(startIndex: number, endIndex: number): SyntaxNode;
descendantForPosition(position: Point): SyntaxNode;
descendantForPosition(startPosition: Point, endPosition: Point): SyntaxNode;
namedDescendantForPosition(position: Point): SyntaxNode;
namedDescendantForPosition(startPosition: Point, endPosition: Point): SyntaxNode;
+ descendantsOfType(types: String | Array, startPosition?: Point, endPosition?: Point): Array;
walk(): TreeCursor;
}
@@ -102,6 +115,7 @@ export class Parser {
export interface TreeCursor {
nodeType: string;
nodeTypeId: number;
+ nodeStateId: number;
nodeText: string;
nodeId: number;
nodeIsNamed: boolean;
@@ -110,66 +124,115 @@ export class Parser {
endPosition: Point;
startIndex: number;
endIndex: number;
+ readonly currentNode: SyntaxNode;
+ readonly currentFieldName: string;
+ readonly currentFieldId: number;
+ readonly currentDepth: number;
+ readonly currentDescendantIndex: number;
reset(node: SyntaxNode): void;
+ resetTo(cursor: TreeCursor): void;
delete(): void;
- currentNode(): SyntaxNode;
- currentFieldId(): number;
- currentFieldName(): string;
gotoParent(): boolean;
gotoFirstChild(): boolean;
- gotoFirstChildForIndex(index: number): boolean;
+ gotoLastChild(): boolean;
+ gotoFirstChildForIndex(goalIndex: number): boolean;
+ gotoFirstChildForPosition(goalPosition: Point): boolean;
gotoNextSibling(): boolean;
+ gotoPreviousSibling(): boolean;
+ gotoDescendant(goalDescendantIndex: number): void;
}
export interface Tree {
readonly rootNode: SyntaxNode;
+ rootNodeWithOffset(offsetBytes: number, offsetExtent: Point): SyntaxNode;
copy(): Tree;
delete(): void;
- edit(delta: Edit): Tree;
+ edit(edit: Edit): void;
walk(): TreeCursor;
getChangedRanges(other: Tree): Range[];
- getEditedRange(other: Tree): Range;
+ getIncludedRanges(): Range[];
getLanguage(): Language;
}
- export class Language {
- static load(input: string | Uint8Array): Promise;
-
- readonly version: number;
- readonly fieldCount: number;
- readonly nodeTypeCount: number;
-
- fieldNameForId(fieldId: number): string | null;
- fieldIdForName(fieldName: string): number | null;
- idForNodeType(type: string, named: boolean): number;
- nodeTypeForId(typeId: number): string | null;
- nodeTypeIsNamed(typeId: number): boolean;
- nodeTypeIsVisible(typeId: number): boolean;
- query(source: string): Query;
- }
-
- interface QueryCapture {
+ export interface QueryCapture {
name: string;
+ text?: string;
node: SyntaxNode;
+ setProperties?: { [prop: string]: string | null };
+ assertedProperties?: { [prop: string]: string | null };
+ refutedProperties?: { [prop: string]: string | null };
}
- interface QueryMatch {
+ export interface QueryMatch {
pattern: number;
captures: QueryCapture[];
}
- interface PredicateResult {
+ export type QueryOptions = {
+ startPosition?: Point;
+ endPosition?: Point;
+ startIndex?: number;
+ endIndex?: number;
+ matchLimit?: number;
+ maxStartDepth?: number;
+ timeoutMicros?: number;
+ };
+
+ export interface PredicateResult {
operator: string;
operands: { name: string; type: string }[];
}
export class Query {
captureNames: string[];
+ readonly predicates: { [name: string]: Function }[];
+ readonly setProperties: any[];
+ readonly assertedProperties: any[];
+ readonly refutedProperties: any[];
+ readonly matchLimit: number;
delete(): void;
- matches(node: SyntaxNode, startPosition?: Point, endPosition?: Point): QueryMatch[];
- captures(node: SyntaxNode, startPosition?: Point, endPosition?: Point): QueryCapture[];
+ captures(node: SyntaxNode, options?: QueryOptions): QueryCapture[];
+ matches(node: SyntaxNode, options?: QueryOptions): QueryMatch[];
predicatesForPattern(patternIndex: number): PredicateResult[];
+ disableCapture(captureName: string): void;
+ disablePattern(patternIndex: number): void;
+ isPatternGuaranteedAtStep(byteOffset: number): boolean;
+ isPatternRooted(patternIndex: number): boolean;
+ isPatternNonLocal(patternIndex: number): boolean;
+ startIndexForPattern(patternIndex: number): number;
+ didExceedMatchLimit(): boolean;
}
+
+ class Language {
+ static load(input: string | Uint8Array): Promise;
+
+ readonly version: number;
+ readonly fieldCount: number;
+ readonly stateCount: number;
+ readonly nodeTypeCount: number;
+
+ fieldNameForId(fieldId: number): string | null;
+ fieldIdForName(fieldName: string): number | null;
+ idForNodeType(type: string, named: boolean): number;
+ nodeTypeForId(typeId: number): string | null;
+ nodeTypeIsNamed(typeId: number): boolean;
+ nodeTypeIsVisible(typeId: number): boolean;
+ nextState(stateId: number, typeId: number): number;
+ query(source: string): Query;
+ lookaheadIterator(stateId: number): LookaheadIterable | null;
+ }
+
+ export class LookaheadIterable {
+ readonly language: Language;
+ readonly currentTypeId: number;
+ readonly currentType: string;
+
+ delete(): void;
+ reset(language: Language, stateId: number): boolean;
+ resetState(stateId: number): boolean;
+ [Symbol.iterator](): Iterator;
+ }
+ }
diff --git a/tree-sitter.js b/tree-sitter.js
index 34396a3..43a9714 100644
--- a/tree-sitter.js
+++ b/tree-sitter.js
@@ -1,1989 +1,3284 @@
-var Module = void 0 !== Module ? Module : {}
+// include: shell.js
+// The Module object: Our interface to the outside world. We import
+// and export values on it. There are various ways Module can be used:
+// 1. Not defined. We create it here
+// 2. A function parameter, function(moduleArg) => Promise
+// 3. pre-run appended it, var Module = {}; ..generated code..
+// 4. External script tag defines var Module.
+// We need to check if Module already exists (e.g. case 3 above).
+// Substitution will be replaced with actual code on later stage of the build,
+// this way Closure Compiler will not mangle it (e.g. case 4. above).
+// Note that if you want to run closure, and also to use Module
+// after the generated code, you will need to define var Module = {};
+// before the code. Then that object will be used in the code, and you
+// can continue to use Module afterwards as well.
+var Module = typeof Module != "undefined" ? Module : {};
+
+// Determine the runtime environment we are in. You can customize this by
+// setting the ENVIRONMENT setting at compile time (see settings.js).
+// Attempt to auto-detect the environment
+var ENVIRONMENT_IS_WEB = typeof window == "object";
+
+var ENVIRONMENT_IS_WORKER = typeof importScripts == "function";
+
+// N.b. Electron.js environment is simultaneously a NODE-environment, but
+// also a web environment.
+var ENVIRONMENT_IS_NODE = typeof process == "object" && typeof process.versions == "object" && typeof process.versions.node == "string";
+
+if (ENVIRONMENT_IS_NODE) {}
+
+// --pre-jses are emitted after the Module integration code, so that they can
+// refer to Module (if they choose; they can also define Module)
+// include: /src/lib/binding_web/prefix.js
var TreeSitter = function() {
- var e, t = "object" == typeof window ? { currentScript: window.document.currentScript } : null;
-
+ var initPromise;
+ var document = typeof window == "object" ? {
+ currentScript: window.document.currentScript
+ } : null;
class Parser {
- constructor () {
+ constructor() {
this.initialize();
}
-
- initialize () {
+ initialize() {
throw new Error("cannot construct a Parser before calling `init()`");
}
-
- static init (r) {
- return e || (Module = Object.assign({}, Module, r), e = new Promise(e => {
- var r, n = {};
- for (r in Module) Module.hasOwnProperty(r) && (n[r] = Module[r]);
- var o, s, _ = [], a = "./this.program", i = function(e, t) {
- throw t;
- }, u = !1, l = !1;
- u = "object" == typeof window, l = "function" == typeof importScripts, o = "object" == typeof process && "object" == typeof process.versions && "string" == typeof process.versions.node, s = !u && !o && !l;
- var d, c, m, f, p, h = "";
- o ? (h = l ? require("path").dirname(h) + "/" : __dirname + "/", d = function(e, t) {
- return f || (f = require("fs")), p || (p = require("path")), e = p.normalize(e), f.readFileSync(e, t ? null : "utf8");
- }, m = function(e) {
- var t = d(e, !0);
- return t.buffer || (t = new Uint8Array(t)), k(t.buffer), t;
- }, process.argv.length > 1 && (a = process.argv[1].replace(/\\/g, "/")), _ = process.argv.slice(2), "undefined" != typeof module && (module.exports = Module), i = function(e) {
- process.exit(e);
- }, Module.inspect = function() {
- return "[Emscripten Module object]";
- }) : s ? ("undefined" != typeof read && (d = function(e) {
- return read(e);
- }), m = function(e) {
- var t;
- return "function" == typeof readbuffer ? new Uint8Array(readbuffer(e)) : (k("object" == typeof (t = read(e, "binary"))), t);
- }, "undefined" != typeof scriptArgs ? _ = scriptArgs : void 0 !== arguments && (_ = arguments), "function" == typeof quit && (i = function(e) {
- quit(e);
- }), "undefined" != typeof print && ("undefined" == typeof console && (console = {}), console.log = print, console.warn = console.error = "undefined" != typeof printErr ? printErr : print)) : (u || l) && (l ? h = self.location.href : void 0 !== t && t.currentScript && (h = t.currentScript.src), h = 0 !== h.indexOf("blob:") ? h.substr(0, h.lastIndexOf("/") + 1) : "", d = function(e) {
- var t = new XMLHttpRequest;
- return t.open("GET", e, !1), t.send(null), t.responseText;
- }, l && (m = function(e) {
- var t = new XMLHttpRequest;
- return t.open("GET", e, !1), t.responseType = "arraybuffer", t.send(null), new Uint8Array(t.response);
- }), c = function(e, t, r) {
- var n = new XMLHttpRequest;
- n.open("GET", e, !0), n.responseType = "arraybuffer", n.onload = function() {
- 200 == n.status || 0 == n.status && n.response ? t(n.response) : r();
- }, n.onerror = r, n.send(null);
- });
- Module.print || console.log.bind(console);
- var g = Module.printErr || console.warn.bind(console);
- for (r in n) n.hasOwnProperty(r) && (Module[r] = n[r]);
- n = null, Module.arguments && (_ = Module.arguments), Module.thisProgram && (a = Module.thisProgram), Module.quit && (i = Module.quit);
- var w = 16;
- var M, y = [];
-
- function b (e, t) {
- if (!M) {
- M = new WeakMap;
- for (var r = 0; r < K.length; r++) {
- var n = K.get(r);
- n && M.set(n, r);
- }
- }
- if (M.has(e)) {
- return M.get(e);
+ static init(moduleOptions) {
+ if (initPromise) return initPromise;
+ Module = Object.assign({}, Module, moduleOptions);
+ return initPromise = new Promise(resolveInitPromise => {
+ // end include: /src/lib/binding_web/prefix.js
+ // Sometimes an existing Module object exists with properties
+ // meant to overwrite the default module functionality. Here
+ // we collect those properties and reapply _after_ we configure
+ // the current environment's defaults to avoid having to be so
+ // defensive during initialization.
+ var moduleOverrides = Object.assign({}, Module);
+ var arguments_ = [];
+ var thisProgram = "./this.program";
+ var quit_ = (status, toThrow) => {
+ throw toThrow;
+ };
+ // `/` should be present at the end if `scriptDirectory` is not empty
+ var scriptDirectory = "";
+ function locateFile(path) {
+ if (Module["locateFile"]) {
+ return Module["locateFile"](path, scriptDirectory);
}
- var o = function() {
- if (y.length) {
- return y.pop();
- }
- try {
- K.grow(1);
- }
- catch (e) {
- if (!(e instanceof RangeError)) {
- throw e;
- }
- throw"Unable to grow wasm table. Set ALLOW_TABLE_GROWTH.";
- }
- return K.length - 1;
- }();
- try {
- K.set(o, e);
- }
- catch (r) {
- if (!(r instanceof TypeError)) {
- throw r;
- }
- var s = function(e, t) {
- if ("function" == typeof WebAssembly.Function) {
- for (var r = { i: "i32", j: "i64", f: "f32", d: "f64" }, n = {
- parameters: [],
- results: "v" == t[0] ? [] : [r[t[0]]]
- }, o = 1; o < t.length; ++o) n.parameters.push(r[t[o]]);
- return new WebAssembly.Function(n, e);
+ return scriptDirectory + path;
+ }
+ // Hooks that are implemented differently in different runtime environments.
+ var readAsync, readBinary;
+ if (ENVIRONMENT_IS_NODE) {
+ // These modules will usually be used on Node.js. Load them eagerly to avoid
+ // the complexity of lazy-loading.
+ var fs = require("fs");
+ var nodePath = require("path");
+ scriptDirectory = __dirname + "/";
+ // include: node_shell_read.js
+ readBinary = filename => {
+ // We need to re-wrap `file://` strings to URLs. Normalizing isn't
+ // necessary in that case, the path should already be absolute.
+ filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename);
+ var ret = fs.readFileSync(filename);
+ return ret;
+ };
+ readAsync = (filename, binary = true) => {
+ // See the comment in the `readBinary` function.
+ filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename);
+ return new Promise((resolve, reject) => {
+ fs.readFile(filename, binary ? undefined : "utf8", (err, data) => {
+ if (err) reject(err); else resolve(binary ? data.buffer : data);
+ });
+ });
+ };
+ // end include: node_shell_read.js
+ if (!Module["thisProgram"] && process.argv.length > 1) {
+ thisProgram = process.argv[1].replace(/\\/g, "/");
+ }
+ arguments_ = process.argv.slice(2);
+ if (typeof module != "undefined") {
+ module["exports"] = Module;
+ }
+ quit_ = (status, toThrow) => {
+ process.exitCode = status;
+ throw toThrow;
+ };
+ } else // Note that this includes Node.js workers when relevant (pthreads is enabled).
+ // Node.js workers are detected as a combination of ENVIRONMENT_IS_WORKER and
+ // ENVIRONMENT_IS_NODE.
+ if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) {
+ if (ENVIRONMENT_IS_WORKER) {
+ // Check worker, not web, since window could be polyfilled
+ scriptDirectory = self.location.href;
+ } else if (typeof document != "undefined" && document.currentScript) {
+ // web
+ scriptDirectory = document.currentScript.src;
+ }
+ // blob urls look like blob:http://site.com/etc/etc and we cannot infer anything from them.
+ // otherwise, slice off the final part of the url to find the script directory.
+ // if scriptDirectory does not contain a slash, lastIndexOf will return -1,
+ // and scriptDirectory will correctly be replaced with an empty string.
+ // If scriptDirectory contains a query (starting with ?) or a fragment (starting with #),
+ // they are removed because they could contain a slash.
+ if (scriptDirectory.startsWith("blob:")) {
+ scriptDirectory = "";
+ } else {
+ scriptDirectory = scriptDirectory.substr(0, scriptDirectory.replace(/[?#].*/, "").lastIndexOf("/") + 1);
+ }
+ {
+ // include: web_or_worker_shell_read.js
+ if (ENVIRONMENT_IS_WORKER) {
+ readBinary = url => {
+ var xhr = new XMLHttpRequest;
+ xhr.open("GET", url, false);
+ xhr.responseType = "arraybuffer";
+ xhr.send(null);
+ return new Uint8Array(/** @type{!ArrayBuffer} */ (xhr.response));
+ };
+ }
+ readAsync = url => {
+ // Fetch has some additional restrictions over XHR, like it can't be used on a file:// url.
+ // See https://github.com/github/fetch/pull/92#issuecomment-140665932
+ // Cordova or Electron apps are typically loaded from a file:// url.
+ // So use XHR on webview if URL is a file URL.
+ if (isFileURI(url)) {
+ return new Promise((reject, resolve) => {
+ var xhr = new XMLHttpRequest;
+ xhr.open("GET", url, true);
+ xhr.responseType = "arraybuffer";
+ xhr.onload = () => {
+ if (xhr.status == 200 || (xhr.status == 0 && xhr.response)) {
+ // file URLs can return 0
+ resolve(xhr.response);
+ }
+ reject(xhr.status);
+ };
+ xhr.onerror = reject;
+ xhr.send(null);
+ });
}
- var s = [1, 0, 1, 96], _ = t.slice(0, 1), a = t.slice(1), i = { i: 127, j: 126, f: 125, d: 124 };
- for (s.push(a.length), o = 0; o < a.length; ++o) s.push(i[a[o]]);
- "v" == _ ? s.push(0) : s = s.concat([1, i[_]]), s[1] = s.length - 2;
- var u = new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0].concat(s, [2, 7, 1, 1, 101, 1, 102, 0, 0, 7, 5, 1, 1, 102, 0, 0])),
- l = new WebAssembly.Module(u);
- return new WebAssembly.Instance(l, { e: { f: e } }).exports.f;
- }(e, t);
- K.set(o, s);
- }
- return M.set(e, o), o;
+ return fetch(url, {
+ credentials: "same-origin"
+ }).then(response => {
+ if (response.ok) {
+ return response.arrayBuffer();
+ }
+ return Promise.reject(new Error(response.status + " : " + response.url));
+ });
+ };
+ }
+ } else // end include: web_or_worker_shell_read.js
+ {}
+ var out = Module["print"] || console.log.bind(console);
+ var err = Module["printErr"] || console.error.bind(console);
+ // Merge back in the overrides
+ Object.assign(Module, moduleOverrides);
+ // Free the object hierarchy contained in the overrides, this lets the GC
+ // reclaim data used.
+ moduleOverrides = null;
+ // Emit code to handle expected values on the Module object. This applies Module.x
+ // to the proper local x. This has two benefits: first, we only emit it if it is
+ // expected to arrive, and second, by using a local everywhere else that can be
+ // minified.
+ if (Module["arguments"]) arguments_ = Module["arguments"];
+ if (Module["thisProgram"]) thisProgram = Module["thisProgram"];
+ if (Module["quit"]) quit_ = Module["quit"];
+ // perform assertions in shell.js after we set up out() and err(), as otherwise if an assertion fails it cannot print the message
+ // end include: shell.js
+ // include: preamble.js
+ // === Preamble library stuff ===
+ // Documentation for the public APIs defined in this file must be updated in:
+ // site/source/docs/api_reference/preamble.js.rst
+ // A prebuilt local version of the documentation is available at:
+ // site/build/text/docs/api_reference/preamble.js.txt
+ // You can also build docs locally as HTML or other formats in site/
+ // An online HTML version (which may be of a different version of Emscripten)
+ // is up at http://kripken.github.io/emscripten-site/docs/api_reference/preamble.js.html
+ var dynamicLibraries = Module["dynamicLibraries"] || [];
+ var wasmBinary;
+ if (Module["wasmBinary"]) wasmBinary = Module["wasmBinary"];
+ // Wasm globals
+ var wasmMemory;
+ //========================================
+ // Runtime essentials
+ //========================================
+ // whether we are quitting the application. no code should run after this.
+ // set in exit() and abort()
+ var ABORT = false;
+ // set by exit() and abort(). Passed to 'onExit' handler.
+ // NOTE: This is also used as the process return code code in shell environments
+ // but only when noExitRuntime is false.
+ var EXITSTATUS;
+ // Memory management
+ var /** @type {!Int8Array} */ HEAP8, /** @type {!Uint8Array} */ HEAPU8, /** @type {!Int16Array} */ HEAP16, /** @type {!Uint16Array} */ HEAPU16, /** @type {!Int32Array} */ HEAP32, /** @type {!Uint32Array} */ HEAPU32, /** @type {!Float32Array} */ HEAPF32, /** @type {!Float64Array} */ HEAPF64;
+ var HEAP_DATA_VIEW;
+ // include: runtime_shared.js
+ function updateMemoryViews() {
+ var b = wasmMemory.buffer;
+ Module["HEAP_DATA_VIEW"] = HEAP_DATA_VIEW = new DataView(b);
+ Module["HEAP8"] = HEAP8 = new Int8Array(b);
+ Module["HEAP16"] = HEAP16 = new Int16Array(b);
+ Module["HEAPU8"] = HEAPU8 = new Uint8Array(b);
+ Module["HEAPU16"] = HEAPU16 = new Uint16Array(b);
+ Module["HEAP32"] = HEAP32 = new Int32Array(b);
+ Module["HEAPU32"] = HEAPU32 = new Uint32Array(b);
+ Module["HEAPF32"] = HEAPF32 = new Float32Array(b);
+ Module["HEAPF64"] = HEAPF64 = new Float64Array(b);
}
-
- var v, E = function(e) {
- e;
- }, S = Module.dynamicLibraries || [];
- Module.wasmBinary && (v = Module.wasmBinary);
- var I, A = Module.noExitRuntime || !0;
-
- function x (e, t, r, n) {
- switch ("*" === (r = r || "i8").charAt(r.length - 1) && (r = "i32"), r) {
- case"i1":
- case"i8":
- q[e >> 0] = t;
- break;
- case"i16":
- R[e >> 1] = t;
- break;
- case"i32":
- W[e >> 2] = t;
- break;
- case"i64":
- ie = [t >>> 0, (ae = t, +Math.abs(ae) >= 1 ? ae > 0 ? (0 | Math.min(+Math.floor(ae / 4294967296), 4294967295)) >>> 0 : ~~+Math.ceil((ae - +(~~ae >>> 0)) / 4294967296) >>> 0 : 0)], W[e >> 2] = ie[0], W[e + 4 >> 2] = ie[1];
- break;
- case"float":
- L[e >> 2] = t;
- break;
- case"double":
- O[e >> 3] = t;
- break;
- default:
- se("invalid type for setValue: " + r);
- }
+ // end include: runtime_shared.js
+ // In non-standalone/normal mode, we create the memory here.
+ // include: runtime_init_memory.js
+ // Create the wasm memory. (Note: this only applies if IMPORTED_MEMORY is defined)
+ // check for full engine support (use string 'subarray' to avoid closure compiler confusion)
+ if (Module["wasmMemory"]) {
+ wasmMemory = Module["wasmMemory"];
+ } else {
+ var INITIAL_MEMORY = Module["INITIAL_MEMORY"] || 33554432;
+ wasmMemory = new WebAssembly.Memory({
+ "initial": INITIAL_MEMORY / 65536,
+ // In theory we should not need to emit the maximum if we want "unlimited"
+ // or 4GB of memory, but VMs error on that atm, see
+ // https://github.com/emscripten-core/emscripten/issues/14130
+ // And in the pthreads case we definitely need to emit a maximum. So
+ // always emit one.
+ "maximum": 2147483648 / 65536
+ });
}
-
- function N (e, t, r) {
- switch ("*" === (t = t || "i8").charAt(t.length - 1) && (t = "i32"), t) {
- case"i1":
- case"i8":
- return q[e >> 0];
- case"i16":
- return R[e >> 1];
- case"i32":
- case"i64":
- return W[e >> 2];
- case"float":
- return L[e >> 2];
- case"double":
- return O[e >> 3];
- default:
- se("invalid type for getValue: " + t);
- }
- return null;
+ updateMemoryViews();
+ // end include: runtime_init_memory.js
+ // include: runtime_stack_check.js
+ // end include: runtime_stack_check.js
+ // include: runtime_assertions.js
+ // end include: runtime_assertions.js
+ var __ATPRERUN__ = [];
+ // functions called before the runtime is initialized
+ var __ATINIT__ = [];
+ // functions called during startup
+ var __ATMAIN__ = [];
+ // functions called during shutdown
+ var __ATPOSTRUN__ = [];
+ // functions called after the main() is called
+ var __RELOC_FUNCS__ = [];
+ var runtimeInitialized = false;
+ function preRun() {
+ if (Module["preRun"]) {
+ if (typeof Module["preRun"] == "function") Module["preRun"] = [ Module["preRun"] ];
+ while (Module["preRun"].length) {
+ addOnPreRun(Module["preRun"].shift());
+ }
+ }
+ callRuntimeCallbacks(__ATPRERUN__);
}
-
- "object" != typeof WebAssembly && se("no native wasm support detected");
- var P = !1;
-
- function k (e, t) {
- e || se("Assertion failed: " + t);
+ function initRuntime() {
+ runtimeInitialized = true;
+ callRuntimeCallbacks(__RELOC_FUNCS__);
+ callRuntimeCallbacks(__ATINIT__);
}
-
- var F = 1;
- var C, q, T, R, W, L, O, j = "undefined" != typeof TextDecoder ? new TextDecoder("utf8") : void 0;
-
- function $ (e, t, r) {
- for (var n = t + r, o = t; e[o] && !(o >= n);) ++o;
- if (o - t > 16 && e.subarray && j) {
- return j.decode(e.subarray(t, o));
- }
- for (var s = ""; t < o;) {
- var _ = e[t++];
- if (128 & _) {
- var a = 63 & e[t++];
- if (192 != (224 & _)) {
- var i = 63 & e[t++];
- if ((_ = 224 == (240 & _) ? (15 & _) << 12 | a << 6 | i : (7 & _) << 18 | a << 12 | i << 6 | 63 & e[t++]) < 65536) {
- s += String.fromCharCode(_);
- }
- else {
- var u = _ - 65536;
- s += String.fromCharCode(55296 | u >> 10, 56320 | 1023 & u);
- }
- }
- else {
- s += String.fromCharCode((31 & _) << 6 | a);
- }
- }
- else {
- s += String.fromCharCode(_);
+ function preMain() {
+ callRuntimeCallbacks(__ATMAIN__);
+ }
+ function postRun() {
+ if (Module["postRun"]) {
+ if (typeof Module["postRun"] == "function") Module["postRun"] = [ Module["postRun"] ];
+ while (Module["postRun"].length) {
+ addOnPostRun(Module["postRun"].shift());
}
}
- return s;
+ callRuntimeCallbacks(__ATPOSTRUN__);
}
-
- function Z (e, t) {
- return e ? $(T, e, t) : "";
+ function addOnPreRun(cb) {
+ __ATPRERUN__.unshift(cb);
}
-
- function D (e, t, r, n) {
- if (!(n > 0)) {
- return 0;
- }
- for (var o = r, s = r + n - 1, _ = 0; _ < e.length; ++_) {
- var a = e.charCodeAt(_);
- if (a >= 55296 && a <= 57343) {
- a = 65536 + ((1023 & a) << 10) | 1023 & e.charCodeAt(++_);
- }
- if (a <= 127) {
- if (r >= s) {
- break;
- }
- t[r++] = a;
- }
- else if (a <= 2047) {
- if (r + 1 >= s) {
- break;
- }
- t[r++] = 192 | a >> 6, t[r++] = 128 | 63 & a;
- }
- else if (a <= 65535) {
- if (r + 2 >= s) {
- break;
- }
- t[r++] = 224 | a >> 12, t[r++] = 128 | a >> 6 & 63, t[r++] = 128 | 63 & a;
+ function addOnInit(cb) {
+ __ATINIT__.unshift(cb);
+ }
+ function addOnPostRun(cb) {
+ __ATPOSTRUN__.unshift(cb);
+ }
+ // include: runtime_math.js
+ // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/imul
+ // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/fround
+ // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/clz32
+ // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/trunc
+ // end include: runtime_math.js
+ // A counter of dependencies for calling run(). If we need to
+ // do asynchronous work before running, increment this and
+ // decrement it. Incrementing must happen in a place like
+ // Module.preRun (used by emcc to add file preloading).
+ // Note that you can add dependencies in preRun, even though
+ // it happens right before run - run will be postponed until
+ // the dependencies are met.
+ var runDependencies = 0;
+ var runDependencyWatcher = null;
+ var dependenciesFulfilled = null;
+ // overridden to take different actions when all run dependencies are fulfilled
+ function getUniqueRunDependency(id) {
+ return id;
+ }
+ function addRunDependency(id) {
+ runDependencies++;
+ Module["monitorRunDependencies"]?.(runDependencies);
+ }
+ function removeRunDependency(id) {
+ runDependencies--;
+ Module["monitorRunDependencies"]?.(runDependencies);
+ if (runDependencies == 0) {
+ if (runDependencyWatcher !== null) {
+ clearInterval(runDependencyWatcher);
+ runDependencyWatcher = null;
}
- else {
- if (r + 3 >= s) {
- break;
- }
- t[r++] = 240 | a >> 18, t[r++] = 128 | a >> 12 & 63, t[r++] = 128 | a >> 6 & 63, t[r++] = 128 | 63 & a;
+ if (dependenciesFulfilled) {
+ var callback = dependenciesFulfilled;
+ dependenciesFulfilled = null;
+ callback();
}
}
- return t[r] = 0, r - o;
}
-
- function z (e, t, r) {
- return D(e, T, t, r);
+ /** @param {string|number=} what */ function abort(what) {
+ Module["onAbort"]?.(what);
+ what = "Aborted(" + what + ")";
+ // TODO(sbc): Should we remove printing and leave it up to whoever
+ // catches the exception?
+ err(what);
+ ABORT = true;
+ EXITSTATUS = 1;
+ what += ". Build with -sASSERTIONS for more info.";
+ // Use a wasm runtime error, because a JS error might be seen as a foreign
+ // exception, which means we'd run destructors on it. We need the error to
+ // simply make the program stop.
+ // FIXME This approach does not work in Wasm EH because it currently does not assume
+ // all RuntimeErrors are from traps; it decides whether a RuntimeError is from
+ // a trap or not based on a hidden field within the object. So at the moment
+ // we don't have a way of throwing a wasm trap from JS. TODO Make a JS API that
+ // allows this in the wasm spec.
+ // Suppress closure compiler warning here. Closure compiler's builtin extern
+ // definition for WebAssembly.RuntimeError claims it takes no arguments even
+ // though it can.
+ // TODO(https://github.com/google/closure-compiler/pull/3913): Remove if/when upstream closure gets fixed.
+ /** @suppress {checkTypes} */ var e = new WebAssembly.RuntimeError(what);
+ // Throw the error whether or not MODULARIZE is set because abort is used
+ // in code paths apart from instantiation where an exception is expected
+ // to be thrown when abort is called.
+ throw e;
}
-
- function U (e) {
- for (var t = 0, r = 0; r < e.length; ++r) {
- var n = e.charCodeAt(r);
- n >= 55296 && n <= 57343 && (n = 65536 + ((1023 & n) << 10) | 1023 & e.charCodeAt(++r)), n <= 127 ? ++t : t += n <= 2047 ? 2 : n <= 65535 ? 3 : 4;
- }
- return t;
+ // include: memoryprofiler.js
+ // end include: memoryprofiler.js
+ // include: URIUtils.js
+ // Prefix of data URIs emitted by SINGLE_FILE and related options.
+ var dataURIPrefix = "data:application/octet-stream;base64,";
+ /**
+ * Indicates whether filename is a base64 data URI.
+ * @noinline
+ */ var isDataURI = filename => filename.startsWith(dataURIPrefix);
+ /**
+ * Indicates whether filename is delivered via file protocol (as opposed to http/https)
+ * @noinline
+ */ var isFileURI = filename => filename.startsWith("file://");
+ // end include: URIUtils.js
+ // include: runtime_exceptions.js
+ // end include: runtime_exceptions.js
+ function findWasmBinary() {
+ var f = "tree-sitter.wasm";
+ if (!isDataURI(f)) {
+ return locateFile(f);
+ }
+ return f;
}
-
- function H (e) {
- var t = U(e) + 1, r = Be(t);
- return D(e, q, r, t), r;
+ var wasmBinaryFile;
+ function getBinarySync(file) {
+ if (file == wasmBinaryFile && wasmBinary) {
+ return new Uint8Array(wasmBinary);
+ }
+ if (readBinary) {
+ return readBinary(file);
+ }
+ throw "both async and sync fetching of the wasm failed";
}
-
- function G (e) {
- C = e, Module.HEAP8 = q = new Int8Array(e), Module.HEAP16 = R = new Int16Array(e), Module.HEAP32 = W = new Int32Array(e), Module.HEAPU8 = T = new Uint8Array(e), Module.HEAPU16 = new Uint16Array(e), Module.HEAPU32 = new Uint32Array(e), Module.HEAPF32 = L = new Float32Array(e), Module.HEAPF64 = O = new Float64Array(e);
+ function getBinaryPromise(binaryFile) {
+ // If we don't have the binary yet, load it asynchronously using readAsync.
+ if (!wasmBinary) {
+ // Fetch the binary using readAsync
+ return readAsync(binaryFile).then(response => new Uint8Array(/** @type{!ArrayBuffer} */ (response)), // Fall back to getBinarySync if readAsync fails
+ () => getBinarySync(binaryFile));
+ }
+ // Otherwise, getBinarySync should be able to get it synchronously
+ return Promise.resolve().then(() => getBinarySync(binaryFile));
}
-
- var B = Module.INITIAL_MEMORY || 33554432;
- (I = Module.wasmMemory ? Module.wasmMemory : new WebAssembly.Memory({
- initial: B / 65536,
- maximum: 32768
- })) && (C = I.buffer), B = C.byteLength, G(C);
- var K = new WebAssembly.Table({ initial: 20, element: "anyfunc" }), V = [], X = [], Q = [], J = [], Y = !1;
- var ee = 0, te = null, re = null;
-
- function ne (e) {
- ee++, Module.monitorRunDependencies && Module.monitorRunDependencies(ee);
+ function instantiateArrayBuffer(binaryFile, imports, receiver) {
+ return getBinaryPromise(binaryFile).then(binary => WebAssembly.instantiate(binary, imports)).then(receiver, reason => {
+ err(`failed to asynchronously prepare wasm: ${reason}`);
+ abort(reason);
+ });
}
-
- function oe (e) {
- if (ee--, Module.monitorRunDependencies && Module.monitorRunDependencies(ee), 0 == ee && (null !== te && (clearInterval(te), te = null), re)) {
- var t = re;
- re = null, t();
+ function instantiateAsync(binary, binaryFile, imports, callback) {
+ if (!binary && typeof WebAssembly.instantiateStreaming == "function" && !isDataURI(binaryFile) && // Don't use streaming for file:// delivered objects in a webview, fetch them synchronously.
+ !isFileURI(binaryFile) && // Avoid instantiateStreaming() on Node.js environment for now, as while
+ // Node.js v18.1.0 implements it, it does not have a full fetch()
+ // implementation yet.
+ // Reference:
+ // https://github.com/emscripten-core/emscripten/pull/16917
+ !ENVIRONMENT_IS_NODE && typeof fetch == "function") {
+ return fetch(binaryFile, {
+ credentials: "same-origin"
+ }).then(response => {
+ // Suppress closure warning here since the upstream definition for
+ // instantiateStreaming only allows Promise rather than
+ // an actual Response.
+ // TODO(https://github.com/google/closure-compiler/pull/3913): Remove if/when upstream closure is fixed.
+ /** @suppress {checkTypes} */ var result = WebAssembly.instantiateStreaming(response, imports);
+ return result.then(callback, function(reason) {
+ // We expect the most common failure cause to be a bad MIME type for the binary,
+ // in which case falling back to ArrayBuffer instantiation should work.
+ err(`wasm streaming compile failed: ${reason}`);
+ err("falling back to ArrayBuffer instantiation");
+ return instantiateArrayBuffer(binaryFile, imports, callback);
+ });
+ });
}
+ return instantiateArrayBuffer(binaryFile, imports, callback);
}
-
- function se (e) {
- throw Module.onAbort && Module.onAbort(e), g(e += ""), P = !0, 1, e = "abort(" + e + "). Build with -s ASSERTIONS=1 for more info.", new WebAssembly.RuntimeError(e);
+ function getWasmImports() {
+ // prepare imports
+ return {
+ "env": wasmImports,
+ "wasi_snapshot_preview1": wasmImports,
+ "GOT.mem": new Proxy(wasmImports, GOTHandler),
+ "GOT.func": new Proxy(wasmImports, GOTHandler)
+ };
}
-
- Module.preloadedImages = {}, Module.preloadedAudios = {}, Module.preloadedWasm = {};
- var _e, ae, ie, ue = "data:application/octet-stream;base64,";
-
- function le (e) {
- return e.startsWith(ue);
+ // Create the wasm instance.
+ // Receives the wasm imports, returns the exports.
+ function createWasm() {
+ var info = getWasmImports();
+ // Load the wasm module and create an instance of using native support in the JS engine.
+ // handle a generated wasm instance, receiving its exports and
+ // performing other necessary setup
+ /** @param {WebAssembly.Module=} module*/ function receiveInstance(instance, module) {
+ wasmExports = instance.exports;
+ wasmExports = relocateExports(wasmExports, 1024);
+ var metadata = getDylinkMetadata(module);
+ if (metadata.neededDynlibs) {
+ dynamicLibraries = metadata.neededDynlibs.concat(dynamicLibraries);
+ }
+ mergeLibSymbols(wasmExports, "main");
+ LDSO.init();
+ loadDylibs();
+ addOnInit(wasmExports["__wasm_call_ctors"]);
+ __RELOC_FUNCS__.push(wasmExports["__wasm_apply_data_relocs"]);
+ removeRunDependency("wasm-instantiate");
+ return wasmExports;
+ }
+ // wait for the pthread pool (if any)
+ addRunDependency("wasm-instantiate");
+ // Prefer streaming instantiation if available.
+ function receiveInstantiationResult(result) {
+ // 'result' is a ResultObject object which has both the module and instance.
+ // receiveInstance() will swap in the exports (to Module.asm) so they can be called
+ receiveInstance(result["instance"], result["module"]);
+ }
+ // User shell pages can write their own Module.instantiateWasm = function(imports, successCallback) callback
+ // to manually instantiate the Wasm module themselves. This allows pages to
+ // run the instantiation parallel to any other async startup actions they are
+ // performing.
+ // Also pthreads and wasm workers initialize the wasm instance through this
+ // path.
+ if (Module["instantiateWasm"]) {
+ try {
+ return Module["instantiateWasm"](info, receiveInstance);
+ } catch (e) {
+ err(`Module.instantiateWasm callback failed with error: ${e}`);
+ return false;
+ }
+ }
+ if (!wasmBinaryFile) wasmBinaryFile = findWasmBinary();
+ instantiateAsync(wasmBinary, wasmBinaryFile, info, receiveInstantiationResult);
+ return {};
}
-
- function de (e) {
- return e.startsWith("file://");
+ // include: runtime_debug.js
+ // end include: runtime_debug.js
+ // === Body ===
+ var ASM_CONSTS = {};
+ // end include: preamble.js
+ /** @constructor */ function ExitStatus(status) {
+ this.name = "ExitStatus";
+ this.message = `Program terminated with exit(${status})`;
+ this.status = status;
}
-
- function ce (e) {
- try {
- if (e == _e && v) {
- return new Uint8Array(v);
+ var GOT = {};
+ var currentModuleWeakSymbols = new Set([]);
+ var GOTHandler = {
+ get(obj, symName) {
+ var rtn = GOT[symName];
+ if (!rtn) {
+ rtn = GOT[symName] = new WebAssembly.Global({
+ "value": "i32",
+ "mutable": true
+ });
}
- if (m) {
- return m(e);
+ if (!currentModuleWeakSymbols.has(symName)) {
+ // Any non-weak reference to a symbol marks it as `required`, which
+ // enabled `reportUndefinedSymbols` to report undefeind symbol errors
+ // correctly.
+ rtn.required = true;
}
- throw"both async and sync fetching of the wasm failed";
- }
- catch (e) {
- se(e);
- }
- }
-
- le(_e = "tree-sitter.wasm") || (_e = function(e) {
- return Module.locateFile ? Module.locateFile(e, h) : h + e;
- }(_e));
- var me = {}, fe = {
- get: function(e, t) {
- return me[t] || (me[t] = new WebAssembly.Global({ value: "i32", mutable: !0 })), me[t];
+ return rtn;
}
};
-
- function pe (e) {
- for (; e.length > 0;) {
- var t = e.shift();
- if ("function" != typeof t) {
- var r = t.func;
- "number" == typeof r ? void 0 === t.arg ? K.get(r)() : K.get(r)(t.arg) : r(void 0 === t.arg ? null : t.arg);
- }
- else {
- t(Module);
- }
+ var LE_HEAP_LOAD_F32 = byteOffset => HEAP_DATA_VIEW.getFloat32(byteOffset, true);
+ var LE_HEAP_LOAD_F64 = byteOffset => HEAP_DATA_VIEW.getFloat64(byteOffset, true);
+ var LE_HEAP_LOAD_I16 = byteOffset => HEAP_DATA_VIEW.getInt16(byteOffset, true);
+ var LE_HEAP_LOAD_I32 = byteOffset => HEAP_DATA_VIEW.getInt32(byteOffset, true);
+ var LE_HEAP_LOAD_U32 = byteOffset => HEAP_DATA_VIEW.getUint32(byteOffset, true);
+ var LE_HEAP_STORE_F32 = (byteOffset, value) => HEAP_DATA_VIEW.setFloat32(byteOffset, value, true);
+ var LE_HEAP_STORE_F64 = (byteOffset, value) => HEAP_DATA_VIEW.setFloat64(byteOffset, value, true);
+ var LE_HEAP_STORE_I16 = (byteOffset, value) => HEAP_DATA_VIEW.setInt16(byteOffset, value, true);
+ var LE_HEAP_STORE_I32 = (byteOffset, value) => HEAP_DATA_VIEW.setInt32(byteOffset, value, true);
+ var LE_HEAP_STORE_U32 = (byteOffset, value) => HEAP_DATA_VIEW.setUint32(byteOffset, value, true);
+ var callRuntimeCallbacks = callbacks => {
+ while (callbacks.length > 0) {
+ // Pass the module as the first argument.
+ callbacks.shift()(Module);
}
- }
-
- function he (e) {
- var t = 0;
-
- function r () {
- for (var r = 0, n = 1; ;) {
- var o = e[t++];
- if (r += (127 & o) * n, n *= 128, !(128 & o)) {
- break;
+ };
+ var UTF8Decoder = typeof TextDecoder != "undefined" ? new TextDecoder : undefined;
+ /**
+ * Given a pointer 'idx' to a null-terminated UTF8-encoded string in the given
+ * array that contains uint8 values, returns a copy of that string as a
+ * Javascript String object.
+ * heapOrArray is either a regular array, or a JavaScript typed array view.
+ * @param {number} idx
+ * @param {number=} maxBytesToRead
+ * @return {string}
+ */ var UTF8ArrayToString = (heapOrArray, idx, maxBytesToRead) => {
+ var endIdx = idx + maxBytesToRead;
+ var endPtr = idx;
+ // TextDecoder needs to know the byte length in advance, it doesn't stop on
+ // null terminator by itself. Also, use the length info to avoid running tiny
+ // strings through TextDecoder, since .subarray() allocates garbage.
+ // (As a tiny code save trick, compare endPtr against endIdx using a negation,
+ // so that undefined means Infinity)
+ while (heapOrArray[endPtr] && !(endPtr >= endIdx)) ++endPtr;
+ if (endPtr - idx > 16 && heapOrArray.buffer && UTF8Decoder) {
+ return UTF8Decoder.decode(heapOrArray.subarray(idx, endPtr));
+ }
+ var str = "";
+ // If building with TextDecoder, we have already computed the string length
+ // above, so test loop end condition against that
+ while (idx < endPtr) {
+ // For UTF8 byte structure, see:
+ // http://en.wikipedia.org/wiki/UTF-8#Description
+ // https://www.ietf.org/rfc/rfc2279.txt
+ // https://tools.ietf.org/html/rfc3629
+ var u0 = heapOrArray[idx++];
+ if (!(u0 & 128)) {
+ str += String.fromCharCode(u0);
+ continue;
+ }
+ var u1 = heapOrArray[idx++] & 63;
+ if ((u0 & 224) == 192) {
+ str += String.fromCharCode(((u0 & 31) << 6) | u1);
+ continue;
+ }
+ var u2 = heapOrArray[idx++] & 63;
+ if ((u0 & 240) == 224) {
+ u0 = ((u0 & 15) << 12) | (u1 << 6) | u2;
+ } else {
+ u0 = ((u0 & 7) << 18) | (u1 << 12) | (u2 << 6) | (heapOrArray[idx++] & 63);
+ }
+ if (u0 < 65536) {
+ str += String.fromCharCode(u0);
+ } else {
+ var ch = u0 - 65536;
+ str += String.fromCharCode(55296 | (ch >> 10), 56320 | (ch & 1023));
+ }
+ }
+ return str;
+ };
+ var getDylinkMetadata = binary => {
+ var offset = 0;
+ var end = 0;
+ function getU8() {
+ return binary[offset++];
+ }
+ function getLEB() {
+ var ret = 0;
+ var mul = 1;
+ while (1) {
+ var byte = binary[offset++];
+ ret += ((byte & 127) * mul);
+ mul *= 128;
+ if (!(byte & 128)) break;
+ }
+ return ret;
+ }
+ function getString() {
+ var len = getLEB();
+ offset += len;
+ return UTF8ArrayToString(binary, offset - len, len);
+ }
+ /** @param {string=} message */ function failIf(condition, message) {
+ if (condition) throw new Error(message);
+ }
+ var name = "dylink.0";
+ if (binary instanceof WebAssembly.Module) {
+ var dylinkSection = WebAssembly.Module.customSections(binary, name);
+ if (dylinkSection.length === 0) {
+ name = "dylink";
+ dylinkSection = WebAssembly.Module.customSections(binary, name);
+ }
+ failIf(dylinkSection.length === 0, "need dylink section");
+ binary = new Uint8Array(dylinkSection[0]);
+ end = binary.length;
+ } else {
+ var int32View = new Uint32Array(new Uint8Array(binary.subarray(0, 24)).buffer);
+ var magicNumberFound = int32View[0] == 1836278016 || int32View[0] == 6386541;
+ failIf(!magicNumberFound, "need to see wasm magic number");
+ // \0asm
+ // we should see the dylink custom section right after the magic number and wasm version
+ failIf(binary[8] !== 0, "need the dylink section to be first");
+ offset = 9;
+ var section_size = getLEB();
+ //section size
+ end = offset + section_size;
+ name = getString();
+ }
+ var customSection = {
+ neededDynlibs: [],
+ tlsExports: new Set,
+ weakImports: new Set
+ };
+ if (name == "dylink") {
+ customSection.memorySize = getLEB();
+ customSection.memoryAlign = getLEB();
+ customSection.tableSize = getLEB();
+ customSection.tableAlign = getLEB();
+ // shared libraries this module needs. We need to load them first, so that
+ // current module could resolve its imports. (see tools/shared.py
+ // WebAssembly.make_shared_library() for "dylink" section extension format)
+ var neededDynlibsCount = getLEB();
+ for (var i = 0; i < neededDynlibsCount; ++i) {
+ var libname = getString();
+ customSection.neededDynlibs.push(libname);
+ }
+ } else {
+ failIf(name !== "dylink.0");
+ var WASM_DYLINK_MEM_INFO = 1;
+ var WASM_DYLINK_NEEDED = 2;
+ var WASM_DYLINK_EXPORT_INFO = 3;
+ var WASM_DYLINK_IMPORT_INFO = 4;
+ var WASM_SYMBOL_TLS = 256;
+ var WASM_SYMBOL_BINDING_MASK = 3;
+ var WASM_SYMBOL_BINDING_WEAK = 1;
+ while (offset < end) {
+ var subsectionType = getU8();
+ var subsectionSize = getLEB();
+ if (subsectionType === WASM_DYLINK_MEM_INFO) {
+ customSection.memorySize = getLEB();
+ customSection.memoryAlign = getLEB();
+ customSection.tableSize = getLEB();
+ customSection.tableAlign = getLEB();
+ } else if (subsectionType === WASM_DYLINK_NEEDED) {
+ var neededDynlibsCount = getLEB();
+ for (var i = 0; i < neededDynlibsCount; ++i) {
+ libname = getString();
+ customSection.neededDynlibs.push(libname);
+ }
+ } else if (subsectionType === WASM_DYLINK_EXPORT_INFO) {
+ var count = getLEB();
+ while (count--) {
+ var symname = getString();
+ var flags = getLEB();
+ if (flags & WASM_SYMBOL_TLS) {
+ customSection.tlsExports.add(symname);
+ }
+ }
+ } else if (subsectionType === WASM_DYLINK_IMPORT_INFO) {
+ var count = getLEB();
+ while (count--) {
+ var modname = getString();
+ var symname = getString();
+ var flags = getLEB();
+ if ((flags & WASM_SYMBOL_BINDING_MASK) == WASM_SYMBOL_BINDING_WEAK) {
+ customSection.weakImports.add(symname);
+ }
+ }
+ } else {
+ // unknown subsection
+ offset += subsectionSize;
}
}
- return r;
}
+ return customSection;
+ };
+ /**
+ * @param {number} ptr
+ * @param {string} type
+ */ function getValue(ptr, type = "i8") {
+ if (type.endsWith("*")) type = "*";
+ switch (type) {
+ case "i1":
+ return HEAP8[ptr];
- if (e instanceof WebAssembly.Module) {
- var n = WebAssembly.Module.customSections(e, "dylink");
- k(0 != n.length, "need dylink section"), e = new Int8Array(n[0]);
- }
- else {
- k(1836278016 == new Uint32Array(new Uint8Array(e.subarray(0, 24)).buffer)[0], "need to see wasm magic number"), k(0 === e[8], "need the dylink section to be first"), t = 9, r(), k(6 === e[t]), k(e[++t] === "d".charCodeAt(0)), k(e[++t] === "y".charCodeAt(0)), k(e[++t] === "l".charCodeAt(0)), k(e[++t] === "i".charCodeAt(0)), k(e[++t] === "n".charCodeAt(0)), k(e[++t] === "k".charCodeAt(0)), t++;
- }
- var o = {};
- o.memorySize = r(), o.memoryAlign = r(), o.tableSize = r(), o.tableAlign = r();
- var s = r();
- o.neededDynlibs = [];
- for (var _ = 0; _ < s; ++_) {
- var a = r(), i = e.subarray(t, t + a);
- t += a;
- var u = $(i, 0);
- o.neededDynlibs.push(u);
- }
- return o;
- }
-
- var ge = 0;
-
- function we () {
- return A || ge > 0;
- }
-
- function Me (e) {
- return 0 == e.indexOf("dynCall_") || ["stackAlloc", "stackSave", "stackRestore"].includes(e) ? e : "_" + e;
- }
-
- function ye (e, t) {
- for (var r in e) if (e.hasOwnProperty(r)) {
- De.hasOwnProperty(r) || (De[r] = e[r]);
- var n = Me(r);
- Module.hasOwnProperty(n) || (Module[n] = e[r]);
- }
- }
+ case "i8":
+ return HEAP8[ptr];
- var be = { nextHandle: 1, loadedLibs: {}, loadedLibNames: {} };
+ case "i16":
+ return LE_HEAP_LOAD_I16(((ptr) >> 1) * 2);
- function ve (e, t, r) {
- return e.includes("j") ? function(e, t, r) {
- var n = Module["dynCall_" + e];
- return r && r.length ? n.apply(null, [t].concat(r)) : n.call(null, t);
- }(e, t, r) : K.get(t).apply(null, r);
- }
+ case "i32":
+ return LE_HEAP_LOAD_I32(((ptr) >> 2) * 4);
- var Ee = 5251072;
+ case "i64":
+ abort("to do getValue(i64) use WASM_BIGINT");
- function Se (e) {
- return ["__cpp_exception", "__wasm_apply_data_relocs", "__dso_handle", "__set_stack_limits"].includes(e);
- }
-
- function Ie (e, t) {
- var r = {};
- for (var n in e) {
- var o = e[n];
- "object" == typeof o && (o = o.value), "number" == typeof o && (o += t), r[n] = o;
- }
- return function(e) {
- for (var t in e) if (!Se(t)) {
- var r = !1, n = e[t];
- t.startsWith("orig$") && (t = t.split("$")[1], r = !0), me[t] || (me[t] = new WebAssembly.Global({
- value: "i32",
- mutable: !0
- })), (r || 0 == me[t].value) && ("function" == typeof n ? me[t].value = b(n) : "number" == typeof n ? me[t].value = n : g("unhandled export type for `" + t + "`: " + typeof n));
- }
- }(r), r;
- }
+ case "float":
+ return LE_HEAP_LOAD_F32(((ptr) >> 2) * 4);
- function Ae (e, t) {
- var r, n;
- return t && (r = De["orig$" + e]), r || (r = De[e]), r || (r = Module[Me(e)]), !r && e.startsWith("invoke_") && (n = e.split("_")[1], r = function() {
- var e = He();
- try {
- return ve(n, arguments[0], Array.prototype.slice.call(arguments, 1));
- }
- catch (t) {
- if (Ge(e), t !== t + 0 && "longjmp" !== t) {
- throw t;
- }
- Ke(1, 0);
- }
- }), r;
- }
+ case "double":
+ return LE_HEAP_LOAD_F64(((ptr) >> 3) * 8);
- function xe (e, t) {
- var r = he(e);
+ case "*":
+ return LE_HEAP_LOAD_U32(((ptr) >> 2) * 4);
- function n () {
- var n = Math.pow(2, r.memoryAlign);
- n = Math.max(n, w);
- var o, s, _, a = (o = function(e) {
- if (Y) {
- return ze(e);
- }
- var t = Ee, r = t + e + 15 & -16;
- return Ee = r, me.__heap_base.value = r, t;
- }(r.memorySize + n), (s = n) || (s = w), Math.ceil(o / s) * s), i = K.length;
- K.grow(r.tableSize);
- for (var u = a; u < a + r.memorySize; u++) q[u] = 0;
- for (u = i; u < i + r.tableSize; u++) K.set(u, null);
- var l = new Proxy({}, {
- get: function(e, t) {
- switch (t) {
- case"__memory_base":
- return a;
- case"__table_base":
- return i;
- }
- if (t in De) {
- return De[t];
- }
- var r;
- t in e || (e[t] = function() {
- return r || (r = function(e) {
- var t = Ae(e, !1);
- return t || (t = _[e]), t;
- }(t)), r.apply(null, arguments);
- });
- return e[t];
- }
- }), d = { "GOT.mem": new Proxy({}, fe), "GOT.func": new Proxy({}, fe), env: l, wasi_snapshot_preview1: l };
-
- function c (e) {
- for (var n = 0; n < r.tableSize; n++) {
- var o = K.get(i + n);
- o && M.set(o, i + n);
- }
- _ = Ie(e.exports, a), t.allowUndefined || Pe();
- var s = _.__wasm_call_ctors;
- return s || (s = _.__post_instantiate), s && (Y ? s() : X.push(s)), _;
- }
-
- if (t.loadAsync) {
- if (e instanceof WebAssembly.Module) {
- var m = new WebAssembly.Instance(e, d);
- return Promise.resolve(c(m));
- }
- return WebAssembly.instantiate(e, d).then(function(e) {
- return c(e.instance);
- });
- }
- var f = e instanceof WebAssembly.Module ? e : new WebAssembly.Module(e);
- return c(m = new WebAssembly.Instance(f, d));
+ default:
+ abort(`invalid type for getValue: ${type}`);
}
-
- return t.loadAsync ? r.neededDynlibs.reduce(function(e, r) {
- return e.then(function() {
- return Ne(r, t);
- });
- }, Promise.resolve()).then(function() {
- return n();
- }) : (r.neededDynlibs.forEach(function(e) {
- Ne(e, t);
- }), n());
}
-
- function Ne (e, t) {
- "__main__" != e || be.loadedLibNames[e] || (be.loadedLibs[-1] = {
- refcount: 1 / 0,
- name: "__main__",
- module: Module.asm,
- global: !0
- }, be.loadedLibNames.__main__ = -1), t = t || { global: !0, nodelete: !0 };
- var r, n = be.loadedLibNames[e];
- if (n) {
- return r = be.loadedLibs[n], t.global && !r.global && (r.global = !0, "loading" !== r.module && ye(r.module)), t.nodelete && r.refcount !== 1 / 0 && (r.refcount = 1 / 0), r.refcount++, t.loadAsync ? Promise.resolve(n) : n;
+ var newDSO = (name, handle, syms) => {
+ var dso = {
+ refcount: Infinity,
+ name: name,
+ exports: syms,
+ global: true
+ };
+ LDSO.loadedLibsByName[name] = dso;
+ if (handle != undefined) {
+ LDSO.loadedLibsByHandle[handle] = dso;
+ }
+ return dso;
+ };
+ var LDSO = {
+ loadedLibsByName: {},
+ loadedLibsByHandle: {},
+ init() {
+ newDSO("__main__", 0, wasmImports);
}
-
- function o (e) {
- if (t.fs) {
- var r = t.fs.readFile(e, { encoding: "binary" });
- return r instanceof Uint8Array || (r = new Uint8Array(r)), t.loadAsync ? Promise.resolve(r) : r;
- }
- return t.loadAsync ? (n = e, fetch(n, { credentials: "same-origin" }).then(function(e) {
- if (!e.ok) {
- throw"failed to load binary file at '" + n + "'";
- }
- return e.arrayBuffer();
- }).then(function(e) {
- return new Uint8Array(e);
- })) : m(e);
- var n;
+ };
+ var ___heap_base = 78112;
+ var zeroMemory = (address, size) => {
+ HEAPU8.fill(0, address, address + size);
+ return address;
+ };
+ var alignMemory = (size, alignment) => Math.ceil(size / alignment) * alignment;
+ var getMemory = size => {
+ // After the runtime is initialized, we must only use sbrk() normally.
+ if (runtimeInitialized) {
+ // Currently we don't support freeing of static data when modules are
+ // unloaded via dlclose. This function is tagged as `noleakcheck` to
+ // avoid having this reported as leak.
+ return zeroMemory(_malloc(size), size);
+ }
+ var ret = ___heap_base;
+ // Keep __heap_base stack aligned.
+ var end = ret + alignMemory(size, 16);
+ ___heap_base = end;
+ GOT["__heap_base"].value = end;
+ return ret;
+ };
+ var isInternalSym = symName => [ "__cpp_exception", "__c_longjmp", "__wasm_apply_data_relocs", "__dso_handle", "__tls_size", "__tls_align", "__set_stack_limits", "_emscripten_tls_init", "__wasm_init_tls", "__wasm_call_ctors", "__start_em_asm", "__stop_em_asm", "__start_em_js", "__stop_em_js" ].includes(symName) || symName.startsWith("__em_js__");
+ var uleb128Encode = (n, target) => {
+ if (n < 128) {
+ target.push(n);
+ } else {
+ target.push((n % 128) | 128, n >> 7);
}
-
- function s () {
- if (void 0 !== Module.preloadedWasm && void 0 !== Module.preloadedWasm[e]) {
- var r = Module.preloadedWasm[e];
- return t.loadAsync ? Promise.resolve(r) : r;
- }
- return t.loadAsync ? o(e).then(function(e) {
- return xe(e, t);
- }) : xe(o(e), t);
+ };
+ var sigToWasmTypes = sig => {
+ var typeNames = {
+ "i": "i32",
+ "j": "i64",
+ "f": "f32",
+ "d": "f64",
+ "e": "externref",
+ "p": "i32"
+ };
+ var type = {
+ parameters: [],
+ results: sig[0] == "v" ? [] : [ typeNames[sig[0]] ]
+ };
+ for (var i = 1; i < sig.length; ++i) {
+ type.parameters.push(typeNames[sig[i]]);
+ }
+ return type;
+ };
+ var generateFuncType = (sig, target) => {
+ var sigRet = sig.slice(0, 1);
+ var sigParam = sig.slice(1);
+ var typeCodes = {
+ "i": 127,
+ // i32
+ "p": 127,
+ // i32
+ "j": 126,
+ // i64
+ "f": 125,
+ // f32
+ "d": 124,
+ // f64
+ "e": 111
+ };
+ // Parameters, length + signatures
+ target.push(96);
+ /* form: func */ uleb128Encode(sigParam.length, target);
+ for (var i = 0; i < sigParam.length; ++i) {
+ target.push(typeCodes[sigParam[i]]);
+ }
+ // Return values, length + signatures
+ // With no multi-return in MVP, either 0 (void) or 1 (anything else)
+ if (sigRet == "v") {
+ target.push(0);
+ } else {
+ target.push(1, typeCodes[sigRet]);
}
-
- function _ (e) {
- r.global && ye(e), r.module = e;
+ };
+ var convertJsFunctionToWasm = (func, sig) => {
+ // If the type reflection proposal is available, use the new
+ // "WebAssembly.Function" constructor.
+ // Otherwise, construct a minimal wasm module importing the JS function and
+ // re-exporting it.
+ if (typeof WebAssembly.Function == "function") {
+ return new WebAssembly.Function(sigToWasmTypes(sig), func);
+ }
+ // The module is static, with the exception of the type section, which is
+ // generated based on the signature passed in.
+ var typeSectionBody = [ 1 ];
+ // count: 1
+ generateFuncType(sig, typeSectionBody);
+ // Rest of the module is static
+ var bytes = [ 0, 97, 115, 109, // magic ("\0asm")
+ 1, 0, 0, 0, // version: 1
+ 1 ];
+ // Write the overall length of the type section followed by the body
+ uleb128Encode(typeSectionBody.length, bytes);
+ bytes.push(...typeSectionBody);
+ // The rest of the module is static
+ bytes.push(2, 7, // import section
+ // (import "e" "f" (func 0 (type 0)))
+ 1, 1, 101, 1, 102, 0, 0, 7, 5, // export section
+ // (export "f" (func 0 (type 0)))
+ 1, 1, 102, 0, 0);
+ // We can compile this wasm module synchronously because it is very small.
+ // This accepts an import (at "e.f"), that it reroutes to an export (at "f")
+ var module = new WebAssembly.Module(new Uint8Array(bytes));
+ var instance = new WebAssembly.Instance(module, {
+ "e": {
+ "f": func
+ }
+ });
+ var wrappedFunc = instance.exports["f"];
+ return wrappedFunc;
+ };
+ var wasmTableMirror = [];
+ /** @type {WebAssembly.Table} */ var wasmTable = new WebAssembly.Table({
+ "initial": 28,
+ "element": "anyfunc"
+ });
+ var getWasmTableEntry = funcPtr => {
+ var func = wasmTableMirror[funcPtr];
+ if (!func) {
+ if (funcPtr >= wasmTableMirror.length) wasmTableMirror.length = funcPtr + 1;
+ wasmTableMirror[funcPtr] = func = wasmTable.get(funcPtr);
}
-
- return n = be.nextHandle++, r = {
- refcount: t.nodelete ? 1 / 0 : 1,
- name: e,
- module: "loading",
- global: t.global
- }, be.loadedLibNames[e] = n, be.loadedLibs[n] = r, t.loadAsync ? s().then(function(e) {
- return _(e), n;
- }) : (_(s()), n);
- }
-
- function Pe () {
- for (var e in me) if (0 == me[e].value) {
- var t = Ae(e, !0);
- "function" == typeof t ? me[e].value = b(t, t.sig) : "number" == typeof t ? me[e].value = t : k(!1, "bad export type for `" + e + "`: " + typeof t);
+ return func;
+ };
+ var updateTableMap = (offset, count) => {
+ if (functionsInTableMap) {
+ for (var i = offset; i < offset + count; i++) {
+ var item = getWasmTableEntry(i);
+ // Ignore null values.
+ if (item) {
+ functionsInTableMap.set(item, i);
+ }
+ }
}
- }
-
- Module.___heap_base = Ee;
- var ke, Fe = new WebAssembly.Global({ value: "i32", mutable: !0 }, 5251072);
-
- function Ce () {
- se();
- }
-
- Module._abort = Ce, Ce.sig = "v", ke = o ? function() {
- var e = process.hrtime();
- return 1e3 * e[0] + e[1] / 1e6;
- } : "undefined" != typeof dateNow ? dateNow : function() {
- return performance.now();
};
- var qe = !0;
-
- function Te (e, t) {
- var r, n;
- if (0 === e) {
- r = Date.now();
+ var functionsInTableMap;
+ var getFunctionAddress = func => {
+ // First, create the map if this is the first use.
+ if (!functionsInTableMap) {
+ functionsInTableMap = new WeakMap;
+ updateTableMap(0, wasmTable.length);
+ }
+ return functionsInTableMap.get(func) || 0;
+ };
+ var freeTableIndexes = [];
+ var getEmptyTableSlot = () => {
+ // Reuse a free index if there is one, otherwise grow.
+ if (freeTableIndexes.length) {
+ return freeTableIndexes.pop();
}
- else {
- if (1 !== e && 4 !== e || !qe) {
- return n = 28, W[Ue() >> 2] = n, -1;
+ // Grow the table
+ try {
+ wasmTable.grow(1);
+ } catch (err) {
+ if (!(err instanceof RangeError)) {
+ throw err;
}
- r = ke();
+ throw "Unable to grow wasm table. Set ALLOW_TABLE_GROWTH.";
}
- return W[t >> 2] = r / 1e3 | 0, W[t + 4 >> 2] = r % 1e3 * 1e3 * 1e3 | 0, 0;
- }
-
- function Re (e) {
+ return wasmTable.length - 1;
+ };
+ var setWasmTableEntry = (idx, func) => {
+ wasmTable.set(idx, func);
+ // With ABORT_ON_WASM_EXCEPTIONS wasmTable.get is overridden to return wrapped
+ // functions so we need to call it here to retrieve the potential wrapper correctly
+ // instead of just storing 'func' directly into wasmTableMirror
+ wasmTableMirror[idx] = wasmTable.get(idx);
+ };
+ /** @param {string=} sig */ var addFunction = (func, sig) => {
+ // Check if the function is already in the table, to ensure each function
+ // gets a unique index.
+ var rtn = getFunctionAddress(func);
+ if (rtn) {
+ return rtn;
+ }
+ // It's not in the table, add it now.
+ var ret = getEmptyTableSlot();
+ // Set the new value.
try {
- return I.grow(e - C.byteLength + 65535 >>> 16), G(I.buffer), 1;
- }
- catch (e) {
+ // Attempting to call this with JS function will cause of table.set() to fail
+ setWasmTableEntry(ret, func);
+ } catch (err) {
+ if (!(err instanceof TypeError)) {
+ throw err;
+ }
+ var wrapped = convertJsFunctionToWasm(func, sig);
+ setWasmTableEntry(ret, wrapped);
}
- }
-
- function We (e) {
- Je(e);
- }
-
- Te.sig = "iii", We.sig = "vi";
- var Le = {
- mappings: {}, DEFAULT_POLLMASK: 5, umask: 511, calculateAt: function(e, t, r) {
- if ("/" === t[0]) {
- return t;
- }
- var n;
- if (-100 === e) {
- n = FS.cwd();
- }
- else {
- var o = FS.getStream(e);
- if (!o) {
- throw new FS.ErrnoError(8);
+ functionsInTableMap.set(func, ret);
+ return ret;
+ };
+ var updateGOT = (exports, replace) => {
+ for (var symName in exports) {
+ if (isInternalSym(symName)) {
+ continue;
+ }
+ var value = exports[symName];
+ if (symName.startsWith("orig$")) {
+ symName = symName.split("$")[1];
+ replace = true;
+ }
+ GOT[symName] ||= new WebAssembly.Global({
+ "value": "i32",
+ "mutable": true
+ });
+ if (replace || GOT[symName].value == 0) {
+ if (typeof value == "function") {
+ GOT[symName].value = addFunction(value);
+ } else if (typeof value == "number") {
+ GOT[symName].value = value;
+ } else {
+ err(`unhandled export type for '${symName}': ${typeof value}`);
}
- n = o.path;
}
- if (0 == t.length) {
- if (!r) {
- throw new FS.ErrnoError(44);
+ }
+ };
+ /** @param {boolean=} replace */ var relocateExports = (exports, memoryBase, replace) => {
+ var relocated = {};
+ for (var e in exports) {
+ var value = exports[e];
+ if (typeof value == "object") {
+ // a breaking change in the wasm spec, globals are now objects
+ // https://github.com/WebAssembly/mutable-global/issues/1
+ value = value.value;
+ }
+ if (typeof value == "number") {
+ value += memoryBase;
+ }
+ relocated[e] = value;
+ }
+ updateGOT(relocated, replace);
+ return relocated;
+ };
+ var isSymbolDefined = symName => {
+ // Ignore 'stub' symbols that are auto-generated as part of the original
+ // `wasmImports` used to instantiate the main module.
+ var existing = wasmImports[symName];
+ if (!existing || existing.stub) {
+ return false;
+ }
+ return true;
+ };
+ var dynCallLegacy = (sig, ptr, args) => {
+ sig = sig.replace(/p/g, "i");
+ var f = Module["dynCall_" + sig];
+ return f(ptr, ...args);
+ };
+ var dynCall = (sig, ptr, args = []) => {
+ // Without WASM_BIGINT support we cannot directly call function with i64 as
+ // part of their signature, so we rely on the dynCall functions generated by
+ // wasm-emscripten-finalize
+ if (sig.includes("j")) {
+ return dynCallLegacy(sig, ptr, args);
+ }
+ var rtn = getWasmTableEntry(ptr)(...args);
+ return rtn;
+ };
+ var stackSave = () => _emscripten_stack_get_current();
+ var stackRestore = val => __emscripten_stack_restore(val);
+ var createInvokeFunction = sig => (ptr, ...args) => {
+ var sp = stackSave();
+ try {
+ return dynCall(sig, ptr, args);
+ } catch (e) {
+ stackRestore(sp);
+ // Create a try-catch guard that rethrows the Emscripten EH exception.
+ // Exceptions thrown from C++ will be a pointer (number) and longjmp
+ // will throw the number Infinity. Use the compact and fast "e !== e+0"
+ // test to check if e was not a Number.
+ if (e !== e + 0) throw e;
+ _setThrew(1, 0);
+ }
+ };
+ var resolveGlobalSymbol = (symName, direct = false) => {
+ var sym;
+ // First look for the orig$ symbol which is the symbol without i64
+ // legalization performed.
+ if (direct && ("orig$" + symName in wasmImports)) {
+ symName = "orig$" + symName;
+ }
+ if (isSymbolDefined(symName)) {
+ sym = wasmImports[symName];
+ } else // Asm.js-style exception handling: invoke wrapper generation
+ if (symName.startsWith("invoke_")) {
+ // Create (and cache) new invoke_ functions on demand.
+ sym = wasmImports[symName] = createInvokeFunction(symName.split("_")[1]);
+ }
+ return {
+ sym: sym,
+ name: symName
+ };
+ };
+ /**
+ * Given a pointer 'ptr' to a null-terminated UTF8-encoded string in the
+ * emscripten HEAP, returns a copy of that string as a Javascript String object.
+ *
+ * @param {number} ptr
+ * @param {number=} maxBytesToRead - An optional length that specifies the
+ * maximum number of bytes to read. You can omit this parameter to scan the
+ * string until the first 0 byte. If maxBytesToRead is passed, and the string
+ * at [ptr, ptr+maxBytesToReadr[ contains a null byte in the middle, then the
+ * string will cut short at that byte index (i.e. maxBytesToRead will not
+ * produce a string of exact length [ptr, ptr+maxBytesToRead[) N.B. mixing
+ * frequent uses of UTF8ToString() with and without maxBytesToRead may throw
+ * JS JIT optimizations off, so it is worth to consider consistently using one
+ * @return {string}
+ */ var UTF8ToString = (ptr, maxBytesToRead) => ptr ? UTF8ArrayToString(HEAPU8, ptr, maxBytesToRead) : "";
+ /**
+ * @param {string=} libName
+ * @param {Object=} localScope
+ * @param {number=} handle
+ */ var loadWebAssemblyModule = (binary, flags, libName, localScope, handle) => {
+ var metadata = getDylinkMetadata(binary);
+ currentModuleWeakSymbols = metadata.weakImports;
+ // loadModule loads the wasm module after all its dependencies have been loaded.
+ // can be called both sync/async.
+ function loadModule() {
+ // The first thread to load a given module needs to allocate the static
+ // table and memory regions. Later threads re-use the same table region
+ // and can ignore the memory region (since memory is shared between
+ // threads already).
+ // If `handle` is specified than it is assumed that the calling thread has
+ // exclusive access to it for the duration of this function. See the
+ // locking in `dynlink.c`.
+ var firstLoad = !handle || !HEAP8[(handle) + (8)];
+ if (firstLoad) {
+ // alignments are powers of 2
+ var memAlign = Math.pow(2, metadata.memoryAlign);
+ // prepare memory
+ var memoryBase = metadata.memorySize ? alignMemory(getMemory(metadata.memorySize + memAlign), memAlign) : 0;
+ // TODO: add to cleanups
+ var tableBase = metadata.tableSize ? wasmTable.length : 0;
+ if (handle) {
+ HEAP8[(handle) + (8)] = 1;
+ LE_HEAP_STORE_U32((((handle) + (12)) >> 2) * 4, memoryBase);
+ LE_HEAP_STORE_I32((((handle) + (16)) >> 2) * 4, metadata.memorySize);
+ LE_HEAP_STORE_U32((((handle) + (20)) >> 2) * 4, tableBase);
+ LE_HEAP_STORE_I32((((handle) + (24)) >> 2) * 4, metadata.tableSize);
}
- return n;
- }
- return PATH.join2(n, t);
- }, doStat: function(e, t, r) {
- try {
- var n = e(t);
- }
- catch (e) {
- if (e && e.node && PATH.normalize(t) !== PATH.normalize(FS.getPath(e.node))) {
- return -54;
+ } else {
+ memoryBase = LE_HEAP_LOAD_U32((((handle) + (12)) >> 2) * 4);
+ tableBase = LE_HEAP_LOAD_U32((((handle) + (20)) >> 2) * 4);
+ }
+ var tableGrowthNeeded = tableBase + metadata.tableSize - wasmTable.length;
+ if (tableGrowthNeeded > 0) {
+ wasmTable.grow(tableGrowthNeeded);
+ }
+ // This is the export map that we ultimately return. We declare it here
+ // so it can be used within resolveSymbol. We resolve symbols against
+ // this local symbol map in the case there they are not present on the
+ // global Module object. We need this fallback because Modules sometime
+ // need to import their own symbols
+ var moduleExports;
+ function resolveSymbol(sym) {
+ var resolved = resolveGlobalSymbol(sym).sym;
+ if (!resolved && localScope) {
+ resolved = localScope[sym];
}
- throw e;
- }
- return W[r >> 2] = n.dev, W[r + 4 >> 2] = 0, W[r + 8 >> 2] = n.ino, W[r + 12 >> 2] = n.mode, W[r + 16 >> 2] = n.nlink, W[r + 20 >> 2] = n.uid, W[r + 24 >> 2] = n.gid, W[r + 28 >> 2] = n.rdev, W[r + 32 >> 2] = 0, ie = [n.size >>> 0, (ae = n.size, +Math.abs(ae) >= 1 ? ae > 0 ? (0 | Math.min(+Math.floor(ae / 4294967296), 4294967295)) >>> 0 : ~~+Math.ceil((ae - +(~~ae >>> 0)) / 4294967296) >>> 0 : 0)], W[r + 40 >> 2] = ie[0], W[r + 44 >> 2] = ie[1], W[r + 48 >> 2] = 4096, W[r + 52 >> 2] = n.blocks, W[r + 56 >> 2] = n.atime.getTime() / 1e3 | 0, W[r + 60 >> 2] = 0, W[r + 64 >> 2] = n.mtime.getTime() / 1e3 | 0, W[r + 68 >> 2] = 0, W[r + 72 >> 2] = n.ctime.getTime() / 1e3 | 0, W[r + 76 >> 2] = 0, ie = [n.ino >>> 0, (ae = n.ino, +Math.abs(ae) >= 1 ? ae > 0 ? (0 | Math.min(+Math.floor(ae / 4294967296), 4294967295)) >>> 0 : ~~+Math.ceil((ae - +(~~ae >>> 0)) / 4294967296) >>> 0 : 0)], W[r + 80 >> 2] = ie[0], W[r + 84 >> 2] = ie[1], 0;
- }, doMsync: function(e, t, r, n, o) {
- var s = T.slice(e, e + r);
- FS.msync(t, s, o, r, n);
- }, doMkdir: function(e, t) {
- return "/" === (e = PATH.normalize(e))[e.length - 1] && (e = e.substr(0, e.length - 1)), FS.mkdir(e, t, 0), 0;
- }, doMknod: function(e, t, r) {
- switch (61440 & t) {
- case 32768:
- case 8192:
- case 24576:
- case 4096:
- case 49152:
- break;
- default:
- return -28;
- }
- return FS.mknod(e, t, r), 0;
- }, doReadlink: function(e, t, r) {
- if (r <= 0) {
- return -28;
- }
- var n = FS.readlink(e), o = Math.min(r, U(n)), s = q[t + o];
- return z(n, t, r + 1), q[t + o] = s, o;
- }, doAccess: function(e, t) {
- if (-8 & t) {
- return -28;
- }
- var r;
- if (!(r = FS.lookupPath(e, { follow: !0 }).node)) {
- return -44;
- }
- var n = "";
- return 4 & t && (n += "r"), 2 & t && (n += "w"), 1 & t && (n += "x"), n && FS.nodePermissions(r, n) ? -2 : 0;
- }, doDup: function(e, t, r) {
- var n = FS.getStream(r);
- return n && FS.close(n), FS.open(e, t, 0, r, r).fd;
- }, doReadv: function(e, t, r, n) {
- for (var o = 0, s = 0; s < r; s++) {
- var _ = W[t + 8 * s >> 2], a = W[t + (8 * s + 4) >> 2], i = FS.read(e, q, _, a, n);
- if (i < 0) {
- return -1;
+ if (!resolved) {
+ resolved = moduleExports[sym];
}
- if (o += i, i < a) {
- break;
+ return resolved;
+ }
+ // TODO kill ↓↓↓ (except "symbols local to this module", it will likely be
+ // not needed if we require that if A wants symbols from B it has to link
+ // to B explicitly: similarly to -Wl,--no-undefined)
+ // wasm dynamic libraries are pure wasm, so they cannot assist in
+ // their own loading. When side module A wants to import something
+ // provided by a side module B that is loaded later, we need to
+ // add a layer of indirection, but worse, we can't even tell what
+ // to add the indirection for, without inspecting what A's imports
+ // are. To do that here, we use a JS proxy (another option would
+ // be to inspect the binary directly).
+ var proxyHandler = {
+ get(stubs, prop) {
+ // symbols that should be local to this module
+ switch (prop) {
+ case "__memory_base":
+ return memoryBase;
+
+ case "__table_base":
+ return tableBase;
+ }
+ if (prop in wasmImports && !wasmImports[prop].stub) {
+ // No stub needed, symbol already exists in symbol table
+ return wasmImports[prop];
+ }
+ // Return a stub function that will resolve the symbol
+ // when first called.
+ if (!(prop in stubs)) {
+ var resolved;
+ stubs[prop] = (...args) => {
+ resolved ||= resolveSymbol(prop);
+ return resolved(...args);
+ };
+ }
+ return stubs[prop];
+ }
+ };
+ var proxy = new Proxy({}, proxyHandler);
+ var info = {
+ "GOT.mem": new Proxy({}, GOTHandler),
+ "GOT.func": new Proxy({}, GOTHandler),
+ "env": proxy,
+ "wasi_snapshot_preview1": proxy
+ };
+ function postInstantiation(module, instance) {
+ // add new entries to functionsInTableMap
+ updateTableMap(tableBase, metadata.tableSize);
+ moduleExports = relocateExports(instance.exports, memoryBase);
+ if (!flags.allowUndefined) {
+ reportUndefinedSymbols();
}
+ function addEmAsm(addr, body) {
+ var args = [];
+ var arity = 0;
+ for (;arity < 16; arity++) {
+ if (body.indexOf("$" + arity) != -1) {
+ args.push("$" + arity);
+ } else {
+ break;
+ }
+ }
+ args = args.join(",");
+ var func = `(${args}) => { ${body} };`;
+ ASM_CONSTS[start] = eval(func);
+ }
+ // Add any EM_ASM function that exist in the side module
+ if ("__start_em_asm" in moduleExports) {
+ var start = moduleExports["__start_em_asm"];
+ var stop = moduleExports["__stop_em_asm"];
+ while (start < stop) {
+ var jsString = UTF8ToString(start);
+ addEmAsm(start, jsString);
+ start = HEAPU8.indexOf(0, start) + 1;
+ }
+ }
+ function addEmJs(name, cSig, body) {
+ // The signature here is a C signature (e.g. "(int foo, char* bar)").
+ // See `create_em_js` in emcc.py` for the build-time version of this
+ // code.
+ var jsArgs = [];
+ cSig = cSig.slice(1, -1);
+ if (cSig != "void") {
+ cSig = cSig.split(",");
+ for (var i in cSig) {
+ var jsArg = cSig[i].split(" ").pop();
+ jsArgs.push(jsArg.replace("*", ""));
+ }
+ }
+ var func = `(${jsArgs}) => ${body};`;
+ moduleExports[name] = eval(func);
+ }
+ for (var name in moduleExports) {
+ if (name.startsWith("__em_js__")) {
+ var start = moduleExports[name];
+ var jsString = UTF8ToString(start);
+ // EM_JS strings are stored in the data section in the form
+ // SIG<::>BODY.
+ var parts = jsString.split("<::>");
+ addEmJs(name.replace("__em_js__", ""), parts[0], parts[1]);
+ delete moduleExports[name];
+ }
+ }
+ // initialize the module
+ var applyRelocs = moduleExports["__wasm_apply_data_relocs"];
+ if (applyRelocs) {
+ if (runtimeInitialized) {
+ applyRelocs();
+ } else {
+ __RELOC_FUNCS__.push(applyRelocs);
+ }
+ }
+ var init = moduleExports["__wasm_call_ctors"];
+ if (init) {
+ if (runtimeInitialized) {
+ init();
+ } else {
+ // we aren't ready to run compiled code yet
+ __ATINIT__.push(init);
+ }
+ }
+ return moduleExports;
}
- return o;
- }, doWritev: function(e, t, r, n) {
- for (var o = 0, s = 0; s < r; s++) {
- var _ = W[t + 8 * s >> 2], a = W[t + (8 * s + 4) >> 2], i = FS.write(e, q, _, a, n);
- if (i < 0) {
- return -1;
+ if (flags.loadAsync) {
+ if (binary instanceof WebAssembly.Module) {
+ var instance = new WebAssembly.Instance(binary, info);
+ return Promise.resolve(postInstantiation(binary, instance));
}
- o += i;
- }
- return o;
- }, varargs: void 0, get: function() {
- return Le.varargs += 4, W[Le.varargs - 4 >> 2];
- }, getStr: function(e) {
- return Z(e);
- }, getStreamFromFD: function(e) {
- var t = FS.getStream(e);
- if (!t) {
- throw new FS.ErrnoError(8);
- }
- return t;
- }, get64: function(e, t) {
- return e;
- }
- };
-
- function Oe (e) {
- try {
- var t = Le.getStreamFromFD(e);
- return FS.close(t), 0;
- }
- catch (e) {
- return "undefined" != typeof FS && e instanceof FS.ErrnoError || se(e), e.errno;
- }
- }
-
- function je (e, t, r, n) {
- try {
- var o = Le.getStreamFromFD(e), s = Le.doWritev(o, t, r);
- return W[n >> 2] = s, 0;
+ return WebAssembly.instantiate(binary, info).then(result => postInstantiation(result.module, result.instance));
+ }
+ var module = binary instanceof WebAssembly.Module ? binary : new WebAssembly.Module(binary);
+ var instance = new WebAssembly.Instance(module, info);
+ return postInstantiation(module, instance);
}
- catch (e) {
- return "undefined" != typeof FS && e instanceof FS.ErrnoError || se(e), e.errno;
+ // now load needed libraries and the module itself.
+ if (flags.loadAsync) {
+ return metadata.neededDynlibs.reduce((chain, dynNeeded) => chain.then(() => loadDynamicLibrary(dynNeeded, flags, localScope)), Promise.resolve()).then(loadModule);
}
- }
-
- function $e (e) {
- E(e);
- }
-
- Oe.sig = "ii", je.sig = "iiiii", $e.sig = "vi";
- var Ze, De = {
- __heap_base: Ee,
- __indirect_function_table: K,
- __memory_base: 1024,
- __stack_pointer: Fe,
- __table_base: 1,
- abort: Ce,
- clock_gettime: Te,
- emscripten_memcpy_big: function(e, t, r) {
- T.copyWithin(e, t, t + r);
- },
- emscripten_resize_heap: function(e) {
- var t, r, n = T.length;
- if ((e >>>= 0) > 2147483648) {
- return !1;
- }
- for (var o = 1; o <= 4; o *= 2) {
- var s = n * (1 + .2 / o);
- if (s = Math.min(s, e + 100663296), Re(Math.min(2147483648, ((t = Math.max(e, s)) % (r = 65536) > 0 && (t += r - t % r), t)))) {
- return !0;
+ metadata.neededDynlibs.forEach(needed => loadDynamicLibrary(needed, flags, localScope));
+ return loadModule();
+ };
+ var mergeLibSymbols = (exports, libName) => {
+ // add symbols into global namespace TODO: weak linking etc.
+ for (var [sym, exp] of Object.entries(exports)) {
+ // When RTLD_GLOBAL is enabled, the symbols defined by this shared object
+ // will be made available for symbol resolution of subsequently loaded
+ // shared objects.
+ // We should copy the symbols (which include methods and variables) from
+ // SIDE_MODULE to MAIN_MODULE.
+ const setImport = target => {
+ if (!isSymbolDefined(target)) {
+ wasmImports[target] = exp;
}
+ };
+ setImport(sym);
+ // Special case for handling of main symbol: If a side module exports
+ // `main` that also acts a definition for `__main_argc_argv` and vice
+ // versa.
+ const main_alias = "__main_argc_argv";
+ if (sym == "main") {
+ setImport(main_alias);
}
- return !1;
- },
- exit: We,
- fd_close: Oe,
- fd_seek: function(e, t, r, n, o) {
- try {
- var s = Le.getStreamFromFD(e), _ = 4294967296 * r + (t >>> 0);
- return _ <= -9007199254740992 || _ >= 9007199254740992 ? -61 : (FS.llseek(s, _, n), ie = [s.position >>> 0, (ae = s.position, +Math.abs(ae) >= 1 ? ae > 0 ? (0 | Math.min(+Math.floor(ae / 4294967296), 4294967295)) >>> 0 : ~~+Math.ceil((ae - +(~~ae >>> 0)) / 4294967296) >>> 0 : 0)], W[o >> 2] = ie[0], W[o + 4 >> 2] = ie[1], s.getdents && 0 === _ && 0 === n && (s.getdents = null), 0);
- }
- catch (e) {
- return "undefined" != typeof FS && e instanceof FS.ErrnoError || se(e), e.errno;
- }
- },
- fd_write: je,
- memory: I,
- setTempRet0: $e,
- tree_sitter_log_callback: function(e, t) {
- if (pt) {
- const r = Z(t);
- pt(r, 0 !== e);
- }
- },
- tree_sitter_parse_callback: function(e, t, r, n, o) {
- var s = ft(t, { row: r, column: n });
- "string" == typeof s ? (x(o, s.length, "i32"), function(e, t, r) {
- if (void 0 === r && (r = 2147483647), r < 2) {
- return 0;
+ if (sym == main_alias) {
+ setImport("main");
+ }
+ if (sym.startsWith("dynCall_") && !Module.hasOwnProperty(sym)) {
+ Module[sym] = exp;
+ }
+ }
+ };
+ /** @param {boolean=} noRunDep */ var asyncLoad = (url, onload, onerror, noRunDep) => {
+ var dep = !noRunDep ? getUniqueRunDependency(`al ${url}`) : "";
+ readAsync(url).then(arrayBuffer => {
+ onload(new Uint8Array(arrayBuffer));
+ if (dep) removeRunDependency(dep);
+ }, err => {
+ if (onerror) {
+ onerror();
+ } else {
+ throw `Loading data file "${url}" failed.`;
+ }
+ });
+ if (dep) addRunDependency(dep);
+ };
+ /**
+ * @param {number=} handle
+ * @param {Object=} localScope
+ */ function loadDynamicLibrary(libName, flags = {
+ global: true,
+ nodelete: true
+ }, localScope, handle) {
+ // when loadDynamicLibrary did not have flags, libraries were loaded
+ // globally & permanently
+ var dso = LDSO.loadedLibsByName[libName];
+ if (dso) {
+ // the library is being loaded or has been loaded already.
+ if (!flags.global) {
+ if (localScope) {
+ Object.assign(localScope, dso.exports);
}
- for (var n = (r -= 2) < 2 * e.length ? r / 2 : e.length, o = 0; o < n; ++o) {
- var s = e.charCodeAt(o);
- R[t >> 1] = s, t += 2;
+ } else if (!dso.global) {
+ // The library was previously loaded only locally but not
+ // we have a request with global=true.
+ dso.global = true;
+ mergeLibSymbols(dso.exports, libName);
+ }
+ // same for "nodelete"
+ if (flags.nodelete && dso.refcount !== Infinity) {
+ dso.refcount = Infinity;
+ }
+ dso.refcount++;
+ if (handle) {
+ LDSO.loadedLibsByHandle[handle] = dso;
+ }
+ return flags.loadAsync ? Promise.resolve(true) : true;
+ }
+ // allocate new DSO
+ dso = newDSO(libName, handle, "loading");
+ dso.refcount = flags.nodelete ? Infinity : 1;
+ dso.global = flags.global;
+ // libName -> libData
+ function loadLibData() {
+ // for wasm, we can use fetch for async, but for fs mode we can only imitate it
+ if (handle) {
+ var data = LE_HEAP_LOAD_U32((((handle) + (28)) >> 2) * 4);
+ var dataSize = LE_HEAP_LOAD_U32((((handle) + (32)) >> 2) * 4);
+ if (data && dataSize) {
+ var libData = HEAP8.slice(data, data + dataSize);
+ return flags.loadAsync ? Promise.resolve(libData) : libData;
}
- R[t >> 1] = 0;
- }(s, e, 10240)) : x(o, 0, "i32");
+ }
+ var libFile = locateFile(libName);
+ if (flags.loadAsync) {
+ return new Promise(function(resolve, reject) {
+ asyncLoad(libFile, resolve, reject);
+ });
+ }
+ // load the binary synchronously
+ if (!readBinary) {
+ throw new Error(`${libFile}: file not found, and synchronous loading of external files is not available`);
+ }
+ return readBinary(libFile);
}
- }, ze = (function() {
- var e = { env: De, wasi_snapshot_preview1: De, "GOT.mem": new Proxy(De, fe), "GOT.func": new Proxy(De, fe) };
-
- function t (e, t) {
- var r = e.exports;
- r = Ie(r, 1024), Module.asm = r;
- var n, o = he(t);
- o.neededDynlibs && (S = o.neededDynlibs.concat(S)), ye(r), n = Module.asm.__wasm_call_ctors, X.unshift(n), oe();
+ // libName -> exports
+ function getExports() {
+ // module not preloaded - load lib data and create new module from it
+ if (flags.loadAsync) {
+ return loadLibData().then(libData => loadWebAssemblyModule(libData, flags, libName, localScope, handle));
+ }
+ return loadWebAssemblyModule(loadLibData(), flags, libName, localScope, handle);
}
-
- function r (e) {
- t(e.instance, e.module);
+ // module for lib is loaded - update the dso & global namespace
+ function moduleLoaded(exports) {
+ if (dso.global) {
+ mergeLibSymbols(exports, libName);
+ } else if (localScope) {
+ Object.assign(localScope, exports);
+ }
+ dso.exports = exports;
}
-
- function n (t) {
- return function() {
- if (!v && (u || l)) {
- if ("function" == typeof fetch && !de(_e)) {
- return fetch(_e, { credentials: "same-origin" }).then(function(e) {
- if (!e.ok) {
- throw"failed to load wasm binary file at '" + _e + "'";
- }
- return e.arrayBuffer();
- }).catch(function() {
- return ce(_e);
- });
- }
- if (c) {
- return new Promise(function(e, t) {
- c(_e, function(t) {
- e(new Uint8Array(t));
- }, t);
- });
- }
- }
- return Promise.resolve().then(function() {
- return ce(_e);
- });
- }().then(function(t) {
- return WebAssembly.instantiate(t, e);
- }).then(t, function(e) {
- g("failed to asynchronously prepare wasm: " + e), se(e);
+ if (flags.loadAsync) {
+ return getExports().then(exports => {
+ moduleLoaded(exports);
+ return true;
});
}
-
- if (ne(), Module.instantiateWasm) {
- try {
- return Module.instantiateWasm(e, t);
- }
- catch (e) {
- return g("Module.instantiateWasm callback failed with error: " + e), !1;
+ moduleLoaded(getExports());
+ return true;
+ }
+ var reportUndefinedSymbols = () => {
+ for (var [symName, entry] of Object.entries(GOT)) {
+ if (entry.value == 0) {
+ var value = resolveGlobalSymbol(symName, true).sym;
+ if (!value && !entry.required) {
+ // Ignore undefined symbols that are imported as weak.
+ continue;
+ }
+ if (typeof value == "function") {
+ /** @suppress {checkTypes} */ entry.value = addFunction(value, value.sig);
+ } else if (typeof value == "number") {
+ entry.value = value;
+ } else {
+ throw new Error(`bad export type for '${symName}': ${typeof value}`);
+ }
}
}
- v || "function" != typeof WebAssembly.instantiateStreaming || le(_e) || de(_e) || "function" != typeof fetch ? n(r) : fetch(_e, { credentials: "same-origin" }).then(function(t) {
- return WebAssembly.instantiateStreaming(t, e).then(r, function(e) {
- return g("wasm streaming compile failed: " + e), g("falling back to ArrayBuffer instantiation"), n(r);
- });
- });
- }(), Module.___wasm_call_ctors = function() {
- return (Module.___wasm_call_ctors = Module.asm.__wasm_call_ctors).apply(null, arguments);
- }, Module._malloc = function() {
- return (ze = Module._malloc = Module.asm.malloc).apply(null, arguments);
- }), Ue = (Module._calloc = function() {
- return (Module._calloc = Module.asm.calloc).apply(null, arguments);
- }, Module._realloc = function() {
- return (Module._realloc = Module.asm.realloc).apply(null, arguments);
- }, Module._free = function() {
- return (Module._free = Module.asm.free).apply(null, arguments);
- }, Module._ts_language_symbol_count = function() {
- return (Module._ts_language_symbol_count = Module.asm.ts_language_symbol_count).apply(null, arguments);
- }, Module._ts_language_version = function() {
- return (Module._ts_language_version = Module.asm.ts_language_version).apply(null, arguments);
- }, Module._ts_language_field_count = function() {
- return (Module._ts_language_field_count = Module.asm.ts_language_field_count).apply(null, arguments);
- }, Module._ts_language_symbol_name = function() {
- return (Module._ts_language_symbol_name = Module.asm.ts_language_symbol_name).apply(null, arguments);
- }, Module._ts_language_symbol_for_name = function() {
- return (Module._ts_language_symbol_for_name = Module.asm.ts_language_symbol_for_name).apply(null, arguments);
- }, Module._ts_language_symbol_type = function() {
- return (Module._ts_language_symbol_type = Module.asm.ts_language_symbol_type).apply(null, arguments);
- }, Module._ts_language_field_name_for_id = function() {
- return (Module._ts_language_field_name_for_id = Module.asm.ts_language_field_name_for_id).apply(null, arguments);
- }, Module._memcpy = function() {
- return (Module._memcpy = Module.asm.memcpy).apply(null, arguments);
- }, Module._ts_parser_delete = function() {
- return (Module._ts_parser_delete = Module.asm.ts_parser_delete).apply(null, arguments);
- }, Module._ts_parser_reset = function() {
- return (Module._ts_parser_reset = Module.asm.ts_parser_reset).apply(null, arguments);
- }, Module._ts_parser_set_language = function() {
- return (Module._ts_parser_set_language = Module.asm.ts_parser_set_language).apply(null, arguments);
- }, Module._ts_parser_timeout_micros = function() {
- return (Module._ts_parser_timeout_micros = Module.asm.ts_parser_timeout_micros).apply(null, arguments);
- }, Module._ts_parser_set_timeout_micros = function() {
- return (Module._ts_parser_set_timeout_micros = Module.asm.ts_parser_set_timeout_micros).apply(null, arguments);
- }, Module._memmove = function() {
- return (Module._memmove = Module.asm.memmove).apply(null, arguments);
- }, Module._memcmp = function() {
- return (Module._memcmp = Module.asm.memcmp).apply(null, arguments);
- }, Module._ts_query_new = function() {
- return (Module._ts_query_new = Module.asm.ts_query_new).apply(null, arguments);
- }, Module._ts_query_delete = function() {
- return (Module._ts_query_delete = Module.asm.ts_query_delete).apply(null, arguments);
- }, Module._iswspace = function() {
- return (Module._iswspace = Module.asm.iswspace).apply(null, arguments);
- }, Module._iswalnum = function() {
- return (Module._iswalnum = Module.asm.iswalnum).apply(null, arguments);
- }, Module._ts_query_pattern_count = function() {
- return (Module._ts_query_pattern_count = Module.asm.ts_query_pattern_count).apply(null, arguments);
- }, Module._ts_query_capture_count = function() {
- return (Module._ts_query_capture_count = Module.asm.ts_query_capture_count).apply(null, arguments);
- }, Module._ts_query_string_count = function() {
- return (Module._ts_query_string_count = Module.asm.ts_query_string_count).apply(null, arguments);
- }, Module._ts_query_capture_name_for_id = function() {
- return (Module._ts_query_capture_name_for_id = Module.asm.ts_query_capture_name_for_id).apply(null, arguments);
- }, Module._ts_query_string_value_for_id = function() {
- return (Module._ts_query_string_value_for_id = Module.asm.ts_query_string_value_for_id).apply(null, arguments);
- }, Module._ts_query_predicates_for_pattern = function() {
- return (Module._ts_query_predicates_for_pattern = Module.asm.ts_query_predicates_for_pattern).apply(null, arguments);
- }, Module._ts_tree_copy = function() {
- return (Module._ts_tree_copy = Module.asm.ts_tree_copy).apply(null, arguments);
- }, Module._ts_tree_delete = function() {
- return (Module._ts_tree_delete = Module.asm.ts_tree_delete).apply(null, arguments);
- }, Module._ts_init = function() {
- return (Module._ts_init = Module.asm.ts_init).apply(null, arguments);
- }, Module._ts_parser_new_wasm = function() {
- return (Module._ts_parser_new_wasm = Module.asm.ts_parser_new_wasm).apply(null, arguments);
- }, Module._ts_parser_enable_logger_wasm = function() {
- return (Module._ts_parser_enable_logger_wasm = Module.asm.ts_parser_enable_logger_wasm).apply(null, arguments);
- }, Module._ts_parser_parse_wasm = function() {
- return (Module._ts_parser_parse_wasm = Module.asm.ts_parser_parse_wasm).apply(null, arguments);
- }, Module._ts_language_type_is_named_wasm = function() {
- return (Module._ts_language_type_is_named_wasm = Module.asm.ts_language_type_is_named_wasm).apply(null, arguments);
- }, Module._ts_language_type_is_visible_wasm = function() {
- return (Module._ts_language_type_is_visible_wasm = Module.asm.ts_language_type_is_visible_wasm).apply(null, arguments);
- }, Module._ts_tree_root_node_wasm = function() {
- return (Module._ts_tree_root_node_wasm = Module.asm.ts_tree_root_node_wasm).apply(null, arguments);
- }, Module._ts_tree_edit_wasm = function() {
- return (Module._ts_tree_edit_wasm = Module.asm.ts_tree_edit_wasm).apply(null, arguments);
- }, Module._ts_tree_get_changed_ranges_wasm = function() {
- return (Module._ts_tree_get_changed_ranges_wasm = Module.asm.ts_tree_get_changed_ranges_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_new_wasm = function() {
- return (Module._ts_tree_cursor_new_wasm = Module.asm.ts_tree_cursor_new_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_delete_wasm = function() {
- return (Module._ts_tree_cursor_delete_wasm = Module.asm.ts_tree_cursor_delete_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_reset_wasm = function() {
- return (Module._ts_tree_cursor_reset_wasm = Module.asm.ts_tree_cursor_reset_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_goto_first_child_wasm = function() {
- return (Module._ts_tree_cursor_goto_first_child_wasm = Module.asm.ts_tree_cursor_goto_first_child_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_goto_next_sibling_wasm = function() {
- return (Module._ts_tree_cursor_goto_next_sibling_wasm = Module.asm.ts_tree_cursor_goto_next_sibling_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_goto_parent_wasm = function() {
- return (Module._ts_tree_cursor_goto_parent_wasm = Module.asm.ts_tree_cursor_goto_parent_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_current_node_type_id_wasm = function() {
- return (Module._ts_tree_cursor_current_node_type_id_wasm = Module.asm.ts_tree_cursor_current_node_type_id_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_current_node_is_named_wasm = function() {
- return (Module._ts_tree_cursor_current_node_is_named_wasm = Module.asm.ts_tree_cursor_current_node_is_named_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_current_node_is_missing_wasm = function() {
- return (Module._ts_tree_cursor_current_node_is_missing_wasm = Module.asm.ts_tree_cursor_current_node_is_missing_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_current_node_id_wasm = function() {
- return (Module._ts_tree_cursor_current_node_id_wasm = Module.asm.ts_tree_cursor_current_node_id_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_start_position_wasm = function() {
- return (Module._ts_tree_cursor_start_position_wasm = Module.asm.ts_tree_cursor_start_position_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_end_position_wasm = function() {
- return (Module._ts_tree_cursor_end_position_wasm = Module.asm.ts_tree_cursor_end_position_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_start_index_wasm = function() {
- return (Module._ts_tree_cursor_start_index_wasm = Module.asm.ts_tree_cursor_start_index_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_end_index_wasm = function() {
- return (Module._ts_tree_cursor_end_index_wasm = Module.asm.ts_tree_cursor_end_index_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_current_field_id_wasm = function() {
- return (Module._ts_tree_cursor_current_field_id_wasm = Module.asm.ts_tree_cursor_current_field_id_wasm).apply(null, arguments);
- }, Module._ts_tree_cursor_current_node_wasm = function() {
- return (Module._ts_tree_cursor_current_node_wasm = Module.asm.ts_tree_cursor_current_node_wasm).apply(null, arguments);
- }, Module._ts_node_symbol_wasm = function() {
- return (Module._ts_node_symbol_wasm = Module.asm.ts_node_symbol_wasm).apply(null, arguments);
- }, Module._ts_node_child_count_wasm = function() {
- return (Module._ts_node_child_count_wasm = Module.asm.ts_node_child_count_wasm).apply(null, arguments);
- }, Module._ts_node_named_child_count_wasm = function() {
- return (Module._ts_node_named_child_count_wasm = Module.asm.ts_node_named_child_count_wasm).apply(null, arguments);
- }, Module._ts_node_child_wasm = function() {
- return (Module._ts_node_child_wasm = Module.asm.ts_node_child_wasm).apply(null, arguments);
- }, Module._ts_node_named_child_wasm = function() {
- return (Module._ts_node_named_child_wasm = Module.asm.ts_node_named_child_wasm).apply(null, arguments);
- }, Module._ts_node_child_by_field_id_wasm = function() {
- return (Module._ts_node_child_by_field_id_wasm = Module.asm.ts_node_child_by_field_id_wasm).apply(null, arguments);
- }, Module._ts_node_next_sibling_wasm = function() {
- return (Module._ts_node_next_sibling_wasm = Module.asm.ts_node_next_sibling_wasm).apply(null, arguments);
- }, Module._ts_node_prev_sibling_wasm = function() {
- return (Module._ts_node_prev_sibling_wasm = Module.asm.ts_node_prev_sibling_wasm).apply(null, arguments);
- }, Module._ts_node_next_named_sibling_wasm = function() {
- return (Module._ts_node_next_named_sibling_wasm = Module.asm.ts_node_next_named_sibling_wasm).apply(null, arguments);
- }, Module._ts_node_prev_named_sibling_wasm = function() {
- return (Module._ts_node_prev_named_sibling_wasm = Module.asm.ts_node_prev_named_sibling_wasm).apply(null, arguments);
- }, Module._ts_node_parent_wasm = function() {
- return (Module._ts_node_parent_wasm = Module.asm.ts_node_parent_wasm).apply(null, arguments);
- }, Module._ts_node_descendant_for_index_wasm = function() {
- return (Module._ts_node_descendant_for_index_wasm = Module.asm.ts_node_descendant_for_index_wasm).apply(null, arguments);
- }, Module._ts_node_named_descendant_for_index_wasm = function() {
- return (Module._ts_node_named_descendant_for_index_wasm = Module.asm.ts_node_named_descendant_for_index_wasm).apply(null, arguments);
- }, Module._ts_node_descendant_for_position_wasm = function() {
- return (Module._ts_node_descendant_for_position_wasm = Module.asm.ts_node_descendant_for_position_wasm).apply(null, arguments);
- }, Module._ts_node_named_descendant_for_position_wasm = function() {
- return (Module._ts_node_named_descendant_for_position_wasm = Module.asm.ts_node_named_descendant_for_position_wasm).apply(null, arguments);
- }, Module._ts_node_start_point_wasm = function() {
- return (Module._ts_node_start_point_wasm = Module.asm.ts_node_start_point_wasm).apply(null, arguments);
- }, Module._ts_node_end_point_wasm = function() {
- return (Module._ts_node_end_point_wasm = Module.asm.ts_node_end_point_wasm).apply(null, arguments);
- }, Module._ts_node_start_index_wasm = function() {
- return (Module._ts_node_start_index_wasm = Module.asm.ts_node_start_index_wasm).apply(null, arguments);
- }, Module._ts_node_end_index_wasm = function() {
- return (Module._ts_node_end_index_wasm = Module.asm.ts_node_end_index_wasm).apply(null, arguments);
- }, Module._ts_node_to_string_wasm = function() {
- return (Module._ts_node_to_string_wasm = Module.asm.ts_node_to_string_wasm).apply(null, arguments);
- }, Module._ts_node_children_wasm = function() {
- return (Module._ts_node_children_wasm = Module.asm.ts_node_children_wasm).apply(null, arguments);
- }, Module._ts_node_named_children_wasm = function() {
- return (Module._ts_node_named_children_wasm = Module.asm.ts_node_named_children_wasm).apply(null, arguments);
- }, Module._ts_node_descendants_of_type_wasm = function() {
- return (Module._ts_node_descendants_of_type_wasm = Module.asm.ts_node_descendants_of_type_wasm).apply(null, arguments);
- }, Module._ts_node_is_named_wasm = function() {
- return (Module._ts_node_is_named_wasm = Module.asm.ts_node_is_named_wasm).apply(null, arguments);
- }, Module._ts_node_has_changes_wasm = function() {
- return (Module._ts_node_has_changes_wasm = Module.asm.ts_node_has_changes_wasm).apply(null, arguments);
- }, Module._ts_node_has_error_wasm = function() {
- return (Module._ts_node_has_error_wasm = Module.asm.ts_node_has_error_wasm).apply(null, arguments);
- }, Module._ts_node_is_missing_wasm = function() {
- return (Module._ts_node_is_missing_wasm = Module.asm.ts_node_is_missing_wasm).apply(null, arguments);
- }, Module._ts_query_matches_wasm = function() {
- return (Module._ts_query_matches_wasm = Module.asm.ts_query_matches_wasm).apply(null, arguments);
- }, Module._ts_query_captures_wasm = function() {
- return (Module._ts_query_captures_wasm = Module.asm.ts_query_captures_wasm).apply(null, arguments);
- }, Module._iswdigit = function() {
- return (Module._iswdigit = Module.asm.iswdigit).apply(null, arguments);
- }, Module._iswalpha = function() {
- return (Module._iswalpha = Module.asm.iswalpha).apply(null, arguments);
- }, Module._iswlower = function() {
- return (Module._iswlower = Module.asm.iswlower).apply(null, arguments);
- }, Module._towupper = function() {
- return (Module._towupper = Module.asm.towupper).apply(null, arguments);
- }, Module.___errno_location = function() {
- return (Ue = Module.___errno_location = Module.asm.__errno_location).apply(null, arguments);
- }), He = (Module._memchr = function() {
- return (Module._memchr = Module.asm.memchr).apply(null, arguments);
- }, Module._strlen = function() {
- return (Module._strlen = Module.asm.strlen).apply(null, arguments);
- }, Module.stackSave = function() {
- return (He = Module.stackSave = Module.asm.stackSave).apply(null, arguments);
- }), Ge = Module.stackRestore = function() {
- return (Ge = Module.stackRestore = Module.asm.stackRestore).apply(null, arguments);
- }, Be = Module.stackAlloc = function() {
- return (Be = Module.stackAlloc = Module.asm.stackAlloc).apply(null, arguments);
- }, Ke = Module._setThrew = function() {
- return (Ke = Module._setThrew = Module.asm.setThrew).apply(null, arguments);
};
- Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEED2Ev = function() {
- return (Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEED2Ev = Module.asm._ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEED2Ev).apply(null, arguments);
- }, Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE9__grow_byEmmmmmm = function() {
- return (Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE9__grow_byEmmmmmm = Module.asm._ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE9__grow_byEmmmmmm).apply(null, arguments);
- }, Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE6__initEPKcm = function() {
- return (Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE6__initEPKcm = Module.asm._ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE6__initEPKcm).apply(null, arguments);
- }, Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE7reserveEm = function() {
- return (Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE7reserveEm = Module.asm._ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE7reserveEm).apply(null, arguments);
- }, Module.__ZNKSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE4copyEPcmm = function() {
- return (Module.__ZNKSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE4copyEPcmm = Module.asm._ZNKSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE4copyEPcmm).apply(null, arguments);
- }, Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE9push_backEc = function() {
- return (Module.__ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE9push_backEc = Module.asm._ZNSt3__212basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE9push_backEc).apply(null, arguments);
- }, Module.__ZNSt3__212basic_stringIwNS_11char_traitsIwEENS_9allocatorIwEEED2Ev = function() {
- return (Module.__ZNSt3__212basic_stringIwNS_11char_traitsIwEENS_9allocatorIwEEED2Ev = Module.asm._ZNSt3__212basic_stringIwNS_11char_traitsIwEENS_9allocatorIwEEED2Ev).apply(null, arguments);
- }, Module.__ZNSt3__212basic_stringIwNS_11char_traitsIwEENS_9allocatorIwEEE9push_backEw = function() {
- return (Module.__ZNSt3__212basic_stringIwNS_11char_traitsIwEENS_9allocatorIwEEE9push_backEw = Module.asm._ZNSt3__212basic_stringIwNS_11char_traitsIwEENS_9allocatorIwEEE9push_backEw).apply(null, arguments);
- }, Module.__Znwm = function() {
- return (Module.__Znwm = Module.asm._Znwm).apply(null, arguments);
- }, Module.__ZdlPv = function() {
- return (Module.__ZdlPv = Module.asm._ZdlPv).apply(null, arguments);
- }, Module.dynCall_jiji = function() {
- return (Module.dynCall_jiji = Module.asm.dynCall_jiji).apply(null, arguments);
- }, Module._orig$ts_parser_timeout_micros = function() {
- return (Module._orig$ts_parser_timeout_micros = Module.asm.orig$ts_parser_timeout_micros).apply(null, arguments);
- }, Module._orig$ts_parser_set_timeout_micros = function() {
- return (Module._orig$ts_parser_set_timeout_micros = Module.asm.orig$ts_parser_set_timeout_micros).apply(null, arguments);
+ var loadDylibs = () => {
+ if (!dynamicLibraries.length) {
+ reportUndefinedSymbols();
+ return;
+ }
+ // Load binaries asynchronously
+ addRunDependency("loadDylibs");
+ dynamicLibraries.reduce((chain, lib) => chain.then(() => loadDynamicLibrary(lib, {
+ loadAsync: true,
+ global: true,
+ nodelete: true,
+ allowUndefined: true
+ })), Promise.resolve()).then(() => {
+ // we got them all, wonderful
+ reportUndefinedSymbols();
+ removeRunDependency("loadDylibs");
+ });
};
-
- function Ve (e) {
- this.name = "ExitStatus", this.message = "Program terminated with exit(" + e + ")", this.status = e;
+ var noExitRuntime = Module["noExitRuntime"] || true;
+ /**
+ * @param {number} ptr
+ * @param {number} value
+ * @param {string} type
+ */ function setValue(ptr, value, type = "i8") {
+ if (type.endsWith("*")) type = "*";
+ switch (type) {
+ case "i1":
+ HEAP8[ptr] = value;
+ break;
+
+ case "i8":
+ HEAP8[ptr] = value;
+ break;
+
+ case "i16":
+ LE_HEAP_STORE_I16(((ptr) >> 1) * 2, value);
+ break;
+
+ case "i32":
+ LE_HEAP_STORE_I32(((ptr) >> 2) * 4, value);
+ break;
+
+ case "i64":
+ abort("to do setValue(i64) use WASM_BIGINT");
+
+ case "float":
+ LE_HEAP_STORE_F32(((ptr) >> 2) * 4, value);
+ break;
+
+ case "double":
+ LE_HEAP_STORE_F64(((ptr) >> 3) * 8, value);
+ break;
+
+ case "*":
+ LE_HEAP_STORE_U32(((ptr) >> 2) * 4, value);
+ break;
+
+ default:
+ abort(`invalid type for setValue: ${type}`);
+ }
}
-
- Module.allocate = function(e, t) {
- var r;
- return r = t == F ? Be(e.length) : ze(e.length), e.subarray || e.slice ? T.set(e, r) : T.set(new Uint8Array(e), r), r;
+ var ___memory_base = new WebAssembly.Global({
+ "value": "i32",
+ "mutable": false
+ }, 1024);
+ var ___stack_pointer = new WebAssembly.Global({
+ "value": "i32",
+ "mutable": true
+ }, 78112);
+ var ___table_base = new WebAssembly.Global({
+ "value": "i32",
+ "mutable": false
+ }, 1);
+ var __abort_js = () => {
+ abort("");
};
- re = function e () {
- Ze || Qe(), Ze || (re = e);
+ __abort_js.sig = "v";
+ var nowIsMonotonic = 1;
+ var __emscripten_get_now_is_monotonic = () => nowIsMonotonic;
+ __emscripten_get_now_is_monotonic.sig = "i";
+ var __emscripten_memcpy_js = (dest, src, num) => HEAPU8.copyWithin(dest, src, src + num);
+ __emscripten_memcpy_js.sig = "vppp";
+ var _emscripten_date_now = () => Date.now();
+ _emscripten_date_now.sig = "d";
+ var _emscripten_get_now;
+ // Modern environment where performance.now() is supported:
+ // N.B. a shorter form "_emscripten_get_now = performance.now;" is
+ // unfortunately not allowed even in current browsers (e.g. FF Nightly 75).
+ _emscripten_get_now = () => performance.now();
+ _emscripten_get_now.sig = "d";
+ var getHeapMax = () => // Stay one Wasm page short of 4GB: while e.g. Chrome is able to allocate
+ // full 4GB Wasm memories, the size will wrap back to 0 bytes in Wasm side
+ // for any code that deals with heap sizes, which would require special
+ // casing all heap size related code to treat 0 specially.
+ 2147483648;
+ var growMemory = size => {
+ var b = wasmMemory.buffer;
+ var pages = (size - b.byteLength + 65535) / 65536;
+ try {
+ // round size grow request up to wasm page size (fixed 64KB per spec)
+ wasmMemory.grow(pages);
+ // .grow() takes a delta compared to the previous size
+ updateMemoryViews();
+ return 1;
+ } /*success*/ catch (e) {}
};
- var Xe = !1;
-
- function Qe (e) {
- function t () {
- Ze || (Ze = !0, Module.calledRun = !0, P || (Y = !0, pe(X), pe(Q), Module.onRuntimeInitialized && Module.onRuntimeInitialized(), Ye && function(e) {
- var t = Module._main;
- if (t) {
- var r = (e = e || []).length + 1, n = Be(4 * (r + 1));
- W[n >> 2] = H(a);
- for (var o = 1; o < r; o++) W[(n >> 2) + o] = H(e[o - 1]);
- W[(n >> 2) + r] = 0;
- try {
- Je(t(r, n), !0);
- }
- catch (e) {
- if (e instanceof Ve) {
- return;
- }
- if ("unwind" == e) {
- return;
- }
- var s = e;
- e && "object" == typeof e && e.stack && (s = [e, e.stack]), g("exception thrown: " + s), i(1, e);
- } finally {
- !0;
- }
- }
- }(e), function() {
- if (Module.postRun) {
- for ("function" == typeof Module.postRun && (Module.postRun = [Module.postRun]); Module.postRun.length;) e = Module.postRun.shift(), J.unshift(e);
- }
- var e;
- pe(J);
- }()));
- }
-
- e = e || _, ee > 0 || !Xe && (function() {
- if (S.length) {
- if (!m) {
- return ne(), void S.reduce(function(e, t) {
- return e.then(function() {
- return Ne(t, { loadAsync: !0, global: !0, nodelete: !0, allowUndefined: !0 });
- });
- }, Promise.resolve()).then(function() {
- oe(), Pe();
- });
- }
- S.forEach(function(e) {
- Ne(e, { global: !0, nodelete: !0, allowUndefined: !0 });
- }), Pe();
- }
- else {
- Pe();
- }
- }(), Xe = !0, ee > 0) || (!function() {
- if (Module.preRun) {
- for ("function" == typeof Module.preRun && (Module.preRun = [Module.preRun]); Module.preRun.length;) e = Module.preRun.shift(), V.unshift(e);
- }
- var e;
- pe(V);
- }(), ee > 0 || (Module.setStatus ? (Module.setStatus("Running..."), setTimeout(function() {
- setTimeout(function() {
- Module.setStatus("");
- }, 1), t();
- }, 1)) : t()));
+ // implicit 0 return to save code size (caller will cast "undefined" into 0
+ // anyhow)
+ var _emscripten_resize_heap = requestedSize => {
+ var oldSize = HEAPU8.length;
+ // With CAN_ADDRESS_2GB or MEMORY64, pointers are already unsigned.
+ requestedSize >>>= 0;
+ // With multithreaded builds, races can happen (another thread might increase the size
+ // in between), so return a failure, and let the caller retry.
+ // Memory resize rules:
+ // 1. Always increase heap size to at least the requested size, rounded up
+ // to next page multiple.
+ // 2a. If MEMORY_GROWTH_LINEAR_STEP == -1, excessively resize the heap
+ // geometrically: increase the heap size according to
+ // MEMORY_GROWTH_GEOMETRIC_STEP factor (default +20%), At most
+ // overreserve by MEMORY_GROWTH_GEOMETRIC_CAP bytes (default 96MB).
+ // 2b. If MEMORY_GROWTH_LINEAR_STEP != -1, excessively resize the heap
+ // linearly: increase the heap size by at least
+ // MEMORY_GROWTH_LINEAR_STEP bytes.
+ // 3. Max size for the heap is capped at 2048MB-WASM_PAGE_SIZE, or by
+ // MAXIMUM_MEMORY, or by ASAN limit, depending on which is smallest
+ // 4. If we were unable to allocate as much memory, it may be due to
+ // over-eager decision to excessively reserve due to (3) above.
+ // Hence if an allocation fails, cut down on the amount of excess
+ // growth, in an attempt to succeed to perform a smaller allocation.
+ // A limit is set for how much we can grow. We should not exceed that
+ // (the wasm binary specifies it, so if we tried, we'd fail anyhow).
+ var maxHeapSize = getHeapMax();
+ if (requestedSize > maxHeapSize) {
+ return false;
+ }
+ var alignUp = (x, multiple) => x + (multiple - x % multiple) % multiple;
+ // Loop through potential heap size increases. If we attempt a too eager
+ // reservation that fails, cut down on the attempted size and reserve a
+ // smaller bump instead. (max 3 times, chosen somewhat arbitrarily)
+ for (var cutDown = 1; cutDown <= 4; cutDown *= 2) {
+ var overGrownHeapSize = oldSize * (1 + .2 / cutDown);
+ // ensure geometric growth
+ // but limit overreserving (default to capping at +96MB overgrowth at most)
+ overGrownHeapSize = Math.min(overGrownHeapSize, requestedSize + 100663296);
+ var newSize = Math.min(maxHeapSize, alignUp(Math.max(requestedSize, overGrownHeapSize), 65536));
+ var replacement = growMemory(newSize);
+ if (replacement) {
+ return true;
+ }
+ }
+ return false;
+ };
+ _emscripten_resize_heap.sig = "ip";
+ var _fd_close = fd => 52;
+ _fd_close.sig = "ii";
+ var convertI32PairToI53Checked = (lo, hi) => ((hi + 2097152) >>> 0 < 4194305 - !!lo) ? (lo >>> 0) + hi * 4294967296 : NaN;
+ function _fd_seek(fd, offset_low, offset_high, whence, newOffset) {
+ var offset = convertI32PairToI53Checked(offset_low, offset_high);
+ return 70;
}
-
- function Je (e, t) {
- e, t && we() && 0 === e || (we() || (!0, Module.onExit && Module.onExit(e), P = !0), i(e, new Ve(e)));
+ _fd_seek.sig = "iiiiip";
+ var printCharBuffers = [ null, [], [] ];
+ var printChar = (stream, curr) => {
+ var buffer = printCharBuffers[stream];
+ if (curr === 0 || curr === 10) {
+ (stream === 1 ? out : err)(UTF8ArrayToString(buffer, 0));
+ buffer.length = 0;
+ } else {
+ buffer.push(curr);
+ }
+ };
+ var _fd_write = (fd, iov, iovcnt, pnum) => {
+ // hack to support printf in SYSCALLS_REQUIRE_FILESYSTEM=0
+ var num = 0;
+ for (var i = 0; i < iovcnt; i++) {
+ var ptr = LE_HEAP_LOAD_U32(((iov) >> 2) * 4);
+ var len = LE_HEAP_LOAD_U32((((iov) + (4)) >> 2) * 4);
+ iov += 8;
+ for (var j = 0; j < len; j++) {
+ printChar(fd, HEAPU8[ptr + j]);
+ }
+ num += len;
+ }
+ LE_HEAP_STORE_U32(((pnum) >> 2) * 4, num);
+ return 0;
+ };
+ _fd_write.sig = "iippp";
+ function _tree_sitter_log_callback(isLexMessage, messageAddress) {
+ if (currentLogCallback) {
+ const message = UTF8ToString(messageAddress);
+ currentLogCallback(message, isLexMessage !== 0);
+ }
}
-
- if (Module.run = Qe, Module.preInit) {
- for ("function" == typeof Module.preInit && (Module.preInit = [Module.preInit]); Module.preInit.length > 0;) Module.preInit.pop()();
+ function _tree_sitter_parse_callback(inputBufferAddress, index, row, column, lengthAddress) {
+ const INPUT_BUFFER_SIZE = 10 * 1024;
+ const string = currentParseCallback(index, {
+ row: row,
+ column: column
+ });
+ if (typeof string === "string") {
+ setValue(lengthAddress, string.length, "i32");
+ stringToUTF16(string, inputBufferAddress, INPUT_BUFFER_SIZE);
+ } else {
+ setValue(lengthAddress, 0, "i32");
+ }
}
- var Ye = !0;
- Module.noInitialRun && (Ye = !1), Qe();
- const et = Module, tt = {}, rt = 4, nt = 5 * rt, ot = 2 * rt, st = 2 * rt + 2 * ot, _t = { row: 0, column: 0 },
- at = /[\w-.]*/g, it = 1, ut = 2, lt = /^_?tree_sitter_\w+/;
- var dt, ct, mt, ft, pt;
-
- class ParserImpl {
- static init () {
- mt = et._ts_init(), dt = N(mt, "i32"), ct = N(mt + rt, "i32");
+ var runtimeKeepaliveCounter = 0;
+ var keepRuntimeAlive = () => noExitRuntime || runtimeKeepaliveCounter > 0;
+ var _proc_exit = code => {
+ EXITSTATUS = code;
+ if (!keepRuntimeAlive()) {
+ Module["onExit"]?.(code);
+ ABORT = true;
+ }
+ quit_(code, new ExitStatus(code));
+ };
+ _proc_exit.sig = "vi";
+ /** @param {boolean|number=} implicit */ var exitJS = (status, implicit) => {
+ EXITSTATUS = status;
+ _proc_exit(status);
+ };
+ var handleException = e => {
+ // Certain exception types we do not treat as errors since they are used for
+ // internal control flow.
+ // 1. ExitStatus, which is thrown by exit()
+ // 2. "unwind", which is thrown by emscripten_unwind_to_js_event_loop() and others
+ // that wish to return to JS event loop.
+ if (e instanceof ExitStatus || e == "unwind") {
+ return EXITSTATUS;
+ }
+ quit_(1, e);
+ };
+ var lengthBytesUTF8 = str => {
+ var len = 0;
+ for (var i = 0; i < str.length; ++i) {
+ // Gotcha: charCodeAt returns a 16-bit word that is a UTF-16 encoded code
+ // unit, not a Unicode code point of the character! So decode
+ // UTF16->UTF32->UTF8.
+ // See http://unicode.org/faq/utf_bom.html#utf16-3
+ var c = str.charCodeAt(i);
+ // possibly a lead surrogate
+ if (c <= 127) {
+ len++;
+ } else if (c <= 2047) {
+ len += 2;
+ } else if (c >= 55296 && c <= 57343) {
+ len += 4;
+ ++i;
+ } else {
+ len += 3;
+ }
+ }
+ return len;
+ };
+ var stringToUTF8Array = (str, heap, outIdx, maxBytesToWrite) => {
+ // Parameter maxBytesToWrite is not optional. Negative values, 0, null,
+ // undefined and false each don't write out any bytes.
+ if (!(maxBytesToWrite > 0)) return 0;
+ var startIdx = outIdx;
+ var endIdx = outIdx + maxBytesToWrite - 1;
+ // -1 for string null terminator.
+ for (var i = 0; i < str.length; ++i) {
+ // Gotcha: charCodeAt returns a 16-bit word that is a UTF-16 encoded code
+ // unit, not a Unicode code point of the character! So decode
+ // UTF16->UTF32->UTF8.
+ // See http://unicode.org/faq/utf_bom.html#utf16-3
+ // For UTF8 byte structure, see http://en.wikipedia.org/wiki/UTF-8#Description
+ // and https://www.ietf.org/rfc/rfc2279.txt
+ // and https://tools.ietf.org/html/rfc3629
+ var u = str.charCodeAt(i);
+ // possibly a lead surrogate
+ if (u >= 55296 && u <= 57343) {
+ var u1 = str.charCodeAt(++i);
+ u = 65536 + ((u & 1023) << 10) | (u1 & 1023);
+ }
+ if (u <= 127) {
+ if (outIdx >= endIdx) break;
+ heap[outIdx++] = u;
+ } else if (u <= 2047) {
+ if (outIdx + 1 >= endIdx) break;
+ heap[outIdx++] = 192 | (u >> 6);
+ heap[outIdx++] = 128 | (u & 63);
+ } else if (u <= 65535) {
+ if (outIdx + 2 >= endIdx) break;
+ heap[outIdx++] = 224 | (u >> 12);
+ heap[outIdx++] = 128 | ((u >> 6) & 63);
+ heap[outIdx++] = 128 | (u & 63);
+ } else {
+ if (outIdx + 3 >= endIdx) break;
+ heap[outIdx++] = 240 | (u >> 18);
+ heap[outIdx++] = 128 | ((u >> 12) & 63);
+ heap[outIdx++] = 128 | ((u >> 6) & 63);
+ heap[outIdx++] = 128 | (u & 63);
+ }
+ }
+ // Null-terminate the pointer to the buffer.
+ heap[outIdx] = 0;
+ return outIdx - startIdx;
+ };
+ var stringToUTF8 = (str, outPtr, maxBytesToWrite) => stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite);
+ var stackAlloc = sz => __emscripten_stack_alloc(sz);
+ var stringToUTF8OnStack = str => {
+ var size = lengthBytesUTF8(str) + 1;
+ var ret = stackAlloc(size);
+ stringToUTF8(str, ret, size);
+ return ret;
+ };
+ var stringToUTF16 = (str, outPtr, maxBytesToWrite) => {
+ // Backwards compatibility: if max bytes is not specified, assume unsafe unbounded write is allowed.
+ maxBytesToWrite ??= 2147483647;
+ if (maxBytesToWrite < 2) return 0;
+ maxBytesToWrite -= 2;
+ // Null terminator.
+ var startPtr = outPtr;
+ var numCharsToWrite = (maxBytesToWrite < str.length * 2) ? (maxBytesToWrite / 2) : str.length;
+ for (var i = 0; i < numCharsToWrite; ++i) {
+ // charCodeAt returns a UTF-16 encoded code unit, so it can be directly written to the HEAP.
+ var codeUnit = str.charCodeAt(i);
+ // possibly a lead surrogate
+ LE_HEAP_STORE_I16(((outPtr) >> 1) * 2, codeUnit);
+ outPtr += 2;
+ }
+ // Null-terminate the pointer to the HEAP.
+ LE_HEAP_STORE_I16(((outPtr) >> 1) * 2, 0);
+ return outPtr - startPtr;
+ };
+ var AsciiToString = ptr => {
+ var str = "";
+ while (1) {
+ var ch = HEAPU8[ptr++];
+ if (!ch) return str;
+ str += String.fromCharCode(ch);
}
-
- initialize () {
- et._ts_parser_new_wasm(), this[0] = N(mt, "i32"), this[1] = N(mt + rt, "i32");
+ };
+ var wasmImports = {
+ /** @export */ __heap_base: ___heap_base,
+ /** @export */ __indirect_function_table: wasmTable,
+ /** @export */ __memory_base: ___memory_base,
+ /** @export */ __stack_pointer: ___stack_pointer,
+ /** @export */ __table_base: ___table_base,
+ /** @export */ _abort_js: __abort_js,
+ /** @export */ _emscripten_get_now_is_monotonic: __emscripten_get_now_is_monotonic,
+ /** @export */ _emscripten_memcpy_js: __emscripten_memcpy_js,
+ /** @export */ emscripten_get_now: _emscripten_get_now,
+ /** @export */ emscripten_resize_heap: _emscripten_resize_heap,
+ /** @export */ fd_close: _fd_close,
+ /** @export */ fd_seek: _fd_seek,
+ /** @export */ fd_write: _fd_write,
+ /** @export */ memory: wasmMemory,
+ /** @export */ tree_sitter_log_callback: _tree_sitter_log_callback,
+ /** @export */ tree_sitter_parse_callback: _tree_sitter_parse_callback
+ };
+ var wasmExports = createWasm();
+ var ___wasm_call_ctors = () => (___wasm_call_ctors = wasmExports["__wasm_call_ctors"])();
+ var ___wasm_apply_data_relocs = () => (___wasm_apply_data_relocs = wasmExports["__wasm_apply_data_relocs"])();
+ var _malloc = Module["_malloc"] = a0 => (_malloc = Module["_malloc"] = wasmExports["malloc"])(a0);
+ var _calloc = Module["_calloc"] = (a0, a1) => (_calloc = Module["_calloc"] = wasmExports["calloc"])(a0, a1);
+ var _realloc = Module["_realloc"] = (a0, a1) => (_realloc = Module["_realloc"] = wasmExports["realloc"])(a0, a1);
+ var _free = Module["_free"] = a0 => (_free = Module["_free"] = wasmExports["free"])(a0);
+ var _ts_language_symbol_count = Module["_ts_language_symbol_count"] = a0 => (_ts_language_symbol_count = Module["_ts_language_symbol_count"] = wasmExports["ts_language_symbol_count"])(a0);
+ var _ts_language_state_count = Module["_ts_language_state_count"] = a0 => (_ts_language_state_count = Module["_ts_language_state_count"] = wasmExports["ts_language_state_count"])(a0);
+ var _ts_language_version = Module["_ts_language_version"] = a0 => (_ts_language_version = Module["_ts_language_version"] = wasmExports["ts_language_version"])(a0);
+ var _ts_language_field_count = Module["_ts_language_field_count"] = a0 => (_ts_language_field_count = Module["_ts_language_field_count"] = wasmExports["ts_language_field_count"])(a0);
+ var _ts_language_next_state = Module["_ts_language_next_state"] = (a0, a1, a2) => (_ts_language_next_state = Module["_ts_language_next_state"] = wasmExports["ts_language_next_state"])(a0, a1, a2);
+ var _ts_language_symbol_name = Module["_ts_language_symbol_name"] = (a0, a1) => (_ts_language_symbol_name = Module["_ts_language_symbol_name"] = wasmExports["ts_language_symbol_name"])(a0, a1);
+ var _ts_language_symbol_for_name = Module["_ts_language_symbol_for_name"] = (a0, a1, a2, a3) => (_ts_language_symbol_for_name = Module["_ts_language_symbol_for_name"] = wasmExports["ts_language_symbol_for_name"])(a0, a1, a2, a3);
+ var _strncmp = Module["_strncmp"] = (a0, a1, a2) => (_strncmp = Module["_strncmp"] = wasmExports["strncmp"])(a0, a1, a2);
+ var _ts_language_symbol_type = Module["_ts_language_symbol_type"] = (a0, a1) => (_ts_language_symbol_type = Module["_ts_language_symbol_type"] = wasmExports["ts_language_symbol_type"])(a0, a1);
+ var _ts_language_field_name_for_id = Module["_ts_language_field_name_for_id"] = (a0, a1) => (_ts_language_field_name_for_id = Module["_ts_language_field_name_for_id"] = wasmExports["ts_language_field_name_for_id"])(a0, a1);
+ var _ts_lookahead_iterator_new = Module["_ts_lookahead_iterator_new"] = (a0, a1) => (_ts_lookahead_iterator_new = Module["_ts_lookahead_iterator_new"] = wasmExports["ts_lookahead_iterator_new"])(a0, a1);
+ var _ts_lookahead_iterator_delete = Module["_ts_lookahead_iterator_delete"] = a0 => (_ts_lookahead_iterator_delete = Module["_ts_lookahead_iterator_delete"] = wasmExports["ts_lookahead_iterator_delete"])(a0);
+ var _ts_lookahead_iterator_reset_state = Module["_ts_lookahead_iterator_reset_state"] = (a0, a1) => (_ts_lookahead_iterator_reset_state = Module["_ts_lookahead_iterator_reset_state"] = wasmExports["ts_lookahead_iterator_reset_state"])(a0, a1);
+ var _ts_lookahead_iterator_reset = Module["_ts_lookahead_iterator_reset"] = (a0, a1, a2) => (_ts_lookahead_iterator_reset = Module["_ts_lookahead_iterator_reset"] = wasmExports["ts_lookahead_iterator_reset"])(a0, a1, a2);
+ var _ts_lookahead_iterator_next = Module["_ts_lookahead_iterator_next"] = a0 => (_ts_lookahead_iterator_next = Module["_ts_lookahead_iterator_next"] = wasmExports["ts_lookahead_iterator_next"])(a0);
+ var _ts_lookahead_iterator_current_symbol = Module["_ts_lookahead_iterator_current_symbol"] = a0 => (_ts_lookahead_iterator_current_symbol = Module["_ts_lookahead_iterator_current_symbol"] = wasmExports["ts_lookahead_iterator_current_symbol"])(a0);
+ var _memset = Module["_memset"] = (a0, a1, a2) => (_memset = Module["_memset"] = wasmExports["memset"])(a0, a1, a2);
+ var _memcpy = Module["_memcpy"] = (a0, a1, a2) => (_memcpy = Module["_memcpy"] = wasmExports["memcpy"])(a0, a1, a2);
+ var _ts_parser_delete = Module["_ts_parser_delete"] = a0 => (_ts_parser_delete = Module["_ts_parser_delete"] = wasmExports["ts_parser_delete"])(a0);
+ var _ts_parser_reset = Module["_ts_parser_reset"] = a0 => (_ts_parser_reset = Module["_ts_parser_reset"] = wasmExports["ts_parser_reset"])(a0);
+ var _ts_parser_set_language = Module["_ts_parser_set_language"] = (a0, a1) => (_ts_parser_set_language = Module["_ts_parser_set_language"] = wasmExports["ts_parser_set_language"])(a0, a1);
+ var _ts_parser_timeout_micros = Module["_ts_parser_timeout_micros"] = a0 => (_ts_parser_timeout_micros = Module["_ts_parser_timeout_micros"] = wasmExports["ts_parser_timeout_micros"])(a0);
+ var _ts_parser_set_timeout_micros = Module["_ts_parser_set_timeout_micros"] = (a0, a1, a2) => (_ts_parser_set_timeout_micros = Module["_ts_parser_set_timeout_micros"] = wasmExports["ts_parser_set_timeout_micros"])(a0, a1, a2);
+ var _ts_parser_set_included_ranges = Module["_ts_parser_set_included_ranges"] = (a0, a1, a2) => (_ts_parser_set_included_ranges = Module["_ts_parser_set_included_ranges"] = wasmExports["ts_parser_set_included_ranges"])(a0, a1, a2);
+ var _memmove = Module["_memmove"] = (a0, a1, a2) => (_memmove = Module["_memmove"] = wasmExports["memmove"])(a0, a1, a2);
+ var _memcmp = Module["_memcmp"] = (a0, a1, a2) => (_memcmp = Module["_memcmp"] = wasmExports["memcmp"])(a0, a1, a2);
+ var _ts_query_new = Module["_ts_query_new"] = (a0, a1, a2, a3, a4) => (_ts_query_new = Module["_ts_query_new"] = wasmExports["ts_query_new"])(a0, a1, a2, a3, a4);
+ var _ts_query_delete = Module["_ts_query_delete"] = a0 => (_ts_query_delete = Module["_ts_query_delete"] = wasmExports["ts_query_delete"])(a0);
+ var _iswspace = Module["_iswspace"] = a0 => (_iswspace = Module["_iswspace"] = wasmExports["iswspace"])(a0);
+ var _iswalnum = Module["_iswalnum"] = a0 => (_iswalnum = Module["_iswalnum"] = wasmExports["iswalnum"])(a0);
+ var _ts_query_pattern_count = Module["_ts_query_pattern_count"] = a0 => (_ts_query_pattern_count = Module["_ts_query_pattern_count"] = wasmExports["ts_query_pattern_count"])(a0);
+ var _ts_query_capture_count = Module["_ts_query_capture_count"] = a0 => (_ts_query_capture_count = Module["_ts_query_capture_count"] = wasmExports["ts_query_capture_count"])(a0);
+ var _ts_query_string_count = Module["_ts_query_string_count"] = a0 => (_ts_query_string_count = Module["_ts_query_string_count"] = wasmExports["ts_query_string_count"])(a0);
+ var _ts_query_capture_name_for_id = Module["_ts_query_capture_name_for_id"] = (a0, a1, a2) => (_ts_query_capture_name_for_id = Module["_ts_query_capture_name_for_id"] = wasmExports["ts_query_capture_name_for_id"])(a0, a1, a2);
+ var _ts_query_string_value_for_id = Module["_ts_query_string_value_for_id"] = (a0, a1, a2) => (_ts_query_string_value_for_id = Module["_ts_query_string_value_for_id"] = wasmExports["ts_query_string_value_for_id"])(a0, a1, a2);
+ var _ts_query_predicates_for_pattern = Module["_ts_query_predicates_for_pattern"] = (a0, a1, a2) => (_ts_query_predicates_for_pattern = Module["_ts_query_predicates_for_pattern"] = wasmExports["ts_query_predicates_for_pattern"])(a0, a1, a2);
+ var _ts_query_disable_capture = Module["_ts_query_disable_capture"] = (a0, a1, a2) => (_ts_query_disable_capture = Module["_ts_query_disable_capture"] = wasmExports["ts_query_disable_capture"])(a0, a1, a2);
+ var _ts_tree_copy = Module["_ts_tree_copy"] = a0 => (_ts_tree_copy = Module["_ts_tree_copy"] = wasmExports["ts_tree_copy"])(a0);
+ var _ts_tree_delete = Module["_ts_tree_delete"] = a0 => (_ts_tree_delete = Module["_ts_tree_delete"] = wasmExports["ts_tree_delete"])(a0);
+ var _ts_init = Module["_ts_init"] = () => (_ts_init = Module["_ts_init"] = wasmExports["ts_init"])();
+ var _ts_parser_new_wasm = Module["_ts_parser_new_wasm"] = () => (_ts_parser_new_wasm = Module["_ts_parser_new_wasm"] = wasmExports["ts_parser_new_wasm"])();
+ var _ts_parser_enable_logger_wasm = Module["_ts_parser_enable_logger_wasm"] = (a0, a1) => (_ts_parser_enable_logger_wasm = Module["_ts_parser_enable_logger_wasm"] = wasmExports["ts_parser_enable_logger_wasm"])(a0, a1);
+ var _ts_parser_parse_wasm = Module["_ts_parser_parse_wasm"] = (a0, a1, a2, a3, a4) => (_ts_parser_parse_wasm = Module["_ts_parser_parse_wasm"] = wasmExports["ts_parser_parse_wasm"])(a0, a1, a2, a3, a4);
+ var _ts_parser_included_ranges_wasm = Module["_ts_parser_included_ranges_wasm"] = a0 => (_ts_parser_included_ranges_wasm = Module["_ts_parser_included_ranges_wasm"] = wasmExports["ts_parser_included_ranges_wasm"])(a0);
+ var _ts_language_type_is_named_wasm = Module["_ts_language_type_is_named_wasm"] = (a0, a1) => (_ts_language_type_is_named_wasm = Module["_ts_language_type_is_named_wasm"] = wasmExports["ts_language_type_is_named_wasm"])(a0, a1);
+ var _ts_language_type_is_visible_wasm = Module["_ts_language_type_is_visible_wasm"] = (a0, a1) => (_ts_language_type_is_visible_wasm = Module["_ts_language_type_is_visible_wasm"] = wasmExports["ts_language_type_is_visible_wasm"])(a0, a1);
+ var _ts_tree_root_node_wasm = Module["_ts_tree_root_node_wasm"] = a0 => (_ts_tree_root_node_wasm = Module["_ts_tree_root_node_wasm"] = wasmExports["ts_tree_root_node_wasm"])(a0);
+ var _ts_tree_root_node_with_offset_wasm = Module["_ts_tree_root_node_with_offset_wasm"] = a0 => (_ts_tree_root_node_with_offset_wasm = Module["_ts_tree_root_node_with_offset_wasm"] = wasmExports["ts_tree_root_node_with_offset_wasm"])(a0);
+ var _ts_tree_edit_wasm = Module["_ts_tree_edit_wasm"] = a0 => (_ts_tree_edit_wasm = Module["_ts_tree_edit_wasm"] = wasmExports["ts_tree_edit_wasm"])(a0);
+ var _ts_tree_included_ranges_wasm = Module["_ts_tree_included_ranges_wasm"] = a0 => (_ts_tree_included_ranges_wasm = Module["_ts_tree_included_ranges_wasm"] = wasmExports["ts_tree_included_ranges_wasm"])(a0);
+ var _ts_tree_get_changed_ranges_wasm = Module["_ts_tree_get_changed_ranges_wasm"] = (a0, a1) => (_ts_tree_get_changed_ranges_wasm = Module["_ts_tree_get_changed_ranges_wasm"] = wasmExports["ts_tree_get_changed_ranges_wasm"])(a0, a1);
+ var _ts_tree_cursor_new_wasm = Module["_ts_tree_cursor_new_wasm"] = a0 => (_ts_tree_cursor_new_wasm = Module["_ts_tree_cursor_new_wasm"] = wasmExports["ts_tree_cursor_new_wasm"])(a0);
+ var _ts_tree_cursor_delete_wasm = Module["_ts_tree_cursor_delete_wasm"] = a0 => (_ts_tree_cursor_delete_wasm = Module["_ts_tree_cursor_delete_wasm"] = wasmExports["ts_tree_cursor_delete_wasm"])(a0);
+ var _ts_tree_cursor_reset_wasm = Module["_ts_tree_cursor_reset_wasm"] = a0 => (_ts_tree_cursor_reset_wasm = Module["_ts_tree_cursor_reset_wasm"] = wasmExports["ts_tree_cursor_reset_wasm"])(a0);
+ var _ts_tree_cursor_reset_to_wasm = Module["_ts_tree_cursor_reset_to_wasm"] = (a0, a1) => (_ts_tree_cursor_reset_to_wasm = Module["_ts_tree_cursor_reset_to_wasm"] = wasmExports["ts_tree_cursor_reset_to_wasm"])(a0, a1);
+ var _ts_tree_cursor_goto_first_child_wasm = Module["_ts_tree_cursor_goto_first_child_wasm"] = a0 => (_ts_tree_cursor_goto_first_child_wasm = Module["_ts_tree_cursor_goto_first_child_wasm"] = wasmExports["ts_tree_cursor_goto_first_child_wasm"])(a0);
+ var _ts_tree_cursor_goto_last_child_wasm = Module["_ts_tree_cursor_goto_last_child_wasm"] = a0 => (_ts_tree_cursor_goto_last_child_wasm = Module["_ts_tree_cursor_goto_last_child_wasm"] = wasmExports["ts_tree_cursor_goto_last_child_wasm"])(a0);
+ var _ts_tree_cursor_goto_first_child_for_index_wasm = Module["_ts_tree_cursor_goto_first_child_for_index_wasm"] = a0 => (_ts_tree_cursor_goto_first_child_for_index_wasm = Module["_ts_tree_cursor_goto_first_child_for_index_wasm"] = wasmExports["ts_tree_cursor_goto_first_child_for_index_wasm"])(a0);
+ var _ts_tree_cursor_goto_first_child_for_position_wasm = Module["_ts_tree_cursor_goto_first_child_for_position_wasm"] = a0 => (_ts_tree_cursor_goto_first_child_for_position_wasm = Module["_ts_tree_cursor_goto_first_child_for_position_wasm"] = wasmExports["ts_tree_cursor_goto_first_child_for_position_wasm"])(a0);
+ var _ts_tree_cursor_goto_next_sibling_wasm = Module["_ts_tree_cursor_goto_next_sibling_wasm"] = a0 => (_ts_tree_cursor_goto_next_sibling_wasm = Module["_ts_tree_cursor_goto_next_sibling_wasm"] = wasmExports["ts_tree_cursor_goto_next_sibling_wasm"])(a0);
+ var _ts_tree_cursor_goto_previous_sibling_wasm = Module["_ts_tree_cursor_goto_previous_sibling_wasm"] = a0 => (_ts_tree_cursor_goto_previous_sibling_wasm = Module["_ts_tree_cursor_goto_previous_sibling_wasm"] = wasmExports["ts_tree_cursor_goto_previous_sibling_wasm"])(a0);
+ var _ts_tree_cursor_goto_descendant_wasm = Module["_ts_tree_cursor_goto_descendant_wasm"] = (a0, a1) => (_ts_tree_cursor_goto_descendant_wasm = Module["_ts_tree_cursor_goto_descendant_wasm"] = wasmExports["ts_tree_cursor_goto_descendant_wasm"])(a0, a1);
+ var _ts_tree_cursor_goto_parent_wasm = Module["_ts_tree_cursor_goto_parent_wasm"] = a0 => (_ts_tree_cursor_goto_parent_wasm = Module["_ts_tree_cursor_goto_parent_wasm"] = wasmExports["ts_tree_cursor_goto_parent_wasm"])(a0);
+ var _ts_tree_cursor_current_node_type_id_wasm = Module["_ts_tree_cursor_current_node_type_id_wasm"] = a0 => (_ts_tree_cursor_current_node_type_id_wasm = Module["_ts_tree_cursor_current_node_type_id_wasm"] = wasmExports["ts_tree_cursor_current_node_type_id_wasm"])(a0);
+ var _ts_tree_cursor_current_node_state_id_wasm = Module["_ts_tree_cursor_current_node_state_id_wasm"] = a0 => (_ts_tree_cursor_current_node_state_id_wasm = Module["_ts_tree_cursor_current_node_state_id_wasm"] = wasmExports["ts_tree_cursor_current_node_state_id_wasm"])(a0);
+ var _ts_tree_cursor_current_node_is_named_wasm = Module["_ts_tree_cursor_current_node_is_named_wasm"] = a0 => (_ts_tree_cursor_current_node_is_named_wasm = Module["_ts_tree_cursor_current_node_is_named_wasm"] = wasmExports["ts_tree_cursor_current_node_is_named_wasm"])(a0);
+ var _ts_tree_cursor_current_node_is_missing_wasm = Module["_ts_tree_cursor_current_node_is_missing_wasm"] = a0 => (_ts_tree_cursor_current_node_is_missing_wasm = Module["_ts_tree_cursor_current_node_is_missing_wasm"] = wasmExports["ts_tree_cursor_current_node_is_missing_wasm"])(a0);
+ var _ts_tree_cursor_current_node_id_wasm = Module["_ts_tree_cursor_current_node_id_wasm"] = a0 => (_ts_tree_cursor_current_node_id_wasm = Module["_ts_tree_cursor_current_node_id_wasm"] = wasmExports["ts_tree_cursor_current_node_id_wasm"])(a0);
+ var _ts_tree_cursor_start_position_wasm = Module["_ts_tree_cursor_start_position_wasm"] = a0 => (_ts_tree_cursor_start_position_wasm = Module["_ts_tree_cursor_start_position_wasm"] = wasmExports["ts_tree_cursor_start_position_wasm"])(a0);
+ var _ts_tree_cursor_end_position_wasm = Module["_ts_tree_cursor_end_position_wasm"] = a0 => (_ts_tree_cursor_end_position_wasm = Module["_ts_tree_cursor_end_position_wasm"] = wasmExports["ts_tree_cursor_end_position_wasm"])(a0);
+ var _ts_tree_cursor_start_index_wasm = Module["_ts_tree_cursor_start_index_wasm"] = a0 => (_ts_tree_cursor_start_index_wasm = Module["_ts_tree_cursor_start_index_wasm"] = wasmExports["ts_tree_cursor_start_index_wasm"])(a0);
+ var _ts_tree_cursor_end_index_wasm = Module["_ts_tree_cursor_end_index_wasm"] = a0 => (_ts_tree_cursor_end_index_wasm = Module["_ts_tree_cursor_end_index_wasm"] = wasmExports["ts_tree_cursor_end_index_wasm"])(a0);
+ var _ts_tree_cursor_current_field_id_wasm = Module["_ts_tree_cursor_current_field_id_wasm"] = a0 => (_ts_tree_cursor_current_field_id_wasm = Module["_ts_tree_cursor_current_field_id_wasm"] = wasmExports["ts_tree_cursor_current_field_id_wasm"])(a0);
+ var _ts_tree_cursor_current_depth_wasm = Module["_ts_tree_cursor_current_depth_wasm"] = a0 => (_ts_tree_cursor_current_depth_wasm = Module["_ts_tree_cursor_current_depth_wasm"] = wasmExports["ts_tree_cursor_current_depth_wasm"])(a0);
+ var _ts_tree_cursor_current_descendant_index_wasm = Module["_ts_tree_cursor_current_descendant_index_wasm"] = a0 => (_ts_tree_cursor_current_descendant_index_wasm = Module["_ts_tree_cursor_current_descendant_index_wasm"] = wasmExports["ts_tree_cursor_current_descendant_index_wasm"])(a0);
+ var _ts_tree_cursor_current_node_wasm = Module["_ts_tree_cursor_current_node_wasm"] = a0 => (_ts_tree_cursor_current_node_wasm = Module["_ts_tree_cursor_current_node_wasm"] = wasmExports["ts_tree_cursor_current_node_wasm"])(a0);
+ var _ts_node_symbol_wasm = Module["_ts_node_symbol_wasm"] = a0 => (_ts_node_symbol_wasm = Module["_ts_node_symbol_wasm"] = wasmExports["ts_node_symbol_wasm"])(a0);
+ var _ts_node_field_name_for_child_wasm = Module["_ts_node_field_name_for_child_wasm"] = (a0, a1) => (_ts_node_field_name_for_child_wasm = Module["_ts_node_field_name_for_child_wasm"] = wasmExports["ts_node_field_name_for_child_wasm"])(a0, a1);
+ var _ts_node_children_by_field_id_wasm = Module["_ts_node_children_by_field_id_wasm"] = (a0, a1) => (_ts_node_children_by_field_id_wasm = Module["_ts_node_children_by_field_id_wasm"] = wasmExports["ts_node_children_by_field_id_wasm"])(a0, a1);
+ var _ts_node_first_child_for_byte_wasm = Module["_ts_node_first_child_for_byte_wasm"] = a0 => (_ts_node_first_child_for_byte_wasm = Module["_ts_node_first_child_for_byte_wasm"] = wasmExports["ts_node_first_child_for_byte_wasm"])(a0);
+ var _ts_node_first_named_child_for_byte_wasm = Module["_ts_node_first_named_child_for_byte_wasm"] = a0 => (_ts_node_first_named_child_for_byte_wasm = Module["_ts_node_first_named_child_for_byte_wasm"] = wasmExports["ts_node_first_named_child_for_byte_wasm"])(a0);
+ var _ts_node_grammar_symbol_wasm = Module["_ts_node_grammar_symbol_wasm"] = a0 => (_ts_node_grammar_symbol_wasm = Module["_ts_node_grammar_symbol_wasm"] = wasmExports["ts_node_grammar_symbol_wasm"])(a0);
+ var _ts_node_child_count_wasm = Module["_ts_node_child_count_wasm"] = a0 => (_ts_node_child_count_wasm = Module["_ts_node_child_count_wasm"] = wasmExports["ts_node_child_count_wasm"])(a0);
+ var _ts_node_named_child_count_wasm = Module["_ts_node_named_child_count_wasm"] = a0 => (_ts_node_named_child_count_wasm = Module["_ts_node_named_child_count_wasm"] = wasmExports["ts_node_named_child_count_wasm"])(a0);
+ var _ts_node_child_wasm = Module["_ts_node_child_wasm"] = (a0, a1) => (_ts_node_child_wasm = Module["_ts_node_child_wasm"] = wasmExports["ts_node_child_wasm"])(a0, a1);
+ var _ts_node_named_child_wasm = Module["_ts_node_named_child_wasm"] = (a0, a1) => (_ts_node_named_child_wasm = Module["_ts_node_named_child_wasm"] = wasmExports["ts_node_named_child_wasm"])(a0, a1);
+ var _ts_node_child_by_field_id_wasm = Module["_ts_node_child_by_field_id_wasm"] = (a0, a1) => (_ts_node_child_by_field_id_wasm = Module["_ts_node_child_by_field_id_wasm"] = wasmExports["ts_node_child_by_field_id_wasm"])(a0, a1);
+ var _ts_node_next_sibling_wasm = Module["_ts_node_next_sibling_wasm"] = a0 => (_ts_node_next_sibling_wasm = Module["_ts_node_next_sibling_wasm"] = wasmExports["ts_node_next_sibling_wasm"])(a0);
+ var _ts_node_prev_sibling_wasm = Module["_ts_node_prev_sibling_wasm"] = a0 => (_ts_node_prev_sibling_wasm = Module["_ts_node_prev_sibling_wasm"] = wasmExports["ts_node_prev_sibling_wasm"])(a0);
+ var _ts_node_next_named_sibling_wasm = Module["_ts_node_next_named_sibling_wasm"] = a0 => (_ts_node_next_named_sibling_wasm = Module["_ts_node_next_named_sibling_wasm"] = wasmExports["ts_node_next_named_sibling_wasm"])(a0);
+ var _ts_node_prev_named_sibling_wasm = Module["_ts_node_prev_named_sibling_wasm"] = a0 => (_ts_node_prev_named_sibling_wasm = Module["_ts_node_prev_named_sibling_wasm"] = wasmExports["ts_node_prev_named_sibling_wasm"])(a0);
+ var _ts_node_descendant_count_wasm = Module["_ts_node_descendant_count_wasm"] = a0 => (_ts_node_descendant_count_wasm = Module["_ts_node_descendant_count_wasm"] = wasmExports["ts_node_descendant_count_wasm"])(a0);
+ var _ts_node_parent_wasm = Module["_ts_node_parent_wasm"] = a0 => (_ts_node_parent_wasm = Module["_ts_node_parent_wasm"] = wasmExports["ts_node_parent_wasm"])(a0);
+ var _ts_node_descendant_for_index_wasm = Module["_ts_node_descendant_for_index_wasm"] = a0 => (_ts_node_descendant_for_index_wasm = Module["_ts_node_descendant_for_index_wasm"] = wasmExports["ts_node_descendant_for_index_wasm"])(a0);
+ var _ts_node_named_descendant_for_index_wasm = Module["_ts_node_named_descendant_for_index_wasm"] = a0 => (_ts_node_named_descendant_for_index_wasm = Module["_ts_node_named_descendant_for_index_wasm"] = wasmExports["ts_node_named_descendant_for_index_wasm"])(a0);
+ var _ts_node_descendant_for_position_wasm = Module["_ts_node_descendant_for_position_wasm"] = a0 => (_ts_node_descendant_for_position_wasm = Module["_ts_node_descendant_for_position_wasm"] = wasmExports["ts_node_descendant_for_position_wasm"])(a0);
+ var _ts_node_named_descendant_for_position_wasm = Module["_ts_node_named_descendant_for_position_wasm"] = a0 => (_ts_node_named_descendant_for_position_wasm = Module["_ts_node_named_descendant_for_position_wasm"] = wasmExports["ts_node_named_descendant_for_position_wasm"])(a0);
+ var _ts_node_start_point_wasm = Module["_ts_node_start_point_wasm"] = a0 => (_ts_node_start_point_wasm = Module["_ts_node_start_point_wasm"] = wasmExports["ts_node_start_point_wasm"])(a0);
+ var _ts_node_end_point_wasm = Module["_ts_node_end_point_wasm"] = a0 => (_ts_node_end_point_wasm = Module["_ts_node_end_point_wasm"] = wasmExports["ts_node_end_point_wasm"])(a0);
+ var _ts_node_start_index_wasm = Module["_ts_node_start_index_wasm"] = a0 => (_ts_node_start_index_wasm = Module["_ts_node_start_index_wasm"] = wasmExports["ts_node_start_index_wasm"])(a0);
+ var _ts_node_end_index_wasm = Module["_ts_node_end_index_wasm"] = a0 => (_ts_node_end_index_wasm = Module["_ts_node_end_index_wasm"] = wasmExports["ts_node_end_index_wasm"])(a0);
+ var _ts_node_to_string_wasm = Module["_ts_node_to_string_wasm"] = a0 => (_ts_node_to_string_wasm = Module["_ts_node_to_string_wasm"] = wasmExports["ts_node_to_string_wasm"])(a0);
+ var _ts_node_children_wasm = Module["_ts_node_children_wasm"] = a0 => (_ts_node_children_wasm = Module["_ts_node_children_wasm"] = wasmExports["ts_node_children_wasm"])(a0);
+ var _ts_node_named_children_wasm = Module["_ts_node_named_children_wasm"] = a0 => (_ts_node_named_children_wasm = Module["_ts_node_named_children_wasm"] = wasmExports["ts_node_named_children_wasm"])(a0);
+ var _ts_node_descendants_of_type_wasm = Module["_ts_node_descendants_of_type_wasm"] = (a0, a1, a2, a3, a4, a5, a6) => (_ts_node_descendants_of_type_wasm = Module["_ts_node_descendants_of_type_wasm"] = wasmExports["ts_node_descendants_of_type_wasm"])(a0, a1, a2, a3, a4, a5, a6);
+ var _ts_node_is_named_wasm = Module["_ts_node_is_named_wasm"] = a0 => (_ts_node_is_named_wasm = Module["_ts_node_is_named_wasm"] = wasmExports["ts_node_is_named_wasm"])(a0);
+ var _ts_node_has_changes_wasm = Module["_ts_node_has_changes_wasm"] = a0 => (_ts_node_has_changes_wasm = Module["_ts_node_has_changes_wasm"] = wasmExports["ts_node_has_changes_wasm"])(a0);
+ var _ts_node_has_error_wasm = Module["_ts_node_has_error_wasm"] = a0 => (_ts_node_has_error_wasm = Module["_ts_node_has_error_wasm"] = wasmExports["ts_node_has_error_wasm"])(a0);
+ var _ts_node_is_error_wasm = Module["_ts_node_is_error_wasm"] = a0 => (_ts_node_is_error_wasm = Module["_ts_node_is_error_wasm"] = wasmExports["ts_node_is_error_wasm"])(a0);
+ var _ts_node_is_missing_wasm = Module["_ts_node_is_missing_wasm"] = a0 => (_ts_node_is_missing_wasm = Module["_ts_node_is_missing_wasm"] = wasmExports["ts_node_is_missing_wasm"])(a0);
+ var _ts_node_is_extra_wasm = Module["_ts_node_is_extra_wasm"] = a0 => (_ts_node_is_extra_wasm = Module["_ts_node_is_extra_wasm"] = wasmExports["ts_node_is_extra_wasm"])(a0);
+ var _ts_node_parse_state_wasm = Module["_ts_node_parse_state_wasm"] = a0 => (_ts_node_parse_state_wasm = Module["_ts_node_parse_state_wasm"] = wasmExports["ts_node_parse_state_wasm"])(a0);
+ var _ts_node_next_parse_state_wasm = Module["_ts_node_next_parse_state_wasm"] = a0 => (_ts_node_next_parse_state_wasm = Module["_ts_node_next_parse_state_wasm"] = wasmExports["ts_node_next_parse_state_wasm"])(a0);
+ var _ts_query_matches_wasm = Module["_ts_query_matches_wasm"] = (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10) => (_ts_query_matches_wasm = Module["_ts_query_matches_wasm"] = wasmExports["ts_query_matches_wasm"])(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10);
+ var _ts_query_captures_wasm = Module["_ts_query_captures_wasm"] = (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10) => (_ts_query_captures_wasm = Module["_ts_query_captures_wasm"] = wasmExports["ts_query_captures_wasm"])(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10);
+ var _iswalpha = Module["_iswalpha"] = a0 => (_iswalpha = Module["_iswalpha"] = wasmExports["iswalpha"])(a0);
+ var _iswblank = Module["_iswblank"] = a0 => (_iswblank = Module["_iswblank"] = wasmExports["iswblank"])(a0);
+ var _iswdigit = Module["_iswdigit"] = a0 => (_iswdigit = Module["_iswdigit"] = wasmExports["iswdigit"])(a0);
+ var _iswlower = Module["_iswlower"] = a0 => (_iswlower = Module["_iswlower"] = wasmExports["iswlower"])(a0);
+ var _iswupper = Module["_iswupper"] = a0 => (_iswupper = Module["_iswupper"] = wasmExports["iswupper"])(a0);
+ var _iswxdigit = Module["_iswxdigit"] = a0 => (_iswxdigit = Module["_iswxdigit"] = wasmExports["iswxdigit"])(a0);
+ var _memchr = Module["_memchr"] = (a0, a1, a2) => (_memchr = Module["_memchr"] = wasmExports["memchr"])(a0, a1, a2);
+ var _strlen = Module["_strlen"] = a0 => (_strlen = Module["_strlen"] = wasmExports["strlen"])(a0);
+ var _strcmp = Module["_strcmp"] = (a0, a1) => (_strcmp = Module["_strcmp"] = wasmExports["strcmp"])(a0, a1);
+ var _strncat = Module["_strncat"] = (a0, a1, a2) => (_strncat = Module["_strncat"] = wasmExports["strncat"])(a0, a1, a2);
+ var _strncpy = Module["_strncpy"] = (a0, a1, a2) => (_strncpy = Module["_strncpy"] = wasmExports["strncpy"])(a0, a1, a2);
+ var _towlower = Module["_towlower"] = a0 => (_towlower = Module["_towlower"] = wasmExports["towlower"])(a0);
+ var _towupper = Module["_towupper"] = a0 => (_towupper = Module["_towupper"] = wasmExports["towupper"])(a0);
+ var _setThrew = (a0, a1) => (_setThrew = wasmExports["setThrew"])(a0, a1);
+ var __emscripten_stack_restore = a0 => (__emscripten_stack_restore = wasmExports["_emscripten_stack_restore"])(a0);
+ var __emscripten_stack_alloc = a0 => (__emscripten_stack_alloc = wasmExports["_emscripten_stack_alloc"])(a0);
+ var _emscripten_stack_get_current = () => (_emscripten_stack_get_current = wasmExports["emscripten_stack_get_current"])();
+ var dynCall_jiji = Module["dynCall_jiji"] = (a0, a1, a2, a3, a4) => (dynCall_jiji = Module["dynCall_jiji"] = wasmExports["dynCall_jiji"])(a0, a1, a2, a3, a4);
+ var _orig$ts_parser_timeout_micros = Module["_orig$ts_parser_timeout_micros"] = a0 => (_orig$ts_parser_timeout_micros = Module["_orig$ts_parser_timeout_micros"] = wasmExports["orig$ts_parser_timeout_micros"])(a0);
+ var _orig$ts_parser_set_timeout_micros = Module["_orig$ts_parser_set_timeout_micros"] = (a0, a1) => (_orig$ts_parser_set_timeout_micros = Module["_orig$ts_parser_set_timeout_micros"] = wasmExports["orig$ts_parser_set_timeout_micros"])(a0, a1);
+ // include: postamble.js
+ // === Auto-generated postamble setup entry stuff ===
+ Module["AsciiToString"] = AsciiToString;
+ Module["stringToUTF16"] = stringToUTF16;
+ var calledRun;
+ dependenciesFulfilled = function runCaller() {
+ // If run has never been called, and we should call run (INVOKE_RUN is true, and Module.noInitialRun is not false)
+ if (!calledRun) run();
+ if (!calledRun) dependenciesFulfilled = runCaller;
+ };
+ // try this again later, after new deps are fulfilled
+ function callMain(args = []) {
+ var entryFunction = resolveGlobalSymbol("main").sym;
+ // Main modules can't tell if they have main() at compile time, since it may
+ // arrive from a dynamic library.
+ if (!entryFunction) return;
+ args.unshift(thisProgram);
+ var argc = args.length;
+ var argv = stackAlloc((argc + 1) * 4);
+ var argv_ptr = argv;
+ args.forEach(arg => {
+ LE_HEAP_STORE_U32(((argv_ptr) >> 2) * 4, stringToUTF8OnStack(arg));
+ argv_ptr += 4;
+ });
+ LE_HEAP_STORE_U32(((argv_ptr) >> 2) * 4, 0);
+ try {
+ var ret = entryFunction(argc, argv);
+ // if we're not running an evented main loop, it's time to exit
+ exitJS(ret, /* implicit = */ true);
+ return ret;
+ } catch (e) {
+ return handleException(e);
}
-
- delete () {
- et._ts_parser_delete(this[0]), et._free(this[1]), this[0] = 0, this[1] = 0;
+ }
+ function run(args = arguments_) {
+ if (runDependencies > 0) {
+ return;
+ }
+ preRun();
+ // a preRun added a dependency, run will be called later
+ if (runDependencies > 0) {
+ return;
+ }
+ function doRun() {
+ // run may have just been called through dependencies being fulfilled just in this very frame,
+ // or while the async setStatus time below was happening
+ if (calledRun) return;
+ calledRun = true;
+ Module["calledRun"] = true;
+ if (ABORT) return;
+ initRuntime();
+ preMain();
+ Module["onRuntimeInitialized"]?.();
+ if (shouldRunNow) callMain(args);
+ postRun();
+ }
+ if (Module["setStatus"]) {
+ Module["setStatus"]("Running...");
+ setTimeout(function() {
+ setTimeout(function() {
+ Module["setStatus"]("");
+ }, 1);
+ doRun();
+ }, 1);
+ } else {
+ doRun();
}
-
- setLanguage (e) {
- let t;
- if (e) {
- if (e.constructor !== Language) {
- throw new Error("Argument must be a Language");
- }
- {
- t = e[0];
- const r = et._ts_language_version(t);
- if (r < ct || dt < r) {
- throw new Error(`Incompatible language version ${r}. ` + `Compatibility range ${ct} through ${dt}.`);
- }
+ }
+ if (Module["preInit"]) {
+ if (typeof Module["preInit"] == "function") Module["preInit"] = [ Module["preInit"] ];
+ while (Module["preInit"].length > 0) {
+ Module["preInit"].pop()();
+ }
+ }
+ // shouldRunNow refers to calling main(), not run().
+ var shouldRunNow = true;
+ if (Module["noInitialRun"]) shouldRunNow = false;
+ run();
+ // end include: postamble.js
+ // include: /src/lib/binding_web/binding.js
+ /* eslint-disable-next-line spaced-comment */ ///
+ /* eslint-disable-next-line spaced-comment */ ///
+ const C = Module;
+ const INTERNAL = {};
+ const SIZE_OF_INT = 4;
+ const SIZE_OF_CURSOR = 4 * SIZE_OF_INT;
+ const SIZE_OF_NODE = 5 * SIZE_OF_INT;
+ const SIZE_OF_POINT = 2 * SIZE_OF_INT;
+ const SIZE_OF_RANGE = 2 * SIZE_OF_INT + 2 * SIZE_OF_POINT;
+ const ZERO_POINT = {
+ row: 0,
+ column: 0
+ };
+ const QUERY_WORD_REGEX = /[\w-.]*/g;
+ const PREDICATE_STEP_TYPE_CAPTURE = 1;
+ const PREDICATE_STEP_TYPE_STRING = 2;
+ const LANGUAGE_FUNCTION_REGEX = /^_?tree_sitter_\w+/;
+ let VERSION;
+ let MIN_COMPATIBLE_VERSION;
+ let TRANSFER_BUFFER;
+ let currentParseCallback;
+ // eslint-disable-next-line no-unused-vars
+ let currentLogCallback;
+ // eslint-disable-next-line no-unused-vars
+ class ParserImpl {
+ static init() {
+ TRANSFER_BUFFER = C._ts_init();
+ VERSION = getValue(TRANSFER_BUFFER, "i32");
+ MIN_COMPATIBLE_VERSION = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ }
+ initialize() {
+ C._ts_parser_new_wasm();
+ this[0] = getValue(TRANSFER_BUFFER, "i32");
+ this[1] = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ }
+ delete() {
+ C._ts_parser_delete(this[0]);
+ C._free(this[1]);
+ this[0] = 0;
+ this[1] = 0;
+ }
+ setLanguage(language) {
+ let address;
+ if (!language) {
+ address = 0;
+ language = null;
+ } else if (language.constructor === Language) {
+ address = language[0];
+ const version = C._ts_language_version(address);
+ if (version < MIN_COMPATIBLE_VERSION || VERSION < version) {
+ throw new Error(`Incompatible language version ${version}. ` + `Compatibility range ${MIN_COMPATIBLE_VERSION} through ${VERSION}.`);
}
+ } else {
+ throw new Error("Argument must be a Language");
}
- else {
- t = 0, e = null;
- }
- return this.language = e, et._ts_parser_set_language(this[0], t), this;
+ this.language = language;
+ C._ts_parser_set_language(this[0], address);
+ return this;
}
-
- getLanguage () {
+ getLanguage() {
return this.language;
}
-
- parse (e, t, r) {
- if ("string" == typeof e) {
- ft = ((t, r, n) => e.slice(t, n));
- }
- else {
- if ("function" != typeof e) {
- throw new Error("Argument must be a string or a function");
+ parse(callback, oldTree, options) {
+ if (typeof callback === "string") {
+ currentParseCallback = (index, _) => callback.slice(index);
+ } else if (typeof callback === "function") {
+ currentParseCallback = callback;
+ } else {
+ throw new Error("Argument must be a string or a function");
+ }
+ if (this.logCallback) {
+ currentLogCallback = this.logCallback;
+ C._ts_parser_enable_logger_wasm(this[0], 1);
+ } else {
+ currentLogCallback = null;
+ C._ts_parser_enable_logger_wasm(this[0], 0);
+ }
+ let rangeCount = 0;
+ let rangeAddress = 0;
+ if (options?.includedRanges) {
+ rangeCount = options.includedRanges.length;
+ rangeAddress = C._calloc(rangeCount, SIZE_OF_RANGE);
+ let address = rangeAddress;
+ for (let i = 0; i < rangeCount; i++) {
+ marshalRange(address, options.includedRanges[i]);
+ address += SIZE_OF_RANGE;
}
- ft = e;
}
- this.logCallback ? (pt = this.logCallback, et._ts_parser_enable_logger_wasm(this[0], 1)) : (pt = null, et._ts_parser_enable_logger_wasm(this[0], 0));
- let n = 0, o = 0;
- if (r && r.includedRanges) {
- n = r.includedRanges.length;
- let e = o = et._calloc(n, st);
- for (let t = 0; t < n; t++) At(e, r.includedRanges[t]), e += st;
- }
- const s = et._ts_parser_parse_wasm(this[0], this[1], t ? t[0] : 0, o, n);
- if (!s) {
- throw ft = null, pt = null, new Error("Parsing failed");
+ const treeAddress = C._ts_parser_parse_wasm(this[0], this[1], oldTree ? oldTree[0] : 0, rangeAddress, rangeCount);
+ if (!treeAddress) {
+ currentParseCallback = null;
+ currentLogCallback = null;
+ throw new Error("Parsing failed");
+ }
+ const result = new Tree(INTERNAL, treeAddress, this.language, currentParseCallback);
+ currentParseCallback = null;
+ currentLogCallback = null;
+ return result;
+ }
+ reset() {
+ C._ts_parser_reset(this[0]);
+ }
+ getIncludedRanges() {
+ C._ts_parser_included_ranges_wasm(this[0]);
+ const count = getValue(TRANSFER_BUFFER, "i32");
+ const buffer = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ const result = new Array(count);
+ if (count > 0) {
+ let address = buffer;
+ for (let i = 0; i < count; i++) {
+ result[i] = unmarshalRange(address);
+ address += SIZE_OF_RANGE;
+ }
+ C._free(buffer);
}
- const _ = new Tree(tt, s, this.language, ft);
- return ft = null, pt = null, _;
+ return result;
}
-
- reset () {
- et._ts_parser_reset(this[0]);
- }
-
- setTimeoutMicros (e) {
- et._ts_parser_set_timeout_micros(this[0], e);
+ getTimeoutMicros() {
+ return C._ts_parser_timeout_micros(this[0]);
}
-
- getTimeoutMicros () {
- return et._ts_parser_timeout_micros(this[0]);
+ setTimeoutMicros(timeout) {
+ C._ts_parser_set_timeout_micros(this[0], timeout);
}
-
- setLogger (e) {
- if (e) {
- if ("function" != typeof e) {
- throw new Error("Logger callback must be a function");
- }
+ setLogger(callback) {
+ if (!callback) {
+ callback = null;
+ } else if (typeof callback !== "function") {
+ throw new Error("Logger callback must be a function");
}
- else {
- e = null;
- }
- return this.logCallback = e, this;
+ this.logCallback = callback;
+ return this;
}
-
- getLogger () {
+ getLogger() {
return this.logCallback;
}
}
-
class Tree {
- constructor (e, t, r, n) {
- wt(e), this[0] = t, this.language = r, this.textCallback = n;
- }
-
- copy () {
- const e = et._ts_tree_copy(this[0]);
- return new Tree(tt, e, this.language, this.textCallback);
- }
-
- delete () {
- et._ts_tree_delete(this[0]), this[0] = 0;
- }
-
- edit (e) {
- !function(e) {
- let t = mt;
- St(t, e.startPosition), St(t += ot, e.oldEndPosition), St(t += ot, e.newEndPosition), x(t += ot, e.startIndex, "i32"), x(t += rt, e.oldEndIndex, "i32"), x(t += rt, e.newEndIndex, "i32"), t += rt;
- }(e), et._ts_tree_edit_wasm(this[0]);
- }
-
- get rootNode () {
- return et._ts_tree_root_node_wasm(this[0]), bt(this);
- }
-
- getLanguage () {
+ constructor(internal, address, language, textCallback) {
+ assertInternal(internal);
+ this[0] = address;
+ this.language = language;
+ this.textCallback = textCallback;
+ }
+ copy() {
+ const address = C._ts_tree_copy(this[0]);
+ return new Tree(INTERNAL, address, this.language, this.textCallback);
+ }
+ delete() {
+ C._ts_tree_delete(this[0]);
+ this[0] = 0;
+ }
+ edit(edit) {
+ marshalEdit(edit);
+ C._ts_tree_edit_wasm(this[0]);
+ }
+ get rootNode() {
+ C._ts_tree_root_node_wasm(this[0]);
+ return unmarshalNode(this);
+ }
+ rootNodeWithOffset(offsetBytes, offsetExtent) {
+ const address = TRANSFER_BUFFER + SIZE_OF_NODE;
+ setValue(address, offsetBytes, "i32");
+ marshalPoint(address + SIZE_OF_INT, offsetExtent);
+ C._ts_tree_root_node_with_offset_wasm(this[0]);
+ return unmarshalNode(this);
+ }
+ getLanguage() {
return this.language;
}
-
- walk () {
+ walk() {
return this.rootNode.walk();
}
-
- getChangedRanges (e) {
- if (e.constructor !== Tree) {
+ getChangedRanges(other) {
+ if (other.constructor !== Tree) {
throw new TypeError("Argument must be a Tree");
}
- et._ts_tree_get_changed_ranges_wasm(this[0], e[0]);
- const t = N(mt, "i32"), r = N(mt + rt, "i32"), n = new Array(t);
- if (t > 0) {
- let e = r;
- for (let r = 0; r < t; r++) n[r] = xt(e), e += st;
- et._free(r);
+ C._ts_tree_get_changed_ranges_wasm(this[0], other[0]);
+ const count = getValue(TRANSFER_BUFFER, "i32");
+ const buffer = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ const result = new Array(count);
+ if (count > 0) {
+ let address = buffer;
+ for (let i = 0; i < count; i++) {
+ result[i] = unmarshalRange(address);
+ address += SIZE_OF_RANGE;
+ }
+ C._free(buffer);
+ }
+ return result;
+ }
+ getIncludedRanges() {
+ C._ts_tree_included_ranges_wasm(this[0]);
+ const count = getValue(TRANSFER_BUFFER, "i32");
+ const buffer = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ const result = new Array(count);
+ if (count > 0) {
+ let address = buffer;
+ for (let i = 0; i < count; i++) {
+ result[i] = unmarshalRange(address);
+ address += SIZE_OF_RANGE;
+ }
+ C._free(buffer);
}
- return n;
+ return result;
}
}
-
class Node {
- constructor (e, t) {
- wt(e), this.tree = t;
+ constructor(internal, tree) {
+ assertInternal(internal);
+ this.tree = tree;
}
-
- get typeId () {
- return yt(this), et._ts_node_symbol_wasm(this.tree[0]);
+ get typeId() {
+ marshalNode(this);
+ return C._ts_node_symbol_wasm(this.tree[0]);
}
-
- get type () {
+ get grammarId() {
+ marshalNode(this);
+ return C._ts_node_grammar_symbol_wasm(this.tree[0]);
+ }
+ get type() {
return this.tree.language.types[this.typeId] || "ERROR";
}
-
- get endPosition () {
- return yt(this), et._ts_node_end_point_wasm(this.tree[0]), It(mt);
+ get grammarType() {
+ return this.tree.language.types[this.grammarId] || "ERROR";
}
-
- get endIndex () {
- return yt(this), et._ts_node_end_index_wasm(this.tree[0]);
+ get endPosition() {
+ marshalNode(this);
+ C._ts_node_end_point_wasm(this.tree[0]);
+ return unmarshalPoint(TRANSFER_BUFFER);
}
-
- get text () {
- return ht(this.tree, this.startIndex, this.endIndex);
+ get endIndex() {
+ marshalNode(this);
+ return C._ts_node_end_index_wasm(this.tree[0]);
}
-
- isNamed () {
- return yt(this), 1 === et._ts_node_is_named_wasm(this.tree[0]);
+ get text() {
+ return getText(this.tree, this.startIndex, this.endIndex);
}
-
- hasError () {
- return yt(this), 1 === et._ts_node_has_error_wasm(this.tree[0]);
+ get parseState() {
+ marshalNode(this);
+ return C._ts_node_parse_state_wasm(this.tree[0]);
}
-
- hasChanges () {
- return yt(this), 1 === et._ts_node_has_changes_wasm(this.tree[0]);
+ get nextParseState() {
+ marshalNode(this);
+ return C._ts_node_next_parse_state_wasm(this.tree[0]);
}
-
- isMissing () {
- return yt(this), 1 === et._ts_node_is_missing_wasm(this.tree[0]);
+ get isNamed() {
+ marshalNode(this);
+ return C._ts_node_is_named_wasm(this.tree[0]) === 1;
}
-
- equals (e) {
- return this.id === e.id;
+ get hasError() {
+ marshalNode(this);
+ return C._ts_node_has_error_wasm(this.tree[0]) === 1;
}
-
- child (e) {
- return yt(this), et._ts_node_child_wasm(this.tree[0], e), bt(this.tree);
+ get hasChanges() {
+ marshalNode(this);
+ return C._ts_node_has_changes_wasm(this.tree[0]) === 1;
}
-
- namedChild (e) {
- return yt(this), et._ts_node_named_child_wasm(this.tree[0], e), bt(this.tree);
+ get isError() {
+ marshalNode(this);
+ return C._ts_node_is_error_wasm(this.tree[0]) === 1;
}
-
- childForFieldId (e) {
- return yt(this), et._ts_node_child_by_field_id_wasm(this.tree[0], e), bt(this.tree);
+ get isMissing() {
+ marshalNode(this);
+ return C._ts_node_is_missing_wasm(this.tree[0]) === 1;
}
-
- childForFieldName (e) {
- const t = this.tree.language.fields.indexOf(e);
- if (-1 !== t) {
- return this.childForFieldId(t);
+ get isExtra() {
+ marshalNode(this);
+ return C._ts_node_is_extra_wasm(this.tree[0]) === 1;
+ }
+ equals(other) {
+ return this.id === other.id;
+ }
+ child(index) {
+ marshalNode(this);
+ C._ts_node_child_wasm(this.tree[0], index);
+ return unmarshalNode(this.tree);
+ }
+ namedChild(index) {
+ marshalNode(this);
+ C._ts_node_named_child_wasm(this.tree[0], index);
+ return unmarshalNode(this.tree);
+ }
+ childForFieldId(fieldId) {
+ marshalNode(this);
+ C._ts_node_child_by_field_id_wasm(this.tree[0], fieldId);
+ return unmarshalNode(this.tree);
+ }
+ childForFieldName(fieldName) {
+ const fieldId = this.tree.language.fields.indexOf(fieldName);
+ if (fieldId !== -1) return this.childForFieldId(fieldId);
+ return null;
+ }
+ fieldNameForChild(index) {
+ marshalNode(this);
+ const address = C._ts_node_field_name_for_child_wasm(this.tree[0], index);
+ if (!address) {
+ return null;
+ }
+ const result = AsciiToString(address);
+ // must not free, the string memory is owned by the language
+ return result;
+ }
+ childrenForFieldName(fieldName) {
+ const fieldId = this.tree.language.fields.indexOf(fieldName);
+ if (fieldId !== -1 && fieldId !== 0) return this.childrenForFieldId(fieldId);
+ return [];
+ }
+ childrenForFieldId(fieldId) {
+ marshalNode(this);
+ C._ts_node_children_by_field_id_wasm(this.tree[0], fieldId);
+ const count = getValue(TRANSFER_BUFFER, "i32");
+ const buffer = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ const result = new Array(count);
+ if (count > 0) {
+ let address = buffer;
+ for (let i = 0; i < count; i++) {
+ result[i] = unmarshalNode(this.tree, address);
+ address += SIZE_OF_NODE;
+ }
+ C._free(buffer);
}
+ return result;
}
-
- get childCount () {
- return yt(this), et._ts_node_child_count_wasm(this.tree[0]);
+ firstChildForIndex(index) {
+ marshalNode(this);
+ const address = TRANSFER_BUFFER + SIZE_OF_NODE;
+ setValue(address, index, "i32");
+ C._ts_node_first_child_for_byte_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
}
-
- get namedChildCount () {
- return yt(this), et._ts_node_named_child_count_wasm(this.tree[0]);
+ firstNamedChildForIndex(index) {
+ marshalNode(this);
+ const address = TRANSFER_BUFFER + SIZE_OF_NODE;
+ setValue(address, index, "i32");
+ C._ts_node_first_named_child_for_byte_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
}
-
- get firstChild () {
+ get childCount() {
+ marshalNode(this);
+ return C._ts_node_child_count_wasm(this.tree[0]);
+ }
+ get namedChildCount() {
+ marshalNode(this);
+ return C._ts_node_named_child_count_wasm(this.tree[0]);
+ }
+ get firstChild() {
return this.child(0);
}
-
- get firstNamedChild () {
+ get firstNamedChild() {
return this.namedChild(0);
}
-
- get lastChild () {
+ get lastChild() {
return this.child(this.childCount - 1);
}
-
- get lastNamedChild () {
+ get lastNamedChild() {
return this.namedChild(this.namedChildCount - 1);
}
-
- get children () {
+ get children() {
if (!this._children) {
- yt(this), et._ts_node_children_wasm(this.tree[0]);
- const e = N(mt, "i32"), t = N(mt + rt, "i32");
- if (this._children = new Array(e), e > 0) {
- let r = t;
- for (let t = 0; t < e; t++) this._children[t] = bt(this.tree, r), r += nt;
- et._free(t);
+ marshalNode(this);
+ C._ts_node_children_wasm(this.tree[0]);
+ const count = getValue(TRANSFER_BUFFER, "i32");
+ const buffer = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ this._children = new Array(count);
+ if (count > 0) {
+ let address = buffer;
+ for (let i = 0; i < count; i++) {
+ this._children[i] = unmarshalNode(this.tree, address);
+ address += SIZE_OF_NODE;
+ }
+ C._free(buffer);
}
}
return this._children;
}
-
- get namedChildren () {
+ get namedChildren() {
if (!this._namedChildren) {
- yt(this), et._ts_node_named_children_wasm(this.tree[0]);
- const e = N(mt, "i32"), t = N(mt + rt, "i32");
- if (this._namedChildren = new Array(e), e > 0) {
- let r = t;
- for (let t = 0; t < e; t++) this._namedChildren[t] = bt(this.tree, r), r += nt;
- et._free(t);
+ marshalNode(this);
+ C._ts_node_named_children_wasm(this.tree[0]);
+ const count = getValue(TRANSFER_BUFFER, "i32");
+ const buffer = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ this._namedChildren = new Array(count);
+ if (count > 0) {
+ let address = buffer;
+ for (let i = 0; i < count; i++) {
+ this._namedChildren[i] = unmarshalNode(this.tree, address);
+ address += SIZE_OF_NODE;
+ }
+ C._free(buffer);
}
}
return this._namedChildren;
}
-
- descendantsOfType (e, t, r) {
- Array.isArray(e) || (e = [e]), t || (t = _t), r || (r = _t);
- const n = [], o = this.tree.language.types;
- for (let t = 0, r = o.length; t < r; t++) e.includes(o[t]) && n.push(t);
- const s = et._malloc(rt * n.length);
- for (let e = 0, t = n.length; e < t; e++) x(s + e * rt, n[e], "i32");
- yt(this), et._ts_node_descendants_of_type_wasm(this.tree[0], s, n.length, t.row, t.column, r.row, r.column);
- const _ = N(mt, "i32"), a = N(mt + rt, "i32"), i = new Array(_);
- if (_ > 0) {
- let e = a;
- for (let t = 0; t < _; t++) i[t] = bt(this.tree, e), e += nt;
- }
- return et._free(a), et._free(s), i;
- }
-
- get nextSibling () {
- return yt(this), et._ts_node_next_sibling_wasm(this.tree[0]), bt(this.tree);
- }
-
- get previousSibling () {
- return yt(this), et._ts_node_prev_sibling_wasm(this.tree[0]), bt(this.tree);
- }
-
- get nextNamedSibling () {
- return yt(this), et._ts_node_next_named_sibling_wasm(this.tree[0]), bt(this.tree);
- }
-
- get previousNamedSibling () {
- return yt(this), et._ts_node_prev_named_sibling_wasm(this.tree[0]), bt(this.tree);
- }
-
- get parent () {
- return yt(this), et._ts_node_parent_wasm(this.tree[0]), bt(this.tree);
- }
-
- descendantForIndex (e, t = e) {
- if ("number" != typeof e || "number" != typeof t) {
+ descendantsOfType(types, startPosition, endPosition) {
+ if (!Array.isArray(types)) types = [ types ];
+ if (!startPosition) startPosition = ZERO_POINT;
+ if (!endPosition) endPosition = ZERO_POINT;
+ // Convert the type strings to numeric type symbols.
+ const symbols = [];
+ const typesBySymbol = this.tree.language.types;
+ for (let i = 0, n = typesBySymbol.length; i < n; i++) {
+ if (types.includes(typesBySymbol[i])) {
+ symbols.push(i);
+ }
+ }
+ // Copy the array of symbols to the WASM heap.
+ const symbolsAddress = C._malloc(SIZE_OF_INT * symbols.length);
+ for (let i = 0, n = symbols.length; i < n; i++) {
+ setValue(symbolsAddress + i * SIZE_OF_INT, symbols[i], "i32");
+ }
+ // Call the C API to compute the descendants.
+ marshalNode(this);
+ C._ts_node_descendants_of_type_wasm(this.tree[0], symbolsAddress, symbols.length, startPosition.row, startPosition.column, endPosition.row, endPosition.column);
+ // Instantiate the nodes based on the data returned.
+ const descendantCount = getValue(TRANSFER_BUFFER, "i32");
+ const descendantAddress = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ const result = new Array(descendantCount);
+ if (descendantCount > 0) {
+ let address = descendantAddress;
+ for (let i = 0; i < descendantCount; i++) {
+ result[i] = unmarshalNode(this.tree, address);
+ address += SIZE_OF_NODE;
+ }
+ }
+ // Free the intermediate buffers
+ C._free(descendantAddress);
+ C._free(symbolsAddress);
+ return result;
+ }
+ get nextSibling() {
+ marshalNode(this);
+ C._ts_node_next_sibling_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
+ }
+ get previousSibling() {
+ marshalNode(this);
+ C._ts_node_prev_sibling_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
+ }
+ get nextNamedSibling() {
+ marshalNode(this);
+ C._ts_node_next_named_sibling_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
+ }
+ get previousNamedSibling() {
+ marshalNode(this);
+ C._ts_node_prev_named_sibling_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
+ }
+ get descendantCount() {
+ marshalNode(this);
+ return C._ts_node_descendant_count_wasm(this.tree[0]);
+ }
+ get parent() {
+ marshalNode(this);
+ C._ts_node_parent_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
+ }
+ descendantForIndex(start, end = start) {
+ if (typeof start !== "number" || typeof end !== "number") {
throw new Error("Arguments must be numbers");
}
- yt(this);
- let r = mt + nt;
- return x(r, e, "i32"), x(r + rt, t, "i32"), et._ts_node_descendant_for_index_wasm(this.tree[0]), bt(this.tree);
+ marshalNode(this);
+ const address = TRANSFER_BUFFER + SIZE_OF_NODE;
+ setValue(address, start, "i32");
+ setValue(address + SIZE_OF_INT, end, "i32");
+ C._ts_node_descendant_for_index_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
}
-
- namedDescendantForIndex (e, t = e) {
- if ("number" != typeof e || "number" != typeof t) {
+ namedDescendantForIndex(start, end = start) {
+ if (typeof start !== "number" || typeof end !== "number") {
throw new Error("Arguments must be numbers");
}
- yt(this);
- let r = mt + nt;
- return x(r, e, "i32"), x(r + rt, t, "i32"), et._ts_node_named_descendant_for_index_wasm(this.tree[0]), bt(this.tree);
+ marshalNode(this);
+ const address = TRANSFER_BUFFER + SIZE_OF_NODE;
+ setValue(address, start, "i32");
+ setValue(address + SIZE_OF_INT, end, "i32");
+ C._ts_node_named_descendant_for_index_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
}
-
- descendantForPosition (e, t = e) {
- if (!Mt(e) || !Mt(t)) {
+ descendantForPosition(start, end = start) {
+ if (!isPoint(start) || !isPoint(end)) {
throw new Error("Arguments must be {row, column} objects");
}
- yt(this);
- let r = mt + nt;
- return St(r, e), St(r + ot, t), et._ts_node_descendant_for_position_wasm(this.tree[0]), bt(this.tree);
+ marshalNode(this);
+ const address = TRANSFER_BUFFER + SIZE_OF_NODE;
+ marshalPoint(address, start);
+ marshalPoint(address + SIZE_OF_POINT, end);
+ C._ts_node_descendant_for_position_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
}
-
- namedDescendantForPosition (e, t = e) {
- if (!Mt(e) || !Mt(t)) {
+ namedDescendantForPosition(start, end = start) {
+ if (!isPoint(start) || !isPoint(end)) {
throw new Error("Arguments must be {row, column} objects");
}
- yt(this);
- let r = mt + nt;
- return St(r, e), St(r + ot, t), et._ts_node_named_descendant_for_position_wasm(this.tree[0]), bt(this.tree);
- }
-
- walk () {
- return yt(this), et._ts_tree_cursor_new_wasm(this.tree[0]), new TreeCursor(tt, this.tree);
- }
-
- toString () {
- yt(this);
- const e = et._ts_node_to_string_wasm(this.tree[0]), t = function(e) {
- for (var t = ""; ;) {
- var r = T[e++ >> 0];
- if (!r) {
- return t;
- }
- t += String.fromCharCode(r);
- }
- }(e);
- return et._free(e), t;
+ marshalNode(this);
+ const address = TRANSFER_BUFFER + SIZE_OF_NODE;
+ marshalPoint(address, start);
+ marshalPoint(address + SIZE_OF_POINT, end);
+ C._ts_node_named_descendant_for_position_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
+ }
+ walk() {
+ marshalNode(this);
+ C._ts_tree_cursor_new_wasm(this.tree[0]);
+ return new TreeCursor(INTERNAL, this.tree);
+ }
+ toString() {
+ marshalNode(this);
+ const address = C._ts_node_to_string_wasm(this.tree[0]);
+ const result = AsciiToString(address);
+ C._free(address);
+ return result;
}
}
-
class TreeCursor {
- constructor (e, t) {
- wt(e), this.tree = t, Et(this);
- }
-
- delete () {
- vt(this), et._ts_tree_cursor_delete_wasm(this.tree[0]), this[0] = this[1] = this[2] = 0;
- }
-
- reset (e) {
- yt(e), vt(this, mt + nt), et._ts_tree_cursor_reset_wasm(this.tree[0]), Et(this);
- }
-
- get nodeType () {
+ constructor(internal, tree) {
+ assertInternal(internal);
+ this.tree = tree;
+ unmarshalTreeCursor(this);
+ }
+ delete() {
+ marshalTreeCursor(this);
+ C._ts_tree_cursor_delete_wasm(this.tree[0]);
+ this[0] = this[1] = this[2] = 0;
+ }
+ reset(node) {
+ marshalNode(node);
+ marshalTreeCursor(this, TRANSFER_BUFFER + SIZE_OF_NODE);
+ C._ts_tree_cursor_reset_wasm(this.tree[0]);
+ unmarshalTreeCursor(this);
+ }
+ resetTo(cursor) {
+ marshalTreeCursor(this, TRANSFER_BUFFER);
+ marshalTreeCursor(cursor, TRANSFER_BUFFER + SIZE_OF_CURSOR);
+ C._ts_tree_cursor_reset_to_wasm(this.tree[0], cursor.tree[0]);
+ unmarshalTreeCursor(this);
+ }
+ get nodeType() {
return this.tree.language.types[this.nodeTypeId] || "ERROR";
}
-
- get nodeTypeId () {
- return vt(this), et._ts_tree_cursor_current_node_type_id_wasm(this.tree[0]);
- }
-
- get nodeId () {
- return vt(this), et._ts_tree_cursor_current_node_id_wasm(this.tree[0]);
- }
-
- get nodeIsNamed () {
- return vt(this), 1 === et._ts_tree_cursor_current_node_is_named_wasm(this.tree[0]);
- }
-
- get nodeIsMissing () {
- return vt(this), 1 === et._ts_tree_cursor_current_node_is_missing_wasm(this.tree[0]);
- }
-
- get nodeText () {
- vt(this);
- const e = et._ts_tree_cursor_start_index_wasm(this.tree[0]),
- t = et._ts_tree_cursor_end_index_wasm(this.tree[0]);
- return ht(this.tree, e, t);
- }
-
- get startPosition () {
- return vt(this), et._ts_tree_cursor_start_position_wasm(this.tree[0]), It(mt);
- }
-
- get endPosition () {
- return vt(this), et._ts_tree_cursor_end_position_wasm(this.tree[0]), It(mt);
- }
-
- get startIndex () {
- return vt(this), et._ts_tree_cursor_start_index_wasm(this.tree[0]);
- }
-
- get endIndex () {
- return vt(this), et._ts_tree_cursor_end_index_wasm(this.tree[0]);
+ get nodeTypeId() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_current_node_type_id_wasm(this.tree[0]);
+ }
+ get nodeStateId() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_current_node_state_id_wasm(this.tree[0]);
+ }
+ get nodeId() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_current_node_id_wasm(this.tree[0]);
+ }
+ get nodeIsNamed() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_current_node_is_named_wasm(this.tree[0]) === 1;
+ }
+ get nodeIsMissing() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_current_node_is_missing_wasm(this.tree[0]) === 1;
+ }
+ get nodeText() {
+ marshalTreeCursor(this);
+ const startIndex = C._ts_tree_cursor_start_index_wasm(this.tree[0]);
+ const endIndex = C._ts_tree_cursor_end_index_wasm(this.tree[0]);
+ return getText(this.tree, startIndex, endIndex);
+ }
+ get startPosition() {
+ marshalTreeCursor(this);
+ C._ts_tree_cursor_start_position_wasm(this.tree[0]);
+ return unmarshalPoint(TRANSFER_BUFFER);
+ }
+ get endPosition() {
+ marshalTreeCursor(this);
+ C._ts_tree_cursor_end_position_wasm(this.tree[0]);
+ return unmarshalPoint(TRANSFER_BUFFER);
+ }
+ get startIndex() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_start_index_wasm(this.tree[0]);
+ }
+ get endIndex() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_end_index_wasm(this.tree[0]);
+ }
+ get currentNode() {
+ marshalTreeCursor(this);
+ C._ts_tree_cursor_current_node_wasm(this.tree[0]);
+ return unmarshalNode(this.tree);
+ }
+ get currentFieldId() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_current_field_id_wasm(this.tree[0]);
+ }
+ get currentFieldName() {
+ return this.tree.language.fields[this.currentFieldId];
+ }
+ get currentDepth() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_current_depth_wasm(this.tree[0]);
+ }
+ get currentDescendantIndex() {
+ marshalTreeCursor(this);
+ return C._ts_tree_cursor_current_descendant_index_wasm(this.tree[0]);
+ }
+ gotoFirstChild() {
+ marshalTreeCursor(this);
+ const result = C._ts_tree_cursor_goto_first_child_wasm(this.tree[0]);
+ unmarshalTreeCursor(this);
+ return result === 1;
+ }
+ gotoLastChild() {
+ marshalTreeCursor(this);
+ const result = C._ts_tree_cursor_goto_last_child_wasm(this.tree[0]);
+ unmarshalTreeCursor(this);
+ return result === 1;
+ }
+ gotoFirstChildForIndex(goalIndex) {
+ marshalTreeCursor(this);
+ setValue(TRANSFER_BUFFER + SIZE_OF_CURSOR, goalIndex, "i32");
+ const result = C._ts_tree_cursor_goto_first_child_for_index_wasm(this.tree[0]);
+ unmarshalTreeCursor(this);
+ return result === 1;
+ }
+ gotoFirstChildForPosition(goalPosition) {
+ marshalTreeCursor(this);
+ marshalPoint(TRANSFER_BUFFER + SIZE_OF_CURSOR, goalPosition);
+ const result = C._ts_tree_cursor_goto_first_child_for_position_wasm(this.tree[0]);
+ unmarshalTreeCursor(this);
+ return result === 1;
+ }
+ gotoNextSibling() {
+ marshalTreeCursor(this);
+ const result = C._ts_tree_cursor_goto_next_sibling_wasm(this.tree[0]);
+ unmarshalTreeCursor(this);
+ return result === 1;
+ }
+ gotoPreviousSibling() {
+ marshalTreeCursor(this);
+ const result = C._ts_tree_cursor_goto_previous_sibling_wasm(this.tree[0]);
+ unmarshalTreeCursor(this);
+ return result === 1;
+ }
+ gotoDescendant(goalDescendantindex) {
+ marshalTreeCursor(this);
+ C._ts_tree_cursor_goto_descendant_wasm(this.tree[0], goalDescendantindex);
+ unmarshalTreeCursor(this);
+ }
+ gotoParent() {
+ marshalTreeCursor(this);
+ const result = C._ts_tree_cursor_goto_parent_wasm(this.tree[0]);
+ unmarshalTreeCursor(this);
+ return result === 1;
}
-
- currentNode () {
- return vt(this), et._ts_tree_cursor_current_node_wasm(this.tree[0]), bt(this.tree);
+ }
+ class Language {
+ constructor(internal, address) {
+ assertInternal(internal);
+ this[0] = address;
+ this.types = new Array(C._ts_language_symbol_count(this[0]));
+ for (let i = 0, n = this.types.length; i < n; i++) {
+ if (C._ts_language_symbol_type(this[0], i) < 2) {
+ this.types[i] = UTF8ToString(C._ts_language_symbol_name(this[0], i));
+ }
+ }
+ this.fields = new Array(C._ts_language_field_count(this[0]) + 1);
+ for (let i = 0, n = this.fields.length; i < n; i++) {
+ const fieldName = C._ts_language_field_name_for_id(this[0], i);
+ if (fieldName !== 0) {
+ this.fields[i] = UTF8ToString(fieldName);
+ } else {
+ this.fields[i] = null;
+ }
+ }
}
-
- currentFieldId () {
- return vt(this), et._ts_tree_cursor_current_field_id_wasm(this.tree[0]);
+ get version() {
+ return C._ts_language_version(this[0]);
}
-
- currentFieldName () {
- return this.tree.language.fields[this.currentFieldId()];
+ get fieldCount() {
+ return this.fields.length - 1;
}
-
- gotoFirstChild () {
- vt(this);
- const e = et._ts_tree_cursor_goto_first_child_wasm(this.tree[0]);
- return Et(this), 1 === e;
+ get stateCount() {
+ return C._ts_language_state_count(this[0]);
}
-
- gotoNextSibling () {
- vt(this);
- const e = et._ts_tree_cursor_goto_next_sibling_wasm(this.tree[0]);
- return Et(this), 1 === e;
+ fieldIdForName(fieldName) {
+ const result = this.fields.indexOf(fieldName);
+ if (result !== -1) {
+ return result;
+ } else {
+ return null;
+ }
}
-
- gotoParent () {
- vt(this);
- const e = et._ts_tree_cursor_goto_parent_wasm(this.tree[0]);
- return Et(this), 1 === e;
+ fieldNameForId(fieldId) {
+ return this.fields[fieldId] || null;
}
- }
-
- class Language {
- constructor (e, t) {
- wt(e), this[0] = t, this.types = new Array(et._ts_language_symbol_count(this[0]));
- for (let e = 0, t = this.types.length; e < t; e++) et._ts_language_symbol_type(this[0], e) < 2 && (this.types[e] = Z(et._ts_language_symbol_name(this[0], e)));
- this.fields = new Array(et._ts_language_field_count(this[0]) + 1);
- for (let e = 0, t = this.fields.length; e < t; e++) {
- const t = et._ts_language_field_name_for_id(this[0], e);
- this.fields[e] = 0 !== t ? Z(t) : null;
- }
+ idForNodeType(type, named) {
+ const typeLength = lengthBytesUTF8(type);
+ const typeAddress = C._malloc(typeLength + 1);
+ stringToUTF8(type, typeAddress, typeLength + 1);
+ const result = C._ts_language_symbol_for_name(this[0], typeAddress, typeLength, named);
+ C._free(typeAddress);
+ return result || null;
}
-
- get version () {
- return et._ts_language_version(this[0]);
+ get nodeTypeCount() {
+ return C._ts_language_symbol_count(this[0]);
}
-
- get fieldCount () {
- return this.fields.length - 1;
+ nodeTypeForId(typeId) {
+ const name = C._ts_language_symbol_name(this[0], typeId);
+ return name ? UTF8ToString(name) : null;
}
-
- fieldIdForName (e) {
- const t = this.fields.indexOf(e);
- return -1 !== t ? t : null;
+ nodeTypeIsNamed(typeId) {
+ return C._ts_language_type_is_named_wasm(this[0], typeId) ? true : false;
}
-
- fieldNameForId (e) {
- return this.fields[e] || null;
+ nodeTypeIsVisible(typeId) {
+ return C._ts_language_type_is_visible_wasm(this[0], typeId) ? true : false;
}
-
- idForNodeType (e, t) {
- const r = U(e), n = et._malloc(r + 1);
- z(e, n, r + 1);
- const o = et._ts_language_symbol_for_name(this[0], n, r, t);
- return et._free(n), o || null;
+ nextState(stateId, typeId) {
+ return C._ts_language_next_state(this[0], stateId, typeId);
}
-
- get nodeTypeCount () {
- return et._ts_language_symbol_count(this[0]);
+ lookaheadIterator(stateId) {
+ const address = C._ts_lookahead_iterator_new(this[0], stateId);
+ if (address) return new LookaheadIterable(INTERNAL, address, this);
+ return null;
}
+ query(source) {
+ const sourceLength = lengthBytesUTF8(source);
+ const sourceAddress = C._malloc(sourceLength + 1);
+ stringToUTF8(source, sourceAddress, sourceLength + 1);
+ const address = C._ts_query_new(this[0], sourceAddress, sourceLength, TRANSFER_BUFFER, TRANSFER_BUFFER + SIZE_OF_INT);
+ if (!address) {
+ const errorId = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ const errorByte = getValue(TRANSFER_BUFFER, "i32");
+ const errorIndex = UTF8ToString(sourceAddress, errorByte).length;
+ const suffix = source.substr(errorIndex, 100).split("\n")[0];
+ let word = suffix.match(QUERY_WORD_REGEX)[0];
+ let error;
+ switch (errorId) {
+ case 2:
+ error = new RangeError(`Bad node name '${word}'`);
+ break;
- nodeTypeForId (e) {
- const t = et._ts_language_symbol_name(this[0], e);
- return t ? Z(t) : null;
- }
+ case 3:
+ error = new RangeError(`Bad field name '${word}'`);
+ break;
- nodeTypeIsNamed (e) {
- return !!et._ts_language_type_is_named_wasm(this[0], e);
- }
+ case 4:
+ error = new RangeError(`Bad capture name @${word}`);
+ break;
- nodeTypeIsVisible (e) {
- return !!et._ts_language_type_is_visible_wasm(this[0], e);
- }
+ case 5:
+ error = new TypeError(`Bad pattern structure at offset ${errorIndex}: '${suffix}'...`);
+ word = "";
+ break;
- query (e) {
- const t = U(e), r = et._malloc(t + 1);
- z(e, r, t + 1);
- const n = et._ts_query_new(this[0], r, t, mt, mt + rt);
- if (!n) {
- const t = N(mt + rt, "i32"), n = Z(r, N(mt, "i32")).length, o = e.substr(n, 100).split("\n")[0];
- let s, _ = o.match(at)[0];
- switch (t) {
- case 2:
- s = new RangeError(`Bad node name '${_}'`);
- break;
- case 3:
- s = new RangeError(`Bad field name '${_}'`);
- break;
- case 4:
- s = new RangeError(`Bad capture name @${_}`);
- break;
- case 5:
- s = new TypeError(`Bad pattern structure at offset ${n}: '${o}'...`), _ = "";
- break;
- default:
- s = new SyntaxError(`Bad syntax at offset ${n}: '${o}'...`), _ = "";
+ default:
+ error = new SyntaxError(`Bad syntax at offset ${errorIndex}: '${suffix}'...`);
+ word = "";
+ break;
}
- throw s.index = n, s.length = _.length, et._free(r), s;
- }
- const o = et._ts_query_string_count(n), s = et._ts_query_capture_count(n),
- _ = et._ts_query_pattern_count(n), a = new Array(s), i = new Array(o);
- for (let e = 0; e < s; e++) {
- const t = et._ts_query_capture_name_for_id(n, e, mt), r = N(mt, "i32");
- a[e] = Z(t, r);
- }
- for (let e = 0; e < o; e++) {
- const t = et._ts_query_string_value_for_id(n, e, mt), r = N(mt, "i32");
- i[e] = Z(t, r);
- }
- const u = new Array(_), l = new Array(_), d = new Array(_), c = new Array(_), m = new Array(_);
- for (let e = 0; e < _; e++) {
- const t = et._ts_query_predicates_for_pattern(n, e, mt), r = N(mt, "i32");
- c[e] = [], m[e] = [];
- const o = [];
- let s = t;
- for (let t = 0; t < r; t++) {
- const t = N(s, "i32"), r = N(s += rt, "i32");
- if (s += rt, t === it) {
- o.push({
+ error.index = errorIndex;
+ error.length = word.length;
+ C._free(sourceAddress);
+ throw error;
+ }
+ const stringCount = C._ts_query_string_count(address);
+ const captureCount = C._ts_query_capture_count(address);
+ const patternCount = C._ts_query_pattern_count(address);
+ const captureNames = new Array(captureCount);
+ const stringValues = new Array(stringCount);
+ for (let i = 0; i < captureCount; i++) {
+ const nameAddress = C._ts_query_capture_name_for_id(address, i, TRANSFER_BUFFER);
+ const nameLength = getValue(TRANSFER_BUFFER, "i32");
+ captureNames[i] = UTF8ToString(nameAddress, nameLength);
+ }
+ for (let i = 0; i < stringCount; i++) {
+ const valueAddress = C._ts_query_string_value_for_id(address, i, TRANSFER_BUFFER);
+ const nameLength = getValue(TRANSFER_BUFFER, "i32");
+ stringValues[i] = UTF8ToString(valueAddress, nameLength);
+ }
+ const setProperties = new Array(patternCount);
+ const assertedProperties = new Array(patternCount);
+ const refutedProperties = new Array(patternCount);
+ const predicates = new Array(patternCount);
+ const textPredicates = new Array(patternCount);
+ for (let i = 0; i < patternCount; i++) {
+ const predicatesAddress = C._ts_query_predicates_for_pattern(address, i, TRANSFER_BUFFER);
+ const stepCount = getValue(TRANSFER_BUFFER, "i32");
+ predicates[i] = [];
+ textPredicates[i] = [];
+ const steps = [];
+ let stepAddress = predicatesAddress;
+ for (let j = 0; j < stepCount; j++) {
+ const stepType = getValue(stepAddress, "i32");
+ stepAddress += SIZE_OF_INT;
+ const stepValueId = getValue(stepAddress, "i32");
+ stepAddress += SIZE_OF_INT;
+ if (stepType === PREDICATE_STEP_TYPE_CAPTURE) {
+ steps.push({
type: "capture",
- name: a[r]
+ name: captureNames[stepValueId]
});
- }
- else if (t === ut) {
- o.push({ type: "string", value: i[r] });
- }
- else if (o.length > 0) {
- if ("string" !== o[0].type) {
+ } else if (stepType === PREDICATE_STEP_TYPE_STRING) {
+ steps.push({
+ type: "string",
+ value: stringValues[stepValueId]
+ });
+ } else if (steps.length > 0) {
+ if (steps[0].type !== "string") {
throw new Error("Predicates must begin with a literal value");
}
- const t = o[0].value;
- let r = !0;
- switch (t) {
- case"not-eq?":
- r = !1;
- case"eq?":
- if (3 !== o.length) {
- throw new Error(`Wrong number of arguments to \`#eq?\` predicate. Expected 2, got ${o.length - 1}`);
- }
- if ("capture" !== o[1].type) {
- throw new Error(`First argument of \`#eq?\` predicate must be a capture. Got "${o[1].value}"`);
- }
- if ("capture" === o[2].type) {
- const t = o[1].name, n = o[2].name;
- m[e].push(function(e) {
- let o, s;
- for (const r of e) r.name === t && (o = r.node), r.name === n && (s = r.node);
- return void 0 === o || void 0 === s || o.text === s.text === r;
- });
- }
- else {
- const t = o[1].name, n = o[2].value;
- m[e].push(function(e) {
- for (const o of e) if (o.name === t) {
- return o.node.text === n === r;
- }
- return !0;
- });
- }
- break;
- case"not-match?":
- r = !1;
- case"match?":
- if (3 !== o.length) {
- throw new Error(`Wrong number of arguments to \`#match?\` predicate. Expected 2, got ${o.length - 1}.`);
- }
- if ("capture" !== o[1].type) {
- throw new Error(`First argument of \`#match?\` predicate must be a capture. Got "${o[1].value}".`);
- }
- if ("string" !== o[2].type) {
- throw new Error(`Second argument of \`#match?\` predicate must be a string. Got @${o[2].value}.`);
- }
- const n = o[1].name, s = new RegExp(o[2].value);
- m[e].push(function(e) {
- for (const t of e) if (t.name === n) {
- return s.test(t.node.text) === r;
+ const operator = steps[0].value;
+ let isPositive = true;
+ let matchAll = true;
+ let captureName;
+ switch (operator) {
+ case "any-not-eq?":
+ case "not-eq?":
+ isPositive = false;
+
+ case "any-eq?":
+ case "eq?":
+ if (steps.length !== 3) {
+ throw new Error(`Wrong number of arguments to \`#${operator}\` predicate. Expected 2, got ${steps.length - 1}`);
+ }
+ if (steps[1].type !== "capture") {
+ throw new Error(`First argument of \`#${operator}\` predicate must be a capture. Got "${steps[1].value}"`);
+ }
+ matchAll = !operator.startsWith("any-");
+ if (steps[2].type === "capture") {
+ const captureName1 = steps[1].name;
+ const captureName2 = steps[2].name;
+ textPredicates[i].push(captures => {
+ const nodes1 = [];
+ const nodes2 = [];
+ for (const c of captures) {
+ if (c.name === captureName1) nodes1.push(c.node);
+ if (c.name === captureName2) nodes2.push(c.node);
}
- return !0;
+ const compare = (n1, n2, positive) => positive ? n1.text === n2.text : n1.text !== n2.text;
+ return matchAll ? nodes1.every(n1 => nodes2.some(n2 => compare(n1, n2, isPositive))) : nodes1.some(n1 => nodes2.some(n2 => compare(n1, n2, isPositive)));
});
- break;
- case"set!":
- if (o.length < 2 || o.length > 3) {
- throw new Error(`Wrong number of arguments to \`#set!\` predicate. Expected 1 or 2. Got ${o.length - 1}.`);
- }
- if (o.some(e => "string" !== e.type)) {
- throw new Error("Arguments to `#set!` predicate must be a strings.\".");
+ } else {
+ captureName = steps[1].name;
+ const stringValue = steps[2].value;
+ const matches = n => n.text === stringValue;
+ const doesNotMatch = n => n.text !== stringValue;
+ textPredicates[i].push(captures => {
+ const nodes = [];
+ for (const c of captures) {
+ if (c.name === captureName) nodes.push(c.node);
+ }
+ const test = isPositive ? matches : doesNotMatch;
+ return matchAll ? nodes.every(test) : nodes.some(test);
+ });
+ }
+ break;
+
+ case "any-not-match?":
+ case "not-match?":
+ isPositive = false;
+
+ case "any-match?":
+ case "match?":
+ if (steps.length !== 3) {
+ throw new Error(`Wrong number of arguments to \`#${operator}\` predicate. Expected 2, got ${steps.length - 1}.`);
+ }
+ if (steps[1].type !== "capture") {
+ throw new Error(`First argument of \`#${operator}\` predicate must be a capture. Got "${steps[1].value}".`);
+ }
+ if (steps[2].type !== "string") {
+ throw new Error(`Second argument of \`#${operator}\` predicate must be a string. Got @${steps[2].value}.`);
+ }
+ captureName = steps[1].name;
+ const regex = new RegExp(steps[2].value);
+ matchAll = !operator.startsWith("any-");
+ textPredicates[i].push(captures => {
+ const nodes = [];
+ for (const c of captures) {
+ if (c.name === captureName) nodes.push(c.node.text);
}
- u[e] || (u[e] = {}), u[e][o[1].value] = o[2] ? o[2].value : null;
- break;
- case"is?":
- case"is-not?":
- if (o.length < 2 || o.length > 3) {
- throw new Error(`Wrong number of arguments to \`#${t}\` predicate. Expected 1 or 2. Got ${o.length - 1}.`);
+ const test = (text, positive) => positive ? regex.test(text) : !regex.test(text);
+ if (nodes.length === 0) return !isPositive;
+ return matchAll ? nodes.every(text => test(text, isPositive)) : nodes.some(text => test(text, isPositive));
+ });
+ break;
+
+ case "set!":
+ if (steps.length < 2 || steps.length > 3) {
+ throw new Error(`Wrong number of arguments to \`#set!\` predicate. Expected 1 or 2. Got ${steps.length - 1}.`);
+ }
+ if (steps.some(s => s.type !== "string")) {
+ throw new Error(`Arguments to \`#set!\` predicate must be a strings.".`);
+ }
+ if (!setProperties[i]) setProperties[i] = {};
+ setProperties[i][steps[1].value] = steps[2] ? steps[2].value : null;
+ break;
+
+ case "is?":
+ case "is-not?":
+ if (steps.length < 2 || steps.length > 3) {
+ throw new Error(`Wrong number of arguments to \`#${operator}\` predicate. Expected 1 or 2. Got ${steps.length - 1}.`);
+ }
+ if (steps.some(s => s.type !== "string")) {
+ throw new Error(`Arguments to \`#${operator}\` predicate must be a strings.".`);
+ }
+ const properties = operator === "is?" ? assertedProperties : refutedProperties;
+ if (!properties[i]) properties[i] = {};
+ properties[i][steps[1].value] = steps[2] ? steps[2].value : null;
+ break;
+
+ case "not-any-of?":
+ isPositive = false;
+
+ case "any-of?":
+ if (steps.length < 2) {
+ throw new Error(`Wrong number of arguments to \`#${operator}\` predicate. Expected at least 1. Got ${steps.length - 1}.`);
+ }
+ if (steps[1].type !== "capture") {
+ throw new Error(`First argument of \`#${operator}\` predicate must be a capture. Got "${steps[1].value}".`);
+ }
+ for (let i = 2; i < steps.length; i++) {
+ if (steps[i].type !== "string") {
+ throw new Error(`Arguments to \`#${operator}\` predicate must be a strings.".`);
}
- if (o.some(e => "string" !== e.type)) {
- throw new Error(`Arguments to \`#${t}\` predicate must be a strings.".`);
+ }
+ captureName = steps[1].name;
+ const values = steps.slice(2).map(s => s.value);
+ textPredicates[i].push(captures => {
+ const nodes = [];
+ for (const c of captures) {
+ if (c.name === captureName) nodes.push(c.node.text);
}
- const _ = "is?" === t ? l : d;
- _[e] || (_[e] = {}), _[e][o[1].value] = o[2] ? o[2].value : null;
- break;
- default:
- c[e].push({ operator: t, operands: o.slice(1) });
+ if (nodes.length === 0) return !isPositive;
+ return nodes.every(text => values.includes(text)) === isPositive;
+ });
+ break;
+
+ default:
+ predicates[i].push({
+ operator: operator,
+ operands: steps.slice(1)
+ });
}
- o.length = 0;
+ steps.length = 0;
}
}
- Object.freeze(u[e]), Object.freeze(l[e]), Object.freeze(d[e]);
- }
- return et._free(r), new Query(tt, n, a, m, c, Object.freeze(u), Object.freeze(l), Object.freeze(d));
- }
-
- static load (e) {
- let t;
- if (e instanceof Uint8Array) {
- t = Promise.resolve(e);
- }
- else {
- const r = e;
- if ("undefined" != typeof process && process.versions && process.versions.node) {
- const e = require("fs");
- t = Promise.resolve(e.readFileSync(r));
- }
- else {
- t = fetch(r).then(e => e.arrayBuffer().then(t => {
- if (e.ok) {
- return new Uint8Array(t);
- }
- {
- const r = new TextDecoder("utf-8").decode(t);
- throw new Error(`Language.load failed with status ${e.status}.\n\n${r}`);
+ Object.freeze(setProperties[i]);
+ Object.freeze(assertedProperties[i]);
+ Object.freeze(refutedProperties[i]);
+ }
+ C._free(sourceAddress);
+ return new Query(INTERNAL, address, captureNames, textPredicates, predicates, Object.freeze(setProperties), Object.freeze(assertedProperties), Object.freeze(refutedProperties));
+ }
+ static load(input) {
+ let bytes;
+ if (input instanceof Uint8Array) {
+ bytes = Promise.resolve(input);
+ } else {
+ const url = input;
+ if (typeof process !== "undefined" && process.versions && process.versions.node) {
+ const fs = require("fs");
+ bytes = Promise.resolve(fs.readFileSync(url));
+ } else {
+ bytes = fetch(url).then(response => response.arrayBuffer().then(buffer => {
+ if (response.ok) {
+ return new Uint8Array(buffer);
+ } else {
+ const body = new TextDecoder("utf-8").decode(buffer);
+ throw new Error(`Language.load failed with status ${response.status}.\n\n${body}`);
}
}));
}
}
- const r = "function" == typeof loadSideModule ? loadSideModule : xe;
- return t.then(e => r(e, { loadAsync: !0 })).then(e => {
- const t = Object.keys(e), r = t.find(e => lt.test(e) && !e.includes("external_scanner_"));
- r || console.log(`Couldn't find language function in WASM file. Symbols:\n${JSON.stringify(t, null, 2)}`);
- const n = e[r]();
- return new Language(tt, n);
+ return bytes.then(bytes => loadWebAssemblyModule(bytes, {
+ loadAsync: true
+ })).then(mod => {
+ const symbolNames = Object.keys(mod);
+ const functionName = symbolNames.find(key => LANGUAGE_FUNCTION_REGEX.test(key) && !key.includes("external_scanner_"));
+ if (!functionName) {
+ console.log(`Couldn't find language function in WASM file. Symbols:\n${JSON.stringify(symbolNames, null, 2)}`);
+ }
+ const languageAddress = mod[functionName]();
+ return new Language(INTERNAL, languageAddress);
});
}
}
-
- class Query {
- constructor (e, t, r, n, o, s, _, a) {
- wt(e), this[0] = t, this.captureNames = r, this.textPredicates = n, this.predicates = o, this.setProperties = s, this.assertedProperties = _, this.refutedProperties = a, this.exceededMatchLimit = !1;
- }
-
- delete () {
- et._ts_query_delete(this[0]), this[0] = 0;
+ class LookaheadIterable {
+ constructor(internal, address, language) {
+ assertInternal(internal);
+ this[0] = address;
+ this.language = language;
+ }
+ get currentTypeId() {
+ return C._ts_lookahead_iterator_current_symbol(this[0]);
+ }
+ get currentType() {
+ return this.language.types[this.currentTypeId] || "ERROR";
+ }
+ delete() {
+ C._ts_lookahead_iterator_delete(this[0]);
+ this[0] = 0;
+ }
+ resetState(stateId) {
+ return C._ts_lookahead_iterator_reset_state(this[0], stateId);
+ }
+ reset(language, stateId) {
+ if (C._ts_lookahead_iterator_reset(this[0], language[0], stateId)) {
+ this.language = language;
+ return true;
+ }
+ return false;
+ }
+ [Symbol.iterator]() {
+ const self = this;
+ return {
+ next() {
+ if (C._ts_lookahead_iterator_next(self[0])) {
+ return {
+ done: false,
+ value: self.currentType
+ };
+ }
+ return {
+ done: true,
+ value: ""
+ };
+ }
+ };
}
-
- matches (e, t, r, n) {
- t || (t = _t), r || (r = _t), n || (n = {});
- let o = n.matchLimit;
- if (void 0 === o) {
- o = 0;
- }
- else if ("number" != typeof o) {
+ }
+ class Query {
+ constructor(internal, address, captureNames, textPredicates, predicates, setProperties, assertedProperties, refutedProperties) {
+ assertInternal(internal);
+ this[0] = address;
+ this.captureNames = captureNames;
+ this.textPredicates = textPredicates;
+ this.predicates = predicates;
+ this.setProperties = setProperties;
+ this.assertedProperties = assertedProperties;
+ this.refutedProperties = refutedProperties;
+ this.exceededMatchLimit = false;
+ }
+ delete() {
+ C._ts_query_delete(this[0]);
+ this[0] = 0;
+ }
+ matches(node, {startPosition: startPosition = ZERO_POINT, endPosition: endPosition = ZERO_POINT, startIndex: startIndex = 0, endIndex: endIndex = 0, matchLimit: matchLimit = 4294967295, maxStartDepth: maxStartDepth = 4294967295, timeoutMicros: timeoutMicros = 0} = {}) {
+ if (typeof matchLimit !== "number") {
throw new Error("Arguments must be numbers");
}
- yt(e), et._ts_query_matches_wasm(this[0], e.tree[0], t.row, t.column, r.row, r.column, o);
- const s = N(mt, "i32"), _ = N(mt + rt, "i32"), a = N(mt + 2 * rt, "i32"), i = new Array(s);
- this.exceededMatchLimit = !!a;
- let u = 0, l = _;
- for (let t = 0; t < s; t++) {
- const r = N(l, "i32"), n = N(l += rt, "i32");
- l += rt;
- const o = new Array(n);
- if (l = gt(this, e.tree, l, o), this.textPredicates[r].every(e => e(o))) {
- i[u++] = { pattern: r, captures: o };
- const e = this.setProperties[r];
- e && (i[t].setProperties = e);
- const n = this.assertedProperties[r];
- n && (i[t].assertedProperties = n);
- const s = this.refutedProperties[r];
- s && (i[t].refutedProperties = s);
+ marshalNode(node);
+ C._ts_query_matches_wasm(this[0], node.tree[0], startPosition.row, startPosition.column, endPosition.row, endPosition.column, startIndex, endIndex, matchLimit, maxStartDepth, timeoutMicros);
+ const rawCount = getValue(TRANSFER_BUFFER, "i32");
+ const startAddress = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ const didExceedMatchLimit = getValue(TRANSFER_BUFFER + 2 * SIZE_OF_INT, "i32");
+ const result = new Array(rawCount);
+ this.exceededMatchLimit = Boolean(didExceedMatchLimit);
+ let filteredCount = 0;
+ let address = startAddress;
+ for (let i = 0; i < rawCount; i++) {
+ const pattern = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ const captureCount = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ const captures = new Array(captureCount);
+ address = unmarshalCaptures(this, node.tree, address, captures);
+ if (this.textPredicates[pattern].every(p => p(captures))) {
+ result[filteredCount] = {
+ pattern: pattern,
+ captures: captures
+ };
+ const setProperties = this.setProperties[pattern];
+ if (setProperties) result[filteredCount].setProperties = setProperties;
+ const assertedProperties = this.assertedProperties[pattern];
+ if (assertedProperties) result[filteredCount].assertedProperties = assertedProperties;
+ const refutedProperties = this.refutedProperties[pattern];
+ if (refutedProperties) result[filteredCount].refutedProperties = refutedProperties;
+ filteredCount++;
}
}
- return i.length = u, et._free(_), i;
+ result.length = filteredCount;
+ C._free(startAddress);
+ return result;
}
-
- captures (e, t, r, n) {
- t || (t = _t), r || (r = _t), n || (n = {});
- let o = n.matchLimit;
- if (void 0 === o) {
- o = 0;
- }
- else if ("number" != typeof o) {
+ captures(node, {startPosition: startPosition = ZERO_POINT, endPosition: endPosition = ZERO_POINT, startIndex: startIndex = 0, endIndex: endIndex = 0, matchLimit: matchLimit = 4294967295, maxStartDepth: maxStartDepth = 4294967295, timeoutMicros: timeoutMicros = 0} = {}) {
+ if (typeof matchLimit !== "number") {
throw new Error("Arguments must be numbers");
}
- yt(e), et._ts_query_captures_wasm(this[0], e.tree[0], t.row, t.column, r.row, r.column, o);
- const s = N(mt, "i32"), _ = N(mt + rt, "i32"), a = N(mt + 2 * rt, "i32"), i = [];
- this.exceededMatchLimit = !!a;
- const u = [];
- let l = _;
- for (let t = 0; t < s; t++) {
- const t = N(l, "i32"), r = N(l += rt, "i32"), n = N(l += rt, "i32");
- if (l += rt, u.length = r, l = gt(this, e.tree, l, u), this.textPredicates[t].every(e => e(u))) {
- const e = u[n], r = this.setProperties[t];
- r && (e.setProperties = r);
- const o = this.assertedProperties[t];
- o && (e.assertedProperties = o);
- const s = this.refutedProperties[t];
- s && (e.refutedProperties = s), i.push(e)
+ marshalNode(node);
+ C._ts_query_captures_wasm(this[0], node.tree[0], startPosition.row, startPosition.column, endPosition.row, endPosition.column, startIndex, endIndex, matchLimit, maxStartDepth, timeoutMicros);
+ const count = getValue(TRANSFER_BUFFER, "i32");
+ const startAddress = getValue(TRANSFER_BUFFER + SIZE_OF_INT, "i32");
+ const didExceedMatchLimit = getValue(TRANSFER_BUFFER + 2 * SIZE_OF_INT, "i32");
+ const result = [];
+ this.exceededMatchLimit = Boolean(didExceedMatchLimit);
+ const captures = [];
+ let address = startAddress;
+ for (let i = 0; i < count; i++) {
+ const pattern = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ const captureCount = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ const captureIndex = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ captures.length = captureCount;
+ address = unmarshalCaptures(this, node.tree, address, captures);
+ if (this.textPredicates[pattern].every(p => p(captures))) {
+ const capture = captures[captureIndex];
+ const setProperties = this.setProperties[pattern];
+ if (setProperties) capture.setProperties = setProperties;
+ const assertedProperties = this.assertedProperties[pattern];
+ if (assertedProperties) capture.assertedProperties = assertedProperties;
+ const refutedProperties = this.refutedProperties[pattern];
+ if (refutedProperties) capture.refutedProperties = refutedProperties;
+ result.push(capture);
}
}
- return et._free(_), i
+ C._free(startAddress);
+ return result;
}
-
- predicatesForPattern (e) {
- return this.predicates[e]
+ predicatesForPattern(patternIndex) {
+ return this.predicates[patternIndex];
}
-
- didExceedMatchLimit () {
- return this.exceededMatchLimit
+ disableCapture(captureName) {
+ const captureNameLength = lengthBytesUTF8(captureName);
+ const captureNameAddress = C._malloc(captureNameLength + 1);
+ stringToUTF8(captureName, captureNameAddress, captureNameLength + 1);
+ C._ts_query_disable_capture(this[0], captureNameAddress, captureNameLength);
+ C._free(captureNameAddress);
+ }
+ didExceedMatchLimit() {
+ return this.exceededMatchLimit;
}
}
-
- function ht (e, t, r) {
- const n = r - t;
- let o = e.textCallback(t, null, r);
- for (t += o.length; t < r;) {
- const n = e.textCallback(t, null, r);
- if (!(n && n.length > 0)) {
+ function getText(tree, startIndex, endIndex) {
+ const length = endIndex - startIndex;
+ let result = tree.textCallback(startIndex, null, endIndex);
+ startIndex += result.length;
+ while (startIndex < endIndex) {
+ const string = tree.textCallback(startIndex, null, endIndex);
+ if (string && string.length > 0) {
+ startIndex += string.length;
+ result += string;
+ } else {
break;
}
- t += n.length, o += n
}
- return t > r && (o = o.slice(0, n)), o
- }
-
- function gt (e, t, r, n) {
- for (let o = 0, s = n.length; o < s; o++) {
- const s = N(r, "i32"), _ = bt(t, r += rt);
- r += nt, n[o] = { name: e.captureNames[s], node: _ }
+ if (startIndex > endIndex) {
+ result = result.slice(0, length);
}
- return r
+ return result;
}
-
- function wt (e) {
- if (e !== tt) {
- throw new Error("Illegal constructor")
- }
+ function unmarshalCaptures(query, tree, address, result) {
+ for (let i = 0, n = result.length; i < n; i++) {
+ const captureIndex = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ const node = unmarshalNode(tree, address);
+ address += SIZE_OF_NODE;
+ result[i] = {
+ name: query.captureNames[captureIndex],
+ node: node
+ };
+ }
+ return address;
}
-
- function Mt (e) {
- return e && "number" == typeof e.row && "number" == typeof e.column
+ function assertInternal(x) {
+ if (x !== INTERNAL) throw new Error("Illegal constructor");
}
-
- function yt (e) {
- let t = mt;
- x(t, e.id, "i32"), x(t += rt, e.startIndex, "i32"), x(t += rt, e.startPosition.row, "i32"), x(t += rt, e.startPosition.column, "i32"), x(t += rt, e[0], "i32")
+ function isPoint(point) {
+ return (point && typeof point.row === "number" && typeof point.column === "number");
}
-
- function bt (e, t = mt) {
- const r = N(t, "i32");
- if (0 === r) {
- return null;
- }
- const n = N(t += rt, "i32"), o = N(t += rt, "i32"), s = N(t += rt, "i32"), _ = N(t += rt, "i32"),
- a = new Node(tt, e);
- return a.id = r, a.startIndex = n, a.startPosition = { row: o, column: s }, a[0] = _, a
+ function marshalNode(node) {
+ let address = TRANSFER_BUFFER;
+ setValue(address, node.id, "i32");
+ address += SIZE_OF_INT;
+ setValue(address, node.startIndex, "i32");
+ address += SIZE_OF_INT;
+ setValue(address, node.startPosition.row, "i32");
+ address += SIZE_OF_INT;
+ setValue(address, node.startPosition.column, "i32");
+ address += SIZE_OF_INT;
+ setValue(address, node[0], "i32");
}
-
- function vt (e, t = mt) {
- x(t + 0 * rt, e[0], "i32"), x(t + 1 * rt, e[1], "i32"), x(t + 2 * rt, e[2], "i32")
+ function unmarshalNode(tree, address = TRANSFER_BUFFER) {
+ const id = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ if (id === 0) return null;
+ const index = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ const row = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ const column = getValue(address, "i32");
+ address += SIZE_OF_INT;
+ const other = getValue(address, "i32");
+ const result = new Node(INTERNAL, tree);
+ result.id = id;
+ result.startIndex = index;
+ result.startPosition = {
+ row: row,
+ column: column
+ };
+ result[0] = other;
+ return result;
}
-
- function Et (e) {
- e[0] = N(mt + 0 * rt, "i32"), e[1] = N(mt + 1 * rt, "i32"), e[2] = N(mt + 2 * rt, "i32")
+ function marshalTreeCursor(cursor, address = TRANSFER_BUFFER) {
+ setValue(address + 0 * SIZE_OF_INT, cursor[0], "i32");
+ setValue(address + 1 * SIZE_OF_INT, cursor[1], "i32");
+ setValue(address + 2 * SIZE_OF_INT, cursor[2], "i32");
+ setValue(address + 3 * SIZE_OF_INT, cursor[3], "i32");
}
-
- function St (e, t) {
- x(e, t.row, "i32"), x(e + rt, t.column, "i32")
+ function unmarshalTreeCursor(cursor) {
+ cursor[0] = getValue(TRANSFER_BUFFER + 0 * SIZE_OF_INT, "i32");
+ cursor[1] = getValue(TRANSFER_BUFFER + 1 * SIZE_OF_INT, "i32");
+ cursor[2] = getValue(TRANSFER_BUFFER + 2 * SIZE_OF_INT, "i32");
+ cursor[3] = getValue(TRANSFER_BUFFER + 3 * SIZE_OF_INT, "i32");
}
-
- function It (e) {
- return { row: N(e, "i32"), column: N(e + rt, "i32") }
+ function marshalPoint(address, point) {
+ setValue(address, point.row, "i32");
+ setValue(address + SIZE_OF_INT, point.column, "i32");
}
-
- function At (e, t) {
- St(e, t.startPosition), St(e += ot, t.endPosition), x(e += ot, t.startIndex, "i32"), x(e += rt, t.endIndex, "i32"), e += rt
+ function unmarshalPoint(address) {
+ const result = {
+ row: getValue(address, "i32") >>> 0,
+ column: getValue(address + SIZE_OF_INT, "i32") >>> 0
+ };
+ return result;
}
-
- function xt (e) {
- const t = {};
- return t.startPosition = It(e), e += ot, t.endPosition = It(e), e += ot, t.startIndex = N(e, "i32"), e += rt, t.endIndex = N(e, "i32"), t
+ function marshalRange(address, range) {
+ marshalPoint(address, range.startPosition);
+ address += SIZE_OF_POINT;
+ marshalPoint(address, range.endPosition);
+ address += SIZE_OF_POINT;
+ setValue(address, range.startIndex, "i32");
+ address += SIZE_OF_INT;
+ setValue(address, range.endIndex, "i32");
+ address += SIZE_OF_INT;
}
-
- for (const e of Object.getOwnPropertyNames(ParserImpl.prototype)) Object.defineProperty(Parser.prototype, e, {
- value: ParserImpl.prototype[e],
- enumerable: !1,
- writable: !1
- });
- Parser.Language = Language, Module.onRuntimeInitialized = (() => {
- ParserImpl.init(), e()
- })
- }))
+ function unmarshalRange(address) {
+ const result = {};
+ result.startPosition = unmarshalPoint(address);
+ address += SIZE_OF_POINT;
+ result.endPosition = unmarshalPoint(address);
+ address += SIZE_OF_POINT;
+ result.startIndex = getValue(address, "i32") >>> 0;
+ address += SIZE_OF_INT;
+ result.endIndex = getValue(address, "i32") >>> 0;
+ return result;
+ }
+ function marshalEdit(edit) {
+ let address = TRANSFER_BUFFER;
+ marshalPoint(address, edit.startPosition);
+ address += SIZE_OF_POINT;
+ marshalPoint(address, edit.oldEndPosition);
+ address += SIZE_OF_POINT;
+ marshalPoint(address, edit.newEndPosition);
+ address += SIZE_OF_POINT;
+ setValue(address, edit.startIndex, "i32");
+ address += SIZE_OF_INT;
+ setValue(address, edit.oldEndIndex, "i32");
+ address += SIZE_OF_INT;
+ setValue(address, edit.newEndIndex, "i32");
+ address += SIZE_OF_INT;
+ }
+ // end include: /src/lib/binding_web/binding.js
+ // include: /src/lib/binding_web/suffix.js
+ for (const name of Object.getOwnPropertyNames(ParserImpl.prototype)) {
+ Object.defineProperty(Parser.prototype, name, {
+ value: ParserImpl.prototype[name],
+ enumerable: false,
+ writable: false
+ });
+ }
+ Parser.Language = Language;
+ Module.onRuntimeInitialized = () => {
+ ParserImpl.init();
+ resolveInitPromise();
+ };
+ });
}
}
-
- return Parser
+ return Parser;
}();
+if (typeof exports === "object") {
+ module.exports = TreeSitter;
+}
await TreeSitter.init({
locateFile(scriptName, scriptDirectory) {
- console.log(scriptName, scriptDirectory);
return "/assets/tree-sitter.wasm";
- }
+ }
});
-
export const Parser = TreeSitter;
-export const Language = TreeSitter.Language;