@mrgrain/cdk-esbuild 2.0.0-alpha.0 → 2.0.0-alpha.5
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/.gitattributes +1 -1
- package/.jsii +560 -504
- package/{.projenrc.mjs → .projenrc.ts} +38 -31
- package/API.md +432 -698
- package/CHANGELOG.md +261 -0
- package/README.md +51 -172
- package/SECURITY.md +5 -5
- package/lib/asset.d.ts +29 -28
- package/lib/asset.js +23 -13
- package/lib/bundler.d.ts +92 -0
- package/lib/bundler.js +85 -0
- package/lib/code.d.ts +75 -28
- package/lib/code.js +61 -7
- package/lib/esbuild-types.js +2 -1
- package/lib/index.d.ts +5 -6
- package/lib/index.js +3 -5
- package/lib/inline-code.d.ts +88 -4
- package/lib/inline-code.js +93 -9
- package/lib/source.d.ts +18 -9
- package/lib/source.js +5 -3
- package/package.json +4 -1
- package/projenrc/TypeScriptSourceFile.ts +50 -0
- package/esbuild/Dockerfile +0 -13
- package/esbuild/esbuild-js +0 -22
- package/lib/bundlers.d.ts +0 -42
- package/lib/bundlers.js +0 -62
- package/lib/bundling.d.ts +0 -20
- package/lib/bundling.js +0 -30
- package/lib/esbuild-types-raw.d.ts +0 -304
- package/lib/esbuild-types-raw.js +0 -4
package/lib/code.js
CHANGED
|
@@ -8,6 +8,8 @@ const asset_1 = require("./asset");
|
|
|
8
8
|
function nodeMajorVersion() {
|
|
9
9
|
return parseInt(process.versions.node.split('.')[0], 10);
|
|
10
10
|
}
|
|
11
|
+
;
|
|
12
|
+
;
|
|
11
13
|
class Code {
|
|
12
14
|
/**
|
|
13
15
|
*
|
|
@@ -16,8 +18,11 @@ class Code {
|
|
|
16
18
|
*/
|
|
17
19
|
constructor(entryPoints, props) {
|
|
18
20
|
var _c, _d;
|
|
21
|
+
this.entryPoints = entryPoints;
|
|
19
22
|
/**
|
|
20
|
-
*
|
|
23
|
+
* (deprecated) Determines whether this Code is inline code or not.
|
|
24
|
+
*
|
|
25
|
+
* @deprecated this value is ignored since inline is now determined based on the the inlineCode field of CodeConfig returned from bind().
|
|
21
26
|
*/
|
|
22
27
|
this.isInline = false;
|
|
23
28
|
const defaultOptions = {
|
|
@@ -27,8 +32,8 @@ class Code {
|
|
|
27
32
|
: {}),
|
|
28
33
|
};
|
|
29
34
|
this.props = {
|
|
30
|
-
entryPoints,
|
|
31
35
|
...props,
|
|
36
|
+
entryPoints,
|
|
32
37
|
buildOptions: {
|
|
33
38
|
...defaultOptions,
|
|
34
39
|
...props.buildOptions,
|
|
@@ -54,6 +59,11 @@ class Code {
|
|
|
54
59
|
};
|
|
55
60
|
}
|
|
56
61
|
/**
|
|
62
|
+
* Called after the CFN function resource has been created to allow the code class to bind to it.
|
|
63
|
+
*
|
|
64
|
+
* Specifically it's required to allow assets to add
|
|
65
|
+
* metadata for tooling like SAM CLI to be able to find their origins.
|
|
66
|
+
*
|
|
57
67
|
* @stability stable
|
|
58
68
|
*/
|
|
59
69
|
bindToResource(resource, options) {
|
|
@@ -66,13 +76,35 @@ class Code {
|
|
|
66
76
|
}
|
|
67
77
|
}
|
|
68
78
|
/**
|
|
79
|
+
* Represents the deployed JavaScript Code.
|
|
80
|
+
*
|
|
69
81
|
* @stability stable
|
|
70
82
|
*/
|
|
71
83
|
class JavaScriptCode extends Code {
|
|
72
84
|
/**
|
|
85
|
+
* @param entryPoints A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
86
|
+
* @param props Props to change the behavior of the bundler.
|
|
87
|
+
* @stability stable
|
|
88
|
+
*/
|
|
89
|
+
constructor(
|
|
90
|
+
/**
|
|
91
|
+
* A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
92
|
+
* E.g. `src/index.ts`.
|
|
93
|
+
*
|
|
73
94
|
* @stability stable
|
|
74
95
|
*/
|
|
75
|
-
|
|
96
|
+
entryPoints,
|
|
97
|
+
/**
|
|
98
|
+
* Props to change the behavior of the bundler.
|
|
99
|
+
*
|
|
100
|
+
* Default values for `props.buildOptions`:
|
|
101
|
+
* - `bundle=true`
|
|
102
|
+
* - `platform=node`
|
|
103
|
+
* - `target=nodeX` with X being the major node version running locally
|
|
104
|
+
*
|
|
105
|
+
* @stability stable
|
|
106
|
+
*/
|
|
107
|
+
props = {}) {
|
|
76
108
|
super(entryPoints, props);
|
|
77
109
|
/**
|
|
78
110
|
* @stability stable
|
|
@@ -82,15 +114,37 @@ class JavaScriptCode extends Code {
|
|
|
82
114
|
}
|
|
83
115
|
exports.JavaScriptCode = JavaScriptCode;
|
|
84
116
|
_a = JSII_RTTI_SYMBOL_1;
|
|
85
|
-
JavaScriptCode[_a] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "2.0.0-alpha.
|
|
117
|
+
JavaScriptCode[_a] = { fqn: "@mrgrain/cdk-esbuild.JavaScriptCode", version: "2.0.0-alpha.5" };
|
|
86
118
|
/**
|
|
119
|
+
* Represents the deployed TypeScript Code.
|
|
120
|
+
*
|
|
87
121
|
* @stability stable
|
|
88
122
|
*/
|
|
89
123
|
class TypeScriptCode extends Code {
|
|
90
124
|
/**
|
|
125
|
+
* @param entryPoints A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
126
|
+
* @param props Props to change the behavior of the bundler.
|
|
127
|
+
* @stability stable
|
|
128
|
+
*/
|
|
129
|
+
constructor(
|
|
130
|
+
/**
|
|
131
|
+
* A relative path or list or map of relative paths to the entry points of your code from the root of the project.
|
|
132
|
+
* E.g. `src/index.ts`.
|
|
133
|
+
*
|
|
134
|
+
* @stability stable
|
|
135
|
+
*/
|
|
136
|
+
entryPoints,
|
|
137
|
+
/**
|
|
138
|
+
* Props to change the behavior of the bundler.
|
|
139
|
+
*
|
|
140
|
+
* Default values for `props.buildOptions`:
|
|
141
|
+
* - `bundle=true`
|
|
142
|
+
* - `platform=node`
|
|
143
|
+
* - `target=nodeX` with X being the major node version running locally
|
|
144
|
+
*
|
|
91
145
|
* @stability stable
|
|
92
146
|
*/
|
|
93
|
-
|
|
147
|
+
props = {}) {
|
|
94
148
|
super(entryPoints, props);
|
|
95
149
|
/**
|
|
96
150
|
* @stability stable
|
|
@@ -100,5 +154,5 @@ class TypeScriptCode extends Code {
|
|
|
100
154
|
}
|
|
101
155
|
exports.TypeScriptCode = TypeScriptCode;
|
|
102
156
|
_b = JSII_RTTI_SYMBOL_1;
|
|
103
|
-
TypeScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "2.0.0-alpha.
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
157
|
+
TypeScriptCode[_b] = { fqn: "@mrgrain/cdk-esbuild.TypeScriptCode", version: "2.0.0-alpha.5" };
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.js","sourceRoot":"","sources":["../src/code.ts"],"names":[],"mappings":";;;;;AAEA,wCAA8D;AAC9D,mCAKiB;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;AAO6D,CAAC;AACD,CAAC;AAE/D,MAAe,IAAI;IAiBjB;;;;OAIG;IACH,YAA4B,WAAwB,EAAE,KAAY;;QAAtC,gBAAW,GAAX,WAAW,CAAa;;;;;;QAP7C,aAAQ,GAAY,KAAK,CAAC;QAQ/B,MAAM,cAAc,GAA0B;YAC5C,GAAG,CAAC,QAAC,KAAK,CAAC,YAAY,0CAAE,QAAQ,CAAA;gBACjC,OAAA,KAAK,CAAC,YAAY,0CAAE,QAAQ,MAAK,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,IAAI,CAAC,UAAU,CAC9B,KAAK,EACL,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,IAAI,CAAC,KAAK,CACX,CAAC;SACH;aAAM,IAAI,YAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,YAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE;YACnD,MAAM,IAAI,KAAK,CACb,mDACE,YAAK,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;;;;;;;;;IAGD,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,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,gBAAgB,KAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QAC5E,6CAA6C;QAC7C,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;IAC7D,CAAC;CACF;;;;;;AAGD,MAAa,cAAe,SAAQ,IAAkC;;;;;;IAGpE;IACE;;;;;OAKG;IACH,WAAwB;IACxB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;;;;QAtBT,eAAU,GAAG,uBAAO,CAAC;IAuBxC,CAAC;;AAxBH,wCAyBC;;;;;;;;AAGD,MAAa,cAAe,SAAQ,IAAkC;;;;;;IAGpE;IACE;;;;;OAKG;IACH,WAAwB;IACxB;;;;;;;;;OASG;IACH,QAA6B,EAAE;QAE/B,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;;;;QAtBT,eAAU,GAAG,uBAAO,CAAC;IAuBxC,CAAC;;AAxBH,wCAyBC","sourcesContent":["import { ResourceBindOptions } from '@aws-cdk/aws-lambda';\nimport { Location } from '@aws-cdk/aws-s3';\nimport { CfnResource, Construct, Stack } from '@aws-cdk/core';\nimport {\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 interface CodeConfig {\n                                                                            \n  readonly s3Location: Location;\n}\n\nexport interface JavaScriptCodeProps extends AssetBaseProps {};\nexport interface TypeScriptCodeProps extends AssetBaseProps {};\n\nabstract class Code<\n  Props extends JavaScriptCodeProps | TypeScriptCodeProps,\n  Asset extends JSAsset | TSAsset\n> {\n  protected abstract readonly assetClass: new (\n    scope: Construct,\n    id: string,\n    props: AssetProps\n  ) => Asset;\n\n  protected props: AssetProps;\n\n  protected asset!: Asset;\n\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    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 = new this.assetClass(\n        scope,\n        this.constructor.name,\n        this.props,\n      );\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  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                                                                           \nexport class JavaScriptCode extends Code<JavaScriptCodeProps, JSAsset> {\n  protected readonly assetClass = JSAsset;\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                                                                           \nexport class TypeScriptCode extends Code<TypeScriptCodeProps, TSAsset> {\n  protected readonly assetClass = TSAsset;\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-types.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
// ~~ Generated by projen. To modify, edit .projenrc.js and run "npx projen".
|
|
2
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
4
|
exports.version = void 0;
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esbuild-types.js","sourceRoot":"","sources":["../src/esbuild-types.ts"],"names":[],"mappings":"","sourcesContent":["export 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';\n\ninterface CommonOptions {\n  readonly sourcemap?: boolean | 'inline' | 'external' | 'both';\n  readonly legalComments?: 'none' | 'inline' | 'eof' | 'linked' | 'external';\n  readonly sourceRoot?: string;\n  readonly sourcesContent?: boolean;\n\n  readonly format?: Format;\n  readonly globalName?: string;\n  readonly target?: string | string[];\n\n  readonly minify?: boolean;\n  readonly minifyWhitespace?: boolean;\n  readonly minifyIdentifiers?: boolean;\n  readonly minifySyntax?: boolean;\n  readonly charset?: Charset;\n  readonly treeShaking?: boolean;\n  readonly ignoreAnnotations?: boolean;\n\n  readonly jsx?: 'transform' | 'preserve';\n  readonly jsxFactory?: string;\n  readonly jsxFragment?: string;\n\n  readonly define?: { [key: string]: string };\n  readonly pure?: string[];\n  readonly keepNames?: boolean;\n\n  readonly color?: boolean;\n  readonly logLevel?: LogLevel;\n  readonly logLimit?: number;\n}\n\nexport interface BuildOptions extends CommonOptions {\n  readonly bundle?: boolean;\n  readonly splitting?: boolean;\n  readonly preserveSymlinks?: boolean;\n  readonly outfile?: string;\n  readonly metafile?: boolean;\n  readonly outdir?: string;\n  readonly outbase?: string;\n  readonly platform?: Platform;\n  readonly external?: string[];\n  readonly loader?: { [ext: string]: Loader };\n  readonly resolveExtensions?: string[];\n  readonly mainFields?: string[];\n  readonly conditions?: string[];\n  readonly write?: boolean;\n  readonly allowOverwrite?: boolean;\n  readonly tsconfig?: string;\n  readonly outExtension?: { [ext: string]: string };\n  readonly publicPath?: string;\n  readonly entryNames?: string;\n  readonly chunkNames?: string;\n  readonly assetNames?: string;\n  readonly inject?: string[];\n  readonly banner?: { [type: string]: string };\n  readonly footer?: { [type: string]: string };\n  readonly incremental?: boolean;\n  readonly absWorkingDir?: string;\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  // Optional user-specified data that is passed through unmodified. You can\n  // use this to stash the original error, for example.\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  line: number; // 1-based\n  column: number; // 0-based, in bytes\n  length: number; // in bytes\n  lineText: string;\n  suggestion: string;\n}\n\nexport interface OutputFile {\n  path: string;\n  contents: Uint8Array; // \"text\" as bytes\n  text: string; // \"contents\" as text\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  outputFiles?: OutputFile[]; // Only when \"write: false\"\n  rebuild?: BuildInvalidate; // Only when \"incremental: true\"\n  stop?: () => void; // Only when \"watch: true\"\n  metafile?: Metafile; // Only when \"metafile: true\"\n}\n\nexport interface BuildFailure extends Error {\n  errors: Message[];\n  warnings: Message[];\n}\n\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  timeInMS: number; // The time to generate the response, not to send it\n}\n\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  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}\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  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\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  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  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// 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\nexport declare function build(options: BuildOptions & { write: false }): Promise<BuildResult & { outputFiles: OutputFile[] }>;\nexport declare function build(options: BuildOptions & { incremental: true }): Promise<BuildIncremental>;\nexport declare function build(options: BuildOptions): Promise<BuildResult>;\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\nexport declare function serve(serveOptions: ServeOptions, buildOptions: BuildOptions): Promise<ServeResult>;\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\nexport declare function transform(input: string, options?: TransformOptions): Promise<TransformResult>;\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\nexport declare function formatMessages(messages: PartialMessage[], options: FormatMessagesOptions): Promise<string[]>;\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\nexport declare function analyzeMetafile(metafile: Metafile | string, options?: AnalyzeMetafileOptions): Promise<string>;\n\n// A synchronous version of \"build\".\n//\n// Works in node: yes\n// Works in browser: no\nexport declare function buildSync(options: BuildOptions & { write: false }): BuildResult & { outputFiles: OutputFile[] };\nexport declare function buildSync(options: BuildOptions): BuildResult;\n\n// A synchronous version of \"transform\".\n//\n// Works in node: yes\n// Works in browser: no\nexport declare function transformSync(input: string, options?: TransformOptions): TransformResult;\n\n// A synchronous version of \"formatMessages\".\n//\n// Works in node: yes\n// Works in browser: no\nexport declare function formatMessagesSync(messages: PartialMessage[], options: FormatMessagesOptions): string[];\n\n// A synchronous version of \"analyzeMetafile\".\n//\n// Works in node: yes\n// Works in browser: no\nexport declare function analyzeMetafileSync(metafile: Metafile | string, options?: AnalyzeMetafileOptions): string;\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)\nexport declare function initialize(options: InitializeOptions): Promise<void>;\n\nexport interface InitializeOptions {\n  // The URL of the \"esbuild.wasm\" file. This must be provided when running\n  // esbuild in the browser.\n  wasmURL?: string;\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  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' | 'default';\nexport type LogLevel = 'verbose' | 'debug' | 'info' | 'warning' | 'error' | 'silent';\nexport type Charset = 'ascii' | 'utf8';\n\ninterface CommonOptions {\n  readonly sourcemap?: boolean | 'inline' | 'external' | 'both';\n  readonly legalComments?: 'none' | 'inline' | 'eof' | 'linked' | 'external';\n  readonly sourceRoot?: string;\n  readonly sourcesContent?: boolean;\n\n  readonly format?: Format;\n  readonly globalName?: string;\n  readonly target?: string | string[];\n\n  readonly minify?: boolean;\n  readonly minifyWhitespace?: boolean;\n  readonly minifyIdentifiers?: boolean;\n  readonly minifySyntax?: boolean;\n  readonly charset?: Charset;\n  readonly treeShaking?: boolean;\n  readonly ignoreAnnotations?: boolean;\n\n  readonly jsx?: 'transform' | 'preserve';\n  readonly jsxFactory?: string;\n  readonly jsxFragment?: string;\n\n  readonly define?: { [key: string]: string };\n  readonly pure?: string[];\n  readonly keepNames?: boolean;\n\n  readonly color?: boolean;\n  readonly logLevel?: LogLevel;\n  readonly logLimit?: number;\n}\n\nexport interface BuildOptions extends CommonOptions {\n  readonly bundle?: boolean;\n  readonly splitting?: boolean;\n  readonly preserveSymlinks?: boolean;\n  readonly outfile?: string;\n  readonly metafile?: boolean;\n  readonly outdir?: string;\n  readonly outbase?: string;\n  readonly platform?: Platform;\n  readonly external?: string[];\n  readonly loader?: { [ext: string]: Loader };\n  readonly resolveExtensions?: string[];\n  readonly mainFields?: string[];\n  readonly conditions?: string[];\n  readonly write?: boolean;\n  readonly allowOverwrite?: boolean;\n  readonly tsconfig?: string;\n  readonly outExtension?: { [ext: string]: string };\n  readonly publicPath?: string;\n  readonly entryNames?: string;\n  readonly chunkNames?: string;\n  readonly assetNames?: string;\n  readonly inject?: string[];\n  readonly banner?: { [type: string]: string };\n  readonly footer?: { [type: string]: string };\n  readonly incremental?: boolean;\n  readonly absWorkingDir?: string;\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  // Optional user-specified data that is passed through unmodified. You can\n  // use this to stash the original error, for example.\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  line: number; // 1-based\n  column: number; // 0-based, in bytes\n  length: number; // in bytes\n  lineText: string;\n  suggestion: string;\n}\n\nexport interface OutputFile {\n  path: string;\n  contents: Uint8Array; // \"text\" as bytes\n  text: string; // \"contents\" as text\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  outputFiles?: OutputFile[]; // Only when \"write: false\"\n  rebuild?: BuildInvalidate; // Only when \"incremental: true\"\n  stop?: () => void; // Only when \"watch: true\"\n  metafile?: Metafile; // Only when \"metafile: true\"\n}\n\nexport interface BuildFailure extends Error {\n  errors: Message[];\n  warnings: Message[];\n}\n\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  timeInMS: number; // The time to generate the response, not to send it\n}\n\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}\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  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\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  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  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// 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\nexport declare function build(options: BuildOptions & { write: false }): Promise<BuildResult & { outputFiles: OutputFile[] }>;\nexport declare function build(options: BuildOptions & { incremental: true }): Promise<BuildIncremental>;\nexport declare function build(options: BuildOptions): Promise<BuildResult>;\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\nexport declare function serve(serveOptions: ServeOptions, buildOptions: BuildOptions): Promise<ServeResult>;\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\nexport declare function transform(input: string, options?: TransformOptions): Promise<TransformResult>;\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\nexport declare function formatMessages(messages: PartialMessage[], options: FormatMessagesOptions): Promise<string[]>;\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\nexport declare function analyzeMetafile(metafile: Metafile | string, options?: AnalyzeMetafileOptions): Promise<string>;\n\n// A synchronous version of \"build\".\n//\n// Works in node: yes\n// Works in browser: no\nexport declare function buildSync(options: BuildOptions & { write: false }): BuildResult & { outputFiles: OutputFile[] };\nexport declare function buildSync(options: BuildOptions): BuildResult;\n\n// A synchronous version of \"transform\".\n//\n// Works in node: yes\n// Works in browser: no\nexport declare function transformSync(input: string, options?: TransformOptions): TransformResult;\n\n// A synchronous version of \"formatMessages\".\n//\n// Works in node: yes\n// Works in browser: no\nexport declare function formatMessagesSync(messages: PartialMessage[], options: FormatMessagesOptions): string[];\n\n// A synchronous version of \"analyzeMetafile\".\n//\n// Works in node: yes\n// Works in browser: no\nexport declare function analyzeMetafileSync(metafile: Metafile | string, options?: AnalyzeMetafileOptions): string;\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)\nexport declare function initialize(options: InitializeOptions): Promise<void>;\n\nexport interface InitializeOptions {\n  // The URL of the \"esbuild.wasm\" file. This must be provided when running\n  // esbuild in the browser.\n  wasmURL?: string;\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  worker?: boolean;\n}\n\nexport let version: string;\n"]}
|
package/lib/index.d.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
export { EsbuildBundling } from './bundling';
|
|
2
|
-
export { EsbuildBundlingProps, LocalBundler, EsbuildOptions } from './bundlers';
|
|
3
|
-
export { JavaScriptAsset, TypeScriptAsset, EsbuildProps, EsbuildAssetProps } from './asset';
|
|
4
|
-
export { JavaScriptCode, TypeScriptCode, CodeConfig, Location } from './code';
|
|
5
|
-
export { InlineJavaScriptCode, InlineJsxCode, InlineTsxCode, InlineTypeScriptCode, } from './inline-code';
|
|
6
|
-
export { JavaScriptSource, TypeScriptSource } from './source';
|
|
7
1
|
export { BuildOptions, TransformOptions } from './esbuild-types';
|
|
2
|
+
export { EsbuildBundler, BundlerProps } from './bundler';
|
|
3
|
+
export { JavaScriptAsset, TypeScriptAsset, AssetBaseProps, AssetProps } from './asset';
|
|
4
|
+
export { JavaScriptCode, JavaScriptCodeProps, TypeScriptCode, TypeScriptCodeProps, CodeConfig, } from './code';
|
|
5
|
+
export { InlineJavaScriptCode, InlineJsxCode, InlineTsxCode, InlineTypeScriptCode, } from './inline-code';
|
|
6
|
+
export { JavaScriptSource, JavaScriptSourceProps, TypeScriptSource, TypeScriptSourceProps, } from './source';
|
package/lib/index.js
CHANGED
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
var
|
|
4
|
-
Object.defineProperty(exports, "
|
|
5
|
-
var bundlers_1 = require("./bundlers");
|
|
6
|
-
Object.defineProperty(exports, "LocalBundler", { enumerable: true, get: function () { return bundlers_1.LocalBundler; } });
|
|
3
|
+
var bundler_1 = require("./bundler");
|
|
4
|
+
Object.defineProperty(exports, "EsbuildBundler", { enumerable: true, get: function () { return bundler_1.EsbuildBundler; } });
|
|
7
5
|
var asset_1 = require("./asset");
|
|
8
6
|
Object.defineProperty(exports, "JavaScriptAsset", { enumerable: true, get: function () { return asset_1.JavaScriptAsset; } });
|
|
9
7
|
Object.defineProperty(exports, "TypeScriptAsset", { enumerable: true, get: function () { return asset_1.TypeScriptAsset; } });
|
|
@@ -18,4 +16,4 @@ Object.defineProperty(exports, "InlineTypeScriptCode", { enumerable: true, get:
|
|
|
18
16
|
var source_1 = require("./source");
|
|
19
17
|
Object.defineProperty(exports, "JavaScriptSource", { enumerable: true, get: function () { return source_1.JavaScriptSource; } });
|
|
20
18
|
Object.defineProperty(exports, "TypeScriptSource", { enumerable: true, get: function () { return source_1.TypeScriptSource; } });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFHQSxxQ0FBeUQ7QUFBaEQseUdBQUEsY0FBYyxPQUFBO0FBRXZCLGlDQUF1RjtBQUE5RSx3R0FBQSxlQUFlLE9BQUE7QUFBRSx3R0FBQSxlQUFlLE9BQUE7QUFFekMsK0JBTWdCO0FBTGQsc0dBQUEsY0FBYyxPQUFBO0FBRWQsc0dBQUEsY0FBYyxPQUFBO0FBS2hCLDZDQUt1QjtBQUpyQixtSEFBQSxvQkFBb0IsT0FBQTtBQUNwQiw0R0FBQSxhQUFhLE9BQUE7QUFDYiw0R0FBQSxhQUFhLE9BQUE7QUFDYixtSEFBQSxvQkFBb0IsT0FBQTtBQUd0QixtQ0FLa0I7QUFKaEIsMEdBQUEsZ0JBQWdCLE9BQUE7QUFFaEIsMEdBQUEsZ0JBQWdCLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJcbmV4cG9ydCB7IEJ1aWxkT3B0aW9ucywgVHJhbnNmb3JtT3B0aW9ucyB9IGZyb20gJy4vZXNidWlsZC10eXBlcyc7XG5cbmV4cG9ydCB7IEVzYnVpbGRCdW5kbGVyLCBCdW5kbGVyUHJvcHMgfSBmcm9tICcuL2J1bmRsZXInO1xuXG5leHBvcnQgeyBKYXZhU2NyaXB0QXNzZXQsIFR5cGVTY3JpcHRBc3NldCwgQXNzZXRCYXNlUHJvcHMsIEFzc2V0UHJvcHMgfSBmcm9tICcuL2Fzc2V0JztcblxuZXhwb3J0IHtcbiAgSmF2YVNjcmlwdENvZGUsXG4gIEphdmFTY3JpcHRDb2RlUHJvcHMsXG4gIFR5cGVTY3JpcHRDb2RlLFxuICBUeXBlU2NyaXB0Q29kZVByb3BzLFxuICBDb2RlQ29uZmlnLFxufSBmcm9tICcuL2NvZGUnO1xuXG5leHBvcnQge1xuICBJbmxpbmVKYXZhU2NyaXB0Q29kZSxcbiAgSW5saW5lSnN4Q29kZSxcbiAgSW5saW5lVHN4Q29kZSxcbiAgSW5saW5lVHlwZVNjcmlwdENvZGUsXG59IGZyb20gJy4vaW5saW5lLWNvZGUnO1xuXG5leHBvcnQge1xuICBKYXZhU2NyaXB0U291cmNlLFxuICBKYXZhU2NyaXB0U291cmNlUHJvcHMsXG4gIFR5cGVTY3JpcHRTb3VyY2UsXG4gIFR5cGVTY3JpcHRTb3VyY2VQcm9wcyxcbn0gZnJvbSAnLi9zb3VyY2UnOyJdfQ==
|
package/lib/inline-code.d.ts
CHANGED
|
@@ -4,39 +4,123 @@ declare abstract class BaseInlineCode extends InlineCode {
|
|
|
4
4
|
constructor(code: string, loader: Loader, transformOptions?: TransformOptions);
|
|
5
5
|
}
|
|
6
6
|
/**
|
|
7
|
+
* (experimental) An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
8
|
+
*
|
|
7
9
|
* @experimental
|
|
8
10
|
*/
|
|
9
11
|
export declare class InlineJavaScriptCode extends BaseInlineCode {
|
|
10
12
|
/**
|
|
13
|
+
* @param code The inline code to be transformed.
|
|
14
|
+
* @param transformOptions Transform options passed on to esbuild.
|
|
11
15
|
* @experimental
|
|
12
16
|
*/
|
|
13
|
-
constructor(
|
|
17
|
+
constructor(
|
|
18
|
+
/**
|
|
19
|
+
* The inline code to be transformed.
|
|
20
|
+
*
|
|
21
|
+
* @stability experimental
|
|
22
|
+
*/
|
|
23
|
+
code: string,
|
|
24
|
+
/**
|
|
25
|
+
* Transform options passed on to esbuild.
|
|
26
|
+
*
|
|
27
|
+
* Please refer to the esbuild Transform API docs for details. \
|
|
28
|
+
* Default values for `transformOptions`:
|
|
29
|
+
* - `loader='js'`
|
|
30
|
+
*
|
|
31
|
+
* @see https://esbuild.github.io/api/#transform-api
|
|
32
|
+
* @stability experimental
|
|
33
|
+
*/
|
|
34
|
+
transformOptions?: TransformOptions);
|
|
14
35
|
}
|
|
15
36
|
/**
|
|
37
|
+
* (experimental) An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
38
|
+
*
|
|
16
39
|
* @experimental
|
|
17
40
|
*/
|
|
18
41
|
export declare class InlineJsxCode extends BaseInlineCode {
|
|
19
42
|
/**
|
|
43
|
+
* @param code The inline code to be transformed.
|
|
44
|
+
* @param transformOptions Transform options passed on to esbuild.
|
|
20
45
|
* @experimental
|
|
21
46
|
*/
|
|
22
|
-
constructor(
|
|
47
|
+
constructor(
|
|
48
|
+
/**
|
|
49
|
+
* The inline code to be transformed.
|
|
50
|
+
*
|
|
51
|
+
* @stability experimental
|
|
52
|
+
*/
|
|
53
|
+
code: string,
|
|
54
|
+
/**
|
|
55
|
+
* Transform options passed on to esbuild.
|
|
56
|
+
*
|
|
57
|
+
* Please refer to the esbuild Transform API docs for details. \
|
|
58
|
+
* Default values for `transformOptions`:
|
|
59
|
+
* - `loader='jsx'`
|
|
60
|
+
*
|
|
61
|
+
* @see https://esbuild.github.io/api/#transform-api
|
|
62
|
+
* @stability experimental
|
|
63
|
+
*/
|
|
64
|
+
transformOptions?: TransformOptions);
|
|
23
65
|
}
|
|
24
66
|
/**
|
|
67
|
+
* (experimental) An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
68
|
+
*
|
|
25
69
|
* @experimental
|
|
26
70
|
*/
|
|
27
71
|
export declare class InlineTypeScriptCode extends BaseInlineCode {
|
|
28
72
|
/**
|
|
73
|
+
* @param code The inline code to be transformed.
|
|
74
|
+
* @param transformOptions Transform options passed on to esbuild.
|
|
29
75
|
* @experimental
|
|
30
76
|
*/
|
|
31
|
-
constructor(
|
|
77
|
+
constructor(
|
|
78
|
+
/**
|
|
79
|
+
* The inline code to be transformed.
|
|
80
|
+
*
|
|
81
|
+
* @stability experimental
|
|
82
|
+
*/
|
|
83
|
+
code: string,
|
|
84
|
+
/**
|
|
85
|
+
* Transform options passed on to esbuild.
|
|
86
|
+
*
|
|
87
|
+
* Please refer to the esbuild Transform API docs for details. \
|
|
88
|
+
* Default values for `transformOptions`:
|
|
89
|
+
* - `loader='ts'`
|
|
90
|
+
*
|
|
91
|
+
* @see https://esbuild.github.io/api/#transform-api
|
|
92
|
+
* @stability experimental
|
|
93
|
+
*/
|
|
94
|
+
transformOptions?: TransformOptions);
|
|
32
95
|
}
|
|
33
96
|
/**
|
|
97
|
+
* (experimental) An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
98
|
+
*
|
|
34
99
|
* @experimental
|
|
35
100
|
*/
|
|
36
101
|
export declare class InlineTsxCode extends BaseInlineCode {
|
|
37
102
|
/**
|
|
103
|
+
* @param code The inline code to be transformed.
|
|
104
|
+
* @param transformOptions Transform options passed on to esbuild.
|
|
38
105
|
* @experimental
|
|
39
106
|
*/
|
|
40
|
-
constructor(
|
|
107
|
+
constructor(
|
|
108
|
+
/**
|
|
109
|
+
* The inline code to be transformed.
|
|
110
|
+
*
|
|
111
|
+
* @stability experimental
|
|
112
|
+
*/
|
|
113
|
+
code: string,
|
|
114
|
+
/**
|
|
115
|
+
* Transform options passed on to esbuild.
|
|
116
|
+
*
|
|
117
|
+
* Please refer to the esbuild Transform API docs for details. \
|
|
118
|
+
* Default values for `transformOptions`:
|
|
119
|
+
* - `loader='tsx'`
|
|
120
|
+
*
|
|
121
|
+
* @see https://esbuild.github.io/api/#transform-api
|
|
122
|
+
* @stability experimental
|
|
123
|
+
*/
|
|
124
|
+
transformOptions?: TransformOptions);
|
|
41
125
|
}
|
|
42
126
|
export {};
|
package/lib/inline-code.js
CHANGED
|
@@ -23,59 +23,143 @@ class BaseInlineCode extends aws_lambda_1.InlineCode {
|
|
|
23
23
|
}
|
|
24
24
|
}
|
|
25
25
|
/**
|
|
26
|
+
* (experimental) An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
27
|
+
*
|
|
26
28
|
* @experimental
|
|
27
29
|
*/
|
|
28
30
|
class InlineJavaScriptCode extends BaseInlineCode {
|
|
29
31
|
/**
|
|
32
|
+
* @param code The inline code to be transformed.
|
|
33
|
+
* @param transformOptions Transform options passed on to esbuild.
|
|
30
34
|
* @experimental
|
|
31
35
|
*/
|
|
32
|
-
constructor(
|
|
36
|
+
constructor(
|
|
37
|
+
/**
|
|
38
|
+
* The inline code to be transformed.
|
|
39
|
+
*
|
|
40
|
+
* @stability experimental
|
|
41
|
+
*/
|
|
42
|
+
code,
|
|
43
|
+
/**
|
|
44
|
+
* Transform options passed on to esbuild.
|
|
45
|
+
*
|
|
46
|
+
* Please refer to the esbuild Transform API docs for details. \
|
|
47
|
+
* Default values for `transformOptions`:
|
|
48
|
+
* - `loader='js'`
|
|
49
|
+
*
|
|
50
|
+
* @see https://esbuild.github.io/api/#transform-api
|
|
51
|
+
* @stability experimental
|
|
52
|
+
*/
|
|
53
|
+
transformOptions) {
|
|
33
54
|
super(code, 'js', transformOptions);
|
|
34
55
|
}
|
|
35
56
|
}
|
|
36
57
|
exports.InlineJavaScriptCode = InlineJavaScriptCode;
|
|
37
58
|
_a = JSII_RTTI_SYMBOL_1;
|
|
38
|
-
InlineJavaScriptCode[_a] = { fqn: "@mrgrain/cdk-esbuild.InlineJavaScriptCode", version: "2.0.0-alpha.
|
|
59
|
+
InlineJavaScriptCode[_a] = { fqn: "@mrgrain/cdk-esbuild.InlineJavaScriptCode", version: "2.0.0-alpha.5" };
|
|
39
60
|
/**
|
|
61
|
+
* (experimental) An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
62
|
+
*
|
|
40
63
|
* @experimental
|
|
41
64
|
*/
|
|
42
65
|
class InlineJsxCode extends BaseInlineCode {
|
|
43
66
|
/**
|
|
67
|
+
* @param code The inline code to be transformed.
|
|
68
|
+
* @param transformOptions Transform options passed on to esbuild.
|
|
44
69
|
* @experimental
|
|
45
70
|
*/
|
|
46
|
-
constructor(
|
|
71
|
+
constructor(
|
|
72
|
+
/**
|
|
73
|
+
* The inline code to be transformed.
|
|
74
|
+
*
|
|
75
|
+
* @stability experimental
|
|
76
|
+
*/
|
|
77
|
+
code,
|
|
78
|
+
/**
|
|
79
|
+
* Transform options passed on to esbuild.
|
|
80
|
+
*
|
|
81
|
+
* Please refer to the esbuild Transform API docs for details. \
|
|
82
|
+
* Default values for `transformOptions`:
|
|
83
|
+
* - `loader='jsx'`
|
|
84
|
+
*
|
|
85
|
+
* @see https://esbuild.github.io/api/#transform-api
|
|
86
|
+
* @stability experimental
|
|
87
|
+
*/
|
|
88
|
+
transformOptions) {
|
|
47
89
|
super(code, 'jsx', transformOptions);
|
|
48
90
|
}
|
|
49
91
|
}
|
|
50
92
|
exports.InlineJsxCode = InlineJsxCode;
|
|
51
93
|
_b = JSII_RTTI_SYMBOL_1;
|
|
52
|
-
InlineJsxCode[_b] = { fqn: "@mrgrain/cdk-esbuild.InlineJsxCode", version: "2.0.0-alpha.
|
|
94
|
+
InlineJsxCode[_b] = { fqn: "@mrgrain/cdk-esbuild.InlineJsxCode", version: "2.0.0-alpha.5" };
|
|
53
95
|
/**
|
|
96
|
+
* (experimental) An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
97
|
+
*
|
|
54
98
|
* @experimental
|
|
55
99
|
*/
|
|
56
100
|
class InlineTypeScriptCode extends BaseInlineCode {
|
|
57
101
|
/**
|
|
102
|
+
* @param code The inline code to be transformed.
|
|
103
|
+
* @param transformOptions Transform options passed on to esbuild.
|
|
58
104
|
* @experimental
|
|
59
105
|
*/
|
|
60
|
-
constructor(
|
|
106
|
+
constructor(
|
|
107
|
+
/**
|
|
108
|
+
* The inline code to be transformed.
|
|
109
|
+
*
|
|
110
|
+
* @stability experimental
|
|
111
|
+
*/
|
|
112
|
+
code,
|
|
113
|
+
/**
|
|
114
|
+
* Transform options passed on to esbuild.
|
|
115
|
+
*
|
|
116
|
+
* Please refer to the esbuild Transform API docs for details. \
|
|
117
|
+
* Default values for `transformOptions`:
|
|
118
|
+
* - `loader='ts'`
|
|
119
|
+
*
|
|
120
|
+
* @see https://esbuild.github.io/api/#transform-api
|
|
121
|
+
* @stability experimental
|
|
122
|
+
*/
|
|
123
|
+
transformOptions) {
|
|
61
124
|
super(code, 'ts', transformOptions);
|
|
62
125
|
}
|
|
63
126
|
}
|
|
64
127
|
exports.InlineTypeScriptCode = InlineTypeScriptCode;
|
|
65
128
|
_c = JSII_RTTI_SYMBOL_1;
|
|
66
|
-
InlineTypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.InlineTypeScriptCode", version: "2.0.0-alpha.
|
|
129
|
+
InlineTypeScriptCode[_c] = { fqn: "@mrgrain/cdk-esbuild.InlineTypeScriptCode", version: "2.0.0-alpha.5" };
|
|
67
130
|
/**
|
|
131
|
+
* (experimental) An implementation of `lambda.InlineCode` using the esbuild Transform API. Inline function code is limited to 4 KiB after transformation.
|
|
132
|
+
*
|
|
68
133
|
* @experimental
|
|
69
134
|
*/
|
|
70
135
|
class InlineTsxCode extends BaseInlineCode {
|
|
71
136
|
/**
|
|
137
|
+
* @param code The inline code to be transformed.
|
|
138
|
+
* @param transformOptions Transform options passed on to esbuild.
|
|
72
139
|
* @experimental
|
|
73
140
|
*/
|
|
74
|
-
constructor(
|
|
141
|
+
constructor(
|
|
142
|
+
/**
|
|
143
|
+
* The inline code to be transformed.
|
|
144
|
+
*
|
|
145
|
+
* @stability experimental
|
|
146
|
+
*/
|
|
147
|
+
code,
|
|
148
|
+
/**
|
|
149
|
+
* Transform options passed on to esbuild.
|
|
150
|
+
*
|
|
151
|
+
* Please refer to the esbuild Transform API docs for details. \
|
|
152
|
+
* Default values for `transformOptions`:
|
|
153
|
+
* - `loader='tsx'`
|
|
154
|
+
*
|
|
155
|
+
* @see https://esbuild.github.io/api/#transform-api
|
|
156
|
+
* @stability experimental
|
|
157
|
+
*/
|
|
158
|
+
transformOptions) {
|
|
75
159
|
super(code, 'tsx', transformOptions);
|
|
76
160
|
}
|
|
77
161
|
}
|
|
78
162
|
exports.InlineTsxCode = InlineTsxCode;
|
|
79
163
|
_d = JSII_RTTI_SYMBOL_1;
|
|
80
|
-
InlineTsxCode[_d] = { fqn: "@mrgrain/cdk-esbuild.InlineTsxCode", version: "2.0.0-alpha.
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
164
|
+
InlineTsxCode[_d] = { fqn: "@mrgrain/cdk-esbuild.InlineTsxCode", version: "2.0.0-alpha.5" };
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5saW5lLWNvZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5saW5lLWNvZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxvREFBaUQ7QUFFakQsdURBQWtEO0FBQ2xELHFEQUFzRDtBQUV0RCxNQUFlLGNBQWUsU0FBUSx1QkFBVTtJQUM5QyxZQUNFLElBQVksRUFDWixNQUFjLEVBQ2QsbUJBQXFDLEVBQUU7UUFFdkMsSUFBSTtZQUNGLE1BQU0sZUFBZSxHQUFHLCtCQUFhLENBQUMsSUFBSSxFQUFFO2dCQUMxQyxNQUFNO2dCQUNOLEdBQUcsZ0JBQWdCO2FBQ3BCLENBQUMsQ0FBQztZQUNILG1DQUFrQixDQUFDLGVBQWUsRUFBRSxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFDO1lBRTlELEtBQUssQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDN0I7UUFBQyxPQUFPLEtBQUssRUFBRTtZQUNkLG1DQUFrQixDQUFDLEtBQXFCLEVBQUUsRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLENBQUMsQ0FBQztZQUVwRSxNQUFNLElBQUksS0FBSyxDQUFDLGdDQUFnQyxDQUFDLENBQUM7U0FDbkQ7SUFDSCxDQUFDO0NBQ0Y7Ozs7OztBQUdELE1BQWEsb0JBQXFCLFNBQVEsY0FBYzs7Ozs7O0lBQ3REO0lBQ0U7Ozs7T0FJRztJQUNILElBQVk7SUFDWjs7Ozs7Ozs7O09BU0c7SUFDSCxnQkFBbUM7UUFFbkMsS0FBSyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztJQUN0QyxDQUFDOztBQXJCSCxvREFzQkM7Ozs7Ozs7O0FBR0QsTUFBYSxhQUFjLFNBQVEsY0FBYzs7Ozs7O0lBQy9DO0lBQ0U7Ozs7T0FJRztJQUNILElBQVk7SUFDWjs7Ozs7Ozs7O09BU0c7SUFDSCxnQkFBbUM7UUFFbkMsS0FBSyxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztJQUN2QyxDQUFDOztBQXJCSCxzQ0FzQkM7Ozs7Ozs7O0FBR0QsTUFBYSxvQkFBcUIsU0FBUSxjQUFjOzs7Ozs7SUFDdEQ7SUFDRTs7OztPQUlHO0lBQ0gsSUFBWTtJQUNaOzs7Ozs7Ozs7T0FTRztJQUNILGdCQUFtQztRQUVuQyxLQUFLLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7O0FBckJILG9EQXNCQzs7Ozs7Ozs7QUFHRCxNQUFhLGFBQWMsU0FBUSxjQUFjOzs7Ozs7SUFDL0M7SUFDRTs7OztPQUlHO0lBQ0gsSUFBWTtJQUNaOzs7Ozs7Ozs7T0FTRztJQUNILGdCQUFtQztRQUVuQyxLQUFLLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7O0FBckJILHNDQXNCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElubGluZUNvZGUgfSBmcm9tICdAYXdzLWNkay9hd3MtbGFtYmRhJztcbmltcG9ydCB7IFRyYW5zZm9ybU9wdGlvbnMsIExvYWRlciwgQnVpbGRGYWlsdXJlIH0gZnJvbSAnLi9lc2J1aWxkLXR5cGVzJztcbmltcG9ydCB7IHRyYW5zZm9ybVN5bmMgfSBmcm9tICcuL2VzYnVpbGQtd3JhcHBlcic7XG5pbXBvcnQgeyBwcmludEJ1aWxkTWVzc2FnZXMgfSBmcm9tICcuL2Zvcm1hdE1lc3NhZ2VzJztcblxuYWJzdHJhY3QgY2xhc3MgQmFzZUlubGluZUNvZGUgZXh0ZW5kcyBJbmxpbmVDb2RlIHtcbiAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgIGNvZGU6IHN0cmluZyxcbiAgICBsb2FkZXI6IExvYWRlcixcbiAgICB0cmFuc2Zvcm1PcHRpb25zOiBUcmFuc2Zvcm1PcHRpb25zID0ge30sXG4gICkge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCB0cmFuc2Zvcm1lZENvZGUgPSB0cmFuc2Zvcm1TeW5jKGNvZGUsIHtcbiAgICAgICAgbG9hZGVyLFxuICAgICAgICAuLi50cmFuc2Zvcm1PcHRpb25zLFxuICAgICAgfSk7XG4gICAgICBwcmludEJ1aWxkTWVzc2FnZXModHJhbnNmb3JtZWRDb2RlLCB7IHByZWZpeDogJ1RyYW5zZm9ybSAnIH0pO1xuXG4gICAgICBzdXBlcih0cmFuc2Zvcm1lZENvZGUuY29kZSk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIHByaW50QnVpbGRNZXNzYWdlcyhlcnJvciBhcyBCdWlsZEZhaWx1cmUsIHsgcHJlZml4OiAnVHJhbnNmb3JtICcgfSk7XG5cbiAgICAgIHRocm93IG5ldyBFcnJvcignRmFpbGVkIHRvIHRyYW5zZm9ybSBJbmxpbmVDb2RlJyk7XG4gICAgfVxuICB9XG59XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFxuZXhwb3J0IGNsYXNzIElubGluZUphdmFTY3JpcHRDb2RlIGV4dGVuZHMgQmFzZUlubGluZUNvZGUge1xuICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgLyoqXG4gICAgICogVGhlIGlubGluZSBjb2RlIHRvIGJlIHRyYW5zZm9ybWVkLlxuICAgICAqXG4gICAgICogQHN0YWJpbGl0eSBleHBlcmltZW50YWxcbiAgICAgKi9cbiAgICBjb2RlOiBzdHJpbmcsXG4gICAgLyoqXG4gICAgICogVHJhbnNmb3JtIG9wdGlvbnMgcGFzc2VkIG9uIHRvIGVzYnVpbGQuXG4gICAgICpcbiAgICAgKiBQbGVhc2UgcmVmZXIgdG8gdGhlIGVzYnVpbGQgVHJhbnNmb3JtIEFQSSBkb2NzIGZvciBkZXRhaWxzLiBcXFxuICAgICAqIERlZmF1bHQgdmFsdWVzIGZvciBgdHJhbnNmb3JtT3B0aW9uc2A6XG4gICAgICogLSBgbG9hZGVyPSdqcydgXG4gICAgICpcbiAgICAgKiBAc2VlIGh0dHBzOi8vZXNidWlsZC5naXRodWIuaW8vYXBpLyN0cmFuc2Zvcm0tYXBpXG4gICAgICogQHN0YWJpbGl0eSBleHBlcmltZW50YWxcbiAgICAgKi9cbiAgICB0cmFuc2Zvcm1PcHRpb25zPzogVHJhbnNmb3JtT3B0aW9ucyxcbiAgKSB7XG4gICAgc3VwZXIoY29kZSwgJ2pzJywgdHJhbnNmb3JtT3B0aW9ucyk7XG4gIH1cbn1cblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgY2xhc3MgSW5saW5lSnN4Q29kZSBleHRlbmRzIEJhc2VJbmxpbmVDb2RlIHtcbiAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgIC8qKlxuICAgICAqIFRoZSBpbmxpbmUgY29kZSB0byBiZSB0cmFuc2Zvcm1lZC5cbiAgICAgKlxuICAgICAqIEBzdGFiaWxpdHkgZXhwZXJpbWVudGFsXG4gICAgICovXG4gICAgY29kZTogc3RyaW5nLFxuICAgIC8qKlxuICAgICAqIFRyYW5zZm9ybSBvcHRpb25zIHBhc3NlZCBvbiB0byBlc2J1aWxkLlxuICAgICAqXG4gICAgICogUGxlYXNlIHJlZmVyIHRvIHRoZSBlc2J1aWxkIFRyYW5zZm9ybSBBUEkgZG9jcyBmb3IgZGV0YWlscy4gXFxcbiAgICAgKiBEZWZhdWx0IHZhbHVlcyBmb3IgYHRyYW5zZm9ybU9wdGlvbnNgOlxuICAgICAqIC0gYGxvYWRlcj0nanN4J2BcbiAgICAgKlxuICAgICAqIEBzZWUgaHR0cHM6Ly9lc2J1aWxkLmdpdGh1Yi5pby9hcGkvI3RyYW5zZm9ybS1hcGlcbiAgICAgKiBAc3RhYmlsaXR5IGV4cGVyaW1lbnRhbFxuICAgICAqL1xuICAgIHRyYW5zZm9ybU9wdGlvbnM/OiBUcmFuc2Zvcm1PcHRpb25zLFxuICApIHtcbiAgICBzdXBlcihjb2RlLCAnanN4JywgdHJhbnNmb3JtT3B0aW9ucyk7XG4gIH1cbn1cblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXG5leHBvcnQgY2xhc3MgSW5saW5lVHlwZVNjcmlwdENvZGUgZXh0ZW5kcyBCYXNlSW5saW5lQ29kZSB7XG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICAvKipcbiAgICAgKiBUaGUgaW5saW5lIGNvZGUgdG8gYmUgdHJhbnNmb3JtZWQuXG4gICAgICpcbiAgICAgKiBAc3RhYmlsaXR5IGV4cGVyaW1lbnRhbFxuICAgICAqL1xuICAgIGNvZGU6IHN0cmluZyxcbiAgICAvKipcbiAgICAgKiBUcmFuc2Zvcm0gb3B0aW9ucyBwYXNzZWQgb24gdG8gZXNidWlsZC5cbiAgICAgKlxuICAgICAqIFBsZWFzZSByZWZlciB0byB0aGUgZXNidWlsZCBUcmFuc2Zvcm0gQVBJIGRvY3MgZm9yIGRldGFpbHMuIFxcXG4gICAgICogRGVmYXVsdCB2YWx1ZXMgZm9yIGB0cmFuc2Zvcm1PcHRpb25zYDpcbiAgICAgKiAtIGBsb2FkZXI9J3RzJ2BcbiAgICAgKlxuICAgICAqIEBzZWUgaHR0cHM6Ly9lc2J1aWxkLmdpdGh1Yi5pby9hcGkvI3RyYW5zZm9ybS1hcGlcbiAgICAgKiBAc3RhYmlsaXR5IGV4cGVyaW1lbnRhbFxuICAgICAqL1xuICAgIHRyYW5zZm9ybU9wdGlvbnM/OiBUcmFuc2Zvcm1PcHRpb25zLFxuICApIHtcbiAgICBzdXBlcihjb2RlLCAndHMnLCB0cmFuc2Zvcm1PcHRpb25zKTtcbiAgfVxufVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcbmV4cG9ydCBjbGFzcyBJbmxpbmVUc3hDb2RlIGV4dGVuZHMgQmFzZUlubGluZUNvZGUge1xuICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgLyoqXG4gICAgICogVGhlIGlubGluZSBjb2RlIHRvIGJlIHRyYW5zZm9ybWVkLlxuICAgICAqXG4gICAgICogQHN0YWJpbGl0eSBleHBlcmltZW50YWxcbiAgICAgKi9cbiAgICBjb2RlOiBzdHJpbmcsXG4gICAgLyoqXG4gICAgICogVHJhbnNmb3JtIG9wdGlvbnMgcGFzc2VkIG9uIHRvIGVzYnVpbGQuXG4gICAgICpcbiAgICAgKiBQbGVhc2UgcmVmZXIgdG8gdGhlIGVzYnVpbGQgVHJhbnNmb3JtIEFQSSBkb2NzIGZvciBkZXRhaWxzLiBcXFxuICAgICAqIERlZmF1bHQgdmFsdWVzIGZvciBgdHJhbnNmb3JtT3B0aW9uc2A6XG4gICAgICogLSBgbG9hZGVyPSd0c3gnYFxuICAgICAqXG4gICAgICogQHNlZSBodHRwczovL2VzYnVpbGQuZ2l0aHViLmlvL2FwaS8jdHJhbnNmb3JtLWFwaVxuICAgICAqIEBzdGFiaWxpdHkgZXhwZXJpbWVudGFsXG4gICAgICovXG4gICAgdHJhbnNmb3JtT3B0aW9ucz86IFRyYW5zZm9ybU9wdGlvbnMsXG4gICkge1xuICAgIHN1cGVyKGNvZGUsICd0c3gnLCB0cmFuc2Zvcm1PcHRpb25zKTtcbiAgfVxufVxuIl19
|
package/lib/source.d.ts
CHANGED
|
@@ -1,14 +1,23 @@
|
|
|
1
1
|
import { DeploymentSourceContext, ISource, SourceConfig } from '@aws-cdk/aws-s3-deployment';
|
|
2
2
|
import { Construct } from '@aws-cdk/core';
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
3
|
+
import { AssetBaseProps, AssetProps, JavaScriptAsset, TypeScriptAsset } from './asset';
|
|
4
|
+
import { EntryPoints } from './bundler';
|
|
5
|
+
/**
|
|
6
|
+
* @stability stable
|
|
7
|
+
*/
|
|
8
|
+
export interface JavaScriptSourceProps extends AssetBaseProps {
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* @stability stable
|
|
12
|
+
*/
|
|
13
|
+
export interface TypeScriptSourceProps extends AssetBaseProps {
|
|
14
|
+
}
|
|
15
|
+
declare abstract class Source<Props extends JavaScriptSourceProps | TypeScriptSourceProps, Asset extends JavaScriptAsset | TypeScriptAsset> implements ISource {
|
|
16
|
+
protected readonly abstract assetClass: new (scope: Construct, id: string, props: AssetProps) => Asset;
|
|
8
17
|
/**
|
|
9
18
|
* @stability stable
|
|
10
19
|
*/
|
|
11
|
-
protected props:
|
|
20
|
+
protected props: AssetProps;
|
|
12
21
|
/**
|
|
13
22
|
* @stability stable
|
|
14
23
|
*/
|
|
@@ -18,7 +27,7 @@ declare abstract class Source<Props extends EsbuildProps, Asset extends JavaScri
|
|
|
18
27
|
* @param entryPoints - Relative path to the source code. Use `props.buildOptions.absWorkingDir` if an absolute path is required.
|
|
19
28
|
* @param props - Source properties.
|
|
20
29
|
*/
|
|
21
|
-
constructor(entryPoints:
|
|
30
|
+
constructor(entryPoints: EntryPoints, props: Props);
|
|
22
31
|
/**
|
|
23
32
|
* Binds the source to a bucket deployment.
|
|
24
33
|
*
|
|
@@ -37,7 +46,7 @@ export declare class JavaScriptSource extends Source<JavaScriptSourceProps, Java
|
|
|
37
46
|
/**
|
|
38
47
|
* @stability stable
|
|
39
48
|
*/
|
|
40
|
-
constructor(entryPoints:
|
|
49
|
+
constructor(entryPoints: EntryPoints, props?: JavaScriptSourceProps);
|
|
41
50
|
}
|
|
42
51
|
/**
|
|
43
52
|
* @stability stable
|
|
@@ -50,6 +59,6 @@ export declare class TypeScriptSource extends Source<TypeScriptSourceProps, Type
|
|
|
50
59
|
/**
|
|
51
60
|
* @stability stable
|
|
52
61
|
*/
|
|
53
|
-
constructor(entryPoints:
|
|
62
|
+
constructor(entryPoints: EntryPoints, props?: TypeScriptSourceProps);
|
|
54
63
|
}
|
|
55
64
|
export {};
|