@cdktn/hcl2json 0.23.0-pre.29 → 0.23.0-pre.33

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/bridge.js CHANGED
@@ -1,8 +1,6 @@
1
1
  "use strict";
2
2
  // Copyright (c) HashiCorp, Inc
3
3
  // SPDX-License-Identifier: MPL-2.0
4
- // eslint-disable-next-line @typescript-eslint/triple-slash-reference
5
- /// <reference lib="dom" />
6
4
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
5
  if (k2 === undefined) k2 = k;
8
6
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -28,6 +26,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
28
26
  };
29
27
  Object.defineProperty(exports, "__esModule", { value: true });
30
28
  exports.getExpressionAst = exports.getReferencesInExpression = exports.convertFiles = exports.parse = void 0;
29
+ /// <reference lib="dom" />
31
30
  // Inspired by
32
31
  // https://github.com/ts-terraform/ts-terraform
33
32
  // https://github.com/aaronpowell/webpack-golang-wasm-async-loader
@@ -174,4 +173,4 @@ async function getExpressionAst(filename, expression) {
174
173
  return ast;
175
174
  }
176
175
  exports.getExpressionAst = getExpressionAst;
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bridge.js","sourceRoot":"","sources":["bridge.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\n// eslint-disable-next-line @typescript-eslint/triple-slash-reference\n/// <reference lib=\"dom\" />\n\n// Inspired by\n// https://github.com/ts-terraform/ts-terraform\n// https://github.com/aaronpowell/webpack-golang-wasm-async-loader\n\nimport * as fs from \"fs-extra\";\nimport { join, resolve } from \"path\";\nimport { deepMerge } from \"./deepmerge\";\nimport { gunzipSync } from \"zlib\";\nimport { Reference, findAllReferencesInAst } from \"./references\";\nimport { ExpressionType } from \"./syntax-tree\";\nimport { wrapTerraformExpression } from \"./util\";\n\ninterface GoBridge {\n  parse: (filename: string, hcl: string) => Promise<string>;\n  parseExpression: (filename: string, hcl: string) => Promise<string>;\n  getExpressionAst: (filename: string, hcl: string) => Promise<string>;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nconst jsRoot: Record<string, Function> = {};\n\nfunction sleep() {\n  return new Promise((resolve) => {\n    setTimeout(resolve, 0);\n  });\n}\n\nfunction goBridge(getBytes: Promise<Buffer>) {\n  let ready = false;\n\n  async function init() {\n    // After: https://github.com/golang/go/commit/680caf15355057ca84857a2a291b6f5c44e73329\n    // Go 1.19+ has a different entrypoint\n    await import(`../wasm/bridge_wasm_exec.js`);\n    const go = new (global as any).Go();\n    const bytes = await getBytes;\n    const result = await WebAssembly.instantiate(bytes, go.importObject);\n    (global as any).__parse_terraform_config_wasm__ = jsRoot;\n    void go.run(result.instance);\n    ready = true;\n  }\n\n  init().catch((error) => {\n    throw error;\n  });\n\n  const proxy = new Proxy({} as GoBridge, {\n    get: (_, key: string) => {\n      return async (...args: unknown[]) => {\n        while (!ready) {\n          await sleep();\n        }\n\n        if (!(key in jsRoot)) {\n          throw new Error(\n            `There is nothing defined with the name \"${key.toString()}\"`,\n          );\n        }\n\n        if (typeof jsRoot[key] !== \"function\") {\n          return jsRoot[key];\n        }\n\n        return new Promise((resolve, reject) => {\n          const cb = (err: string, ...msg: string[]) =>\n            // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n            // @ts-ignore\n            err ? reject(new Error(err)) : resolve(...msg);\n\n          const run = () => {\n            jsRoot[key].apply(undefined, [...args, cb]);\n          };\n\n          run();\n        });\n      };\n    },\n  });\n\n  return proxy;\n}\n\nconst loadWasm = async () => {\n  return gunzipSync(await fs.readFile(join(__dirname, \"..\", \"main.wasm.gz\")));\n};\n\nconst wasm = goBridge(loadWasm());\n\nexport async function parse(\n  filename: string,\n  contents: string,\n): Promise<Record<string, any>> {\n  const res = await wasm.parse(filename, contents);\n  return JSON.parse(res);\n}\n\nexport async function convertFiles(\n  workingDirectory: string,\n): Promise<Record<string, any>> {\n  let tfFileContents = \"\";\n  const tfJSONFileContents: Record<string, any>[] = [];\n\n  for (const file of fs.readdirSync(workingDirectory)) {\n    const filePath = resolve(workingDirectory, file);\n    if (!fs.lstatSync(filePath).isDirectory()) {\n      if (file.match(/\\.tf$/)) {\n        tfFileContents += fs.readFileSync(filePath, \"utf-8\");\n        tfFileContents += \"\\n\";\n      } else if (file.match(/\\.tf\\.json$/)) {\n        tfJSONFileContents.push(JSON.parse(fs.readFileSync(filePath, \"utf-8\")));\n      }\n    }\n  }\n\n  if (tfFileContents === \"\" && tfJSONFileContents.length === 0) {\n    console.error(`No '.tf' or '.tf.json' files found in ${workingDirectory}`);\n    return {};\n  }\n\n  return deepMerge(\n    await parse(\"hcl2json.tf\", tfFileContents),\n    ...tfJSONFileContents,\n  );\n}\n\n/**\n * Parse a Terraform expression and return the AST. This function expects a string input, and will wrap the expression in quotes if it is not already quoted.\n * @param filename The filename to use for the expression. This is used for error reporting.\n * @param expression The expression to parse.\n * @returns An array of References found in the expression.\n */\nexport async function getReferencesInExpression(\n  filename: string,\n  expression: string,\n): Promise<Reference[]> {\n  // We have to do this twice because of the problem with HEREDOCS\n  // Our current hcl2json implementation removes HEREDOCS and replaces them\n  // with a multi-line string, which is causing all kinds of problems\n  let offset = 0;\n  let quoteWrappedExpression = expression;\n  if (!expression.startsWith('\"')) {\n    quoteWrappedExpression = `\"${expression}\"`;\n    offset = 1;\n  }\n\n  const { wrap: wrappedExpression, wrapOffset: startOffset } =\n    wrapTerraformExpression(`${quoteWrappedExpression}`);\n\n  offset += startOffset;\n\n  const ast = await getExpressionAst(filename, wrappedExpression);\n  if (!ast) {\n    return [];\n  }\n\n  const refs = findAllReferencesInAst(expression, ast);\n  if (wrappedExpression === expression) {\n    return refs;\n  }\n\n  return refs.map((ref) => {\n    return {\n      ...ref,\n      startPosition: ref.startPosition - offset,\n      endPosition: ref.endPosition - offset,\n    };\n  });\n}\n\n/**\n * Parse a Terraform expression and return the AST. The expression does not need to be a Terraform string.\n * @param filename The filename to use for the expression. This is used for error reporting.\n * @param expression The expression to parse.\n * @returns The AST for the expression.\n *\n *   The returned AST has the following structure:\n *   - type: The type of the node. This is a string.\n *   - range: This contains the start and end of the node in the expression.\n *   - children: This contains the children of the node. This is an array of nodes.\n *   - meta: This contains metadata about the node. This is an object, and varies depending on the type of the node.\n */\nexport async function getExpressionAst(\n  filename: string,\n  expression: string,\n): Promise<ExpressionType | null> {\n  const res = await wasm.getExpressionAst(filename, expression);\n  const ast = JSON.parse(res) as ExpressionType;\n\n  if (!ast) {\n    return null;\n  }\n\n  return ast;\n}\n"]}
176
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bridge.js","sourceRoot":"","sources":["bridge.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) HashiCorp, Inc\n// SPDX-License-Identifier: MPL-2.0\n\n/// <reference lib=\"dom\" />\n\n// Inspired by\n// https://github.com/ts-terraform/ts-terraform\n// https://github.com/aaronpowell/webpack-golang-wasm-async-loader\n\nimport * as fs from \"fs-extra\";\nimport { join, resolve } from \"path\";\nimport { deepMerge } from \"./deepmerge\";\nimport { gunzipSync } from \"zlib\";\nimport { Reference, findAllReferencesInAst } from \"./references\";\nimport { ExpressionType } from \"./syntax-tree\";\nimport { wrapTerraformExpression } from \"./util\";\n\ninterface GoBridge {\n  parse: (filename: string, hcl: string) => Promise<string>;\n  parseExpression: (filename: string, hcl: string) => Promise<string>;\n  getExpressionAst: (filename: string, hcl: string) => Promise<string>;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nconst jsRoot: Record<string, Function> = {};\n\nfunction sleep() {\n  return new Promise((resolve) => {\n    setTimeout(resolve, 0);\n  });\n}\n\nfunction goBridge(getBytes: Promise<Buffer>) {\n  let ready = false;\n\n  async function init() {\n    // After: https://github.com/golang/go/commit/680caf15355057ca84857a2a291b6f5c44e73329\n    // Go 1.19+ has a different entrypoint\n    await import(`../wasm/bridge_wasm_exec.js`);\n    const go = new (global as any).Go();\n    const bytes = await getBytes;\n    const result = await WebAssembly.instantiate(bytes, go.importObject);\n    (global as any).__parse_terraform_config_wasm__ = jsRoot;\n    void go.run(result.instance);\n    ready = true;\n  }\n\n  init().catch((error) => {\n    throw error;\n  });\n\n  const proxy = new Proxy({} as GoBridge, {\n    get: (_, key: string) => {\n      return async (...args: unknown[]) => {\n        while (!ready) {\n          await sleep();\n        }\n\n        if (!(key in jsRoot)) {\n          throw new Error(\n            `There is nothing defined with the name \"${key.toString()}\"`,\n          );\n        }\n\n        if (typeof jsRoot[key] !== \"function\") {\n          return jsRoot[key];\n        }\n\n        return new Promise((resolve, reject) => {\n          const cb = (err: string, ...msg: string[]) =>\n            // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n            // @ts-ignore\n            err ? reject(new Error(err)) : resolve(...msg);\n\n          const run = () => {\n            jsRoot[key].apply(undefined, [...args, cb]);\n          };\n\n          run();\n        });\n      };\n    },\n  });\n\n  return proxy;\n}\n\nconst loadWasm = async () => {\n  return gunzipSync(await fs.readFile(join(__dirname, \"..\", \"main.wasm.gz\")));\n};\n\nconst wasm = goBridge(loadWasm());\n\nexport async function parse(\n  filename: string,\n  contents: string,\n): Promise<Record<string, any>> {\n  const res = await wasm.parse(filename, contents);\n  return JSON.parse(res);\n}\n\nexport async function convertFiles(\n  workingDirectory: string,\n): Promise<Record<string, any>> {\n  let tfFileContents = \"\";\n  const tfJSONFileContents: Record<string, any>[] = [];\n\n  for (const file of fs.readdirSync(workingDirectory)) {\n    const filePath = resolve(workingDirectory, file);\n    if (!fs.lstatSync(filePath).isDirectory()) {\n      if (file.match(/\\.tf$/)) {\n        tfFileContents += fs.readFileSync(filePath, \"utf-8\");\n        tfFileContents += \"\\n\";\n      } else if (file.match(/\\.tf\\.json$/)) {\n        tfJSONFileContents.push(JSON.parse(fs.readFileSync(filePath, \"utf-8\")));\n      }\n    }\n  }\n\n  if (tfFileContents === \"\" && tfJSONFileContents.length === 0) {\n    console.error(`No '.tf' or '.tf.json' files found in ${workingDirectory}`);\n    return {};\n  }\n\n  return deepMerge(\n    await parse(\"hcl2json.tf\", tfFileContents),\n    ...tfJSONFileContents,\n  );\n}\n\n/**\n * Parse a Terraform expression and return the AST. This function expects a string input, and will wrap the expression in quotes if it is not already quoted.\n * @param filename The filename to use for the expression. This is used for error reporting.\n * @param expression The expression to parse.\n * @returns An array of References found in the expression.\n */\nexport async function getReferencesInExpression(\n  filename: string,\n  expression: string,\n): Promise<Reference[]> {\n  // We have to do this twice because of the problem with HEREDOCS\n  // Our current hcl2json implementation removes HEREDOCS and replaces them\n  // with a multi-line string, which is causing all kinds of problems\n  let offset = 0;\n  let quoteWrappedExpression = expression;\n  if (!expression.startsWith('\"')) {\n    quoteWrappedExpression = `\"${expression}\"`;\n    offset = 1;\n  }\n\n  const { wrap: wrappedExpression, wrapOffset: startOffset } =\n    wrapTerraformExpression(`${quoteWrappedExpression}`);\n\n  offset += startOffset;\n\n  const ast = await getExpressionAst(filename, wrappedExpression);\n  if (!ast) {\n    return [];\n  }\n\n  const refs = findAllReferencesInAst(expression, ast);\n  if (wrappedExpression === expression) {\n    return refs;\n  }\n\n  return refs.map((ref) => {\n    return {\n      ...ref,\n      startPosition: ref.startPosition - offset,\n      endPosition: ref.endPosition - offset,\n    };\n  });\n}\n\n/**\n * Parse a Terraform expression and return the AST. The expression does not need to be a Terraform string.\n * @param filename The filename to use for the expression. This is used for error reporting.\n * @param expression The expression to parse.\n * @returns The AST for the expression.\n *\n *   The returned AST has the following structure:\n *   - type: The type of the node. This is a string.\n *   - range: This contains the start and end of the node in the expression.\n *   - children: This contains the children of the node. This is an array of nodes.\n *   - meta: This contains metadata about the node. This is an object, and varies depending on the type of the node.\n */\nexport async function getExpressionAst(\n  filename: string,\n  expression: string,\n): Promise<ExpressionType | null> {\n  const res = await wasm.getExpressionAst(filename, expression);\n  const ast = JSON.parse(res) as ExpressionType;\n\n  if (!ast) {\n    return null;\n  }\n\n  return ast;\n}\n"]}
package/lib/references.js CHANGED
@@ -9,8 +9,8 @@ function traversalToReference(traversalExpression, localVariables) {
9
9
  // We do not want to include property access through brackets here
10
10
  // although it is technically a traversal / reference
11
11
  function onlyTakeTraversalPartsUntilFirstBracketPropertyAccess(traversals) {
12
- let filtered = [];
13
- let index = 0;
12
+ const filtered = [];
13
+ const index = 0;
14
14
  for (const traversal of traversals) {
15
15
  if ("segment" in traversal) {
16
16
  if (index === 0) {
@@ -74,4 +74,4 @@ function findAllReferencesInAst(input, entry, localVariables) {
74
74
  }
75
75
  }
76
76
  exports.findAllReferencesInAst = findAllReferencesInAst;
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmZXJlbmNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInJlZmVyZW5jZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLCtCQUErQjtBQUMvQixtQ0FBbUM7OztBQUVuQywrQ0FNdUI7QUFRdkIsU0FBZ0Isb0JBQW9CLENBQ2xDLG1CQUFrQyxFQUNsQyxjQUF5QjtJQUV6QixNQUFNLElBQUksR0FBRyxtQkFBbUIsQ0FBQyxJQUFvQyxDQUFDO0lBRXRFLGtFQUFrRTtJQUNsRSxxREFBcUQ7SUFDckQsU0FBUyxxREFBcUQsQ0FDNUQsVUFBb0M7UUFFcEMsSUFBSSxRQUFRLEdBQUcsRUFBRSxDQUFDO1FBQ2xCLElBQUksS0FBSyxHQUFHLENBQUMsQ0FBQztRQUVkLEtBQUssTUFBTSxTQUFTLElBQUksVUFBVSxFQUFFLENBQUM7WUFDbkMsSUFBSSxTQUFTLElBQUksU0FBUyxFQUFFLENBQUM7Z0JBQzNCLElBQUksS0FBSyxLQUFLLENBQUMsRUFBRSxDQUFDO29CQUNoQixpRUFBaUU7b0JBQ2pFLElBQUksY0FBYyxhQUFkLGNBQWMsdUJBQWQsY0FBYyxDQUFFLFFBQVEsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQzt3QkFDaEQsb0NBQW9DO3dCQUNwQyxPQUFPLEVBQUUsQ0FBQztvQkFDWixDQUFDO2dCQUNILENBQUM7Z0JBQ0QsUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUMzQixDQUFDO2lCQUFNLENBQUM7Z0JBQ04sNkJBQTZCO2dCQUM3QixPQUFPLFFBQVEsQ0FBQztZQUNsQixDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sUUFBUSxDQUFDO0lBQ2xCLENBQUM7SUFFRCxNQUFNLGFBQWEsR0FBRyxxREFBcUQsQ0FDekUsSUFBSSxDQUFDLFNBQVMsQ0FDZixDQUFDO0lBRUYsSUFBSSxhQUFhLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQy9CLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELE1BQU0sYUFBYSxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQztJQUN4RCxNQUFNLFdBQVcsR0FBRyxhQUFhLENBQUMsYUFBYSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQztJQUUzRSxPQUFPO1FBQ0wsS0FBSyxFQUFFLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1FBQzFELGFBQWE7UUFDYixXQUFXO0tBQ1osQ0FBQztBQUNKLENBQUM7QUFqREQsb0RBaURDO0FBRUQsU0FBZ0Isc0JBQXNCLENBQ3BDLEtBQWEsRUFDYixLQUF1QyxFQUN2QyxjQUF5QjtJQUV6QixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDWCxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRCxRQUFRLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNuQixLQUFLLGdCQUFnQixDQUFDLENBQUMsQ0FBQztZQUN0QiwwQ0FBMEM7WUFDMUMsOERBQThEO1lBQzlELE1BQU0sU0FBUyxHQUFHLG9CQUFvQixDQUFDLEtBQUssRUFBRSxjQUFjLENBQUMsQ0FBQztZQUM5RCxJQUFJLFNBQVM7Z0JBQUUsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ2xDLE9BQU8sRUFBRSxDQUFDO1FBQ1osQ0FBQztRQUVELEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQztZQUNYLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUF5QixDQUFDO1lBQzdDLE1BQU0sd0JBQXdCLEdBQUc7Z0JBQy9CLElBQUksQ0FBQyxNQUFNO2dCQUNYLElBQUksQ0FBQyxNQUFNO2dCQUNYLEdBQUcsQ0FBQyxjQUFjLElBQUksRUFBRSxDQUFDO2FBQzFCLENBQUM7WUFFRixPQUFPO2dCQUNMLEdBQUcsc0JBQXNCLENBQ3ZCLEtBQUssRUFDTCxJQUFBLCtCQUFpQixFQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsb0JBQW9CLENBQUMsRUFDbkQsd0JBQXdCLENBQ3pCO2dCQUNELEdBQUcsc0JBQXNCLENBQ3ZCLEtBQUssRUFDTCxJQUFBLCtCQUFpQixFQUFDLEtBQUssRUFBRSxJQUFJLENBQUMscUJBQXFCLENBQUMsRUFDcEQsd0JBQXdCLENBQ3pCO2FBQ0YsQ0FBQztRQUNKLENBQUM7UUFDRDtZQUNFLE9BQU8sS0FBSyxDQUFDLFFBQVE7aUJBQ2xCLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsc0JBQXNCLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxjQUFjLENBQUMsQ0FBQztpQkFDcEUsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0FBQ0gsQ0FBQztBQTVDRCx3REE0Q0MiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIEhhc2hpQ29ycCwgSW5jXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTVBMLTIuMFxuXG5pbXBvcnQge1xuICBFeHByZXNzaW9uQXN0LFxuICBTY29wZVRyYXZlcnNhbEV4cHJlc3Npb25NZXRhLFxuICBUZXJyYWZvcm1UcmF2ZXJzYWxQYXJ0LFxuICBGb3JFeHByZXNzaW9uTWV0YSxcbiAgZ2V0Q2hpbGRXaXRoVmFsdWUsXG59IGZyb20gXCIuL3N5bnRheC10cmVlXCI7XG5cbmV4cG9ydCB0eXBlIFJlZmVyZW5jZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgc3RhcnRQb3NpdGlvbjogbnVtYmVyO1xuICBlbmRQb3NpdGlvbjogbnVtYmVyO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIHRyYXZlcnNhbFRvUmVmZXJlbmNlKFxuICB0cmF2ZXJzYWxFeHByZXNzaW9uOiBFeHByZXNzaW9uQXN0LFxuICBsb2NhbFZhcmlhYmxlcz86IHN0cmluZ1tdLFxuKTogUmVmZXJlbmNlIHwgbnVsbCB7XG4gIGNvbnN0IG1ldGEgPSB0cmF2ZXJzYWxFeHByZXNzaW9uLm1ldGEgYXMgU2NvcGVUcmF2ZXJzYWxFeHByZXNzaW9uTWV0YTtcblxuICAvLyBXZSBkbyBub3Qgd2FudCB0byBpbmNsdWRlIHByb3BlcnR5IGFjY2VzcyB0aHJvdWdoIGJyYWNrZXRzIGhlcmVcbiAgLy8gYWx0aG91Z2ggaXQgaXMgdGVjaG5pY2FsbHkgYSB0cmF2ZXJzYWwgLyByZWZlcmVuY2VcbiAgZnVuY3Rpb24gb25seVRha2VUcmF2ZXJzYWxQYXJ0c1VudGlsRmlyc3RCcmFja2V0UHJvcGVydHlBY2Nlc3MoXG4gICAgdHJhdmVyc2FsczogVGVycmFmb3JtVHJhdmVyc2FsUGFydFtdLFxuICApIHtcbiAgICBsZXQgZmlsdGVyZWQgPSBbXTtcbiAgICBsZXQgaW5kZXggPSAwO1xuXG4gICAgZm9yIChjb25zdCB0cmF2ZXJzYWwgb2YgdHJhdmVyc2Fscykge1xuICAgICAgaWYgKFwic2VnbWVudFwiIGluIHRyYXZlcnNhbCkge1xuICAgICAgICBpZiAoaW5kZXggPT09IDApIHtcbiAgICAgICAgICAvLyBXZSBhcmUgYXQgdGhlIGZpcnN0IHRyYXZlcnNhbCwgY2hlY2sgaWYgaXQgaXMgYSBsb2NhbCB2YXJpYWJsZVxuICAgICAgICAgIGlmIChsb2NhbFZhcmlhYmxlcz8uaW5jbHVkZXModHJhdmVyc2FsLnNlZ21lbnQpKSB7XG4gICAgICAgICAgICAvLyBXZSByZWFjaGVkIGEgbG9jYWwgdmFyaWFibGUsIHN0b3BcbiAgICAgICAgICAgIHJldHVybiBbXTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgZmlsdGVyZWQucHVzaCh0cmF2ZXJzYWwpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gV2UgcmVhY2hlZCBhIGJyYWNrZXQsIHN0b3BcbiAgICAgICAgcmV0dXJuIGZpbHRlcmVkO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBmaWx0ZXJlZDtcbiAgfVxuXG4gIGNvbnN0IGZpbHRlcmVkUGFydHMgPSBvbmx5VGFrZVRyYXZlcnNhbFBhcnRzVW50aWxGaXJzdEJyYWNrZXRQcm9wZXJ0eUFjY2VzcyhcbiAgICBtZXRhLnRyYXZlcnNhbCxcbiAgKTtcblxuICBpZiAoZmlsdGVyZWRQYXJ0cy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IHN0YXJ0UG9zaXRpb24gPSBmaWx0ZXJlZFBhcnRzWzBdLnJhbmdlLnN0YXJ0LmJ5dGU7XG4gIGNvbnN0IGVuZFBvc2l0aW9uID0gZmlsdGVyZWRQYXJ0c1tmaWx0ZXJlZFBhcnRzLmxlbmd0aCAtIDFdLnJhbmdlLmVuZC5ieXRlO1xuXG4gIHJldHVybiB7XG4gICAgdmFsdWU6IGZpbHRlcmVkUGFydHMubWFwKChwYXJ0KSA9PiBwYXJ0LnNlZ21lbnQpLmpvaW4oXCIuXCIpLFxuICAgIHN0YXJ0UG9zaXRpb24sXG4gICAgZW5kUG9zaXRpb24sXG4gIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmaW5kQWxsUmVmZXJlbmNlc0luQXN0KFxuICBpbnB1dDogc3RyaW5nLFxuICBlbnRyeTogRXhwcmVzc2lvbkFzdCB8IHVuZGVmaW5lZCB8IG51bGwsXG4gIGxvY2FsVmFyaWFibGVzPzogc3RyaW5nW10sXG4pOiBSZWZlcmVuY2VbXSB7XG4gIGlmICghZW50cnkpIHtcbiAgICByZXR1cm4gW107XG4gIH1cblxuICBzd2l0Y2ggKGVudHJ5LnR5cGUpIHtcbiAgICBjYXNlIFwic2NvcGVUcmF2ZXJzYWxcIjoge1xuICAgICAgLy8gRm9yIHRyYXZlcnNhbHMgd2l0aGluIGEgZm9yIGV4cHJlc3Npb24sXG4gICAgICAvLyB3ZSB3YW50IHRvIGlnbm9yZSB0aGUgbG9jYWwgdmFyaWFibGVzIG9mIHRoZSBmb3IgZXhwcmVzc2lvblxuICAgICAgY29uc3QgcmVmZXJlbmNlID0gdHJhdmVyc2FsVG9SZWZlcmVuY2UoZW50cnksIGxvY2FsVmFyaWFibGVzKTtcbiAgICAgIGlmIChyZWZlcmVuY2UpIHJldHVybiBbcmVmZXJlbmNlXTtcbiAgICAgIHJldHVybiBbXTtcbiAgICB9XG5cbiAgICBjYXNlIFwiZm9yXCI6IHtcbiAgICAgIGNvbnN0IG1ldGEgPSBlbnRyeS5tZXRhIGFzIEZvckV4cHJlc3Npb25NZXRhO1xuICAgICAgY29uc3QgYWRkaXRpb25hbExvY2FsVmFyaWFibGVzID0gW1xuICAgICAgICBtZXRhLmtleVZhcixcbiAgICAgICAgbWV0YS52YWxWYXIsXG4gICAgICAgIC4uLihsb2NhbFZhcmlhYmxlcyB8fCBbXSksXG4gICAgICBdO1xuXG4gICAgICByZXR1cm4gW1xuICAgICAgICAuLi5maW5kQWxsUmVmZXJlbmNlc0luQXN0KFxuICAgICAgICAgIGlucHV0LFxuICAgICAgICAgIGdldENoaWxkV2l0aFZhbHVlKGVudHJ5LCBtZXRhLmNvbGxlY3Rpb25FeHByZXNzaW9uKSxcbiAgICAgICAgICBhZGRpdGlvbmFsTG9jYWxWYXJpYWJsZXMsXG4gICAgICAgICksXG4gICAgICAgIC4uLmZpbmRBbGxSZWZlcmVuY2VzSW5Bc3QoXG4gICAgICAgICAgaW5wdXQsXG4gICAgICAgICAgZ2V0Q2hpbGRXaXRoVmFsdWUoZW50cnksIG1ldGEuY29uZGl0aW9uYWxFeHByZXNzaW9uKSxcbiAgICAgICAgICBhZGRpdGlvbmFsTG9jYWxWYXJpYWJsZXMsXG4gICAgICAgICksXG4gICAgICBdO1xuICAgIH1cbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIGVudHJ5LmNoaWxkcmVuXG4gICAgICAgIC5tYXAoKGNoaWxkKSA9PiBmaW5kQWxsUmVmZXJlbmNlc0luQXN0KGlucHV0LCBjaGlsZCwgbG9jYWxWYXJpYWJsZXMpKVxuICAgICAgICAuZmxhdCgpO1xuICB9XG59XG4iXX0=
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmZXJlbmNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInJlZmVyZW5jZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLCtCQUErQjtBQUMvQixtQ0FBbUM7OztBQUVuQywrQ0FNdUI7QUFRdkIsU0FBZ0Isb0JBQW9CLENBQ2xDLG1CQUFrQyxFQUNsQyxjQUF5QjtJQUV6QixNQUFNLElBQUksR0FBRyxtQkFBbUIsQ0FBQyxJQUFvQyxDQUFDO0lBRXRFLGtFQUFrRTtJQUNsRSxxREFBcUQ7SUFDckQsU0FBUyxxREFBcUQsQ0FDNUQsVUFBb0M7UUFFcEMsTUFBTSxRQUFRLEdBQUcsRUFBRSxDQUFDO1FBQ3BCLE1BQU0sS0FBSyxHQUFHLENBQUMsQ0FBQztRQUVoQixLQUFLLE1BQU0sU0FBUyxJQUFJLFVBQVUsRUFBRSxDQUFDO1lBQ25DLElBQUksU0FBUyxJQUFJLFNBQVMsRUFBRSxDQUFDO2dCQUMzQixJQUFJLEtBQUssS0FBSyxDQUFDLEVBQUUsQ0FBQztvQkFDaEIsaUVBQWlFO29CQUNqRSxJQUFJLGNBQWMsYUFBZCxjQUFjLHVCQUFkLGNBQWMsQ0FBRSxRQUFRLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7d0JBQ2hELG9DQUFvQzt3QkFDcEMsT0FBTyxFQUFFLENBQUM7b0JBQ1osQ0FBQztnQkFDSCxDQUFDO2dCQUNELFFBQVEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDM0IsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLDZCQUE2QjtnQkFDN0IsT0FBTyxRQUFRLENBQUM7WUFDbEIsQ0FBQztRQUNILENBQUM7UUFFRCxPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDO0lBRUQsTUFBTSxhQUFhLEdBQUcscURBQXFELENBQ3pFLElBQUksQ0FBQyxTQUFTLENBQ2YsQ0FBQztJQUVGLElBQUksYUFBYSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUMvQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxNQUFNLGFBQWEsR0FBRyxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUM7SUFDeEQsTUFBTSxXQUFXLEdBQUcsYUFBYSxDQUFDLGFBQWEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUM7SUFFM0UsT0FBTztRQUNMLEtBQUssRUFBRSxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQztRQUMxRCxhQUFhO1FBQ2IsV0FBVztLQUNaLENBQUM7QUFDSixDQUFDO0FBakRELG9EQWlEQztBQUVELFNBQWdCLHNCQUFzQixDQUNwQyxLQUFhLEVBQ2IsS0FBdUMsRUFDdkMsY0FBeUI7SUFFekIsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ1gsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDO0lBRUQsUUFBUSxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDbkIsS0FBSyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUM7WUFDdEIsMENBQTBDO1lBQzFDLDhEQUE4RDtZQUM5RCxNQUFNLFNBQVMsR0FBRyxvQkFBb0IsQ0FBQyxLQUFLLEVBQUUsY0FBYyxDQUFDLENBQUM7WUFDOUQsSUFBSSxTQUFTO2dCQUFFLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUNsQyxPQUFPLEVBQUUsQ0FBQztRQUNaLENBQUM7UUFFRCxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDWCxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsSUFBeUIsQ0FBQztZQUM3QyxNQUFNLHdCQUF3QixHQUFHO2dCQUMvQixJQUFJLENBQUMsTUFBTTtnQkFDWCxJQUFJLENBQUMsTUFBTTtnQkFDWCxHQUFHLENBQUMsY0FBYyxJQUFJLEVBQUUsQ0FBQzthQUMxQixDQUFDO1lBRUYsT0FBTztnQkFDTCxHQUFHLHNCQUFzQixDQUN2QixLQUFLLEVBQ0wsSUFBQSwrQkFBaUIsRUFBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLG9CQUFvQixDQUFDLEVBQ25ELHdCQUF3QixDQUN6QjtnQkFDRCxHQUFHLHNCQUFzQixDQUN2QixLQUFLLEVBQ0wsSUFBQSwrQkFBaUIsRUFBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLHFCQUFxQixDQUFDLEVBQ3BELHdCQUF3QixDQUN6QjthQUNGLENBQUM7UUFDSixDQUFDO1FBQ0Q7WUFDRSxPQUFPLEtBQUssQ0FBQyxRQUFRO2lCQUNsQixHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLHNCQUFzQixDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsY0FBYyxDQUFDLENBQUM7aUJBQ3BFLElBQUksRUFBRSxDQUFDO0lBQ2QsQ0FBQztBQUNILENBQUM7QUE1Q0Qsd0RBNENDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IChjKSBIYXNoaUNvcnAsIEluY1xuLy8gU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IE1QTC0yLjBcblxuaW1wb3J0IHtcbiAgRXhwcmVzc2lvbkFzdCxcbiAgU2NvcGVUcmF2ZXJzYWxFeHByZXNzaW9uTWV0YSxcbiAgVGVycmFmb3JtVHJhdmVyc2FsUGFydCxcbiAgRm9yRXhwcmVzc2lvbk1ldGEsXG4gIGdldENoaWxkV2l0aFZhbHVlLFxufSBmcm9tIFwiLi9zeW50YXgtdHJlZVwiO1xuXG5leHBvcnQgdHlwZSBSZWZlcmVuY2UgPSB7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIHN0YXJ0UG9zaXRpb246IG51bWJlcjtcbiAgZW5kUG9zaXRpb246IG51bWJlcjtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiB0cmF2ZXJzYWxUb1JlZmVyZW5jZShcbiAgdHJhdmVyc2FsRXhwcmVzc2lvbjogRXhwcmVzc2lvbkFzdCxcbiAgbG9jYWxWYXJpYWJsZXM/OiBzdHJpbmdbXSxcbik6IFJlZmVyZW5jZSB8IG51bGwge1xuICBjb25zdCBtZXRhID0gdHJhdmVyc2FsRXhwcmVzc2lvbi5tZXRhIGFzIFNjb3BlVHJhdmVyc2FsRXhwcmVzc2lvbk1ldGE7XG5cbiAgLy8gV2UgZG8gbm90IHdhbnQgdG8gaW5jbHVkZSBwcm9wZXJ0eSBhY2Nlc3MgdGhyb3VnaCBicmFja2V0cyBoZXJlXG4gIC8vIGFsdGhvdWdoIGl0IGlzIHRlY2huaWNhbGx5IGEgdHJhdmVyc2FsIC8gcmVmZXJlbmNlXG4gIGZ1bmN0aW9uIG9ubHlUYWtlVHJhdmVyc2FsUGFydHNVbnRpbEZpcnN0QnJhY2tldFByb3BlcnR5QWNjZXNzKFxuICAgIHRyYXZlcnNhbHM6IFRlcnJhZm9ybVRyYXZlcnNhbFBhcnRbXSxcbiAgKSB7XG4gICAgY29uc3QgZmlsdGVyZWQgPSBbXTtcbiAgICBjb25zdCBpbmRleCA9IDA7XG5cbiAgICBmb3IgKGNvbnN0IHRyYXZlcnNhbCBvZiB0cmF2ZXJzYWxzKSB7XG4gICAgICBpZiAoXCJzZWdtZW50XCIgaW4gdHJhdmVyc2FsKSB7XG4gICAgICAgIGlmIChpbmRleCA9PT0gMCkge1xuICAgICAgICAgIC8vIFdlIGFyZSBhdCB0aGUgZmlyc3QgdHJhdmVyc2FsLCBjaGVjayBpZiBpdCBpcyBhIGxvY2FsIHZhcmlhYmxlXG4gICAgICAgICAgaWYgKGxvY2FsVmFyaWFibGVzPy5pbmNsdWRlcyh0cmF2ZXJzYWwuc2VnbWVudCkpIHtcbiAgICAgICAgICAgIC8vIFdlIHJlYWNoZWQgYSBsb2NhbCB2YXJpYWJsZSwgc3RvcFxuICAgICAgICAgICAgcmV0dXJuIFtdO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBmaWx0ZXJlZC5wdXNoKHRyYXZlcnNhbCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyBXZSByZWFjaGVkIGEgYnJhY2tldCwgc3RvcFxuICAgICAgICByZXR1cm4gZmlsdGVyZWQ7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGZpbHRlcmVkO1xuICB9XG5cbiAgY29uc3QgZmlsdGVyZWRQYXJ0cyA9IG9ubHlUYWtlVHJhdmVyc2FsUGFydHNVbnRpbEZpcnN0QnJhY2tldFByb3BlcnR5QWNjZXNzKFxuICAgIG1ldGEudHJhdmVyc2FsLFxuICApO1xuXG4gIGlmIChmaWx0ZXJlZFBhcnRzLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgY29uc3Qgc3RhcnRQb3NpdGlvbiA9IGZpbHRlcmVkUGFydHNbMF0ucmFuZ2Uuc3RhcnQuYnl0ZTtcbiAgY29uc3QgZW5kUG9zaXRpb24gPSBmaWx0ZXJlZFBhcnRzW2ZpbHRlcmVkUGFydHMubGVuZ3RoIC0gMV0ucmFuZ2UuZW5kLmJ5dGU7XG5cbiAgcmV0dXJuIHtcbiAgICB2YWx1ZTogZmlsdGVyZWRQYXJ0cy5tYXAoKHBhcnQpID0+IHBhcnQuc2VnbWVudCkuam9pbihcIi5cIiksXG4gICAgc3RhcnRQb3NpdGlvbixcbiAgICBlbmRQb3NpdGlvbixcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZpbmRBbGxSZWZlcmVuY2VzSW5Bc3QoXG4gIGlucHV0OiBzdHJpbmcsXG4gIGVudHJ5OiBFeHByZXNzaW9uQXN0IHwgdW5kZWZpbmVkIHwgbnVsbCxcbiAgbG9jYWxWYXJpYWJsZXM/OiBzdHJpbmdbXSxcbik6IFJlZmVyZW5jZVtdIHtcbiAgaWYgKCFlbnRyeSkge1xuICAgIHJldHVybiBbXTtcbiAgfVxuXG4gIHN3aXRjaCAoZW50cnkudHlwZSkge1xuICAgIGNhc2UgXCJzY29wZVRyYXZlcnNhbFwiOiB7XG4gICAgICAvLyBGb3IgdHJhdmVyc2FscyB3aXRoaW4gYSBmb3IgZXhwcmVzc2lvbixcbiAgICAgIC8vIHdlIHdhbnQgdG8gaWdub3JlIHRoZSBsb2NhbCB2YXJpYWJsZXMgb2YgdGhlIGZvciBleHByZXNzaW9uXG4gICAgICBjb25zdCByZWZlcmVuY2UgPSB0cmF2ZXJzYWxUb1JlZmVyZW5jZShlbnRyeSwgbG9jYWxWYXJpYWJsZXMpO1xuICAgICAgaWYgKHJlZmVyZW5jZSkgcmV0dXJuIFtyZWZlcmVuY2VdO1xuICAgICAgcmV0dXJuIFtdO1xuICAgIH1cblxuICAgIGNhc2UgXCJmb3JcIjoge1xuICAgICAgY29uc3QgbWV0YSA9IGVudHJ5Lm1ldGEgYXMgRm9yRXhwcmVzc2lvbk1ldGE7XG4gICAgICBjb25zdCBhZGRpdGlvbmFsTG9jYWxWYXJpYWJsZXMgPSBbXG4gICAgICAgIG1ldGEua2V5VmFyLFxuICAgICAgICBtZXRhLnZhbFZhcixcbiAgICAgICAgLi4uKGxvY2FsVmFyaWFibGVzIHx8IFtdKSxcbiAgICAgIF07XG5cbiAgICAgIHJldHVybiBbXG4gICAgICAgIC4uLmZpbmRBbGxSZWZlcmVuY2VzSW5Bc3QoXG4gICAgICAgICAgaW5wdXQsXG4gICAgICAgICAgZ2V0Q2hpbGRXaXRoVmFsdWUoZW50cnksIG1ldGEuY29sbGVjdGlvbkV4cHJlc3Npb24pLFxuICAgICAgICAgIGFkZGl0aW9uYWxMb2NhbFZhcmlhYmxlcyxcbiAgICAgICAgKSxcbiAgICAgICAgLi4uZmluZEFsbFJlZmVyZW5jZXNJbkFzdChcbiAgICAgICAgICBpbnB1dCxcbiAgICAgICAgICBnZXRDaGlsZFdpdGhWYWx1ZShlbnRyeSwgbWV0YS5jb25kaXRpb25hbEV4cHJlc3Npb24pLFxuICAgICAgICAgIGFkZGl0aW9uYWxMb2NhbFZhcmlhYmxlcyxcbiAgICAgICAgKSxcbiAgICAgIF07XG4gICAgfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gZW50cnkuY2hpbGRyZW5cbiAgICAgICAgLm1hcCgoY2hpbGQpID0+IGZpbmRBbGxSZWZlcmVuY2VzSW5Bc3QoaW5wdXQsIGNoaWxkLCBsb2NhbFZhcmlhYmxlcykpXG4gICAgICAgIC5mbGF0KCk7XG4gIH1cbn1cbiJdfQ==
package/main.wasm.gz CHANGED
Binary file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cdktn/hcl2json",
3
- "version": "0.23.0-pre.29",
3
+ "version": "0.23.0-pre.33",
4
4
  "description": "Transform HCL into JSON",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
package/wasm/wasm_exec.js CHANGED
@@ -14,13 +14,13 @@
14
14
  if (!globalThis.fs) {
15
15
  let outputBuf = "";
16
16
  globalThis.fs = {
17
- constants: { O_WRONLY: -1, O_RDWR: -1, O_CREAT: -1, O_TRUNC: -1, O_APPEND: -1, O_EXCL: -1 }, // unused
17
+ constants: { O_WRONLY: -1, O_RDWR: -1, O_CREAT: -1, O_TRUNC: -1, O_APPEND: -1, O_EXCL: -1, O_DIRECTORY: -1 }, // unused
18
18
  writeSync(fd, buf) {
19
19
  outputBuf += decoder.decode(buf);
20
20
  const nl = outputBuf.lastIndexOf("\n");
21
21
  if (nl != -1) {
22
- console.log(outputBuf.substr(0, nl));
23
- outputBuf = outputBuf.substr(nl + 1);
22
+ console.log(outputBuf.substring(0, nl));
23
+ outputBuf = outputBuf.substring(nl + 1);
24
24
  }
25
25
  return buf.length;
26
26
  },
@@ -73,6 +73,14 @@
73
73
  }
74
74
  }
75
75
 
76
+ if (!globalThis.path) {
77
+ globalThis.path = {
78
+ resolve(...pathSegments) {
79
+ return pathSegments.join("/");
80
+ }
81
+ }
82
+ }
83
+
76
84
  if (!globalThis.crypto) {
77
85
  throw new Error("globalThis.crypto is not available, polyfill required (crypto.getRandomValues only)");
78
86
  }
@@ -113,6 +121,10 @@
113
121
  this.mem.setUint32(addr + 4, Math.floor(v / 4294967296), true);
114
122
  }
115
123
 
124
+ const setInt32 = (addr, v) => {
125
+ this.mem.setUint32(addr + 0, v, true);
126
+ }
127
+
116
128
  const getInt64 = (addr) => {
117
129
  const low = this.mem.getUint32(addr + 0, true);
118
130
  const high = this.mem.getInt32(addr + 4, true);
@@ -204,9 +216,18 @@
204
216
  return decoder.decode(new DataView(this._inst.exports.mem.buffer, saddr, len));
205
217
  }
206
218
 
219
+ const testCallExport = (a, b) => {
220
+ this._inst.exports.testExport0();
221
+ return this._inst.exports.testExport(a, b);
222
+ }
223
+
207
224
  const timeOrigin = Date.now() - performance.now();
208
225
  this.importObject = {
209
- go: {
226
+ _gotest: {
227
+ add: (a, b) => a + b,
228
+ callExport: testCallExport,
229
+ },
230
+ gojs: {
210
231
  // Go's SP does not change as long as no Go code is running. Some operations (e.g. calls, getters and setters)
211
232
  // may synchronously trigger a Go event handler. This makes Go code get executed in the middle of the imported
212
233
  // function. A goroutine can switch to a new stack if the current stack is too small (see morestack function).
@@ -269,7 +290,7 @@
269
290
  this._resume();
270
291
  }
271
292
  },
272
- getInt64(sp + 8) + 1, // setTimeout has been seen to fire up to 1 millisecond early
293
+ getInt64(sp + 8),
273
294
  ));
274
295
  this.mem.setInt32(sp + 16, id, true);
275
296
  },