@mrgrain/cdk-esbuild 4.0.0-alpha.7 → 4.0.0-beta.0

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.
Files changed (51) hide show
  1. package/.jsii +1573 -588
  2. package/CHANGELOG.md +104 -0
  3. package/LICENSE +1 -1
  4. package/README.md +223 -102
  5. package/lib/asset.d.ts +20 -5
  6. package/lib/asset.js +31 -19
  7. package/lib/bundler.d.ts +51 -28
  8. package/lib/bundler.js +28 -17
  9. package/lib/code.d.ts +82 -16
  10. package/lib/code.js +71 -25
  11. package/lib/esbuild-types.d.ts +49 -18
  12. package/lib/esbuild-types.js +1 -1
  13. package/lib/index.d.ts +5 -4
  14. package/lib/index.js +8 -7
  15. package/lib/inline-code.d.ts +29 -77
  16. package/lib/inline-code.js +53 -104
  17. package/lib/private/dynamic-package.d.ts +41 -0
  18. package/lib/private/dynamic-package.js +115 -0
  19. package/lib/private/esbuild-source.d.ts +33 -0
  20. package/lib/private/esbuild-source.js +59 -0
  21. package/lib/private/utils.d.ts +7 -0
  22. package/lib/private/utils.js +23 -0
  23. package/lib/provider.d.ts +129 -0
  24. package/lib/provider.js +115 -0
  25. package/lib/source.d.ts +81 -5
  26. package/lib/source.js +84 -8
  27. package/package.json +33 -25
  28. package/rosetta/default.ts-fixture +32 -0
  29. package/.gitattributes +0 -24
  30. package/.projenrc.ts +0 -208
  31. package/API.md +0 -2477
  32. package/SECURITY.md +0 -19
  33. package/lib/esbuild-polyfill.js +0 -2302
  34. package/lib/esbuild-wrapper.d.ts +0 -3
  35. package/lib/esbuild-wrapper.js +0 -31
  36. package/lib/formatMessages.d.ts +0 -18
  37. package/lib/formatMessages.js +0 -34
  38. package/node_modules/isexe/.npmignore +0 -2
  39. package/node_modules/isexe/LICENSE +0 -15
  40. package/node_modules/isexe/README.md +0 -51
  41. package/node_modules/isexe/index.js +0 -57
  42. package/node_modules/isexe/mode.js +0 -41
  43. package/node_modules/isexe/package.json +0 -35
  44. package/node_modules/isexe/test/basic.js +0 -221
  45. package/node_modules/isexe/windows.js +0 -42
  46. package/node_modules/which/CHANGELOG.md +0 -166
  47. package/node_modules/which/LICENSE +0 -15
  48. package/node_modules/which/README.md +0 -54
  49. package/node_modules/which/bin/node-which +0 -52
  50. package/node_modules/which/package.json +0 -47
  51. package/node_modules/which/which.js +0 -125
package/lib/code.js CHANGED
@@ -1,23 +1,51 @@
1
1
  "use strict";
2
2
  var _a, _b, _c;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.TypeScriptCode = exports.JavaScriptCode = exports.Code = void 0;
4
+ exports.TypeScriptCode = exports.JavaScriptCode = exports.EsbuildCode = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const aws_cdk_lib_1 = require("aws-cdk-lib");
7
7
  const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
8
8
  const asset_1 = require("./asset");
9
- function nodeMajorVersion() {
10
- return parseInt(process.versions.node.split('.')[0], 10);
11
- }
9
+ const utils_1 = require("./private/utils");
12
10
  ;
13
11
  ;
14
- class Code extends aws_lambda_1.Code {
12
+ /**
13
+ * Represents a generic esbuild code bundle.
14
+ *
15
+ * You should always use `TypeScriptCode` or `JavaScriptCode`.
16
+ *
17
+ * @stability experimental
18
+ */
19
+ class EsbuildCode extends aws_lambda_1.Code {
20
+ constructor(
15
21
  /**
22
+ * A path or list or map of paths to the entry points of your code.
23
+ *
24
+ * Relative paths are by default resolved from the current working directory.
25
+ * To change the working directory, see `buildOptions.absWorkingDir`.
26
+ *
27
+ * Absolute paths can be used if files are part of the working directory.
28
+ *
29
+ * Examples:
30
+ * - `'src/index.ts'`
31
+ * - `require.resolve('./lambda')`
32
+ * - `['src/index.ts', 'src/util.ts']`
33
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
34
+ *
35
+ * @stability stable
36
+ */
37
+ entryPoints,
38
+ /**
39
+ * Props to change the behavior of the bundler.
16
40
  *
17
- * @param entryPoints - Relative path to the asset code. Use `props.buildOptions.absWorkingDir` if an absolute path is required.
18
- * @param props - Asset properties.
41
+ * Default values for `props.buildOptions`:
42
+ * - `bundle=true`
43
+ * - `platform=node`
44
+ * - `target=nodeX` with X being the major node version running locally
45
+ *
46
+ * @stability stable
19
47
  */
20
- constructor(entryPoints, props) {
48
+ props) {
21
49
  super();
22
50
  this.entryPoints = entryPoints;
23
51
  /**
@@ -26,12 +54,7 @@ class Code extends aws_lambda_1.Code {
26
54
  * @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().
27
55
  */
28
56
  this.isInline = false;
29
- const defaultOptions = {
30
- ...(!props.buildOptions?.platform ||
31
- props.buildOptions?.platform === 'node'
32
- ? { platform: 'node', target: 'node' + nodeMajorVersion() }
33
- : {}),
34
- };
57
+ const defaultOptions = utils_1.defaultPlatformProps(props.buildOptions);
35
58
  this.props = {
36
59
  ...props,
37
60
  entryPoints,
@@ -41,6 +64,9 @@ class Code extends aws_lambda_1.Code {
41
64
  },
42
65
  };
43
66
  }
67
+ getAsset(scope) {
68
+ return new asset_1.EsbuildAsset(scope, this.constructor.name, this.props);
69
+ }
44
70
  bind(scope) {
45
71
  // If the same AssetCode is used multiple times, retain only the first instantiation.
46
72
  if (!this.asset) {
@@ -73,19 +99,29 @@ class Code extends aws_lambda_1.Code {
73
99
  this.asset.addResourceMetadata(resource, resourceProperty);
74
100
  }
75
101
  }
76
- exports.Code = Code;
102
+ exports.EsbuildCode = EsbuildCode;
77
103
  _a = JSII_RTTI_SYMBOL_1;
78
- Code[_a] = { fqn: "@mrgrain/cdk-esbuild.Code", version: "4.0.0-alpha.7" };
104
+ EsbuildCode[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildCode", version: "4.0.0-beta.0" };
79
105
  /**
80
106
  * Represents the deployed JavaScript Code.
81
107
  *
82
108
  * @stability stable
83
109
  */
84
- class JavaScriptCode extends Code {
110
+ class JavaScriptCode extends EsbuildCode {
85
111
  constructor(
86
112
  /**
87
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project.
88
- * E.g. `src/index.ts`.
113
+ * A path or list or map of paths to the entry points of your code.
114
+ *
115
+ * Relative paths are by default resolved from the current working directory.
116
+ * To change the working directory, see `buildOptions.absWorkingDir`.
117
+ *
118
+ * Absolute paths can be used if files are part of the working directory.
119
+ *
120
+ * Examples:
121
+ * - `'src/index.ts'`
122
+ * - `require.resolve('./lambda')`
123
+ * - `['src/index.ts', 'src/util.ts']`
124
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
89
125
  *
90
126
  * @stability stable
91
127
  */
@@ -109,17 +145,27 @@ class JavaScriptCode extends Code {
109
145
  }
110
146
  exports.JavaScriptCode = JavaScriptCode;
111
147
  _b = JSII_RTTI_SYMBOL_1;
112
- JavaScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "4.0.0-alpha.7" };
148
+ JavaScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "4.0.0-beta.0" };
113
149
  /**
114
150
  * Represents the deployed TypeScript Code.
115
151
  *
116
152
  * @stability stable
117
153
  */
118
- class TypeScriptCode extends Code {
154
+ class TypeScriptCode extends EsbuildCode {
119
155
  constructor(
120
156
  /**
121
- * A relative path or list or map of relative paths to the entry points of your code from the root of the project.
122
- * E.g. `src/index.ts`.
157
+ * A path or list or map of paths to the entry points of your code.
158
+ *
159
+ * Relative paths are by default resolved from the current working directory.
160
+ * To change the working directory, see `buildOptions.absWorkingDir`.
161
+ *
162
+ * Absolute paths can be used if files are part of the working directory.
163
+ *
164
+ * Examples:
165
+ * - `'src/index.ts'`
166
+ * - `require.resolve('./lambda')`
167
+ * - `['src/index.ts', 'src/util.ts']`
168
+ * - `{one: 'src/two.ts', two: 'src/one.ts'}`
123
169
  *
124
170
  * @stability stable
125
171
  */
@@ -143,5 +189,5 @@ class TypeScriptCode extends Code {
143
189
  }
144
190
  exports.TypeScriptCode = TypeScriptCode;
145
191
  _c = JSII_RTTI_SYMBOL_1;
146
- TypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "4.0.0-alpha.7" };
147
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["../src/code.ts"],"names":[],"mappings":";;;;;AAAA,6CAAiD;AACjD,uDAA6F;AAE7F,mCAMiB;AAIjB,SAAS,gBAAgB;IACvB,OAAO,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AAC3D,CAAC;AAG6D,CAAC;AACD,CAAC;AAE/D,MAAsB,IAEpB,SAAQ,iBAAU;IAclB;;;;OAIG;IACH,YAA4B,WAAwB,EAAE,KAAY;QAChE,KAAK,EAAE,CAAC;QADkB,gBAAW,GAAX,WAAW,CAAa;QAZpD;;;;WAIG;QACI,aAAQ,GAAY,KAAK,CAAC;QAS/B,MAAM,cAAc,GAA0B;YAC5C,GAAG,CAAC,CAAC,KAAK,CAAC,YAAY,EAAE,QAAQ;gBACjC,KAAK,CAAC,YAAY,EAAE,QAAQ,KAAK,MAAM;gBACrC,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,gBAAgB,EAAE,EAAE;gBAC3D,CAAC,CAAC,EAAE,CAAC;SACR,CAAC;QAEF,IAAI,CAAC,KAAK,GAAG;YACX,GAAG,KAAK;YACR,WAAW;YACX,YAAY,EAAE;gBACZ,GAAG,cAAc;gBACjB,GAAG,KAAK,CAAC,YAAY;aACtB;SACF,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,KAAgB;QACnB,qFAAqF;QACrF,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACnC;aAAM,IAAI,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE;YACnD,MAAM,IAAI,KAAK,CACb,mDACE,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SACvB,KAAK,GAAG,8CAA8C,CACvD,CAAC;SACH;QAED,OAAO;YACL,UAAU,EAAE;gBACV,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY;gBACnC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW;aAClC;SACF,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,cAAc,CAAC,QAAqB,EAAE,OAA6B;QACjE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QACD,MAAM,gBAAgB,GAAG,OAAO,EAAE,gBAAgB,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QAC5E,6CAA6C;QAC7C,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;IAC7D,CAAC;;AA3EH,oBA4EC;;;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,IAAyB;IAS3D;IACE;;;;;OAKG;IACH,WAAwB;IACxB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;IAC5B,CAAC;IA7BS,QAAQ,CAAC,KAAgB;QACjC,OAAO,IAAI,uBAAO,CAChB,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;IACJ,CAAC;;AAPH,wCA+BC;;;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,IAAyB;IAS3D;IACE;;;;;OAKG;IACH,WAAwB;IACxB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;IAC5B,CAAC;IA7BS,QAAQ,CAAC,KAAgB;QACjC,OAAO,IAAI,uBAAO,CAChB,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;IACJ,CAAC;;AAPH,wCA+BC","sourcesContent":["import { CfnResource, Stack } from 'aws-cdk-lib';\nimport { ResourceBindOptions, Code as LambdaCode, CodeConfig } from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\nimport {\n  Asset,\n  AssetBaseProps,\n  AssetProps,\n  JavaScriptAsset as JSAsset,\n  TypeScriptAsset as TSAsset,\n} from './asset';\nimport { EntryPoints } from './bundler';\nimport { BuildOptions } from './esbuild-types';\n\nfunction nodeMajorVersion(): number {\n  return parseInt(process.versions.node.split('.')[0], 10);\n}\n\nexport { CodeConfig } from 'aws-cdk-lib/aws-lambda';\nexport interface JavaScriptCodeProps extends AssetBaseProps {};\nexport interface TypeScriptCodeProps extends AssetBaseProps {};\n\nexport abstract class Code<\n  Props extends JavaScriptCodeProps | TypeScriptCodeProps,\n> extends LambdaCode {\n  protected abstract getAsset(scope: Construct): Asset<AssetProps>;\n\n  protected props: AssetProps;\n\n  protected asset!: Asset<AssetProps>;\n\n  /**\n   * Determines whether this Code is inline code or not.\n   *\n   * @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().\n   */\n  public isInline: boolean = false;\n\n  /**\n   *\n   * @param entryPoints - Relative path to the asset code. Use `props.buildOptions.absWorkingDir` if an absolute path is required.\n   * @param props - Asset properties.\n   */\n  constructor(public readonly entryPoints: EntryPoints, props: Props) {\n    super();\n    const defaultOptions: Partial<BuildOptions> = {\n      ...(!props.buildOptions?.platform ||\n      props.buildOptions?.platform === 'node'\n        ? { platform: 'node', target: 'node' + nodeMajorVersion() }\n        : {}),\n    };\n\n    this.props = {\n      ...props,\n      entryPoints,\n      buildOptions: {\n        ...defaultOptions,\n        ...props.buildOptions,\n      },\n    };\n  }\n\n  bind(scope: Construct): CodeConfig {\n    // If the same AssetCode is used multiple times, retain only the first instantiation.\n    if (!this.asset) {\n      this.asset = this.getAsset(scope);\n    } else if (Stack.of(this.asset) !== Stack.of(scope)) {\n      throw new Error(\n        `Asset is already associated with another stack '${\n          Stack.of(this.asset).stackName\n        }'. ` + 'Create a new Asset instance for every stack.',\n      );\n    }\n\n    return {\n      s3Location: {\n        bucketName: this.asset.s3BucketName,\n        objectKey: this.asset.s3ObjectKey,\n      },\n    };\n  }\n\n  /**\n   * Called after the CFN function resource has been created to allow the code class to bind to it.\n   *\n   * Specifically it's required to allow assets to add\n   * metadata for tooling like SAM CLI to be able to find their origins.\n   *\n   * @stability stable\n   */\n  bindToResource(resource: CfnResource, options?: ResourceBindOptions) {\n    if (!this.asset) {\n      throw new Error('bindToResource() must be called after bind()');\n    }\n    const resourceProperty = options?.resourceProperty || this.constructor.name;\n    // https://github.com/aws/aws-cdk/issues/1432\n    this.asset.addResourceMetadata(resource, resourceProperty);\n  }\n}\n\n/**\n * Represents the deployed JavaScript Code.\n *\n * @stability stable\n */\nexport class JavaScriptCode extends Code<JavaScriptCodeProps> {\n  protected getAsset(scope: Construct): Asset<AssetProps> {\n    return new JSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A relative path or list or map of relative paths to the entry points of your code from the root of the project.\n     * E.g. `src/index.ts`.\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: JavaScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n\n/**\n * Represents the deployed TypeScript Code.\n *\n * @stability stable\n */\nexport class TypeScriptCode extends Code<TypeScriptCodeProps> {\n  protected getAsset(scope: Construct): Asset<AssetProps> {\n    return new TSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A relative path or list or map of relative paths to the entry points of your code from the root of the project.\n     * E.g. `src/index.ts`.\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: TypeScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n"]}
192
+ TypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "4.0.0-beta.0" };
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["../src/code.ts"],"names":[],"mappings":";;;;;AAAA,6CAAiD;AACjD,uDAA+E;AAE/E,mCAMiB;AAGjB,2CAAuD;AAGO,CAAC;AACD,CAAC;AAE/D;;;;;;GAMG;AACH,MAAa,WAEX,SAAQ,iBAAI;IAoBZ;IACE;;;;;;;;;;;;;;;OAeG;IACM,WAAwB;IAEjC;;;;;;;;;OASG;IACH,KAAY;QAEZ,KAAK,EAAE,CAAC;QAdC,gBAAW,GAAX,WAAW,CAAa;QAxBnC;;;;WAIG;QACI,aAAQ,GAAY,KAAK,CAAC;QAmC/B,MAAM,cAAc,GAA0B,4BAAoB,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAEvF,IAAI,CAAC,KAAK,GAAG;YACX,GAAG,KAAK;YACR,WAAW;YACX,YAAY,EAAE;gBACZ,GAAG,cAAc;gBACjB,GAAG,KAAK,CAAC,YAAY;aACtB;SACF,CAAC;IACJ,CAAC;IA9DS,QAAQ,CAAC,KAAgB;QACjC,OAAO,IAAI,oBAAY,CACrB,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;IACJ,CAAC;IA0DD,IAAI,CAAC,KAAgB;QACnB,qFAAqF;QACrF,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACnC;aAAM,IAAI,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE;YACnD,MAAM,IAAI,KAAK,CACb,mDACE,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SACvB,KAAK,GAAG,8CAA8C,CACvD,CAAC;SACH;QAED,OAAO;YACL,UAAU,EAAE;gBACV,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY;gBACnC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW;aAClC;SACF,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,cAAc,CAAC,QAAqB,EAAE,OAA6B;QACjE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QACD,MAAM,gBAAgB,GAAG,OAAO,EAAE,gBAAgB,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QAC5E,6CAA6C;QAC7C,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;IAC7D,CAAC;;AAtGH,kCAuGC;;;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,WAAgC;IASlE;IACE;;;;;;;;;;;;;;;OAeG;IACH,WAAwB;IAExB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;IAC5B,CAAC;IAxCS,QAAQ,CAAC,KAAgB;QACjC,OAAO,IAAI,uBAAO,CAChB,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;IACJ,CAAC;;AAPH,wCA0CC;;;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,WAAgC;IASlE;IACE;;;;;;;;;;;;;;;OAeG;IACH,WAAwB;IAExB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;IAC5B,CAAC;IAxCS,QAAQ,CAAC,KAAgB;QACjC,OAAO,IAAI,uBAAO,CAChB,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;IACJ,CAAC;;AAPH,wCA0CC","sourcesContent":["import { CfnResource, Stack } from 'aws-cdk-lib';\nimport { ResourceBindOptions, Code, CodeConfig } from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\nimport {\n  EsbuildAsset,\n  AssetBaseProps,\n  AssetProps,\n  JavaScriptAsset as JSAsset,\n  TypeScriptAsset as TSAsset,\n} from './asset';\nimport { EntryPoints } from './bundler';\nimport { BuildOptions } from './esbuild-types';\nimport { defaultPlatformProps } from './private/utils';\n\nexport { CodeConfig } from 'aws-cdk-lib/aws-lambda';\nexport interface JavaScriptCodeProps extends AssetBaseProps {};\nexport interface TypeScriptCodeProps extends AssetBaseProps {};\n\n/**\n * Represents a generic esbuild code bundle.\n *\n * You should always use `TypeScriptCode` or `JavaScriptCode`.\n *\n * @stability experimental\n */\nexport class EsbuildCode<\n  Props extends JavaScriptCodeProps | TypeScriptCodeProps,\n> extends Code {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new EsbuildAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  protected props: AssetProps;\n\n  protected asset!: EsbuildAsset<AssetProps>;\n\n  /**\n   * Determines whether this Code is inline code or not.\n   *\n   * @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().\n   */\n  public isInline: boolean = false;\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    readonly entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: Props,\n  ) {\n    super();\n\n    const defaultOptions: Partial<BuildOptions> = defaultPlatformProps(props.buildOptions);\n\n    this.props = {\n      ...props,\n      entryPoints,\n      buildOptions: {\n        ...defaultOptions,\n        ...props.buildOptions,\n      },\n    };\n  }\n\n  bind(scope: Construct): CodeConfig {\n    // If the same AssetCode is used multiple times, retain only the first instantiation.\n    if (!this.asset) {\n      this.asset = this.getAsset(scope);\n    } else if (Stack.of(this.asset) !== Stack.of(scope)) {\n      throw new Error(\n        `Asset is already associated with another stack '${\n          Stack.of(this.asset).stackName\n        }'. ` + 'Create a new Asset instance for every stack.',\n      );\n    }\n\n    return {\n      s3Location: {\n        bucketName: this.asset.s3BucketName,\n        objectKey: this.asset.s3ObjectKey,\n      },\n    };\n  }\n\n  /**\n   * Called after the CFN function resource has been created to allow the code class to bind to it.\n   *\n   * Specifically it's required to allow assets to add\n   * metadata for tooling like SAM CLI to be able to find their origins.\n   *\n   * @stability stable\n   */\n  bindToResource(resource: CfnResource, options?: ResourceBindOptions) {\n    if (!this.asset) {\n      throw new Error('bindToResource() must be called after bind()');\n    }\n    const resourceProperty = options?.resourceProperty || this.constructor.name;\n    // https://github.com/aws/aws-cdk/issues/1432\n    this.asset.addResourceMetadata(resource, resourceProperty);\n  }\n}\n\n/**\n * Represents the deployed JavaScript Code.\n *\n * @stability stable\n */\nexport class JavaScriptCode extends EsbuildCode<JavaScriptCodeProps> {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new JSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: JavaScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n\n/**\n * Represents the deployed TypeScript Code.\n *\n * @stability stable\n */\nexport class TypeScriptCode extends EsbuildCode<TypeScriptCodeProps> {\n  protected getAsset(scope: Construct): EsbuildAsset<AssetProps> {\n    return new TSAsset(\n      scope,\n      this.constructor.name,\n      this.props,\n    );\n  }\n\n  constructor(\n    /**\n     * A path or list or map of paths to the entry points of your code.\n     *\n     * Relative paths are by default resolved from the current working directory.\n     * To change the working directory, see `buildOptions.absWorkingDir`.\n     *\n     * Absolute paths can be used if files are part of the working directory.\n     *\n     * Examples:\n     *  - `'src/index.ts'`\n     *  - `require.resolve('./lambda')`\n     *  - `['src/index.ts', 'src/util.ts']`\n     *  - `{one: 'src/two.ts', two: 'src/one.ts'}`\n     *\n     * @stability stable\n     */\n    entryPoints: EntryPoints,\n\n    /**\n     * Props to change the behavior of the bundler.\n     *\n     * Default values for `props.buildOptions`:\n     * - `bundle=true`\n     * - `platform=node`\n     * - `target=nodeX` with X being the major node version running locally\n     *\n     * @stability stable\n     */\n    props: TypeScriptCodeProps = {},\n  ) {\n    super(entryPoints, props);\n  }\n}\n"]}
@@ -1,6 +1,7 @@
1
+ /// <reference types="node" />
1
2
  export declare type Platform = 'browser' | 'node' | 'neutral';
2
3
  export declare type Format = 'iife' | 'cjs' | 'esm';
3
- export declare type Loader = 'js' | 'jsx' | 'ts' | 'tsx' | 'css' | 'json' | 'text' | 'base64' | 'file' | 'dataurl' | 'binary' | 'default';
4
+ export declare type Loader = 'base64' | 'binary' | 'copy' | 'css' | 'dataurl' | 'default' | 'empty' | 'file' | 'js' | 'json' | 'jsx' | 'text' | 'ts' | 'tsx';
4
5
  export declare type LogLevel = 'verbose' | 'debug' | 'info' | 'warning' | 'error' | 'silent';
5
6
  export declare type Charset = 'ascii' | 'utf8';
6
7
  export declare type Drop = 'console' | 'debugger';
@@ -15,10 +16,14 @@ interface CommonOptions {
15
16
  readonly sourcesContent?: boolean;
16
17
  /** Documentation: https://esbuild.github.io/api/#format */
17
18
  readonly format?: Format;
18
- /** Documentation: https://esbuild.github.io/api/#globalName */
19
+ /** Documentation: https://esbuild.github.io/api/#global-name */
19
20
  readonly globalName?: string;
20
21
  /** Documentation: https://esbuild.github.io/api/#target */
21
22
  readonly target?: string | string[];
23
+ /** Documentation: https://esbuild.github.io/api/#supported */
24
+ readonly supported?: Record<string, boolean>;
25
+ /** Documentation: https://esbuild.github.io/api/#platform */
26
+ readonly platform?: Platform;
22
27
  /** Documentation: https://esbuild.github.io/api/#mangle-props */
23
28
  readonly mangleProps?: any;
24
29
  /** Documentation: https://esbuild.github.io/api/#mangle-props */
@@ -44,11 +49,17 @@ interface CommonOptions {
44
49
  /** Documentation: https://esbuild.github.io/api/#ignore-annotations */
45
50
  readonly ignoreAnnotations?: boolean;
46
51
  /** Documentation: https://esbuild.github.io/api/#jsx */
47
- readonly jsx?: 'transform' | 'preserve';
52
+ readonly jsx?: 'transform' | 'preserve' | 'automatic';
48
53
  /** Documentation: https://esbuild.github.io/api/#jsx-factory */
49
54
  readonly jsxFactory?: string;
50
55
  /** Documentation: https://esbuild.github.io/api/#jsx-fragment */
51
56
  readonly jsxFragment?: string;
57
+ /** Documentation: https://esbuild.github.io/api/#jsx-import-source */
58
+ readonly jsxImportSource?: string;
59
+ /** Documentation: https://esbuild.github.io/api/#jsx-development */
60
+ readonly jsxDev?: boolean;
61
+ /** Documentation: https://esbuild.github.io/api/#jsx-side-effects */
62
+ readonly jsxSideEffects?: boolean;
52
63
  /** Documentation: https://esbuild.github.io/api/#define */
53
64
  readonly define?: {
54
65
  [key: string]: string;
@@ -81,17 +92,19 @@ export interface BuildOptions extends CommonOptions {
81
92
  readonly outdir?: string;
82
93
  /** Documentation: https://esbuild.github.io/api/#outbase */
83
94
  readonly outbase?: string;
84
- /** Documentation: https://esbuild.github.io/api/#platform */
85
- readonly platform?: Platform;
86
95
  /** Documentation: https://esbuild.github.io/api/#external */
87
96
  readonly external?: string[];
97
+ /** Documentation: https://esbuild.github.io/api/#packages */
98
+ readonly packages?: 'external';
99
+ /** Documentation: https://esbuild.github.io/api/#alias */
100
+ readonly alias?: Record<string, string>;
88
101
  /** Documentation: https://esbuild.github.io/api/#loader */
89
102
  readonly loader?: {
90
103
  [ext: string]: Loader;
91
104
  };
92
105
  /** Documentation: https://esbuild.github.io/api/#resolve-extensions */
93
106
  readonly resolveExtensions?: string[];
94
- /** Documentation: https://esbuild.github.io/api/#mainFields */
107
+ /** Documentation: https://esbuild.github.io/api/#main-fields */
95
108
  readonly mainFields?: string[];
96
109
  /** Documentation: https://esbuild.github.io/api/#conditions */
97
110
  readonly conditions?: string[];
@@ -134,12 +147,13 @@ export interface WatchMode {
134
147
  onRebuild?: (error: BuildFailure | null, result: BuildResult | null) => void;
135
148
  }
136
149
  export interface StdinOptions {
137
- contents: string;
150
+ contents: string | Uint8Array;
138
151
  resolveDir?: string;
139
152
  sourcefile?: string;
140
153
  loader?: Loader;
141
154
  }
142
155
  export interface Message {
156
+ id: string;
143
157
  pluginName: string;
144
158
  text: string;
145
159
  location: Location | null;
@@ -166,13 +180,6 @@ export interface Location {
166
180
  lineText: string;
167
181
  suggestion: string;
168
182
  }
169
- export interface OutputFile {
170
- path: string;
171
- /** "text" as bytes */
172
- contents: Uint8Array;
173
- /** "contents" as text */
174
- text: string;
175
- }
176
183
  export interface BuildInvalidate {
177
184
  (): Promise<BuildIncremental>;
178
185
  dispose(): void;
@@ -221,7 +228,7 @@ export interface ServeResult {
221
228
  stop: () => void;
222
229
  }
223
230
  export interface TransformOptions extends CommonOptions {
224
- readonly tsconfigRaw?: string;
231
+ readonly tsconfigRaw?: string | TsconfigOptions;
225
232
  readonly sourcefile?: string;
226
233
  readonly loader?: Loader;
227
234
  readonly banner?: string;
@@ -233,6 +240,8 @@ export interface TransformResult {
233
240
  warnings: Message[];
234
241
  /** Only when "mangleCache" is present */
235
242
  mangleCache?: Record<string, string | false>;
243
+ /** Only when "legalComments" is "external" */
244
+ legalComments?: string;
236
245
  }
237
246
  export interface TransformFailure extends Error {
238
247
  errors: Message[];
@@ -333,6 +342,7 @@ export interface OnLoadResult {
333
342
  watchDirs?: string[];
334
343
  }
335
344
  export interface PartialMessage {
345
+ id?: string;
336
346
  pluginName?: string;
337
347
  text?: string;
338
348
  location?: Partial<Location> | null;
@@ -350,6 +360,8 @@ export interface Metafile {
350
360
  imports: {
351
361
  path: string;
352
362
  kind: ImportKind;
363
+ external?: boolean;
364
+ original?: string;
353
365
  }[];
354
366
  };
355
367
  };
@@ -363,10 +375,12 @@ export interface Metafile {
363
375
  };
364
376
  imports: {
365
377
  path: string;
366
- kind: ImportKind;
378
+ kind: ImportKind | 'file-loader';
379
+ external?: boolean;
367
380
  }[];
368
381
  exports: string[];
369
382
  entryPoint?: string;
383
+ cssBundle?: string;
370
384
  };
371
385
  };
372
386
  }
@@ -430,7 +444,7 @@ export declare function serve(serveOptions: ServeOptions, buildOptions: BuildOpt
430
444
  *
431
445
  * Documentation: https://esbuild.github.io/api/#transform-api
432
446
  */
433
- export declare function transform(input: string, options?: TransformOptions): Promise<TransformResult>;
447
+ export declare function transform(input: string | Uint8Array, options?: TransformOptions): Promise<TransformResult>;
434
448
  /**
435
449
  * Converts log messages to formatted message strings suitable for printing in
436
450
  * the terminal. This allows you to reuse the built-in behavior of esbuild's
@@ -506,7 +520,7 @@ export interface InitializeOptions {
506
520
  * The URL of the "esbuild.wasm" file. This must be provided when running
507
521
  * esbuild in the browser.
508
522
  */
509
- wasmURL?: string;
523
+ wasmURL?: string | URL;
510
524
  /**
511
525
  * The result of calling "new WebAssembly.Module(buffer)" where "buffer"
512
526
  * is a typed array or ArrayBuffer containing the binary code of the
@@ -524,4 +538,21 @@ export interface InitializeOptions {
524
538
  worker?: boolean;
525
539
  }
526
540
  export declare let version: string;
541
+ export interface OutputFile {
542
+ path: string;
543
+ /** "text" as bytes */
544
+ contents: Uint8Array;
545
+ /** "contents" as text (changes automatically with "contents") */
546
+ text: string;
547
+ }
548
+ export interface CompilerOptions {
549
+ readonly jsxFactory?: string;
550
+ readonly jsxFragmentFactory?: string;
551
+ readonly useDefineForClassFields?: boolean;
552
+ readonly importsNotUsedAsValues?: 'remove' | 'preserve' | 'error';
553
+ readonly preserveValueImports?: boolean;
554
+ }
555
+ export interface TsconfigOptions {
556
+ readonly compilerOptions?: CompilerOptions;
557
+ }
527
558
  export {};
@@ -2,4 +2,4 @@
2
2
  // ~~ Generated by projen. To modify, edit .projenrc.js and run "npx projen".
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  exports.version = void 0;
5
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esbuild-types.js","sourceRoot":"","sources":["../src/esbuild-types.ts"],"names":[],"mappings":";AAAA,6EAA6E","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.js and run \"npx projen\".\n\nexport type Platform = 'browser' | 'node' | 'neutral';\nexport type Format = 'iife' | 'cjs' | 'esm';\nexport type Loader = 'js' | 'jsx' | 'ts' | 'tsx' | 'css' | 'json' | 'text' | 'base64' | 'file' | 'dataurl' | 'binary' | 'default';\nexport type LogLevel = 'verbose' | 'debug' | 'info' | 'warning' | 'error' | 'silent';\nexport type Charset = 'ascii' | 'utf8';\nexport type Drop = 'console' | 'debugger';\n\ninterface CommonOptions {\n  /** Documentation: https://esbuild.github.io/api/#sourcemap */\n  readonly sourcemap?: boolean | 'linked' | 'inline' | 'external' | 'both';\n  /** Documentation: https://esbuild.github.io/api/#legal-comments */\n  readonly legalComments?: 'none' | 'inline' | 'eof' | 'linked' | 'external';\n  /** Documentation: https://esbuild.github.io/api/#source-root */\n  readonly sourceRoot?: string;\n  /** Documentation: https://esbuild.github.io/api/#sources-content */\n  readonly sourcesContent?: boolean;\n\n  /** Documentation: https://esbuild.github.io/api/#format */\n  readonly format?: Format;\n  /** Documentation: https://esbuild.github.io/api/#globalName */\n  readonly globalName?: string;\n  /** Documentation: https://esbuild.github.io/api/#target */\n  readonly target?: string | string[];\n\n  /** Documentation: https://esbuild.github.io/api/#mangle-props */\n  readonly mangleProps?: any;\n  /** Documentation: https://esbuild.github.io/api/#mangle-props */\n  readonly reserveProps?: any;\n  /** Documentation: https://esbuild.github.io/api/#mangle-props */\n  readonly mangleQuoted?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#mangle-props */\n  readonly mangleCache?: Record<string, string | false>;\n  /** Documentation: https://esbuild.github.io/api/#drop */\n  readonly drop?: Drop[];\n  /** Documentation: https://esbuild.github.io/api/#minify */\n  readonly minify?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#minify */\n  readonly minifyWhitespace?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#minify */\n  readonly minifyIdentifiers?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#minify */\n  readonly minifySyntax?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#charset */\n  readonly charset?: Charset;\n  /** Documentation: https://esbuild.github.io/api/#tree-shaking */\n  readonly treeShaking?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#ignore-annotations */\n  readonly ignoreAnnotations?: boolean;\n\n  /** Documentation: https://esbuild.github.io/api/#jsx */\n  readonly jsx?: 'transform' | 'preserve';\n  /** Documentation: https://esbuild.github.io/api/#jsx-factory */\n  readonly jsxFactory?: string;\n  /** Documentation: https://esbuild.github.io/api/#jsx-fragment */\n  readonly jsxFragment?: string;\n\n  /** Documentation: https://esbuild.github.io/api/#define */\n  readonly define?: { [key: string]: string };\n  /** Documentation: https://esbuild.github.io/api/#pure */\n  readonly pure?: string[];\n  /** Documentation: https://esbuild.github.io/api/#keep-names */\n  readonly keepNames?: boolean;\n\n  /** Documentation: https://esbuild.github.io/api/#color */\n  readonly color?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#log-level */\n  readonly logLevel?: LogLevel;\n  /** Documentation: https://esbuild.github.io/api/#log-limit */\n  readonly logLimit?: number;\n  /** Documentation: https://esbuild.github.io/api/#log-override */\n  readonly logOverride?: Record<string, LogLevel>;\n}\n\nexport interface BuildOptions extends CommonOptions {\n  /** Documentation: https://esbuild.github.io/api/#bundle */\n  readonly bundle?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#splitting */\n  readonly splitting?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#preserve-symlinks */\n  readonly preserveSymlinks?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#outfile */\n  readonly outfile?: string;\n  /** Documentation: https://esbuild.github.io/api/#metafile */\n  readonly metafile?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#outdir */\n  readonly outdir?: string;\n  /** Documentation: https://esbuild.github.io/api/#outbase */\n  readonly outbase?: string;\n  /** Documentation: https://esbuild.github.io/api/#platform */\n  readonly platform?: Platform;\n  /** Documentation: https://esbuild.github.io/api/#external */\n  readonly external?: string[];\n  /** Documentation: https://esbuild.github.io/api/#loader */\n  readonly loader?: { [ext: string]: Loader };\n  /** Documentation: https://esbuild.github.io/api/#resolve-extensions */\n  readonly resolveExtensions?: string[];\n  /** Documentation: https://esbuild.github.io/api/#mainFields */\n  readonly mainFields?: string[];\n  /** Documentation: https://esbuild.github.io/api/#conditions */\n  readonly conditions?: string[];\n  /** Documentation: https://esbuild.github.io/api/#write */\n  readonly write?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#allow-overwrite */\n  readonly allowOverwrite?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#tsconfig */\n  readonly tsconfig?: string;\n  /** Documentation: https://esbuild.github.io/api/#out-extension */\n  readonly outExtension?: { [ext: string]: string };\n  /** Documentation: https://esbuild.github.io/api/#public-path */\n  readonly publicPath?: string;\n  /** Documentation: https://esbuild.github.io/api/#entry-names */\n  readonly entryNames?: string;\n  /** Documentation: https://esbuild.github.io/api/#chunk-names */\n  readonly chunkNames?: string;\n  /** Documentation: https://esbuild.github.io/api/#asset-names */\n  readonly assetNames?: string;\n  /** Documentation: https://esbuild.github.io/api/#inject */\n  readonly inject?: string[];\n  /** Documentation: https://esbuild.github.io/api/#banner */\n  readonly banner?: { [type: string]: string };\n  /** Documentation: https://esbuild.github.io/api/#footer */\n  readonly footer?: { [type: string]: string };\n  /** Documentation: https://esbuild.github.io/api/#incremental */\n  readonly incremental?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#working-directory */\n  readonly absWorkingDir?: string;\n  /** Documentation: https://esbuild.github.io/api/#node-paths */\n  readonly nodePaths?: string[]; // The \"NODE_PATH\" variable from Node.js\n}\n\nexport interface WatchMode {\n  onRebuild?: (error: BuildFailure | null, result: BuildResult | null) => void;\n}\n\nexport interface StdinOptions {\n  contents: string;\n  resolveDir?: string;\n  sourcefile?: string;\n  loader?: Loader;\n}\n\nexport interface Message {\n  pluginName: string;\n  text: string;\n  location: Location | null;\n  notes: Note[];\n\n  /**\n   * Optional user-specified data that is passed through unmodified. You can\n   * use this to stash the original error, for example.\n   */\n  detail: any;\n}\n\nexport interface Note {\n  text: string;\n  location: Location | null;\n}\n\nexport interface Location {\n  file: string;\n  namespace: string;\n  /** 1-based */\n  line: number;\n  /** 0-based, in bytes */\n  column: number;\n  /** in bytes */\n  length: number;\n  lineText: string;\n  suggestion: string;\n}\n\nexport interface OutputFile {\n  path: string;\n  /** \"text\" as bytes */\n  contents: Uint8Array;\n  /** \"contents\" as text */\n  text: string;\n}\n\nexport interface BuildInvalidate {\n  (): Promise<BuildIncremental>;\n  dispose(): void;\n}\n\nexport interface BuildIncremental extends BuildResult {\n  rebuild: BuildInvalidate;\n}\n\nexport interface BuildResult {\n  errors: Message[];\n  warnings: Message[];\n  /** Only when \"write: false\" */\n  outputFiles?: OutputFile[];\n  /** Only when \"incremental: true\" */\n  rebuild?: BuildInvalidate;\n  /** Only when \"watch: true\" */\n  stop?: () => void;\n  /** Only when \"metafile: true\" */\n  metafile?: Metafile;\n  /** Only when \"mangleCache\" is present */\n  mangleCache?: Record<string, string | false>;\n}\n\nexport interface BuildFailure extends Error {\n  errors: Message[];\n  warnings: Message[];\n}\n\n/** Documentation: https://esbuild.github.io/api/#serve-arguments */\nexport interface ServeOptions {\n  port?: number;\n  host?: string;\n  servedir?: string;\n  onRequest?: (args: ServeOnRequestArgs) => void;\n}\n\nexport interface ServeOnRequestArgs {\n  remoteAddress: string;\n  method: string;\n  path: string;\n  status: number;\n  /** The time to generate the response, not to send it */\n  timeInMS: number;\n}\n\n/** Documentation: https://esbuild.github.io/api/#serve-return-values */\nexport interface ServeResult {\n  port: number;\n  host: string;\n  wait: Promise<void>;\n  stop: () => void;\n}\n\nexport interface TransformOptions extends CommonOptions {\n  readonly tsconfigRaw?: string;\n\n  readonly sourcefile?: string;\n  readonly loader?: Loader;\n  readonly banner?: string;\n  readonly footer?: string;\n}\n\nexport interface TransformResult {\n  code: string;\n  map: string;\n  warnings: Message[];\n  /** Only when \"mangleCache\" is present */\n  mangleCache?: Record<string, string | false>;\n}\n\nexport interface TransformFailure extends Error {\n  errors: Message[];\n  warnings: Message[];\n}\n\nexport interface Plugin {\n  name: string;\n  setup: (build: PluginBuild) => (void | Promise<void>);\n}\n\nexport interface PluginBuild {\n  initialOptions: BuildOptions;\n  resolve(path: string, options?: ResolveOptions): Promise<ResolveResult>;\n\n  onStart(callback: () =>\n  (OnStartResult | null | void | Promise<OnStartResult | null | void>)): void;\n  onEnd(callback: (result: BuildResult) =>\n  (void | Promise<void>)): void;\n  onResolve(options: OnResolveOptions, callback: (args: OnResolveArgs) =>\n  (OnResolveResult | null | undefined | Promise<OnResolveResult | null | undefined>)): void;\n  onLoad(options: OnLoadOptions, callback: (args: OnLoadArgs) =>\n  (OnLoadResult | null | undefined | Promise<OnLoadResult | null | undefined>)): void;\n\n  // This is a full copy of the esbuild library in case you need it\n  esbuild: {\n    serve: typeof serve;\n    build: typeof build;\n    buildSync: typeof buildSync;\n    transform: typeof transform;\n    transformSync: typeof transformSync;\n    formatMessages: typeof formatMessages;\n    formatMessagesSync: typeof formatMessagesSync;\n    analyzeMetafile: typeof analyzeMetafile;\n    analyzeMetafileSync: typeof analyzeMetafileSync;\n    initialize: typeof initialize;\n    version: typeof version;\n  };\n}\n\nexport interface ResolveOptions {\n  pluginName?: string;\n  importer?: string;\n  namespace?: string;\n  resolveDir?: string;\n  kind?: ImportKind;\n  pluginData?: any;\n}\n\nexport interface ResolveResult {\n  errors: Message[];\n  warnings: Message[];\n\n  path: string;\n  external: boolean;\n  sideEffects: boolean;\n  namespace: string;\n  suffix: string;\n  pluginData: any;\n}\n\nexport interface OnStartResult {\n  errors?: PartialMessage[];\n  warnings?: PartialMessage[];\n}\n\nexport interface OnResolveOptions {\n  filter: RegExp;\n  namespace?: string;\n}\n\nexport interface OnResolveArgs {\n  path: string;\n  importer: string;\n  namespace: string;\n  resolveDir: string;\n  kind: ImportKind;\n  pluginData: any;\n}\n\nexport type ImportKind =\n  | 'entry-point'\n\n  // JS\n  | 'import-statement'\n  | 'require-call'\n  | 'dynamic-import'\n  | 'require-resolve'\n\n  // CSS\n  | 'import-rule'\n  | 'url-token'\n\nexport interface OnResolveResult {\n  pluginName?: string;\n\n  errors?: PartialMessage[];\n  warnings?: PartialMessage[];\n\n  path?: string;\n  external?: boolean;\n  sideEffects?: boolean;\n  namespace?: string;\n  suffix?: string;\n  pluginData?: any;\n\n  watchFiles?: string[];\n  watchDirs?: string[];\n}\n\nexport interface OnLoadOptions {\n  filter: RegExp;\n  namespace?: string;\n}\n\nexport interface OnLoadArgs {\n  path: string;\n  namespace: string;\n  suffix: string;\n  pluginData: any;\n}\n\nexport interface OnLoadResult {\n  pluginName?: string;\n\n  errors?: PartialMessage[];\n  warnings?: PartialMessage[];\n\n  contents?: string | Uint8Array;\n  resolveDir?: string;\n  loader?: Loader;\n  pluginData?: any;\n\n  watchFiles?: string[];\n  watchDirs?: string[];\n}\n\nexport interface PartialMessage {\n  pluginName?: string;\n  text?: string;\n  location?: Partial<Location> | null;\n  notes?: PartialNote[];\n  detail?: any;\n}\n\nexport interface PartialNote {\n  text?: string;\n  location?: Partial<Location> | null;\n}\n\nexport interface Metafile {\n  inputs: {\n    [path: string]: {\n      bytes: number;\n      imports: {\n        path: string;\n        kind: ImportKind;\n      }[];\n    };\n  };\n  outputs: {\n    [path: string]: {\n      bytes: number;\n      inputs: {\n        [path: string]: {\n          bytesInOutput: number;\n        };\n      };\n      imports: {\n        path: string;\n        kind: ImportKind;\n      }[];\n      exports: string[];\n      entryPoint?: string;\n    };\n  };\n}\n\nexport interface FormatMessagesOptions {\n  kind: 'error' | 'warning';\n  color?: boolean;\n  terminalWidth?: number;\n}\n\nexport interface AnalyzeMetafileOptions {\n  color?: boolean;\n  verbose?: boolean;\n}\n\n/**\n * This function invokes the \"esbuild\" command-line tool for you. It returns a\n * promise that either resolves with a \"BuildResult\" object or rejects with a\n * \"BuildFailure\" object.\n *\n * - Works in node: yes\n * - Works in browser: yes\n *\n * Documentation: https://esbuild.github.io/api/#build-api\n */\nexport declare function build(options: BuildOptions & { write: false }): Promise<BuildResult & { outputFiles: OutputFile[] }>;\nexport declare function build(options: BuildOptions & { incremental: true; metafile: true }): Promise<BuildIncremental & { metafile: Metafile }>;\nexport declare function build(options: BuildOptions & { incremental: true }): Promise<BuildIncremental>;\nexport declare function build(options: BuildOptions & { metafile: true }): Promise<BuildResult & { metafile: Metafile }>;\nexport declare function build(options: BuildOptions): Promise<BuildResult>;\n\n/**\n * This function is similar to \"build\" but it serves the resulting files over\n * HTTP on a localhost address with the specified port.\n *\n * - Works in node: yes\n * - Works in browser: no\n *\n * Documentation: https://esbuild.github.io/api/#serve\n */\nexport declare function serve(serveOptions: ServeOptions, buildOptions: BuildOptions): Promise<ServeResult>;\n\n/**\n * This function transforms a single JavaScript file. It can be used to minify\n * JavaScript, convert TypeScript/JSX to JavaScript, or convert newer JavaScript\n * to older JavaScript. It returns a promise that is either resolved with a\n * \"TransformResult\" object or rejected with a \"TransformFailure\" object.\n *\n * - Works in node: yes\n * - Works in browser: yes\n *\n * Documentation: https://esbuild.github.io/api/#transform-api\n */\nexport declare function transform(input: string, options?: TransformOptions): Promise<TransformResult>;\n\n/**\n * Converts log messages to formatted message strings suitable for printing in\n * the terminal. This allows you to reuse the built-in behavior of esbuild's\n * log message formatter. This is a batch-oriented API for efficiency.\n *\n * - Works in node: yes\n * - Works in browser: yes\n */\nexport declare function formatMessages(messages: PartialMessage[], options: FormatMessagesOptions): Promise<string[]>;\n\n/**\n * Pretty-prints an analysis of the metafile JSON to a string. This is just for\n * convenience to be able to match esbuild's pretty-printing exactly. If you want\n * to customize it, you can just inspect the data in the metafile yourself.\n *\n * - Works in node: yes\n * - Works in browser: yes\n *\n * Documentation: https://esbuild.github.io/api/#analyze\n */\nexport declare function analyzeMetafile(metafile: Metafile | string, options?: AnalyzeMetafileOptions): Promise<string>;\n\n/**\n * A synchronous version of \"build\".\n *\n * - Works in node: yes\n * - Works in browser: no\n *\n * Documentation: https://esbuild.github.io/api/#build-api\n */\nexport declare function buildSync(options: BuildOptions & { write: false }): BuildResult & { outputFiles: OutputFile[] };\nexport declare function buildSync(options: BuildOptions): BuildResult;\n\n/**\n * A synchronous version of \"transform\".\n *\n * - Works in node: yes\n * - Works in browser: no\n *\n * Documentation: https://esbuild.github.io/api/#transform-api\n */\nexport declare function transformSync(input: string, options?: TransformOptions): TransformResult;\n\n/**\n * A synchronous version of \"formatMessages\".\n *\n * - Works in node: yes\n * - Works in browser: no\n */\nexport declare function formatMessagesSync(messages: PartialMessage[], options: FormatMessagesOptions): string[];\n\n/**\n * A synchronous version of \"analyzeMetafile\".\n *\n * - Works in node: yes\n * - Works in browser: no\n *\n * Documentation: https://esbuild.github.io/api/#analyze\n */\nexport declare function analyzeMetafileSync(metafile: Metafile | string, options?: AnalyzeMetafileOptions): string;\n\n/**\n * This configures the browser-based version of esbuild. It is necessary to\n * call this first and wait for the returned promise to be resolved before\n * making other API calls when using esbuild in the browser.\n *\n * - Works in node: yes\n * - Works in browser: yes (\"options\" is required)\n *\n * Documentation: https://esbuild.github.io/api/#running-in-the-browser\n */\nexport declare function initialize(options: InitializeOptions): Promise<void>;\n\nexport interface InitializeOptions {\n  /**\n   * The URL of the \"esbuild.wasm\" file. This must be provided when running\n   * esbuild in the browser.\n   */\n  wasmURL?: string;\n\n  /**\n   * The result of calling \"new WebAssembly.Module(buffer)\" where \"buffer\"\n   * is a typed array or ArrayBuffer containing the binary code of the\n   * \"esbuild.wasm\" file.\n   *\n   * You can use this as an alternative to \"wasmURL\" for environments where it's\n   * not possible to download the WebAssembly module.\n   */\n  wasmModule?: any;\n\n  /**\n   * By default esbuild runs the WebAssembly-based browser API in a web worker\n   * to avoid blocking the UI thread. This can be disabled by setting \"worker\"\n   * to false.\n   */\n  worker?: boolean;\n}\n\nexport let version: string;\n"]}
5
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esbuild-types.js","sourceRoot":"","sources":["../src/esbuild-types.ts"],"names":[],"mappings":";AAAA,6EAA6E","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.js and run \"npx projen\".\n\nexport type Platform = 'browser' | 'node' | 'neutral';\nexport type Format = 'iife' | 'cjs' | 'esm';\nexport type Loader = 'base64' | 'binary' | 'copy' | 'css' | 'dataurl' | 'default' | 'empty' | 'file' | 'js' | 'json' | 'jsx' | 'text' | 'ts' | 'tsx';\nexport type LogLevel = 'verbose' | 'debug' | 'info' | 'warning' | 'error' | 'silent';\nexport type Charset = 'ascii' | 'utf8';\nexport type Drop = 'console' | 'debugger';\n\ninterface CommonOptions {\n  /** Documentation: https://esbuild.github.io/api/#sourcemap */\n  readonly sourcemap?: boolean | 'linked' | 'inline' | 'external' | 'both';\n  /** Documentation: https://esbuild.github.io/api/#legal-comments */\n  readonly legalComments?: 'none' | 'inline' | 'eof' | 'linked' | 'external';\n  /** Documentation: https://esbuild.github.io/api/#source-root */\n  readonly sourceRoot?: string;\n  /** Documentation: https://esbuild.github.io/api/#sources-content */\n  readonly sourcesContent?: boolean;\n\n  /** Documentation: https://esbuild.github.io/api/#format */\n  readonly format?: Format;\n  /** Documentation: https://esbuild.github.io/api/#global-name */\n  readonly globalName?: string;\n  /** Documentation: https://esbuild.github.io/api/#target */\n  readonly target?: string | string[];\n  /** Documentation: https://esbuild.github.io/api/#supported */\n  readonly supported?: Record<string, boolean>;\n  /** Documentation: https://esbuild.github.io/api/#platform */\n  readonly platform?: Platform;\n\n  /** Documentation: https://esbuild.github.io/api/#mangle-props */\n  readonly mangleProps?: any;\n  /** Documentation: https://esbuild.github.io/api/#mangle-props */\n  readonly reserveProps?: any;\n  /** Documentation: https://esbuild.github.io/api/#mangle-props */\n  readonly mangleQuoted?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#mangle-props */\n  readonly mangleCache?: Record<string, string | false>;\n  /** Documentation: https://esbuild.github.io/api/#drop */\n  readonly drop?: Drop[];\n  /** Documentation: https://esbuild.github.io/api/#minify */\n  readonly minify?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#minify */\n  readonly minifyWhitespace?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#minify */\n  readonly minifyIdentifiers?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#minify */\n  readonly minifySyntax?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#charset */\n  readonly charset?: Charset;\n  /** Documentation: https://esbuild.github.io/api/#tree-shaking */\n  readonly treeShaking?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#ignore-annotations */\n  readonly ignoreAnnotations?: boolean;\n\n  /** Documentation: https://esbuild.github.io/api/#jsx */\n  readonly jsx?: 'transform' | 'preserve' | 'automatic';\n  /** Documentation: https://esbuild.github.io/api/#jsx-factory */\n  readonly jsxFactory?: string;\n  /** Documentation: https://esbuild.github.io/api/#jsx-fragment */\n  readonly jsxFragment?: string;\n  /** Documentation: https://esbuild.github.io/api/#jsx-import-source */\n  readonly jsxImportSource?: string;\n  /** Documentation: https://esbuild.github.io/api/#jsx-development */\n  readonly jsxDev?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#jsx-side-effects */\n  readonly jsxSideEffects?: boolean;\n\n  /** Documentation: https://esbuild.github.io/api/#define */\n  readonly define?: { [key: string]: string };\n  /** Documentation: https://esbuild.github.io/api/#pure */\n  readonly pure?: string[];\n  /** Documentation: https://esbuild.github.io/api/#keep-names */\n  readonly keepNames?: boolean;\n\n  /** Documentation: https://esbuild.github.io/api/#color */\n  readonly color?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#log-level */\n  readonly logLevel?: LogLevel;\n  /** Documentation: https://esbuild.github.io/api/#log-limit */\n  readonly logLimit?: number;\n  /** Documentation: https://esbuild.github.io/api/#log-override */\n  readonly logOverride?: Record<string, LogLevel>;\n}\n\nexport interface BuildOptions extends CommonOptions {\n  /** Documentation: https://esbuild.github.io/api/#bundle */\n  readonly bundle?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#splitting */\n  readonly splitting?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#preserve-symlinks */\n  readonly preserveSymlinks?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#outfile */\n  readonly outfile?: string;\n  /** Documentation: https://esbuild.github.io/api/#metafile */\n  readonly metafile?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#outdir */\n  readonly outdir?: string;\n  /** Documentation: https://esbuild.github.io/api/#outbase */\n  readonly outbase?: string;\n  /** Documentation: https://esbuild.github.io/api/#external */\n  readonly external?: string[];\n  /** Documentation: https://esbuild.github.io/api/#packages */\n  readonly packages?: 'external';\n  /** Documentation: https://esbuild.github.io/api/#alias */\n  readonly alias?: Record<string, string>;\n  /** Documentation: https://esbuild.github.io/api/#loader */\n  readonly loader?: { [ext: string]: Loader };\n  /** Documentation: https://esbuild.github.io/api/#resolve-extensions */\n  readonly resolveExtensions?: string[];\n  /** Documentation: https://esbuild.github.io/api/#main-fields */\n  readonly mainFields?: string[];\n  /** Documentation: https://esbuild.github.io/api/#conditions */\n  readonly conditions?: string[];\n  /** Documentation: https://esbuild.github.io/api/#write */\n  readonly write?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#allow-overwrite */\n  readonly allowOverwrite?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#tsconfig */\n  readonly tsconfig?: string;\n  /** Documentation: https://esbuild.github.io/api/#out-extension */\n  readonly outExtension?: { [ext: string]: string };\n  /** Documentation: https://esbuild.github.io/api/#public-path */\n  readonly publicPath?: string;\n  /** Documentation: https://esbuild.github.io/api/#entry-names */\n  readonly entryNames?: string;\n  /** Documentation: https://esbuild.github.io/api/#chunk-names */\n  readonly chunkNames?: string;\n  /** Documentation: https://esbuild.github.io/api/#asset-names */\n  readonly assetNames?: string;\n  /** Documentation: https://esbuild.github.io/api/#inject */\n  readonly inject?: string[];\n  /** Documentation: https://esbuild.github.io/api/#banner */\n  readonly banner?: { [type: string]: string };\n  /** Documentation: https://esbuild.github.io/api/#footer */\n  readonly footer?: { [type: string]: string };\n  /** Documentation: https://esbuild.github.io/api/#incremental */\n  readonly incremental?: boolean;\n  /** Documentation: https://esbuild.github.io/api/#working-directory */\n  readonly absWorkingDir?: string;\n  /** Documentation: https://esbuild.github.io/api/#node-paths */\n  readonly nodePaths?: string[]; // The \"NODE_PATH\" variable from Node.js\n}\n\nexport interface WatchMode {\n  onRebuild?: (error: BuildFailure | null, result: BuildResult | null) => void;\n}\n\nexport interface StdinOptions {\n  contents: string | Uint8Array;\n  resolveDir?: string;\n  sourcefile?: string;\n  loader?: Loader;\n}\n\nexport interface Message {\n  id: string;\n  pluginName: string;\n  text: string;\n  location: Location | null;\n  notes: Note[];\n\n  /**\n   * Optional user-specified data that is passed through unmodified. You can\n   * use this to stash the original error, for example.\n   */\n  detail: any;\n}\n\nexport interface Note {\n  text: string;\n  location: Location | null;\n}\n\nexport interface Location {\n  file: string;\n  namespace: string;\n  /** 1-based */\n  line: number;\n  /** 0-based, in bytes */\n  column: number;\n  /** in bytes */\n  length: number;\n  lineText: string;\n  suggestion: string;\n}\n\nexport interface BuildInvalidate {\n  (): Promise<BuildIncremental>;\n  dispose(): void;\n}\n\nexport interface BuildIncremental extends BuildResult {\n  rebuild: BuildInvalidate;\n}\n\nexport interface BuildResult {\n  errors: Message[];\n  warnings: Message[];\n  /** Only when \"write: false\" */\n  outputFiles?: OutputFile[];\n  /** Only when \"incremental: true\" */\n  rebuild?: BuildInvalidate;\n  /** Only when \"watch: true\" */\n  stop?: () => void;\n  /** Only when \"metafile: true\" */\n  metafile?: Metafile;\n  /** Only when \"mangleCache\" is present */\n  mangleCache?: Record<string, string | false>;\n}\n\nexport interface BuildFailure extends Error {\n  errors: Message[];\n  warnings: Message[];\n}\n\n/** Documentation: https://esbuild.github.io/api/#serve-arguments */\nexport interface ServeOptions {\n  port?: number;\n  host?: string;\n  servedir?: string;\n  onRequest?: (args: ServeOnRequestArgs) => void;\n}\n\nexport interface ServeOnRequestArgs {\n  remoteAddress: string;\n  method: string;\n  path: string;\n  status: number;\n  /** The time to generate the response, not to send it */\n  timeInMS: number;\n}\n\n/** Documentation: https://esbuild.github.io/api/#serve-return-values */\nexport interface ServeResult {\n  port: number;\n  host: string;\n  wait: Promise<void>;\n  stop: () => void;\n}\n\nexport interface TransformOptions extends CommonOptions {\n  readonly tsconfigRaw?: string | TsconfigOptions;\n\n  readonly sourcefile?: string;\n  readonly loader?: Loader;\n  readonly banner?: string;\n  readonly footer?: string;\n}\n\nexport interface TransformResult {\n  code: string;\n  map: string;\n  warnings: Message[];\n  /** Only when \"mangleCache\" is present */\n  mangleCache?: Record<string, string | false>;\n  /** Only when \"legalComments\" is \"external\" */\n  legalComments?: string;\n}\n\nexport interface TransformFailure extends Error {\n  errors: Message[];\n  warnings: Message[];\n}\n\nexport interface Plugin {\n  name: string;\n  setup: (build: PluginBuild) => (void | Promise<void>);\n}\n\nexport interface PluginBuild {\n  initialOptions: BuildOptions;\n  resolve(path: string, options?: ResolveOptions): Promise<ResolveResult>;\n\n  onStart(callback: () =>\n  (OnStartResult | null | void | Promise<OnStartResult | null | void>)): void;\n  onEnd(callback: (result: BuildResult) =>\n  (void | Promise<void>)): void;\n  onResolve(options: OnResolveOptions, callback: (args: OnResolveArgs) =>\n  (OnResolveResult | null | undefined | Promise<OnResolveResult | null | undefined>)): void;\n  onLoad(options: OnLoadOptions, callback: (args: OnLoadArgs) =>\n  (OnLoadResult | null | undefined | Promise<OnLoadResult | null | undefined>)): void;\n\n  // This is a full copy of the esbuild library in case you need it\n  esbuild: {\n    serve: typeof serve;\n    build: typeof build;\n    buildSync: typeof buildSync;\n    transform: typeof transform;\n    transformSync: typeof transformSync;\n    formatMessages: typeof formatMessages;\n    formatMessagesSync: typeof formatMessagesSync;\n    analyzeMetafile: typeof analyzeMetafile;\n    analyzeMetafileSync: typeof analyzeMetafileSync;\n    initialize: typeof initialize;\n    version: typeof version;\n  };\n}\n\nexport interface ResolveOptions {\n  pluginName?: string;\n  importer?: string;\n  namespace?: string;\n  resolveDir?: string;\n  kind?: ImportKind;\n  pluginData?: any;\n}\n\nexport interface ResolveResult {\n  errors: Message[];\n  warnings: Message[];\n\n  path: string;\n  external: boolean;\n  sideEffects: boolean;\n  namespace: string;\n  suffix: string;\n  pluginData: any;\n}\n\nexport interface OnStartResult {\n  errors?: PartialMessage[];\n  warnings?: PartialMessage[];\n}\n\nexport interface OnResolveOptions {\n  filter: RegExp;\n  namespace?: string;\n}\n\nexport interface OnResolveArgs {\n  path: string;\n  importer: string;\n  namespace: string;\n  resolveDir: string;\n  kind: ImportKind;\n  pluginData: any;\n}\n\nexport type ImportKind =\n  | 'entry-point'\n\n  // JS\n  | 'import-statement'\n  | 'require-call'\n  | 'dynamic-import'\n  | 'require-resolve'\n\n  // CSS\n  | 'import-rule'\n  | 'url-token'\n\nexport interface OnResolveResult {\n  pluginName?: string;\n\n  errors?: PartialMessage[];\n  warnings?: PartialMessage[];\n\n  path?: string;\n  external?: boolean;\n  sideEffects?: boolean;\n  namespace?: string;\n  suffix?: string;\n  pluginData?: any;\n\n  watchFiles?: string[];\n  watchDirs?: string[];\n}\n\nexport interface OnLoadOptions {\n  filter: RegExp;\n  namespace?: string;\n}\n\nexport interface OnLoadArgs {\n  path: string;\n  namespace: string;\n  suffix: string;\n  pluginData: any;\n}\n\nexport interface OnLoadResult {\n  pluginName?: string;\n\n  errors?: PartialMessage[];\n  warnings?: PartialMessage[];\n\n  contents?: string | Uint8Array;\n  resolveDir?: string;\n  loader?: Loader;\n  pluginData?: any;\n\n  watchFiles?: string[];\n  watchDirs?: string[];\n}\n\nexport interface PartialMessage {\n  id?: string;\n  pluginName?: string;\n  text?: string;\n  location?: Partial<Location> | null;\n  notes?: PartialNote[];\n  detail?: any;\n}\n\nexport interface PartialNote {\n  text?: string;\n  location?: Partial<Location> | null;\n}\n\nexport interface Metafile {\n  inputs: {\n    [path: string]: {\n      bytes: number;\n      imports: {\n        path: string;\n        kind: ImportKind;\n        external?: boolean;\n        original?: string;\n      }[];\n    };\n  };\n  outputs: {\n    [path: string]: {\n      bytes: number;\n      inputs: {\n        [path: string]: {\n          bytesInOutput: number;\n        };\n      };\n      imports: {\n        path: string;\n        kind: ImportKind | 'file-loader';\n        external?: boolean;\n      }[];\n      exports: string[];\n      entryPoint?: string;\n      cssBundle?: string;\n    };\n  };\n}\n\nexport interface FormatMessagesOptions {\n  kind: 'error' | 'warning';\n  color?: boolean;\n  terminalWidth?: number;\n}\n\nexport interface AnalyzeMetafileOptions {\n  color?: boolean;\n  verbose?: boolean;\n}\n\n/**\n * This function invokes the \"esbuild\" command-line tool for you. It returns a\n * promise that either resolves with a \"BuildResult\" object or rejects with a\n * \"BuildFailure\" object.\n *\n * - Works in node: yes\n * - Works in browser: yes\n *\n * Documentation: https://esbuild.github.io/api/#build-api\n */\nexport declare function build(options: BuildOptions & { write: false }): Promise<BuildResult & { outputFiles: OutputFile[] }>;\nexport declare function build(options: BuildOptions & { incremental: true; metafile: true }): Promise<BuildIncremental & { metafile: Metafile }>;\nexport declare function build(options: BuildOptions & { incremental: true }): Promise<BuildIncremental>;\nexport declare function build(options: BuildOptions & { metafile: true }): Promise<BuildResult & { metafile: Metafile }>;\nexport declare function build(options: BuildOptions): Promise<BuildResult>;\n\n/**\n * This function is similar to \"build\" but it serves the resulting files over\n * HTTP on a localhost address with the specified port.\n *\n * - Works in node: yes\n * - Works in browser: no\n *\n * Documentation: https://esbuild.github.io/api/#serve\n */\nexport declare function serve(serveOptions: ServeOptions, buildOptions: BuildOptions): Promise<ServeResult>;\n\n/**\n * This function transforms a single JavaScript file. It can be used to minify\n * JavaScript, convert TypeScript/JSX to JavaScript, or convert newer JavaScript\n * to older JavaScript. It returns a promise that is either resolved with a\n * \"TransformResult\" object or rejected with a \"TransformFailure\" object.\n *\n * - Works in node: yes\n * - Works in browser: yes\n *\n * Documentation: https://esbuild.github.io/api/#transform-api\n */\nexport declare function transform(input: string | Uint8Array, options?: TransformOptions): Promise<TransformResult>;\n\n/**\n * Converts log messages to formatted message strings suitable for printing in\n * the terminal. This allows you to reuse the built-in behavior of esbuild's\n * log message formatter. This is a batch-oriented API for efficiency.\n *\n * - Works in node: yes\n * - Works in browser: yes\n */\nexport declare function formatMessages(messages: PartialMessage[], options: FormatMessagesOptions): Promise<string[]>;\n\n/**\n * Pretty-prints an analysis of the metafile JSON to a string. This is just for\n * convenience to be able to match esbuild's pretty-printing exactly. If you want\n * to customize it, you can just inspect the data in the metafile yourself.\n *\n * - Works in node: yes\n * - Works in browser: yes\n *\n * Documentation: https://esbuild.github.io/api/#analyze\n */\nexport declare function analyzeMetafile(metafile: Metafile | string, options?: AnalyzeMetafileOptions): Promise<string>;\n\n/**\n * A synchronous version of \"build\".\n *\n * - Works in node: yes\n * - Works in browser: no\n *\n * Documentation: https://esbuild.github.io/api/#build-api\n */\nexport declare function buildSync(options: BuildOptions & { write: false }): BuildResult & { outputFiles: OutputFile[] };\nexport declare function buildSync(options: BuildOptions): BuildResult;\n\n/**\n * A synchronous version of \"transform\".\n *\n * - Works in node: yes\n * - Works in browser: no\n *\n * Documentation: https://esbuild.github.io/api/#transform-api\n */\nexport declare function transformSync(input: string, options?: TransformOptions): TransformResult;\n\n/**\n * A synchronous version of \"formatMessages\".\n *\n * - Works in node: yes\n * - Works in browser: no\n */\nexport declare function formatMessagesSync(messages: PartialMessage[], options: FormatMessagesOptions): string[];\n\n/**\n * A synchronous version of \"analyzeMetafile\".\n *\n * - Works in node: yes\n * - Works in browser: no\n *\n * Documentation: https://esbuild.github.io/api/#analyze\n */\nexport declare function analyzeMetafileSync(metafile: Metafile | string, options?: AnalyzeMetafileOptions): string;\n\n/**\n * This configures the browser-based version of esbuild. It is necessary to\n * call this first and wait for the returned promise to be resolved before\n * making other API calls when using esbuild in the browser.\n *\n * - Works in node: yes\n * - Works in browser: yes (\"options\" is required)\n *\n * Documentation: https://esbuild.github.io/api/#running-in-the-browser\n */\nexport declare function initialize(options: InitializeOptions): Promise<void>;\n\nexport interface InitializeOptions {\n  /**\n   * The URL of the \"esbuild.wasm\" file. This must be provided when running\n   * esbuild in the browser.\n   */\n  wasmURL?: string | URL;\n\n  /**\n   * The result of calling \"new WebAssembly.Module(buffer)\" where \"buffer\"\n   * is a typed array or ArrayBuffer containing the binary code of the\n   * \"esbuild.wasm\" file.\n   *\n   * You can use this as an alternative to \"wasmURL\" for environments where it's\n   * not possible to download the WebAssembly module.\n   */\n  wasmModule?: any;\n\n  /**\n   * By default esbuild runs the WebAssembly-based browser API in a web worker\n   * to avoid blocking the UI thread. This can be disabled by setting \"worker\"\n   * to false.\n   */\n  worker?: boolean;\n}\n\nexport let version: string;\n\nexport interface OutputFile {\n  path: string;\n  /** \"text\" as bytes */\n  contents: Uint8Array;\n  /** \"contents\" as text (changes automatically with \"contents\") */\n  text: string;\n}\n\nexport interface CompilerOptions {\n  readonly jsxFactory?: string;\n  readonly jsxFragmentFactory?: string;\n  readonly useDefineForClassFields?: boolean;\n  readonly importsNotUsedAsValues?: 'remove' | 'preserve' | 'error';\n  readonly preserveValueImports?: boolean;\n}\n\nexport interface TsconfigOptions {\n  readonly compilerOptions?: CompilerOptions;\n}\n"]}
package/lib/index.d.ts CHANGED
@@ -1,6 +1,7 @@
1
- export { BuildOptions, TransformOptions, } from './esbuild-types';
1
+ export { AssetBaseProps, AssetProps, EsbuildAsset, JavaScriptAsset, TypeScriptAsset, } from './asset';
2
2
  export { EsbuildBundler, BundlerProps, } from './bundler';
3
- export { Asset, AssetBaseProps, AssetProps, JavaScriptAsset, TypeScriptAsset, } from './asset';
4
- export { Code, CodeConfig, JavaScriptCode, JavaScriptCodeProps, TypeScriptCode, TypeScriptCodeProps, } from './code';
5
- export { TransformerProps, InlineJavaScriptCode, InlineJsxCode, InlineTsxCode, InlineTypeScriptCode, } from './inline-code';
3
+ export { CodeConfig, EsbuildCode, JavaScriptCode, JavaScriptCodeProps, TypeScriptCode, TypeScriptCodeProps, } from './code';
4
+ export { BuildOptions, TransformOptions, TsconfigOptions, CompilerOptions, } from './esbuild-types';
5
+ export { TransformerProps, InlineJavaScriptCode, InlineTypeScriptCode, } from './inline-code';
6
+ export { EsbuildProvider, EsbuildProviderProps, EsbuildSource, IBuildProvider, IEsbuildProvider, ITransformProvider, ProviderBuildOptions, ProviderTransformOptions, } from './provider';
6
7
  export { JavaScriptSource, JavaScriptSourceProps, TypeScriptSource, TypeScriptSourceProps, } from './source';
package/lib/index.js CHANGED
@@ -1,21 +1,22 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- var bundler_1 = require("./bundler");
4
- Object.defineProperty(exports, "EsbuildBundler", { enumerable: true, get: function () { return bundler_1.EsbuildBundler; } });
5
3
  var asset_1 = require("./asset");
6
- Object.defineProperty(exports, "Asset", { enumerable: true, get: function () { return asset_1.Asset; } });
4
+ Object.defineProperty(exports, "EsbuildAsset", { enumerable: true, get: function () { return asset_1.EsbuildAsset; } });
7
5
  Object.defineProperty(exports, "JavaScriptAsset", { enumerable: true, get: function () { return asset_1.JavaScriptAsset; } });
8
6
  Object.defineProperty(exports, "TypeScriptAsset", { enumerable: true, get: function () { return asset_1.TypeScriptAsset; } });
7
+ var bundler_1 = require("./bundler");
8
+ Object.defineProperty(exports, "EsbuildBundler", { enumerable: true, get: function () { return bundler_1.EsbuildBundler; } });
9
9
  var code_1 = require("./code");
10
- Object.defineProperty(exports, "Code", { enumerable: true, get: function () { return code_1.Code; } });
10
+ Object.defineProperty(exports, "EsbuildCode", { enumerable: true, get: function () { return code_1.EsbuildCode; } });
11
11
  Object.defineProperty(exports, "JavaScriptCode", { enumerable: true, get: function () { return code_1.JavaScriptCode; } });
12
12
  Object.defineProperty(exports, "TypeScriptCode", { enumerable: true, get: function () { return code_1.TypeScriptCode; } });
13
13
  var inline_code_1 = require("./inline-code");
14
14
  Object.defineProperty(exports, "InlineJavaScriptCode", { enumerable: true, get: function () { return inline_code_1.InlineJavaScriptCode; } });
15
- Object.defineProperty(exports, "InlineJsxCode", { enumerable: true, get: function () { return inline_code_1.InlineJsxCode; } });
16
- Object.defineProperty(exports, "InlineTsxCode", { enumerable: true, get: function () { return inline_code_1.InlineTsxCode; } });
17
15
  Object.defineProperty(exports, "InlineTypeScriptCode", { enumerable: true, get: function () { return inline_code_1.InlineTypeScriptCode; } });
16
+ var provider_1 = require("./provider");
17
+ Object.defineProperty(exports, "EsbuildProvider", { enumerable: true, get: function () { return provider_1.EsbuildProvider; } });
18
+ Object.defineProperty(exports, "EsbuildSource", { enumerable: true, get: function () { return provider_1.EsbuildSource; } });
18
19
  var source_1 = require("./source");
19
20
  Object.defineProperty(exports, "JavaScriptSource", { enumerable: true, get: function () { return source_1.JavaScriptSource; } });
20
21
  Object.defineProperty(exports, "TypeScriptSource", { enumerable: true, get: function () { return source_1.TypeScriptSource; } });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFNQSxxQ0FHbUI7QUFGakIseUdBQUEsY0FBYyxPQUFBO0FBSWhCLGlDQU1pQjtBQUxmLDhGQUFBLEtBQUssT0FBQTtBQUdMLHdHQUFBLGVBQWUsT0FBQTtBQUNmLHdHQUFBLGVBQWUsT0FBQTtBQUdqQiwrQkFPZ0I7QUFOZCw0RkFBQSxJQUFJLE9BQUE7QUFFSixzR0FBQSxjQUFjLE9BQUE7QUFFZCxzR0FBQSxjQUFjLE9BQUE7QUFJaEIsNkNBTXVCO0FBSnJCLG1IQUFBLG9CQUFvQixPQUFBO0FBQ3BCLDRHQUFBLGFBQWEsT0FBQTtBQUNiLDRHQUFBLGFBQWEsT0FBQTtBQUNiLG1IQUFBLG9CQUFvQixPQUFBO0FBR3RCLG1DQUtrQjtBQUpoQiwwR0FBQSxnQkFBZ0IsT0FBQTtBQUVoQiwwR0FBQSxnQkFBZ0IsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbIlxuZXhwb3J0IHtcbiAgQnVpbGRPcHRpb25zLFxuICBUcmFuc2Zvcm1PcHRpb25zLFxufSBmcm9tICcuL2VzYnVpbGQtdHlwZXMnO1xuXG5leHBvcnQge1xuICBFc2J1aWxkQnVuZGxlcixcbiAgQnVuZGxlclByb3BzLFxufSBmcm9tICcuL2J1bmRsZXInO1xuXG5leHBvcnQge1xuICBBc3NldCxcbiAgQXNzZXRCYXNlUHJvcHMsXG4gIEFzc2V0UHJvcHMsXG4gIEphdmFTY3JpcHRBc3NldCxcbiAgVHlwZVNjcmlwdEFzc2V0LFxufSBmcm9tICcuL2Fzc2V0JztcblxuZXhwb3J0IHtcbiAgQ29kZSxcbiAgQ29kZUNvbmZpZyxcbiAgSmF2YVNjcmlwdENvZGUsXG4gIEphdmFTY3JpcHRDb2RlUHJvcHMsXG4gIFR5cGVTY3JpcHRDb2RlLFxuICBUeXBlU2NyaXB0Q29kZVByb3BzLFxufSBmcm9tICcuL2NvZGUnO1xuXG5leHBvcnQge1xuICBUcmFuc2Zvcm1lclByb3BzLFxuICBJbmxpbmVKYXZhU2NyaXB0Q29kZSxcbiAgSW5saW5lSnN4Q29kZSxcbiAgSW5saW5lVHN4Q29kZSxcbiAgSW5saW5lVHlwZVNjcmlwdENvZGUsXG59IGZyb20gJy4vaW5saW5lLWNvZGUnO1xuXG5leHBvcnQge1xuICBKYXZhU2NyaXB0U291cmNlLFxuICBKYXZhU2NyaXB0U291cmNlUHJvcHMsXG4gIFR5cGVTY3JpcHRTb3VyY2UsXG4gIFR5cGVTY3JpcHRTb3VyY2VQcm9wcyxcbn0gZnJvbSAnLi9zb3VyY2UnOyJdfQ==
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxpQ0FNaUI7QUFIZixxR0FBQSxZQUFZLE9BQUE7QUFDWix3R0FBQSxlQUFlLE9BQUE7QUFDZix3R0FBQSxlQUFlLE9BQUE7QUFHakIscUNBR21CO0FBRmpCLHlHQUFBLGNBQWMsT0FBQTtBQUloQiwrQkFPZ0I7QUFMZCxtR0FBQSxXQUFXLE9BQUE7QUFDWCxzR0FBQSxjQUFjLE9BQUE7QUFFZCxzR0FBQSxjQUFjLE9BQUE7QUFXaEIsNkNBSXVCO0FBRnJCLG1IQUFBLG9CQUFvQixPQUFBO0FBQ3BCLG1IQUFBLG9CQUFvQixPQUFBO0FBR3RCLHVDQVNvQjtBQVJsQiwyR0FBQSxlQUFlLE9BQUE7QUFFZix5R0FBQSxhQUFhLE9BQUE7QUFRZixtQ0FLa0I7QUFKaEIsMEdBQUEsZ0JBQWdCLE9BQUE7QUFFaEIsMEdBQUEsZ0JBQWdCLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQge1xuICBBc3NldEJhc2VQcm9wcyxcbiAgQXNzZXRQcm9wcyxcbiAgRXNidWlsZEFzc2V0LFxuICBKYXZhU2NyaXB0QXNzZXQsXG4gIFR5cGVTY3JpcHRBc3NldCxcbn0gZnJvbSAnLi9hc3NldCc7XG5cbmV4cG9ydCB7XG4gIEVzYnVpbGRCdW5kbGVyLFxuICBCdW5kbGVyUHJvcHMsXG59IGZyb20gJy4vYnVuZGxlcic7XG5cbmV4cG9ydCB7XG4gIENvZGVDb25maWcsXG4gIEVzYnVpbGRDb2RlLFxuICBKYXZhU2NyaXB0Q29kZSxcbiAgSmF2YVNjcmlwdENvZGVQcm9wcyxcbiAgVHlwZVNjcmlwdENvZGUsXG4gIFR5cGVTY3JpcHRDb2RlUHJvcHMsXG59IGZyb20gJy4vY29kZSc7XG5cbmV4cG9ydCB7XG4gIEJ1aWxkT3B0aW9ucyxcbiAgVHJhbnNmb3JtT3B0aW9ucyxcbiAgVHNjb25maWdPcHRpb25zLFxuICBDb21waWxlck9wdGlvbnMsXG59IGZyb20gJy4vZXNidWlsZC10eXBlcyc7XG5cbmV4cG9ydCB7XG4gIFRyYW5zZm9ybWVyUHJvcHMsXG4gIElubGluZUphdmFTY3JpcHRDb2RlLFxuICBJbmxpbmVUeXBlU2NyaXB0Q29kZSxcbn0gZnJvbSAnLi9pbmxpbmUtY29kZSc7XG5cbmV4cG9ydCB7XG4gIEVzYnVpbGRQcm92aWRlcixcbiAgRXNidWlsZFByb3ZpZGVyUHJvcHMsXG4gIEVzYnVpbGRTb3VyY2UsXG4gIElCdWlsZFByb3ZpZGVyLFxuICBJRXNidWlsZFByb3ZpZGVyLFxuICBJVHJhbnNmb3JtUHJvdmlkZXIsXG4gIFByb3ZpZGVyQnVpbGRPcHRpb25zLFxuICBQcm92aWRlclRyYW5zZm9ybU9wdGlvbnMsXG59IGZyb20gJy4vcHJvdmlkZXInO1xuXG5leHBvcnQge1xuICBKYXZhU2NyaXB0U291cmNlLFxuICBKYXZhU2NyaXB0U291cmNlUHJvcHMsXG4gIFR5cGVTY3JpcHRTb3VyY2UsXG4gIFR5cGVTY3JpcHRTb3VyY2VQcm9wcyxcbn0gZnJvbSAnLi9zb3VyY2UnO1xuIl19