@mrgrain/cdk-esbuild 4.0.0-alpha.7 → 4.0.0-alpha.8
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/.jsii +447 -402
- package/.projenrc.ts +10 -4
- package/API.md +117 -80
- package/CHANGELOG.md +12 -0
- package/README.md +6 -6
- package/lib/asset.d.ts +8 -4
- package/lib/asset.js +14 -10
- package/lib/bundler.js +1 -1
- package/lib/code.d.ts +38 -12
- package/lib/code.js +35 -12
- package/lib/esbuild-polyfill.js +29 -31
- package/lib/esbuild-types.d.ts +5 -1
- package/lib/esbuild-types.js +1 -1
- package/lib/esbuild-wrapper.js +5 -11
- package/lib/index.d.ts +2 -2
- package/lib/index.js +3 -3
- package/lib/inline-code.js +4 -4
- package/lib/source.js +2 -2
- package/package.json +7 -13
- package/node_modules/isexe/.npmignore +0 -2
- package/node_modules/isexe/LICENSE +0 -15
- package/node_modules/isexe/README.md +0 -51
- package/node_modules/isexe/index.js +0 -57
- package/node_modules/isexe/mode.js +0 -41
- package/node_modules/isexe/package.json +0 -35
- package/node_modules/isexe/test/basic.js +0 -221
- package/node_modules/isexe/windows.js +0 -42
- package/node_modules/which/CHANGELOG.md +0 -166
- package/node_modules/which/LICENSE +0 -15
- package/node_modules/which/README.md +0 -54
- package/node_modules/which/bin/node-which +0 -52
- package/node_modules/which/package.json +0 -47
- package/node_modules/which/which.js +0 -125
package/lib/code.d.ts
CHANGED
|
@@ -1,30 +1,56 @@
|
|
|
1
1
|
import { CfnResource } from 'aws-cdk-lib';
|
|
2
|
-
import { ResourceBindOptions, Code
|
|
2
|
+
import { ResourceBindOptions, Code, CodeConfig } from 'aws-cdk-lib/aws-lambda';
|
|
3
3
|
import { Construct } from 'constructs';
|
|
4
|
-
import {
|
|
4
|
+
import { EsbuildAsset, AssetBaseProps, AssetProps } from './asset';
|
|
5
5
|
import { EntryPoints } from './bundler';
|
|
6
6
|
export { CodeConfig } from 'aws-cdk-lib/aws-lambda';
|
|
7
7
|
export interface JavaScriptCodeProps extends AssetBaseProps {
|
|
8
8
|
}
|
|
9
9
|
export interface TypeScriptCodeProps extends AssetBaseProps {
|
|
10
10
|
}
|
|
11
|
-
|
|
11
|
+
/**
|
|
12
|
+
* Represents a generic esbuild code bundle.
|
|
13
|
+
*
|
|
14
|
+
* You should always use `TypeScriptCode` or `JavaScriptCode`.
|
|
15
|
+
*
|
|
16
|
+
* @stability experimental
|
|
17
|
+
*/
|
|
18
|
+
export declare class EsbuildCode<Props extends JavaScriptCodeProps | TypeScriptCodeProps> extends Code {
|
|
19
|
+
/**
|
|
20
|
+
* A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
21
|
+
* E.g. `src/index.ts`.
|
|
22
|
+
*
|
|
23
|
+
* @stability stable
|
|
24
|
+
*/
|
|
12
25
|
readonly entryPoints: EntryPoints;
|
|
13
|
-
protected
|
|
26
|
+
protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
|
|
14
27
|
protected props: AssetProps;
|
|
15
|
-
protected asset:
|
|
28
|
+
protected asset: EsbuildAsset<AssetProps>;
|
|
16
29
|
/**
|
|
17
30
|
* Determines whether this Code is inline code or not.
|
|
18
31
|
*
|
|
19
32
|
* @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().
|
|
20
33
|
*/
|
|
21
34
|
isInline: boolean;
|
|
35
|
+
constructor(
|
|
22
36
|
/**
|
|
37
|
+
* A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
38
|
+
* E.g. `src/index.ts`.
|
|
23
39
|
*
|
|
24
|
-
* @
|
|
25
|
-
|
|
40
|
+
* @stability stable
|
|
41
|
+
*/
|
|
42
|
+
entryPoints: EntryPoints,
|
|
43
|
+
/**
|
|
44
|
+
* Props to change the behavior of the bundler.
|
|
45
|
+
*
|
|
46
|
+
* Default values for `props.buildOptions`:
|
|
47
|
+
* - `bundle=true`
|
|
48
|
+
* - `platform=node`
|
|
49
|
+
* - `target=nodeX` with X being the major node version running locally
|
|
50
|
+
*
|
|
51
|
+
* @stability stable
|
|
26
52
|
*/
|
|
27
|
-
|
|
53
|
+
props: Props);
|
|
28
54
|
bind(scope: Construct): CodeConfig;
|
|
29
55
|
/**
|
|
30
56
|
* Called after the CFN function resource has been created to allow the code class to bind to it.
|
|
@@ -41,8 +67,8 @@ export declare abstract class Code<Props extends JavaScriptCodeProps | TypeScrip
|
|
|
41
67
|
*
|
|
42
68
|
* @stability stable
|
|
43
69
|
*/
|
|
44
|
-
export declare class JavaScriptCode extends
|
|
45
|
-
protected getAsset(scope: Construct):
|
|
70
|
+
export declare class JavaScriptCode extends EsbuildCode<JavaScriptCodeProps> {
|
|
71
|
+
protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
|
|
46
72
|
constructor(
|
|
47
73
|
/**
|
|
48
74
|
* A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
@@ -68,8 +94,8 @@ export declare class JavaScriptCode extends Code<JavaScriptCodeProps> {
|
|
|
68
94
|
*
|
|
69
95
|
* @stability stable
|
|
70
96
|
*/
|
|
71
|
-
export declare class TypeScriptCode extends
|
|
72
|
-
protected getAsset(scope: Construct):
|
|
97
|
+
export declare class TypeScriptCode extends EsbuildCode<TypeScriptCodeProps> {
|
|
98
|
+
protected getAsset(scope: Construct): EsbuildAsset<AssetProps>;
|
|
73
99
|
constructor(
|
|
74
100
|
/**
|
|
75
101
|
* A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
package/lib/code.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var _a, _b, _c;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.TypeScriptCode = exports.JavaScriptCode = exports.
|
|
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");
|
|
@@ -11,13 +11,33 @@ function nodeMajorVersion() {
|
|
|
11
11
|
}
|
|
12
12
|
;
|
|
13
13
|
;
|
|
14
|
-
|
|
14
|
+
/**
|
|
15
|
+
* Represents a generic esbuild code bundle.
|
|
16
|
+
*
|
|
17
|
+
* You should always use `TypeScriptCode` or `JavaScriptCode`.
|
|
18
|
+
*
|
|
19
|
+
* @stability experimental
|
|
20
|
+
*/
|
|
21
|
+
class EsbuildCode extends aws_lambda_1.Code {
|
|
22
|
+
constructor(
|
|
15
23
|
/**
|
|
24
|
+
* A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
25
|
+
* E.g. `src/index.ts`.
|
|
16
26
|
*
|
|
17
|
-
* @
|
|
18
|
-
* @param props - Asset properties.
|
|
27
|
+
* @stability stable
|
|
19
28
|
*/
|
|
20
|
-
|
|
29
|
+
entryPoints,
|
|
30
|
+
/**
|
|
31
|
+
* Props to change the behavior of the bundler.
|
|
32
|
+
*
|
|
33
|
+
* Default values for `props.buildOptions`:
|
|
34
|
+
* - `bundle=true`
|
|
35
|
+
* - `platform=node`
|
|
36
|
+
* - `target=nodeX` with X being the major node version running locally
|
|
37
|
+
*
|
|
38
|
+
* @stability stable
|
|
39
|
+
*/
|
|
40
|
+
props) {
|
|
21
41
|
super();
|
|
22
42
|
this.entryPoints = entryPoints;
|
|
23
43
|
/**
|
|
@@ -41,6 +61,9 @@ class Code extends aws_lambda_1.Code {
|
|
|
41
61
|
},
|
|
42
62
|
};
|
|
43
63
|
}
|
|
64
|
+
getAsset(scope) {
|
|
65
|
+
return new asset_1.EsbuildAsset(scope, this.constructor.name, this.props);
|
|
66
|
+
}
|
|
44
67
|
bind(scope) {
|
|
45
68
|
// If the same AssetCode is used multiple times, retain only the first instantiation.
|
|
46
69
|
if (!this.asset) {
|
|
@@ -73,15 +96,15 @@ class Code extends aws_lambda_1.Code {
|
|
|
73
96
|
this.asset.addResourceMetadata(resource, resourceProperty);
|
|
74
97
|
}
|
|
75
98
|
}
|
|
76
|
-
exports.
|
|
99
|
+
exports.EsbuildCode = EsbuildCode;
|
|
77
100
|
_a = JSII_RTTI_SYMBOL_1;
|
|
78
|
-
|
|
101
|
+
EsbuildCode[_a] = { fqn: "@mrgrain/cdk-esbuild.EsbuildCode", version: "4.0.0-alpha.8" };
|
|
79
102
|
/**
|
|
80
103
|
* Represents the deployed JavaScript Code.
|
|
81
104
|
*
|
|
82
105
|
* @stability stable
|
|
83
106
|
*/
|
|
84
|
-
class JavaScriptCode extends
|
|
107
|
+
class JavaScriptCode extends EsbuildCode {
|
|
85
108
|
constructor(
|
|
86
109
|
/**
|
|
87
110
|
* A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
@@ -109,13 +132,13 @@ class JavaScriptCode extends Code {
|
|
|
109
132
|
}
|
|
110
133
|
exports.JavaScriptCode = JavaScriptCode;
|
|
111
134
|
_b = JSII_RTTI_SYMBOL_1;
|
|
112
|
-
JavaScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "4.0.0-alpha.
|
|
135
|
+
JavaScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "4.0.0-alpha.8" };
|
|
113
136
|
/**
|
|
114
137
|
* Represents the deployed TypeScript Code.
|
|
115
138
|
*
|
|
116
139
|
* @stability stable
|
|
117
140
|
*/
|
|
118
|
-
class TypeScriptCode extends
|
|
141
|
+
class TypeScriptCode extends EsbuildCode {
|
|
119
142
|
constructor(
|
|
120
143
|
/**
|
|
121
144
|
* A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
@@ -143,5 +166,5 @@ class TypeScriptCode extends Code {
|
|
|
143
166
|
}
|
|
144
167
|
exports.TypeScriptCode = TypeScriptCode;
|
|
145
168
|
_c = JSII_RTTI_SYMBOL_1;
|
|
146
|
-
TypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "4.0.0-alpha.
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["../src/code.ts"],"names":[],"mappings":"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","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"]}
|
|
169
|
+
TypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "4.0.0-alpha.8" };
|
|
170
|
+
//# 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;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;;;;;;GAMG;AACH,MAAa,WAEX,SAAQ,iBAAI;IAoBZ;IACE;;;;;OAKG;IACM,WAAwB;IAEjC;;;;;;;;;OASG;IACH,KAAY;QAEZ,KAAK,EAAE,CAAC;QAdC,gBAAW,GAAX,WAAW,CAAa;QAdnC;;;;WAIG;QACI,aAAQ,GAAY,KAAK,CAAC;QAyB/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;IAzDS,QAAQ,CAAC,KAAgB;QACjC,OAAO,IAAI,oBAAY,CACrB,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;IACJ,CAAC;IAqDD,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;;AAjGH,kCAkGC;;;AAED;;;;GAIG;AACH,MAAa,cAAe,SAAQ,WAAgC;IASlE;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,WAAgC;IASlE;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, 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';\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\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 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    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> = {\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 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 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 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 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"]}
|
package/lib/esbuild-polyfill.js
CHANGED
|
@@ -1,26 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
1
2
|
var __create = Object.create;
|
|
2
3
|
var __defProp = Object.defineProperty;
|
|
3
|
-
var __defProps = Object.defineProperties;
|
|
4
4
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
6
5
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
-
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
6
|
var __getProtoOf = Object.getPrototypeOf;
|
|
9
7
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
10
|
-
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
11
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
12
|
-
var __spreadValues = (a, b) => {
|
|
13
|
-
for (var prop in b || (b = {}))
|
|
14
|
-
if (__hasOwnProp.call(b, prop))
|
|
15
|
-
__defNormalProp(a, prop, b[prop]);
|
|
16
|
-
if (__getOwnPropSymbols)
|
|
17
|
-
for (var prop of __getOwnPropSymbols(b)) {
|
|
18
|
-
if (__propIsEnum.call(b, prop))
|
|
19
|
-
__defNormalProp(a, prop, b[prop]);
|
|
20
|
-
}
|
|
21
|
-
return a;
|
|
22
|
-
};
|
|
23
|
-
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
24
8
|
var __export = (target, all) => {
|
|
25
9
|
for (var name in all)
|
|
26
10
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
@@ -319,6 +303,7 @@ function pushCommonFlags(flags, options, keys) {
|
|
|
319
303
|
let jsxFragment = getFlag(options, keys, "jsxFragment", mustBeString);
|
|
320
304
|
let define = getFlag(options, keys, "define", mustBeObject);
|
|
321
305
|
let logOverride = getFlag(options, keys, "logOverride", mustBeObject);
|
|
306
|
+
let supported = getFlag(options, keys, "supported", mustBeObject);
|
|
322
307
|
let pure = getFlag(options, keys, "pure", mustBeArray);
|
|
323
308
|
let keepNames = getFlag(options, keys, "keepNames", mustBeBoolean);
|
|
324
309
|
if (legalComments)
|
|
@@ -380,6 +365,13 @@ function pushCommonFlags(flags, options, keys) {
|
|
|
380
365
|
flags.push(`--log-override:${key}=${logOverride[key]}`);
|
|
381
366
|
}
|
|
382
367
|
}
|
|
368
|
+
if (supported) {
|
|
369
|
+
for (let key in supported) {
|
|
370
|
+
if (key.indexOf("=") >= 0)
|
|
371
|
+
throw new Error(`Invalid supported: ${key}`);
|
|
372
|
+
flags.push(`--supported:${key}=${supported[key]}`);
|
|
373
|
+
}
|
|
374
|
+
}
|
|
383
375
|
if (pure)
|
|
384
376
|
for (let fn of pure)
|
|
385
377
|
flags.push(`--pure:${fn}`);
|
|
@@ -754,8 +746,8 @@ function createChannel(streamIn) {
|
|
|
754
746
|
if (isFirstPacket) {
|
|
755
747
|
isFirstPacket = false;
|
|
756
748
|
let binaryVersion = String.fromCharCode(...bytes);
|
|
757
|
-
if (binaryVersion !== "0.14.
|
|
758
|
-
throw new Error(`Cannot start service: Host version "${"0.14.
|
|
749
|
+
if (binaryVersion !== "0.14.47") {
|
|
750
|
+
throw new Error(`Cannot start service: Host version "${"0.14.47"}" does not match binary version ${JSON.stringify(binaryVersion)}`);
|
|
759
751
|
}
|
|
760
752
|
return;
|
|
761
753
|
}
|
|
@@ -1147,14 +1139,15 @@ function createChannel(streamIn) {
|
|
|
1147
1139
|
handleError(result.error, result.pluginName);
|
|
1148
1140
|
} else {
|
|
1149
1141
|
try {
|
|
1150
|
-
buildOrServeContinue(
|
|
1142
|
+
buildOrServeContinue({
|
|
1143
|
+
...args,
|
|
1151
1144
|
key,
|
|
1152
1145
|
details,
|
|
1153
1146
|
logPluginError,
|
|
1154
1147
|
requestPlugins: result.requestPlugins,
|
|
1155
1148
|
runOnEndCallbacks: result.runOnEndCallbacks,
|
|
1156
1149
|
pluginRefs: result.pluginRefs
|
|
1157
|
-
})
|
|
1150
|
+
});
|
|
1158
1151
|
} catch (e) {
|
|
1159
1152
|
handleError(e, "");
|
|
1160
1153
|
}
|
|
@@ -1162,14 +1155,15 @@ function createChannel(streamIn) {
|
|
|
1162
1155
|
}, (e) => handleError(e, ""));
|
|
1163
1156
|
} else {
|
|
1164
1157
|
try {
|
|
1165
|
-
buildOrServeContinue(
|
|
1158
|
+
buildOrServeContinue({
|
|
1159
|
+
...args,
|
|
1166
1160
|
key,
|
|
1167
1161
|
details,
|
|
1168
1162
|
logPluginError,
|
|
1169
1163
|
requestPlugins: null,
|
|
1170
1164
|
runOnEndCallbacks: (result, logPluginError2, done) => done(),
|
|
1171
1165
|
pluginRefs: null
|
|
1172
|
-
})
|
|
1166
|
+
});
|
|
1173
1167
|
} catch (e) {
|
|
1174
1168
|
handleError(e, "");
|
|
1175
1169
|
}
|
|
@@ -1264,7 +1258,7 @@ function createChannel(streamIn) {
|
|
|
1264
1258
|
throw new Error("Cannot rebuild");
|
|
1265
1259
|
sendRequest(refs, { command: "rebuild", key }, (error2, response2) => {
|
|
1266
1260
|
if (error2) {
|
|
1267
|
-
const message = { pluginName: "", text: error2, location: null, notes: [], detail: void 0 };
|
|
1261
|
+
const message = { id: "", pluginName: "", text: error2, location: null, notes: [], detail: void 0 };
|
|
1268
1262
|
return callback2(failureErrorWithLog("Build failed", [message], []), null);
|
|
1269
1263
|
}
|
|
1270
1264
|
buildResponseToResult(response2, (error3, result3) => {
|
|
@@ -1547,7 +1541,7 @@ function extractErrorMessageV8(e, streamIn, stash, note, pluginName) {
|
|
|
1547
1541
|
location = parseStackLinesV8(streamIn, (e.stack + "").split("\n"), "");
|
|
1548
1542
|
} catch {
|
|
1549
1543
|
}
|
|
1550
|
-
return { pluginName, text, location, notes: note ? [note] : [], detail: stash ? stash.store(e) : -1 };
|
|
1544
|
+
return { id: "", pluginName, text, location, notes: note ? [note] : [], detail: stash ? stash.store(e) : -1 };
|
|
1551
1545
|
}
|
|
1552
1546
|
function parseStackLinesV8(streamIn, lines, ident) {
|
|
1553
1547
|
let at = " at ";
|
|
@@ -1646,6 +1640,7 @@ function sanitizeMessages(messages, property, stash, fallbackPluginName) {
|
|
|
1646
1640
|
let index = 0;
|
|
1647
1641
|
for (const message of messages) {
|
|
1648
1642
|
let keys = {};
|
|
1643
|
+
let id = getFlag(message, keys, "id", mustBeString);
|
|
1649
1644
|
let pluginName = getFlag(message, keys, "pluginName", mustBeString);
|
|
1650
1645
|
let text = getFlag(message, keys, "text", mustBeString);
|
|
1651
1646
|
let location = getFlag(message, keys, "location", mustBeObjectOrNull);
|
|
@@ -1667,6 +1662,7 @@ function sanitizeMessages(messages, property, stash, fallbackPluginName) {
|
|
|
1667
1662
|
}
|
|
1668
1663
|
}
|
|
1669
1664
|
messagesClone.push({
|
|
1665
|
+
id: id || "",
|
|
1670
1666
|
pluginName: pluginName || fallbackPluginName,
|
|
1671
1667
|
text: text || "",
|
|
1672
1668
|
location: sanitizeLocation(location, where),
|
|
@@ -1867,7 +1863,7 @@ if (process.env.ESBUILD_WORKER_THREADS !== "0") {
|
|
|
1867
1863
|
}
|
|
1868
1864
|
}
|
|
1869
1865
|
var _a;
|
|
1870
|
-
var isInternalWorkerThread = ((_a = worker_threads == null ? void 0 : worker_threads.workerData) == null ? void 0 : _a.esbuildVersion) === "0.14.
|
|
1866
|
+
var isInternalWorkerThread = ((_a = worker_threads == null ? void 0 : worker_threads.workerData) == null ? void 0 : _a.esbuildVersion) === "0.14.47";
|
|
1871
1867
|
var esbuildCommandAndArgs = () => {
|
|
1872
1868
|
if ((!ESBUILD_BINARY_PATH || false) && (path2.basename(__filename) !== "main.js" || path2.basename(__dirname) !== "lib")) {
|
|
1873
1869
|
throw new Error(`The esbuild JavaScript API cannot be bundled. Please mark the "esbuild" package as external so it's not included in the bundle.
|
|
@@ -1931,7 +1927,7 @@ var fsAsync = {
|
|
|
1931
1927
|
}
|
|
1932
1928
|
}
|
|
1933
1929
|
};
|
|
1934
|
-
var version = "0.14.
|
|
1930
|
+
var version = "0.14.47";
|
|
1935
1931
|
var build = (options) => ensureServiceIsRunning().build(options);
|
|
1936
1932
|
var serve = (serveOptions, buildOptions) => ensureServiceIsRunning().serve(serveOptions, buildOptions);
|
|
1937
1933
|
var transform = (input, options) => ensureServiceIsRunning().transform(input, options);
|
|
@@ -2026,6 +2022,8 @@ var initialize = (options) => {
|
|
|
2026
2022
|
options = validateInitializeOptions(options || {});
|
|
2027
2023
|
if (options.wasmURL)
|
|
2028
2024
|
throw new Error(`The "wasmURL" option only works in the browser`);
|
|
2025
|
+
if (options.wasmModule)
|
|
2026
|
+
throw new Error(`The "wasmModule" option only works in the browser`);
|
|
2029
2027
|
if (options.worker)
|
|
2030
2028
|
throw new Error(`The "worker" option only works in the browser`);
|
|
2031
2029
|
if (initializeWasCalled)
|
|
@@ -2040,7 +2038,7 @@ var ensureServiceIsRunning = () => {
|
|
|
2040
2038
|
if (longLivedService)
|
|
2041
2039
|
return longLivedService;
|
|
2042
2040
|
let [command, args] = esbuildCommandAndArgs();
|
|
2043
|
-
let child = child_process.spawn(command, args.concat(`--service=${"0.14.
|
|
2041
|
+
let child = child_process.spawn(command, args.concat(`--service=${"0.14.47"}`, "--ping"), {
|
|
2044
2042
|
windowsHide: true,
|
|
2045
2043
|
stdio: ["pipe", "pipe", "inherit"],
|
|
2046
2044
|
cwd: defaultWD
|
|
@@ -2154,7 +2152,7 @@ var runServiceSync = (callback) => {
|
|
|
2154
2152
|
esbuild: node_exports
|
|
2155
2153
|
});
|
|
2156
2154
|
callback(service);
|
|
2157
|
-
let stdout = child_process.execFileSync(command, args.concat(`--service=${"0.14.
|
|
2155
|
+
let stdout = child_process.execFileSync(command, args.concat(`--service=${"0.14.47"}`), {
|
|
2158
2156
|
cwd: defaultWD,
|
|
2159
2157
|
windowsHide: true,
|
|
2160
2158
|
input: stdin,
|
|
@@ -2170,7 +2168,7 @@ var workerThreadService = null;
|
|
|
2170
2168
|
var startWorkerThreadService = (worker_threads2) => {
|
|
2171
2169
|
let { port1: mainPort, port2: workerPort } = new worker_threads2.MessageChannel();
|
|
2172
2170
|
let worker = new worker_threads2.Worker(__filename, {
|
|
2173
|
-
workerData: { workerPort, defaultWD, esbuildVersion: "0.14.
|
|
2171
|
+
workerData: { workerPort, defaultWD, esbuildVersion: "0.14.47" },
|
|
2174
2172
|
transferList: [workerPort],
|
|
2175
2173
|
execArgv: []
|
|
2176
2174
|
});
|
|
@@ -2179,7 +2177,7 @@ var startWorkerThreadService = (worker_threads2) => {
|
|
|
2179
2177
|
let fakeBuildError = (text) => {
|
|
2180
2178
|
let error = new Error(`Build failed with 1 error:
|
|
2181
2179
|
error: ${text}`);
|
|
2182
|
-
let errors = [{ pluginName: "", text, location: null, notes: [], detail: void 0 }];
|
|
2180
|
+
let errors = [{ id: "", pluginName: "", text, location: null, notes: [], detail: void 0 }];
|
|
2183
2181
|
error.errors = errors;
|
|
2184
2182
|
error.warnings = [];
|
|
2185
2183
|
return error;
|
package/lib/esbuild-types.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export declare type Platform = 'browser' | 'node' | 'neutral';
|
|
2
2
|
export declare type Format = 'iife' | 'cjs' | 'esm';
|
|
3
|
-
export declare type Loader = 'js' | 'jsx' | 'ts' | 'tsx' | 'css' | 'json' | 'text' | 'base64' | 'file' | 'dataurl' | 'binary' | 'default';
|
|
3
|
+
export declare type Loader = 'js' | 'jsx' | 'ts' | 'tsx' | 'css' | 'json' | 'text' | 'base64' | 'file' | 'dataurl' | 'binary' | 'copy' | 'default';
|
|
4
4
|
export declare type LogLevel = 'verbose' | 'debug' | 'info' | 'warning' | 'error' | 'silent';
|
|
5
5
|
export declare type Charset = 'ascii' | 'utf8';
|
|
6
6
|
export declare type Drop = 'console' | 'debugger';
|
|
@@ -19,6 +19,8 @@ interface CommonOptions {
|
|
|
19
19
|
readonly globalName?: string;
|
|
20
20
|
/** Documentation: https://esbuild.github.io/api/#target */
|
|
21
21
|
readonly target?: string | string[];
|
|
22
|
+
/** Documentation: https://esbuild.github.io/api/#supported */
|
|
23
|
+
readonly supported?: Record<string, boolean>;
|
|
22
24
|
/** Documentation: https://esbuild.github.io/api/#mangle-props */
|
|
23
25
|
readonly mangleProps?: any;
|
|
24
26
|
/** Documentation: https://esbuild.github.io/api/#mangle-props */
|
|
@@ -140,6 +142,7 @@ export interface StdinOptions {
|
|
|
140
142
|
loader?: Loader;
|
|
141
143
|
}
|
|
142
144
|
export interface Message {
|
|
145
|
+
id: string;
|
|
143
146
|
pluginName: string;
|
|
144
147
|
text: string;
|
|
145
148
|
location: Location | null;
|
|
@@ -333,6 +336,7 @@ export interface OnLoadResult {
|
|
|
333
336
|
watchDirs?: string[];
|
|
334
337
|
}
|
|
335
338
|
export interface PartialMessage {
|
|
339
|
+
id?: string;
|
|
336
340
|
pluginName?: string;
|
|
337
341
|
text?: string;
|
|
338
342
|
location?: Partial<Location> | null;
|
package/lib/esbuild-types.js
CHANGED
|
@@ -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 = 'js' | 'jsx' | 'ts' | 'tsx' | 'css' | 'json' | 'text' | 'base64' | 'file' | 'dataurl' | 'binary' | 'copy' | '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  /** Documentation: https://esbuild.github.io/api/#supported */\n  readonly supported?: Record<string, boolean>;\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  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 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  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      }[];\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"]}
|
package/lib/esbuild-wrapper.js
CHANGED
|
@@ -1,25 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
/* eslint-disable import/no-extraneous-dependencies */
|
|
2
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
4
|
exports.transformSync = exports.formatMessagesSync = exports.buildSync = void 0;
|
|
4
|
-
const which = require("which");
|
|
5
|
-
/* eslint-disable import/no-extraneous-dependencies */
|
|
6
5
|
function esbuild() {
|
|
7
6
|
try {
|
|
8
7
|
// eslint-disable-next-line @typescript-eslint/no-require-imports
|
|
9
8
|
return require('esbuild');
|
|
10
9
|
}
|
|
11
|
-
catch (
|
|
10
|
+
catch (_unused) {
|
|
12
11
|
/**
|
|
13
12
|
* esbuild is not installed. We fallback to use a (hopefully available)
|
|
14
13
|
* global binary and our bundled polyfill.
|
|
15
14
|
*/
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
process.env.ESBUILD_BINARY_PATH = which.sync('esbuild');
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
catch (_two) {
|
|
22
|
-
throw new Error('The esbuild binary could not be found in path. Please follow the instructions to ensure esbuild is correctly installed.');
|
|
15
|
+
if (!process.env?.ESBUILD_BINARY_PATH) {
|
|
16
|
+
process.env.ESBUILD_BINARY_PATH = 'esbuild';
|
|
23
17
|
}
|
|
24
18
|
// eslint-disable-next-line @typescript-eslint/no-require-imports
|
|
25
19
|
return require('./esbuild-polyfill');
|
|
@@ -28,4 +22,4 @@ function esbuild() {
|
|
|
28
22
|
exports.buildSync = esbuild().buildSync;
|
|
29
23
|
exports.formatMessagesSync = esbuild().formatMessagesSync;
|
|
30
24
|
exports.transformSync = esbuild().transformSync;
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNidWlsZC13cmFwcGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2VzYnVpbGQtd3JhcHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsc0RBQXNEOzs7QUFFdEQsU0FBUyxPQUFPO0lBQ2QsSUFBSTtRQUNGLGlFQUFpRTtRQUNqRSxPQUFPLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztLQUMzQjtJQUFDLE9BQU8sT0FBTyxFQUFFO1FBQ2hCOzs7V0FHRztRQUNILElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLG1CQUFtQixFQUFFO1lBQ3JDLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQW1CLEdBQUcsU0FBUyxDQUFDO1NBQzdDO1FBRUQsaUVBQWlFO1FBQ2pFLE9BQU8sT0FBTyxDQUFDLG9CQUFvQixDQUFDLENBQUM7S0FDdEM7QUFDSCxDQUFDO0FBRVksUUFBQSxTQUFTLEdBQUcsT0FBTyxFQUFFLENBQUMsU0FBUyxDQUFDO0FBQ2hDLFFBQUEsa0JBQWtCLEdBQUcsT0FBTyxFQUFFLENBQUMsa0JBQWtCLENBQUM7QUFDbEQsUUFBQSxhQUFhLEdBQUcsT0FBTyxFQUFFLENBQUMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgaW1wb3J0L25vLWV4dHJhbmVvdXMtZGVwZW5kZW5jaWVzICovXG5cbmZ1bmN0aW9uIGVzYnVpbGQoKSB7XG4gIHRyeSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1yZXF1aXJlLWltcG9ydHNcbiAgICByZXR1cm4gcmVxdWlyZSgnZXNidWlsZCcpO1xuICB9IGNhdGNoIChfdW51c2VkKSB7XG4gICAgLyoqXG4gICAgICogZXNidWlsZCBpcyBub3QgaW5zdGFsbGVkLiBXZSBmYWxsYmFjayB0byB1c2UgYSAoaG9wZWZ1bGx5IGF2YWlsYWJsZSlcbiAgICAgKiBnbG9iYWwgYmluYXJ5IGFuZCBvdXIgYnVuZGxlZCBwb2x5ZmlsbC5cbiAgICAgKi9cbiAgICBpZiAoIXByb2Nlc3MuZW52Py5FU0JVSUxEX0JJTkFSWV9QQVRIKSB7XG4gICAgICBwcm9jZXNzLmVudi5FU0JVSUxEX0JJTkFSWV9QQVRIID0gJ2VzYnVpbGQnO1xuICAgIH1cblxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tcmVxdWlyZS1pbXBvcnRzXG4gICAgcmV0dXJuIHJlcXVpcmUoJy4vZXNidWlsZC1wb2x5ZmlsbCcpO1xuICB9XG59XG5cbmV4cG9ydCBjb25zdCBidWlsZFN5bmMgPSBlc2J1aWxkKCkuYnVpbGRTeW5jO1xuZXhwb3J0IGNvbnN0IGZvcm1hdE1lc3NhZ2VzU3luYyA9IGVzYnVpbGQoKS5mb3JtYXRNZXNzYWdlc1N5bmM7XG5leHBvcnQgY29uc3QgdHJhbnNmb3JtU3luYyA9IGVzYnVpbGQoKS50cmFuc2Zvcm1TeW5jO1xuIl19
|
package/lib/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export { BuildOptions, TransformOptions, } from './esbuild-types';
|
|
2
2
|
export { EsbuildBundler, BundlerProps, } from './bundler';
|
|
3
|
-
export {
|
|
4
|
-
export {
|
|
3
|
+
export { AssetBaseProps, AssetProps, EsbuildAsset, JavaScriptAsset, TypeScriptAsset, } from './asset';
|
|
4
|
+
export { CodeConfig, EsbuildCode, JavaScriptCode, JavaScriptCodeProps, TypeScriptCode, TypeScriptCodeProps, } from './code';
|
|
5
5
|
export { TransformerProps, InlineJavaScriptCode, InlineJsxCode, InlineTsxCode, InlineTypeScriptCode, } from './inline-code';
|
|
6
6
|
export { JavaScriptSource, JavaScriptSourceProps, TypeScriptSource, TypeScriptSourceProps, } from './source';
|