@rushstack/heft-webpack5-plugin 0.9.10 → 0.9.11
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/LICENSE +24 -24
- package/README.md +12 -12
- package/dist/tsdoc-metadata.json +1 -1
- package/heft-plugin.json +20 -20
- package/lib/DeferredWatchFileSystem.js.map +1 -1
- package/lib/Webpack5Plugin.js.map +1 -1
- package/lib/WebpackConfigurationLoader.js.map +1 -1
- package/lib/WebpackConfigurationLoader.test.js.map +1 -1
- package/lib/index.js.map +1 -1
- package/lib/schemas/heft-webpack5-plugin.schema.json +25 -25
- package/lib/shared.js.map +1 -1
- package/package.json +4 -4
package/LICENSE
CHANGED
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
@rushstack/heft-webpack5-plugin
|
|
2
|
-
|
|
3
|
-
Copyright (c) Microsoft Corporation. All rights reserved.
|
|
4
|
-
|
|
5
|
-
MIT License
|
|
6
|
-
|
|
7
|
-
Permission is hereby granted, free of charge, to any person obtaining
|
|
8
|
-
a copy of this software and associated documentation files (the
|
|
9
|
-
"Software"), to deal in the Software without restriction, including
|
|
10
|
-
without limitation the rights to use, copy, modify, merge, publish,
|
|
11
|
-
distribute, sublicense, and/or sell copies of the Software, and to
|
|
12
|
-
permit persons to whom the Software is furnished to do so, subject to
|
|
13
|
-
the following conditions:
|
|
14
|
-
|
|
15
|
-
The above copyright notice and this permission notice shall be
|
|
16
|
-
included in all copies or substantial portions of the Software.
|
|
17
|
-
|
|
18
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
19
|
-
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
20
|
-
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
21
|
-
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
22
|
-
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
23
|
-
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
24
|
-
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
1
|
+
@rushstack/heft-webpack5-plugin
|
|
2
|
+
|
|
3
|
+
Copyright (c) Microsoft Corporation. All rights reserved.
|
|
4
|
+
|
|
5
|
+
MIT License
|
|
6
|
+
|
|
7
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
|
8
|
+
a copy of this software and associated documentation files (the
|
|
9
|
+
"Software"), to deal in the Software without restriction, including
|
|
10
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
|
11
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
|
12
|
+
permit persons to whom the Software is furnished to do so, subject to
|
|
13
|
+
the following conditions:
|
|
14
|
+
|
|
15
|
+
The above copyright notice and this permission notice shall be
|
|
16
|
+
included in all copies or substantial portions of the Software.
|
|
17
|
+
|
|
18
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
19
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
20
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
21
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
22
|
+
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
23
|
+
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
24
|
+
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
package/README.md
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
# @rushstack/heft-webpack5-plugin
|
|
2
|
-
|
|
3
|
-
This is a Heft plugin for using Webpack 5.
|
|
4
|
-
|
|
5
|
-
## Links
|
|
6
|
-
|
|
7
|
-
- [CHANGELOG.md](
|
|
8
|
-
https://github.com/microsoft/rushstack/blob/main/heft-plugins/heft-webpack5-plugin/CHANGELOG.md) - Find
|
|
9
|
-
out what's new in the latest version
|
|
10
|
-
- [@rushstack/heft](https://www.npmjs.com/package/@rushstack/heft) - Heft is a config-driven toolchain that invokes popular tools such as TypeScript, ESLint, Jest, Webpack, and API Extractor.
|
|
11
|
-
|
|
12
|
-
Heft is part of the [Rush Stack](https://rushstack.io/) family of projects.
|
|
1
|
+
# @rushstack/heft-webpack5-plugin
|
|
2
|
+
|
|
3
|
+
This is a Heft plugin for using Webpack 5.
|
|
4
|
+
|
|
5
|
+
## Links
|
|
6
|
+
|
|
7
|
+
- [CHANGELOG.md](
|
|
8
|
+
https://github.com/microsoft/rushstack/blob/main/heft-plugins/heft-webpack5-plugin/CHANGELOG.md) - Find
|
|
9
|
+
out what's new in the latest version
|
|
10
|
+
- [@rushstack/heft](https://www.npmjs.com/package/@rushstack/heft) - Heft is a config-driven toolchain that invokes popular tools such as TypeScript, ESLint, Jest, Webpack, and API Extractor.
|
|
11
|
+
|
|
12
|
+
Heft is part of the [Rush Stack](https://rushstack.io/) family of projects.
|
package/dist/tsdoc-metadata.json
CHANGED
package/heft-plugin.json
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "https://developer.microsoft.com/json-schemas/heft/v0/heft-plugin.schema.json",
|
|
3
|
-
|
|
4
|
-
"taskPlugins": [
|
|
5
|
-
{
|
|
6
|
-
"pluginName": "webpack5-plugin",
|
|
7
|
-
"entryPoint": "./lib/Webpack5Plugin",
|
|
8
|
-
"optionsSchema": "./lib/schemas/heft-webpack5-plugin.schema.json",
|
|
9
|
-
|
|
10
|
-
"parameterScope": "webpack5",
|
|
11
|
-
"parameters": [
|
|
12
|
-
{
|
|
13
|
-
"longName": "--serve",
|
|
14
|
-
"parameterKind": "flag",
|
|
15
|
-
"description": "Start a local web server for testing purposes using webpack-dev-server. This parameter is only available when running in watch mode."
|
|
16
|
-
}
|
|
17
|
-
]
|
|
18
|
-
}
|
|
19
|
-
]
|
|
20
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://developer.microsoft.com/json-schemas/heft/v0/heft-plugin.schema.json",
|
|
3
|
+
|
|
4
|
+
"taskPlugins": [
|
|
5
|
+
{
|
|
6
|
+
"pluginName": "webpack5-plugin",
|
|
7
|
+
"entryPoint": "./lib/Webpack5Plugin",
|
|
8
|
+
"optionsSchema": "./lib/schemas/heft-webpack5-plugin.schema.json",
|
|
9
|
+
|
|
10
|
+
"parameterScope": "webpack5",
|
|
11
|
+
"parameters": [
|
|
12
|
+
{
|
|
13
|
+
"longName": "--serve",
|
|
14
|
+
"parameterKind": "flag",
|
|
15
|
+
"description": "Start a local web server for testing purposes using webpack-dev-server. This parameter is only available when running in watch mode."
|
|
16
|
+
}
|
|
17
|
+
]
|
|
18
|
+
}
|
|
19
|
+
]
|
|
20
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DeferredWatchFileSystem.js","sourceRoot":"","sources":["../src/DeferredWatchFileSystem.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\r\n// See LICENSE in the project root for license information.\r\n\r\nimport Watchpack, { type WatchOptions } from 'watchpack';\r\nimport type { Compiler, WebpackPluginInstance } from 'webpack';\r\n\r\nexport type InputFileSystem = Compiler['inputFileSystem'];\r\nexport type WatchFileSystem = Compiler['watchFileSystem'];\r\nexport type WatchCallback = Parameters<WatchFileSystem['watch']>[5];\r\nexport type WatchUndelayedCallback = Parameters<WatchFileSystem['watch']>[6];\r\nexport type Watcher = ReturnType<WatchFileSystem['watch']>;\r\nexport type WatcherInfo = ReturnType<Required<Watcher>['getInfo']>;\r\ntype FileSystemMap = ReturnType<Watcher['getFileTimeInfoEntries']>;\r\n\r\ninterface IWatchState {\r\n changes: Set<string>;\r\n removals: Set<string>;\r\n\r\n callback: WatchCallback;\r\n}\r\n\r\ninterface ITimeEntry {\r\n timestamp: number;\r\n safeTime: number;\r\n}\r\n\r\ntype IRawFileSystemMap = Map<string, ITimeEntry>;\r\n\r\ninterface ITimeInfoEntries {\r\n fileTimeInfoEntries: FileSystemMap;\r\n contextTimeInfoEntries: FileSystemMap;\r\n}\r\n\r\nexport class DeferredWatchFileSystem implements WatchFileSystem {\r\n public readonly inputFileSystem: InputFileSystem;\r\n public readonly watcherOptions: WatchOptions;\r\n public watcher: Watchpack | undefined;\r\n\r\n private readonly _onChange: () => void;\r\n private _state: IWatchState | undefined;\r\n\r\n public constructor(inputFileSystem: InputFileSystem, onChange: () => void) {\r\n this.inputFileSystem = inputFileSystem;\r\n this.watcherOptions = {\r\n aggregateTimeout: 0\r\n };\r\n this.watcher = new Watchpack(this.watcherOptions);\r\n this._onChange = onChange;\r\n }\r\n\r\n public flush(): boolean {\r\n const state: IWatchState | undefined = this._state;\r\n\r\n if (!state) {\r\n return false;\r\n }\r\n\r\n const { changes, removals, callback } = state;\r\n\r\n // Force flush the aggregation callback\r\n const { changes: newChanges, removals: newRemovals } = this.watcher!.getAggregated();\r\n\r\n // Webpack 5 treats changes and removals as separate things\r\n if (newRemovals) {\r\n for (const removal of newRemovals) {\r\n changes.delete(removal);\r\n removals.add(removal);\r\n }\r\n }\r\n if (newChanges) {\r\n for (const change of newChanges) {\r\n removals.delete(change);\r\n changes.add(change);\r\n }\r\n }\r\n\r\n if (changes.size > 0 || removals.size > 0) {\r\n this._purge(removals, changes);\r\n\r\n const { fileTimeInfoEntries, contextTimeInfoEntries } = this._fetchTimeInfo();\r\n\r\n callback(undefined, fileTimeInfoEntries, contextTimeInfoEntries, changes, removals);\r\n\r\n changes.clear();\r\n removals.clear();\r\n\r\n return true;\r\n }\r\n\r\n return false;\r\n }\r\n\r\n public watch(\r\n files: Iterable<string>,\r\n directories: Iterable<string>,\r\n missing: Iterable<string>,\r\n startTime: number,\r\n options: WatchOptions,\r\n callback: WatchCallback,\r\n callbackUndelayed: WatchUndelayedCallback\r\n ): Watcher {\r\n const oldWatcher: Watchpack | undefined = this.watcher;\r\n this.watcher = new Watchpack(options);\r\n\r\n const changes: Set<string> = new Set();\r\n const removals: Set<string> = new Set();\r\n\r\n this._state = {\r\n changes,\r\n removals,\r\n\r\n callback\r\n };\r\n\r\n this.watcher.on('aggregated', (newChanges: Set<string>, newRemovals: Set<string>) => {\r\n for (const change of newChanges) {\r\n removals.delete(change);\r\n changes.add(change);\r\n }\r\n for (const removal of newRemovals) {\r\n changes.delete(removal);\r\n removals.add(removal);\r\n }\r\n\r\n this._onChange();\r\n });\r\n\r\n this.watcher.watch({\r\n files,\r\n directories,\r\n missing,\r\n startTime\r\n });\r\n\r\n if (oldWatcher) {\r\n oldWatcher.close();\r\n }\r\n\r\n return {\r\n close: () => {\r\n if (this.watcher) {\r\n this.watcher.close();\r\n this.watcher = undefined;\r\n }\r\n },\r\n pause: () => {\r\n if (this.watcher) {\r\n this.watcher.pause();\r\n }\r\n },\r\n getInfo: () => {\r\n const newRemovals: Set<string> | undefined = this.watcher?.aggregatedRemovals;\r\n const newChanges: Set<string> | undefined = this.watcher?.aggregatedChanges;\r\n this._purge(newRemovals, newChanges);\r\n const { fileTimeInfoEntries, contextTimeInfoEntries } = this._fetchTimeInfo();\r\n return {\r\n changes: newChanges!,\r\n removals: newRemovals!,\r\n fileTimeInfoEntries,\r\n contextTimeInfoEntries\r\n };\r\n },\r\n getContextTimeInfoEntries: () => {\r\n const { contextTimeInfoEntries } = this._fetchTimeInfo();\r\n return contextTimeInfoEntries;\r\n },\r\n getFileTimeInfoEntries: () => {\r\n const { fileTimeInfoEntries } = this._fetchTimeInfo();\r\n return fileTimeInfoEntries;\r\n }\r\n };\r\n }\r\n\r\n private _fetchTimeInfo(): ITimeInfoEntries {\r\n const fileTimeInfoEntries: IRawFileSystemMap = new Map();\r\n const contextTimeInfoEntries: IRawFileSystemMap = new Map();\r\n this.watcher?.collectTimeInfoEntries(fileTimeInfoEntries, contextTimeInfoEntries);\r\n return { fileTimeInfoEntries, contextTimeInfoEntries };\r\n }\r\n\r\n private _purge(removals: Set<string> | undefined, changes: Set<string> | undefined): void {\r\n const fs: InputFileSystem = this.inputFileSystem;\r\n if (fs.purge) {\r\n if (removals) {\r\n for (const removal of removals) {\r\n fs.purge(removal);\r\n }\r\n }\r\n if (changes) {\r\n for (const change of changes) {\r\n fs.purge(change);\r\n }\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport class OverrideNodeWatchFSPlugin implements WebpackPluginInstance {\r\n public readonly fileSystems: Set<DeferredWatchFileSystem> = new Set();\r\n private readonly _onChange: () => void;\r\n\r\n public constructor(onChange: () => void) {\r\n this._onChange = onChange;\r\n }\r\n\r\n public apply(compiler: Compiler): void {\r\n const watchFileSystem: DeferredWatchFileSystem = new DeferredWatchFileSystem(\r\n compiler.inputFileSystem,\r\n this._onChange\r\n );\r\n this.fileSystems.add(watchFileSystem);\r\n compiler.watchFileSystem = watchFileSystem;\r\n }\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"DeferredWatchFileSystem.js","sourceRoot":"","sources":["../src/DeferredWatchFileSystem.ts"],"names":[],"mappings":";AAAA,4FAA4F;AAC5F,2DAA2D;;;;;;AAE3D,0DAAyD;AA8BzD,MAAa,uBAAuB;IAQlC,YAAmB,eAAgC,EAAE,QAAoB;QACvE,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QACvC,IAAI,CAAC,cAAc,GAAG;YACpB,gBAAgB,EAAE,CAAC;SACpB,CAAC;QACF,IAAI,CAAC,OAAO,GAAG,IAAI,mBAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAClD,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAEM,KAAK;QACV,MAAM,KAAK,GAA4B,IAAI,CAAC,MAAM,CAAC;QAEnD,IAAI,CAAC,KAAK,EAAE;YACV,OAAO,KAAK,CAAC;SACd;QAED,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;QAE9C,uCAAuC;QACvC,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,OAAQ,CAAC,aAAa,EAAE,CAAC;QAErF,2DAA2D;QAC3D,IAAI,WAAW,EAAE;YACf,KAAK,MAAM,OAAO,IAAI,WAAW,EAAE;gBACjC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBACxB,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;aACvB;SACF;QACD,IAAI,UAAU,EAAE;YACd,KAAK,MAAM,MAAM,IAAI,UAAU,EAAE;gBAC/B,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;aACrB;SACF;QAED,IAAI,OAAO,CAAC,IAAI,GAAG,CAAC,IAAI,QAAQ,CAAC,IAAI,GAAG,CAAC,EAAE;YACzC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YAE/B,MAAM,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;YAE9E,QAAQ,CAAC,SAAS,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;YAEpF,OAAO,CAAC,KAAK,EAAE,CAAC;YAChB,QAAQ,CAAC,KAAK,EAAE,CAAC;YAEjB,OAAO,IAAI,CAAC;SACb;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,KAAK,CACV,KAAuB,EACvB,WAA6B,EAC7B,OAAyB,EACzB,SAAiB,EACjB,OAAqB,EACrB,QAAuB,EACvB,iBAAyC;QAEzC,MAAM,UAAU,GAA0B,IAAI,CAAC,OAAO,CAAC;QACvD,IAAI,CAAC,OAAO,GAAG,IAAI,mBAAS,CAAC,OAAO,CAAC,CAAC;QAEtC,MAAM,OAAO,GAAgB,IAAI,GAAG,EAAE,CAAC;QACvC,MAAM,QAAQ,GAAgB,IAAI,GAAG,EAAE,CAAC;QAExC,IAAI,CAAC,MAAM,GAAG;YACZ,OAAO;YACP,QAAQ;YAER,QAAQ;SACT,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,UAAuB,EAAE,WAAwB,EAAE,EAAE;YAClF,KAAK,MAAM,MAAM,IAAI,UAAU,EAAE;gBAC/B,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;aACrB;YACD,KAAK,MAAM,OAAO,IAAI,WAAW,EAAE;gBACjC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBACxB,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;aACvB;YAED,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;YACjB,KAAK;YACL,WAAW;YACX,OAAO;YACP,SAAS;SACV,CAAC,CAAC;QAEH,IAAI,UAAU,EAAE;YACd,UAAU,CAAC,KAAK,EAAE,CAAC;SACpB;QAED,OAAO;YACL,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,IAAI,CAAC,OAAO,EAAE;oBAChB,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;oBACrB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;iBAC1B;YACH,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,IAAI,CAAC,OAAO,EAAE;oBAChB,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;iBACtB;YACH,CAAC;YACD,OAAO,EAAE,GAAG,EAAE;;gBACZ,MAAM,WAAW,GAA4B,MAAA,IAAI,CAAC,OAAO,0CAAE,kBAAkB,CAAC;gBAC9E,MAAM,UAAU,GAA4B,MAAA,IAAI,CAAC,OAAO,0CAAE,iBAAiB,CAAC;gBAC5E,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;gBACrC,MAAM,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;gBAC9E,OAAO;oBACL,OAAO,EAAE,UAAW;oBACpB,QAAQ,EAAE,WAAY;oBACtB,mBAAmB;oBACnB,sBAAsB;iBACvB,CAAC;YACJ,CAAC;YACD,yBAAyB,EAAE,GAAG,EAAE;gBAC9B,MAAM,EAAE,sBAAsB,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;gBACzD,OAAO,sBAAsB,CAAC;YAChC,CAAC;YACD,sBAAsB,EAAE,GAAG,EAAE;gBAC3B,MAAM,EAAE,mBAAmB,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtD,OAAO,mBAAmB,CAAC;YAC7B,CAAC;SACF,CAAC;IACJ,CAAC;IAEO,cAAc;;QACpB,MAAM,mBAAmB,GAAsB,IAAI,GAAG,EAAE,CAAC;QACzD,MAAM,sBAAsB,GAAsB,IAAI,GAAG,EAAE,CAAC;QAC5D,MAAA,IAAI,CAAC,OAAO,0CAAE,sBAAsB,CAAC,mBAAmB,EAAE,sBAAsB,CAAC,CAAC;QAClF,OAAO,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,CAAC;IACzD,CAAC;IAEO,MAAM,CAAC,QAAiC,EAAE,OAAgC;QAChF,MAAM,EAAE,GAAoB,IAAI,CAAC,eAAe,CAAC;QACjD,IAAI,EAAE,CAAC,KAAK,EAAE;YACZ,IAAI,QAAQ,EAAE;gBACZ,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE;oBAC9B,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;iBACnB;aACF;YACD,IAAI,OAAO,EAAE;gBACX,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;oBAC5B,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;iBAClB;aACF;SACF;IACH,CAAC;CACF;AAlKD,0DAkKC;AAED,MAAa,yBAAyB;IAIpC,YAAmB,QAAoB;QAHvB,gBAAW,GAAiC,IAAI,GAAG,EAAE,CAAC;QAIpE,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAEM,KAAK,CAAC,QAAkB;QAC7B,MAAM,eAAe,GAA4B,IAAI,uBAAuB,CAC1E,QAAQ,CAAC,eAAe,EACxB,IAAI,CAAC,SAAS,CACf,CAAC;QACF,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QACtC,QAAQ,CAAC,eAAe,GAAG,eAAe,CAAC;IAC7C,CAAC;CACF;AAhBD,8DAgBC","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\n// See LICENSE in the project root for license information.\n\nimport Watchpack, { type WatchOptions } from 'watchpack';\nimport type { Compiler, WebpackPluginInstance } from 'webpack';\n\nexport type InputFileSystem = Compiler['inputFileSystem'];\nexport type WatchFileSystem = Compiler['watchFileSystem'];\nexport type WatchCallback = Parameters<WatchFileSystem['watch']>[5];\nexport type WatchUndelayedCallback = Parameters<WatchFileSystem['watch']>[6];\nexport type Watcher = ReturnType<WatchFileSystem['watch']>;\nexport type WatcherInfo = ReturnType<Required<Watcher>['getInfo']>;\ntype FileSystemMap = ReturnType<Watcher['getFileTimeInfoEntries']>;\n\ninterface IWatchState {\n changes: Set<string>;\n removals: Set<string>;\n\n callback: WatchCallback;\n}\n\ninterface ITimeEntry {\n timestamp: number;\n safeTime: number;\n}\n\ntype IRawFileSystemMap = Map<string, ITimeEntry>;\n\ninterface ITimeInfoEntries {\n fileTimeInfoEntries: FileSystemMap;\n contextTimeInfoEntries: FileSystemMap;\n}\n\nexport class DeferredWatchFileSystem implements WatchFileSystem {\n public readonly inputFileSystem: InputFileSystem;\n public readonly watcherOptions: WatchOptions;\n public watcher: Watchpack | undefined;\n\n private readonly _onChange: () => void;\n private _state: IWatchState | undefined;\n\n public constructor(inputFileSystem: InputFileSystem, onChange: () => void) {\n this.inputFileSystem = inputFileSystem;\n this.watcherOptions = {\n aggregateTimeout: 0\n };\n this.watcher = new Watchpack(this.watcherOptions);\n this._onChange = onChange;\n }\n\n public flush(): boolean {\n const state: IWatchState | undefined = this._state;\n\n if (!state) {\n return false;\n }\n\n const { changes, removals, callback } = state;\n\n // Force flush the aggregation callback\n const { changes: newChanges, removals: newRemovals } = this.watcher!.getAggregated();\n\n // Webpack 5 treats changes and removals as separate things\n if (newRemovals) {\n for (const removal of newRemovals) {\n changes.delete(removal);\n removals.add(removal);\n }\n }\n if (newChanges) {\n for (const change of newChanges) {\n removals.delete(change);\n changes.add(change);\n }\n }\n\n if (changes.size > 0 || removals.size > 0) {\n this._purge(removals, changes);\n\n const { fileTimeInfoEntries, contextTimeInfoEntries } = this._fetchTimeInfo();\n\n callback(undefined, fileTimeInfoEntries, contextTimeInfoEntries, changes, removals);\n\n changes.clear();\n removals.clear();\n\n return true;\n }\n\n return false;\n }\n\n public watch(\n files: Iterable<string>,\n directories: Iterable<string>,\n missing: Iterable<string>,\n startTime: number,\n options: WatchOptions,\n callback: WatchCallback,\n callbackUndelayed: WatchUndelayedCallback\n ): Watcher {\n const oldWatcher: Watchpack | undefined = this.watcher;\n this.watcher = new Watchpack(options);\n\n const changes: Set<string> = new Set();\n const removals: Set<string> = new Set();\n\n this._state = {\n changes,\n removals,\n\n callback\n };\n\n this.watcher.on('aggregated', (newChanges: Set<string>, newRemovals: Set<string>) => {\n for (const change of newChanges) {\n removals.delete(change);\n changes.add(change);\n }\n for (const removal of newRemovals) {\n changes.delete(removal);\n removals.add(removal);\n }\n\n this._onChange();\n });\n\n this.watcher.watch({\n files,\n directories,\n missing,\n startTime\n });\n\n if (oldWatcher) {\n oldWatcher.close();\n }\n\n return {\n close: () => {\n if (this.watcher) {\n this.watcher.close();\n this.watcher = undefined;\n }\n },\n pause: () => {\n if (this.watcher) {\n this.watcher.pause();\n }\n },\n getInfo: () => {\n const newRemovals: Set<string> | undefined = this.watcher?.aggregatedRemovals;\n const newChanges: Set<string> | undefined = this.watcher?.aggregatedChanges;\n this._purge(newRemovals, newChanges);\n const { fileTimeInfoEntries, contextTimeInfoEntries } = this._fetchTimeInfo();\n return {\n changes: newChanges!,\n removals: newRemovals!,\n fileTimeInfoEntries,\n contextTimeInfoEntries\n };\n },\n getContextTimeInfoEntries: () => {\n const { contextTimeInfoEntries } = this._fetchTimeInfo();\n return contextTimeInfoEntries;\n },\n getFileTimeInfoEntries: () => {\n const { fileTimeInfoEntries } = this._fetchTimeInfo();\n return fileTimeInfoEntries;\n }\n };\n }\n\n private _fetchTimeInfo(): ITimeInfoEntries {\n const fileTimeInfoEntries: IRawFileSystemMap = new Map();\n const contextTimeInfoEntries: IRawFileSystemMap = new Map();\n this.watcher?.collectTimeInfoEntries(fileTimeInfoEntries, contextTimeInfoEntries);\n return { fileTimeInfoEntries, contextTimeInfoEntries };\n }\n\n private _purge(removals: Set<string> | undefined, changes: Set<string> | undefined): void {\n const fs: InputFileSystem = this.inputFileSystem;\n if (fs.purge) {\n if (removals) {\n for (const removal of removals) {\n fs.purge(removal);\n }\n }\n if (changes) {\n for (const change of changes) {\n fs.purge(change);\n }\n }\n }\n }\n}\n\nexport class OverrideNodeWatchFSPlugin implements WebpackPluginInstance {\n public readonly fileSystems: Set<DeferredWatchFileSystem> = new Set();\n private readonly _onChange: () => void;\n\n public constructor(onChange: () => void) {\n this._onChange = onChange;\n }\n\n public apply(compiler: Compiler): void {\n const watchFileSystem: DeferredWatchFileSystem = new DeferredWatchFileSystem(\n compiler.inputFileSystem,\n this._onChange\n );\n this.fileSystems.add(watchFileSystem);\n compiler.watchFileSystem = watchFileSystem;\n }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Webpack5Plugin.js","sourceRoot":"","sources":["../src/Webpack5Plugin.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\r\n// See LICENSE in the project root for license information.\r\n\r\nimport type { AddressInfo } from 'net';\r\n\r\nimport type * as TWebpack from 'webpack';\r\nimport type TWebpackDevServer from 'webpack-dev-server';\r\nimport { AsyncParallelHook, AsyncSeriesBailHook, AsyncSeriesHook } from 'tapable';\r\n\r\nimport { CertificateManager, type ICertificate } from '@rushstack/debug-certificate-manager';\r\nimport { FileError, InternalError, LegacyAdapters } from '@rushstack/node-core-library';\r\nimport type {\r\n HeftConfiguration,\r\n IHeftTaskSession,\r\n IHeftTaskPlugin,\r\n IHeftTaskRunHookOptions,\r\n IScopedLogger,\r\n IHeftTaskRunIncrementalHookOptions\r\n} from '@rushstack/heft';\r\n\r\nimport {\r\n type IWebpackConfiguration,\r\n type IWebpackPluginAccessor,\r\n PLUGIN_NAME,\r\n type IWebpackPluginAccessorHooks\r\n} from './shared';\r\nimport { tryLoadWebpackConfigurationAsync } from './WebpackConfigurationLoader';\r\nimport { type DeferredWatchFileSystem, OverrideNodeWatchFSPlugin } from './DeferredWatchFileSystem';\r\n\r\nexport interface IWebpackPluginOptions {\r\n devConfigurationPath?: string | undefined;\r\n configurationPath?: string | undefined;\r\n}\r\nconst SERVE_PARAMETER_LONG_NAME: '--serve' = '--serve';\r\nconst WEBPACK_PACKAGE_NAME: 'webpack' = 'webpack';\r\nconst WEBPACK_DEV_SERVER_PACKAGE_NAME: 'webpack-dev-server' = 'webpack-dev-server';\r\nconst WEBPACK_DEV_SERVER_ENV_VAR_NAME: 'WEBPACK_DEV_SERVER' = 'WEBPACK_DEV_SERVER';\r\nconst WEBPACK_DEV_MIDDLEWARE_PACKAGE_NAME: 'webpack-dev-middleware' = 'webpack-dev-middleware';\r\n\r\n/**\r\n * @internal\r\n */\r\nexport default class Webpack5Plugin implements IHeftTaskPlugin<IWebpackPluginOptions> {\r\n private _accessor: IWebpackPluginAccessor | undefined;\r\n private _isServeMode: boolean = false;\r\n private _webpack: typeof TWebpack | undefined;\r\n private _webpackCompiler: TWebpack.Compiler | TWebpack.MultiCompiler | undefined;\r\n private _webpackConfiguration: IWebpackConfiguration | undefined | false = false;\r\n private _webpackCompilationDonePromise: Promise<void> | undefined;\r\n private _webpackCompilationDonePromiseResolveFn: (() => void) | undefined;\r\n private _watchFileSystems: Set<DeferredWatchFileSystem> | undefined;\r\n\r\n private _warnings: Error[] = [];\r\n private _errors: Error[] = [];\r\n\r\n public get accessor(): IWebpackPluginAccessor {\r\n if (!this._accessor) {\r\n this._accessor = {\r\n hooks: _createAccessorHooks(),\r\n parameters: {\r\n isServeMode: this._isServeMode\r\n }\r\n };\r\n }\r\n return this._accessor;\r\n }\r\n\r\n public apply(\r\n taskSession: IHeftTaskSession,\r\n heftConfiguration: HeftConfiguration,\r\n options: IWebpackPluginOptions = {}\r\n ): void {\r\n this._isServeMode = taskSession.parameters.getFlagParameter(SERVE_PARAMETER_LONG_NAME).value;\r\n if (this._isServeMode && !taskSession.parameters.watch) {\r\n throw new Error(\r\n `The ${JSON.stringify(\r\n SERVE_PARAMETER_LONG_NAME\r\n )} parameter is only available when running in watch mode.` +\r\n ` Try replacing \"${taskSession.parsedCommandLine?.unaliasedCommandName}\" with` +\r\n ` \"${taskSession.parsedCommandLine?.unaliasedCommandName}-watch\" in your Heft command line.`\r\n );\r\n }\r\n\r\n taskSession.hooks.run.tapPromise(PLUGIN_NAME, async (runOptions: IHeftTaskRunHookOptions) => {\r\n await this._runWebpackAsync(taskSession, heftConfiguration, options);\r\n });\r\n\r\n taskSession.hooks.runIncremental.tapPromise(\r\n PLUGIN_NAME,\r\n async (runOptions: IHeftTaskRunIncrementalHookOptions) => {\r\n await this._runWebpackWatchAsync(taskSession, heftConfiguration, options, runOptions.requestRun);\r\n }\r\n );\r\n }\r\n\r\n private async _getWebpackConfigurationAsync(\r\n taskSession: IHeftTaskSession,\r\n heftConfiguration: HeftConfiguration,\r\n options: IWebpackPluginOptions,\r\n requestRun?: () => void\r\n ): Promise<IWebpackConfiguration | undefined> {\r\n if (this._webpackConfiguration === false) {\r\n const webpackConfiguration: IWebpackConfiguration | undefined = await tryLoadWebpackConfigurationAsync(\r\n {\r\n taskSession,\r\n heftConfiguration,\r\n hooks: this.accessor.hooks,\r\n serveMode: this._isServeMode,\r\n loadWebpackAsyncFn: this._loadWebpackAsync.bind(this)\r\n },\r\n options\r\n );\r\n\r\n if (webpackConfiguration && requestRun) {\r\n const overrideWatchFSPlugin: OverrideNodeWatchFSPlugin = new OverrideNodeWatchFSPlugin(requestRun);\r\n this._watchFileSystems = overrideWatchFSPlugin.fileSystems;\r\n for (const config of Array.isArray(webpackConfiguration)\r\n ? webpackConfiguration\r\n : [webpackConfiguration]) {\r\n if (!config.plugins) {\r\n config.plugins = [overrideWatchFSPlugin];\r\n } else {\r\n config.plugins.unshift(overrideWatchFSPlugin);\r\n }\r\n }\r\n }\r\n\r\n this._webpackConfiguration = webpackConfiguration;\r\n }\r\n\r\n return this._webpackConfiguration;\r\n }\r\n\r\n private async _loadWebpackAsync(): Promise<typeof TWebpack> {\r\n if (!this._webpack) {\r\n // Allow this to fail if webpack is not installed\r\n this._webpack = await import(WEBPACK_PACKAGE_NAME);\r\n }\r\n return this._webpack!;\r\n }\r\n\r\n private async _getWebpackCompilerAsync(\r\n taskSession: IHeftTaskSession,\r\n webpackConfiguration: IWebpackConfiguration\r\n ): Promise<TWebpack.Compiler | TWebpack.MultiCompiler> {\r\n if (!this._webpackCompiler) {\r\n const webpack: typeof TWebpack = await this._loadWebpackAsync();\r\n taskSession.logger.terminal.writeLine(`Using Webpack version ${webpack.version}`);\r\n this._webpackCompiler = Array.isArray(webpackConfiguration)\r\n ? webpack.default(webpackConfiguration) /* (webpack.Compilation[]) => MultiCompiler */\r\n : webpack.default(webpackConfiguration); /* (webpack.Compilation) => Compiler */\r\n }\r\n return this._webpackCompiler;\r\n }\r\n\r\n private async _runWebpackAsync(\r\n taskSession: IHeftTaskSession,\r\n heftConfiguration: HeftConfiguration,\r\n options: IWebpackPluginOptions\r\n ): Promise<void> {\r\n this._validateEnvironmentVariable(taskSession);\r\n if (taskSession.parameters.watch || this._isServeMode) {\r\n // Should never happen, but just in case\r\n throw new InternalError('Cannot run Webpack in compilation mode when watch mode is enabled');\r\n }\r\n\r\n // Load the config and compiler, and return if there is no config found\r\n const webpackConfiguration: IWebpackConfiguration | undefined = await this._getWebpackConfigurationAsync(\r\n taskSession,\r\n heftConfiguration,\r\n options\r\n );\r\n if (!webpackConfiguration) {\r\n return;\r\n }\r\n const compiler: TWebpack.Compiler | TWebpack.MultiCompiler = await this._getWebpackCompilerAsync(\r\n taskSession,\r\n webpackConfiguration\r\n );\r\n taskSession.logger.terminal.writeLine('Running Webpack compilation');\r\n\r\n // Run the webpack compiler\r\n let stats: TWebpack.Stats | TWebpack.MultiStats | undefined;\r\n try {\r\n stats = await LegacyAdapters.convertCallbackToPromise(\r\n (compiler as TWebpack.Compiler).run.bind(compiler)\r\n );\r\n await LegacyAdapters.convertCallbackToPromise(compiler.close.bind(compiler));\r\n } catch (e) {\r\n taskSession.logger.emitError(e as Error);\r\n }\r\n\r\n // Emit the errors from the stats object, if present\r\n if (stats) {\r\n this._recordErrors(stats, heftConfiguration.buildFolderPath);\r\n this._emitErrors(taskSession.logger);\r\n if (this.accessor.hooks.onEmitStats.isUsed()) {\r\n await this.accessor.hooks.onEmitStats.promise(stats);\r\n }\r\n }\r\n }\r\n\r\n private async _runWebpackWatchAsync(\r\n taskSession: IHeftTaskSession,\r\n heftConfiguration: HeftConfiguration,\r\n options: IWebpackPluginOptions,\r\n requestRun: () => void\r\n ): Promise<void> {\r\n // Save a handle to the original promise, since the this-scoped promise will be replaced whenever\r\n // the compilation completes.\r\n let webpackCompilationDonePromise: Promise<void> | undefined = this._webpackCompilationDonePromise;\r\n\r\n let isInitial: boolean = false;\r\n\r\n if (!this._webpackCompiler) {\r\n isInitial = true;\r\n this._validateEnvironmentVariable(taskSession);\r\n if (!taskSession.parameters.watch) {\r\n // Should never happen, but just in case\r\n throw new InternalError('Cannot run Webpack in watch mode when compilation mode is enabled');\r\n }\r\n\r\n // Load the config and compiler, and return if there is no config found\r\n const webpackConfiguration: IWebpackConfiguration | undefined =\r\n await this._getWebpackConfigurationAsync(taskSession, heftConfiguration, options, requestRun);\r\n if (!webpackConfiguration) {\r\n return;\r\n }\r\n\r\n // Get the compiler which will be used for both serve and watch mode\r\n const compiler: TWebpack.Compiler | TWebpack.MultiCompiler = await this._getWebpackCompilerAsync(\r\n taskSession,\r\n webpackConfiguration\r\n );\r\n\r\n // Set up the hook to detect when the watcher completes the watcher compilation. We will also log out\r\n // errors from the compilation if present from the output stats object.\r\n this._webpackCompilationDonePromise = new Promise((resolve: () => void) => {\r\n this._webpackCompilationDonePromiseResolveFn = resolve;\r\n });\r\n webpackCompilationDonePromise = this._webpackCompilationDonePromise;\r\n compiler.hooks.done.tap(PLUGIN_NAME, (stats?: TWebpack.Stats | TWebpack.MultiStats) => {\r\n this._webpackCompilationDonePromiseResolveFn!();\r\n this._webpackCompilationDonePromise = new Promise((resolve: () => void) => {\r\n this._webpackCompilationDonePromiseResolveFn = resolve;\r\n });\r\n\r\n if (stats) {\r\n this._recordErrors(stats, heftConfiguration.buildFolderPath);\r\n }\r\n });\r\n\r\n // Determine how we will run the compiler. When serving, we will run the compiler\r\n // via the webpack-dev-server. Otherwise, we will run the compiler directly.\r\n if (this._isServeMode) {\r\n const defaultDevServerOptions: TWebpackDevServer.Configuration = {\r\n host: 'localhost',\r\n devMiddleware: {\r\n publicPath: '/',\r\n stats: {\r\n cached: false,\r\n cachedAssets: false,\r\n colors: heftConfiguration.terminalProvider.supportsColor\r\n }\r\n },\r\n client: {\r\n logging: 'info',\r\n webSocketURL: {\r\n port: 8080\r\n }\r\n },\r\n port: 8080,\r\n onListening: (server: TWebpackDevServer) => {\r\n const addressInfo: AddressInfo | string | undefined = server.server?.address() as AddressInfo;\r\n if (addressInfo) {\r\n const address: string =\r\n typeof addressInfo === 'string' ? addressInfo : `${addressInfo.address}:${addressInfo.port}`;\r\n taskSession.logger.terminal.writeLine(`Started Webpack Dev Server at https://${address}`);\r\n }\r\n }\r\n };\r\n\r\n // Obtain the devServerOptions from the webpack configuration, and combine with the default options\r\n let devServerOptions: TWebpackDevServer.Configuration;\r\n if (Array.isArray(webpackConfiguration)) {\r\n const filteredDevServerOptions: TWebpackDevServer.Configuration[] = webpackConfiguration\r\n .map((configuration) => configuration.devServer)\r\n .filter((devServer): devServer is TWebpackDevServer.Configuration => !!devServer);\r\n if (filteredDevServerOptions.length > 1) {\r\n taskSession.logger.emitWarning(\r\n new Error(`Detected multiple webpack devServer configurations, using the first one.`)\r\n );\r\n }\r\n devServerOptions = { ...defaultDevServerOptions, ...filteredDevServerOptions[0] };\r\n } else {\r\n devServerOptions = { ...defaultDevServerOptions, ...webpackConfiguration.devServer };\r\n }\r\n\r\n // Add the certificate and key to the devServerOptions if these fields don't already have values\r\n if (!devServerOptions.server) {\r\n const certificateManager: CertificateManager = new CertificateManager();\r\n const certificate: ICertificate = await certificateManager.ensureCertificateAsync(\r\n true,\r\n taskSession.logger.terminal\r\n );\r\n\r\n // Update the web socket URL to use the hostname provided by the certificate\r\n const clientConfiguration: TWebpackDevServer.Configuration['client'] = devServerOptions.client;\r\n const hostname: string | undefined = certificate.subjectAltNames?.[0];\r\n if (hostname && typeof clientConfiguration === 'object') {\r\n const { webSocketURL } = clientConfiguration;\r\n if (typeof webSocketURL === 'object') {\r\n clientConfiguration.webSocketURL = {\r\n ...webSocketURL,\r\n hostname\r\n };\r\n }\r\n }\r\n\r\n devServerOptions = {\r\n ...devServerOptions,\r\n server: {\r\n type: 'https',\r\n options: {\r\n minVersion: 'TLSv1.3',\r\n key: certificate.pemKey,\r\n cert: certificate.pemCertificate,\r\n ca: certificate.pemCaCertificate\r\n }\r\n }\r\n };\r\n }\r\n\r\n // Since the webpack-dev-server does not return infrastructure errors via a callback like\r\n // compiler.watch(...), we will need to intercept them and log them ourselves.\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n compiler.hooks.infrastructureLog.tap(PLUGIN_NAME, (name: string, type: string, args: any[]) => {\r\n if (name === WEBPACK_DEV_MIDDLEWARE_PACKAGE_NAME && type === 'error') {\r\n const error: Error | undefined = args[0];\r\n if (error) {\r\n taskSession.logger.emitError(error);\r\n }\r\n }\r\n return true;\r\n });\r\n\r\n // The webpack-dev-server package has a design flaw, where merely loading its package will set the\r\n // WEBPACK_DEV_SERVER environment variable -- even if no APIs are accessed. This environment variable\r\n // causes incorrect behavior if Heft is not running in serve mode. Thus, we need to be careful to call\r\n // require() only if Heft is in serve mode.\r\n taskSession.logger.terminal.writeLine('Starting webpack-dev-server');\r\n const WebpackDevServer: typeof TWebpackDevServer = (await import(WEBPACK_DEV_SERVER_PACKAGE_NAME))\r\n .default;\r\n const webpackDevServer: TWebpackDevServer = new WebpackDevServer(devServerOptions, compiler);\r\n await webpackDevServer.start();\r\n } else {\r\n // Create the watcher. Compilation will start immediately after invoking watch().\r\n taskSession.logger.terminal.writeLine('Starting Webpack watcher');\r\n compiler.watch({}, (error?: Error | null) => {\r\n if (error) {\r\n taskSession.logger.emitError(error);\r\n }\r\n });\r\n }\r\n }\r\n\r\n let hasChanges: boolean = true;\r\n if (!isInitial && this._watchFileSystems) {\r\n hasChanges = false;\r\n for (const watchFileSystem of this._watchFileSystems) {\r\n hasChanges = watchFileSystem.flush() || hasChanges;\r\n }\r\n }\r\n\r\n // Resume the compilation, wait for the compilation to complete, then suspend the watchers until the\r\n // next iteration. Even if there are no changes, the promise should resolve since resuming from a\r\n // suspended state invalidates the state of the watcher.\r\n if (hasChanges) {\r\n taskSession.logger.terminal.writeLine('Running incremental Webpack compilation');\r\n await webpackCompilationDonePromise;\r\n } else {\r\n taskSession.logger.terminal.writeLine(\r\n 'Webpack has not detected changes. Listing previous diagnostics.'\r\n );\r\n }\r\n\r\n this._emitErrors(taskSession.logger);\r\n }\r\n\r\n private _validateEnvironmentVariable(taskSession: IHeftTaskSession): void {\r\n if (!this._isServeMode && process.env[WEBPACK_DEV_SERVER_ENV_VAR_NAME]) {\r\n taskSession.logger.emitWarning(\r\n new Error(\r\n `The \"${WEBPACK_DEV_SERVER_ENV_VAR_NAME}\" environment variable is set, ` +\r\n 'which will cause problems when webpack is not running in serve mode. ' +\r\n `(Did a dependency inadvertently load the \"${WEBPACK_DEV_SERVER_PACKAGE_NAME}\" package?)`\r\n )\r\n );\r\n }\r\n }\r\n\r\n private _emitErrors(logger: IScopedLogger): void {\r\n for (const warning of this._warnings) {\r\n logger.emitWarning(warning);\r\n }\r\n for (const error of this._errors) {\r\n logger.emitError(error);\r\n }\r\n }\r\n\r\n private _recordErrors(stats: TWebpack.Stats | TWebpack.MultiStats, buildFolderPath: string): void {\r\n const errors: Error[] = this._errors;\r\n const warnings: Error[] = this._warnings;\r\n\r\n errors.length = 0;\r\n warnings.length = 0;\r\n\r\n if (stats.hasErrors() || stats.hasWarnings()) {\r\n const serializedStats: TWebpack.StatsCompilation[] = [stats.toJson('errors-warnings')];\r\n\r\n for (const compilationStats of serializedStats) {\r\n if (compilationStats.warnings) {\r\n for (const warning of compilationStats.warnings) {\r\n warnings.push(this._normalizeError(buildFolderPath, warning));\r\n }\r\n }\r\n\r\n if (compilationStats.errors) {\r\n for (const error of compilationStats.errors) {\r\n errors.push(this._normalizeError(buildFolderPath, error));\r\n }\r\n }\r\n\r\n if (compilationStats.children) {\r\n for (const child of compilationStats.children) {\r\n serializedStats.push(child);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n private _normalizeError(buildFolderPath: string, error: TWebpack.StatsError): Error {\r\n if (error instanceof Error) {\r\n return error;\r\n } else if (error.moduleIdentifier) {\r\n let lineNumber: number | undefined;\r\n let columnNumber: number | undefined;\r\n if (error.loc) {\r\n // Format of \"<line>:<columnStart>-<columnEnd>\"\r\n // https://webpack.js.org/api/stats/#errors-and-warnings\r\n const [lineNumberRaw, columnRangeRaw] = error.loc.split(':');\r\n const [startColumnRaw] = columnRangeRaw.split('-');\r\n if (lineNumberRaw) {\r\n lineNumber = parseInt(lineNumberRaw, 10);\r\n if (isNaN(lineNumber)) {\r\n lineNumber = undefined;\r\n }\r\n }\r\n if (startColumnRaw) {\r\n columnNumber = parseInt(startColumnRaw, 10);\r\n if (isNaN(columnNumber)) {\r\n columnNumber = undefined;\r\n }\r\n }\r\n }\r\n\r\n return new FileError(error.message, {\r\n absolutePath: error.moduleIdentifier,\r\n projectFolder: buildFolderPath,\r\n line: lineNumber,\r\n column: columnNumber\r\n });\r\n } else {\r\n return new Error(error.message);\r\n }\r\n }\r\n}\r\n\r\n/**\r\n * @internal\r\n */\r\nexport function _createAccessorHooks(): IWebpackPluginAccessorHooks {\r\n return {\r\n onLoadConfiguration: new AsyncSeriesBailHook(),\r\n onConfigure: new AsyncSeriesHook(['webpackConfiguration']),\r\n onAfterConfigure: new AsyncParallelHook(['webpackConfiguration']),\r\n onEmitStats: new AsyncParallelHook(['webpackStats'])\r\n };\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"Webpack5Plugin.js","sourceRoot":"","sources":["../src/Webpack5Plugin.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\n// See LICENSE in the project root for license information.\n\nimport type { AddressInfo } from 'net';\n\nimport type * as TWebpack from 'webpack';\nimport type TWebpackDevServer from 'webpack-dev-server';\nimport { AsyncParallelHook, AsyncSeriesBailHook, AsyncSeriesHook } from 'tapable';\n\nimport { CertificateManager, type ICertificate } from '@rushstack/debug-certificate-manager';\nimport { FileError, InternalError, LegacyAdapters } from '@rushstack/node-core-library';\nimport type {\n HeftConfiguration,\n IHeftTaskSession,\n IHeftTaskPlugin,\n IHeftTaskRunHookOptions,\n IScopedLogger,\n IHeftTaskRunIncrementalHookOptions\n} from '@rushstack/heft';\n\nimport {\n type IWebpackConfiguration,\n type IWebpackPluginAccessor,\n PLUGIN_NAME,\n type IWebpackPluginAccessorHooks\n} from './shared';\nimport { tryLoadWebpackConfigurationAsync } from './WebpackConfigurationLoader';\nimport { type DeferredWatchFileSystem, OverrideNodeWatchFSPlugin } from './DeferredWatchFileSystem';\n\nexport interface IWebpackPluginOptions {\n devConfigurationPath?: string | undefined;\n configurationPath?: string | undefined;\n}\nconst SERVE_PARAMETER_LONG_NAME: '--serve' = '--serve';\nconst WEBPACK_PACKAGE_NAME: 'webpack' = 'webpack';\nconst WEBPACK_DEV_SERVER_PACKAGE_NAME: 'webpack-dev-server' = 'webpack-dev-server';\nconst WEBPACK_DEV_SERVER_ENV_VAR_NAME: 'WEBPACK_DEV_SERVER' = 'WEBPACK_DEV_SERVER';\nconst WEBPACK_DEV_MIDDLEWARE_PACKAGE_NAME: 'webpack-dev-middleware' = 'webpack-dev-middleware';\n\n/**\n * @internal\n */\nexport default class Webpack5Plugin implements IHeftTaskPlugin<IWebpackPluginOptions> {\n private _accessor: IWebpackPluginAccessor | undefined;\n private _isServeMode: boolean = false;\n private _webpack: typeof TWebpack | undefined;\n private _webpackCompiler: TWebpack.Compiler | TWebpack.MultiCompiler | undefined;\n private _webpackConfiguration: IWebpackConfiguration | undefined | false = false;\n private _webpackCompilationDonePromise: Promise<void> | undefined;\n private _webpackCompilationDonePromiseResolveFn: (() => void) | undefined;\n private _watchFileSystems: Set<DeferredWatchFileSystem> | undefined;\n\n private _warnings: Error[] = [];\n private _errors: Error[] = [];\n\n public get accessor(): IWebpackPluginAccessor {\n if (!this._accessor) {\n this._accessor = {\n hooks: _createAccessorHooks(),\n parameters: {\n isServeMode: this._isServeMode\n }\n };\n }\n return this._accessor;\n }\n\n public apply(\n taskSession: IHeftTaskSession,\n heftConfiguration: HeftConfiguration,\n options: IWebpackPluginOptions = {}\n ): void {\n this._isServeMode = taskSession.parameters.getFlagParameter(SERVE_PARAMETER_LONG_NAME).value;\n if (this._isServeMode && !taskSession.parameters.watch) {\n throw new Error(\n `The ${JSON.stringify(\n SERVE_PARAMETER_LONG_NAME\n )} parameter is only available when running in watch mode.` +\n ` Try replacing \"${taskSession.parsedCommandLine?.unaliasedCommandName}\" with` +\n ` \"${taskSession.parsedCommandLine?.unaliasedCommandName}-watch\" in your Heft command line.`\n );\n }\n\n taskSession.hooks.run.tapPromise(PLUGIN_NAME, async (runOptions: IHeftTaskRunHookOptions) => {\n await this._runWebpackAsync(taskSession, heftConfiguration, options);\n });\n\n taskSession.hooks.runIncremental.tapPromise(\n PLUGIN_NAME,\n async (runOptions: IHeftTaskRunIncrementalHookOptions) => {\n await this._runWebpackWatchAsync(taskSession, heftConfiguration, options, runOptions.requestRun);\n }\n );\n }\n\n private async _getWebpackConfigurationAsync(\n taskSession: IHeftTaskSession,\n heftConfiguration: HeftConfiguration,\n options: IWebpackPluginOptions,\n requestRun?: () => void\n ): Promise<IWebpackConfiguration | undefined> {\n if (this._webpackConfiguration === false) {\n const webpackConfiguration: IWebpackConfiguration | undefined = await tryLoadWebpackConfigurationAsync(\n {\n taskSession,\n heftConfiguration,\n hooks: this.accessor.hooks,\n serveMode: this._isServeMode,\n loadWebpackAsyncFn: this._loadWebpackAsync.bind(this)\n },\n options\n );\n\n if (webpackConfiguration && requestRun) {\n const overrideWatchFSPlugin: OverrideNodeWatchFSPlugin = new OverrideNodeWatchFSPlugin(requestRun);\n this._watchFileSystems = overrideWatchFSPlugin.fileSystems;\n for (const config of Array.isArray(webpackConfiguration)\n ? webpackConfiguration\n : [webpackConfiguration]) {\n if (!config.plugins) {\n config.plugins = [overrideWatchFSPlugin];\n } else {\n config.plugins.unshift(overrideWatchFSPlugin);\n }\n }\n }\n\n this._webpackConfiguration = webpackConfiguration;\n }\n\n return this._webpackConfiguration;\n }\n\n private async _loadWebpackAsync(): Promise<typeof TWebpack> {\n if (!this._webpack) {\n // Allow this to fail if webpack is not installed\n this._webpack = await import(WEBPACK_PACKAGE_NAME);\n }\n return this._webpack!;\n }\n\n private async _getWebpackCompilerAsync(\n taskSession: IHeftTaskSession,\n webpackConfiguration: IWebpackConfiguration\n ): Promise<TWebpack.Compiler | TWebpack.MultiCompiler> {\n if (!this._webpackCompiler) {\n const webpack: typeof TWebpack = await this._loadWebpackAsync();\n taskSession.logger.terminal.writeLine(`Using Webpack version ${webpack.version}`);\n this._webpackCompiler = Array.isArray(webpackConfiguration)\n ? webpack.default(webpackConfiguration) /* (webpack.Compilation[]) => MultiCompiler */\n : webpack.default(webpackConfiguration); /* (webpack.Compilation) => Compiler */\n }\n return this._webpackCompiler;\n }\n\n private async _runWebpackAsync(\n taskSession: IHeftTaskSession,\n heftConfiguration: HeftConfiguration,\n options: IWebpackPluginOptions\n ): Promise<void> {\n this._validateEnvironmentVariable(taskSession);\n if (taskSession.parameters.watch || this._isServeMode) {\n // Should never happen, but just in case\n throw new InternalError('Cannot run Webpack in compilation mode when watch mode is enabled');\n }\n\n // Load the config and compiler, and return if there is no config found\n const webpackConfiguration: IWebpackConfiguration | undefined = await this._getWebpackConfigurationAsync(\n taskSession,\n heftConfiguration,\n options\n );\n if (!webpackConfiguration) {\n return;\n }\n const compiler: TWebpack.Compiler | TWebpack.MultiCompiler = await this._getWebpackCompilerAsync(\n taskSession,\n webpackConfiguration\n );\n taskSession.logger.terminal.writeLine('Running Webpack compilation');\n\n // Run the webpack compiler\n let stats: TWebpack.Stats | TWebpack.MultiStats | undefined;\n try {\n stats = await LegacyAdapters.convertCallbackToPromise(\n (compiler as TWebpack.Compiler).run.bind(compiler)\n );\n await LegacyAdapters.convertCallbackToPromise(compiler.close.bind(compiler));\n } catch (e) {\n taskSession.logger.emitError(e as Error);\n }\n\n // Emit the errors from the stats object, if present\n if (stats) {\n this._recordErrors(stats, heftConfiguration.buildFolderPath);\n this._emitErrors(taskSession.logger);\n if (this.accessor.hooks.onEmitStats.isUsed()) {\n await this.accessor.hooks.onEmitStats.promise(stats);\n }\n }\n }\n\n private async _runWebpackWatchAsync(\n taskSession: IHeftTaskSession,\n heftConfiguration: HeftConfiguration,\n options: IWebpackPluginOptions,\n requestRun: () => void\n ): Promise<void> {\n // Save a handle to the original promise, since the this-scoped promise will be replaced whenever\n // the compilation completes.\n let webpackCompilationDonePromise: Promise<void> | undefined = this._webpackCompilationDonePromise;\n\n let isInitial: boolean = false;\n\n if (!this._webpackCompiler) {\n isInitial = true;\n this._validateEnvironmentVariable(taskSession);\n if (!taskSession.parameters.watch) {\n // Should never happen, but just in case\n throw new InternalError('Cannot run Webpack in watch mode when compilation mode is enabled');\n }\n\n // Load the config and compiler, and return if there is no config found\n const webpackConfiguration: IWebpackConfiguration | undefined =\n await this._getWebpackConfigurationAsync(taskSession, heftConfiguration, options, requestRun);\n if (!webpackConfiguration) {\n return;\n }\n\n // Get the compiler which will be used for both serve and watch mode\n const compiler: TWebpack.Compiler | TWebpack.MultiCompiler = await this._getWebpackCompilerAsync(\n taskSession,\n webpackConfiguration\n );\n\n // Set up the hook to detect when the watcher completes the watcher compilation. We will also log out\n // errors from the compilation if present from the output stats object.\n this._webpackCompilationDonePromise = new Promise((resolve: () => void) => {\n this._webpackCompilationDonePromiseResolveFn = resolve;\n });\n webpackCompilationDonePromise = this._webpackCompilationDonePromise;\n compiler.hooks.done.tap(PLUGIN_NAME, (stats?: TWebpack.Stats | TWebpack.MultiStats) => {\n this._webpackCompilationDonePromiseResolveFn!();\n this._webpackCompilationDonePromise = new Promise((resolve: () => void) => {\n this._webpackCompilationDonePromiseResolveFn = resolve;\n });\n\n if (stats) {\n this._recordErrors(stats, heftConfiguration.buildFolderPath);\n }\n });\n\n // Determine how we will run the compiler. When serving, we will run the compiler\n // via the webpack-dev-server. Otherwise, we will run the compiler directly.\n if (this._isServeMode) {\n const defaultDevServerOptions: TWebpackDevServer.Configuration = {\n host: 'localhost',\n devMiddleware: {\n publicPath: '/',\n stats: {\n cached: false,\n cachedAssets: false,\n colors: heftConfiguration.terminalProvider.supportsColor\n }\n },\n client: {\n logging: 'info',\n webSocketURL: {\n port: 8080\n }\n },\n port: 8080,\n onListening: (server: TWebpackDevServer) => {\n const addressInfo: AddressInfo | string | undefined = server.server?.address() as AddressInfo;\n if (addressInfo) {\n const address: string =\n typeof addressInfo === 'string' ? addressInfo : `${addressInfo.address}:${addressInfo.port}`;\n taskSession.logger.terminal.writeLine(`Started Webpack Dev Server at https://${address}`);\n }\n }\n };\n\n // Obtain the devServerOptions from the webpack configuration, and combine with the default options\n let devServerOptions: TWebpackDevServer.Configuration;\n if (Array.isArray(webpackConfiguration)) {\n const filteredDevServerOptions: TWebpackDevServer.Configuration[] = webpackConfiguration\n .map((configuration) => configuration.devServer)\n .filter((devServer): devServer is TWebpackDevServer.Configuration => !!devServer);\n if (filteredDevServerOptions.length > 1) {\n taskSession.logger.emitWarning(\n new Error(`Detected multiple webpack devServer configurations, using the first one.`)\n );\n }\n devServerOptions = { ...defaultDevServerOptions, ...filteredDevServerOptions[0] };\n } else {\n devServerOptions = { ...defaultDevServerOptions, ...webpackConfiguration.devServer };\n }\n\n // Add the certificate and key to the devServerOptions if these fields don't already have values\n if (!devServerOptions.server) {\n const certificateManager: CertificateManager = new CertificateManager();\n const certificate: ICertificate = await certificateManager.ensureCertificateAsync(\n true,\n taskSession.logger.terminal\n );\n\n // Update the web socket URL to use the hostname provided by the certificate\n const clientConfiguration: TWebpackDevServer.Configuration['client'] = devServerOptions.client;\n const hostname: string | undefined = certificate.subjectAltNames?.[0];\n if (hostname && typeof clientConfiguration === 'object') {\n const { webSocketURL } = clientConfiguration;\n if (typeof webSocketURL === 'object') {\n clientConfiguration.webSocketURL = {\n ...webSocketURL,\n hostname\n };\n }\n }\n\n devServerOptions = {\n ...devServerOptions,\n server: {\n type: 'https',\n options: {\n minVersion: 'TLSv1.3',\n key: certificate.pemKey,\n cert: certificate.pemCertificate,\n ca: certificate.pemCaCertificate\n }\n }\n };\n }\n\n // Since the webpack-dev-server does not return infrastructure errors via a callback like\n // compiler.watch(...), we will need to intercept them and log them ourselves.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n compiler.hooks.infrastructureLog.tap(PLUGIN_NAME, (name: string, type: string, args: any[]) => {\n if (name === WEBPACK_DEV_MIDDLEWARE_PACKAGE_NAME && type === 'error') {\n const error: Error | undefined = args[0];\n if (error) {\n taskSession.logger.emitError(error);\n }\n }\n return true;\n });\n\n // The webpack-dev-server package has a design flaw, where merely loading its package will set the\n // WEBPACK_DEV_SERVER environment variable -- even if no APIs are accessed. This environment variable\n // causes incorrect behavior if Heft is not running in serve mode. Thus, we need to be careful to call\n // require() only if Heft is in serve mode.\n taskSession.logger.terminal.writeLine('Starting webpack-dev-server');\n const WebpackDevServer: typeof TWebpackDevServer = (await import(WEBPACK_DEV_SERVER_PACKAGE_NAME))\n .default;\n const webpackDevServer: TWebpackDevServer = new WebpackDevServer(devServerOptions, compiler);\n await webpackDevServer.start();\n } else {\n // Create the watcher. Compilation will start immediately after invoking watch().\n taskSession.logger.terminal.writeLine('Starting Webpack watcher');\n compiler.watch({}, (error?: Error | null) => {\n if (error) {\n taskSession.logger.emitError(error);\n }\n });\n }\n }\n\n let hasChanges: boolean = true;\n if (!isInitial && this._watchFileSystems) {\n hasChanges = false;\n for (const watchFileSystem of this._watchFileSystems) {\n hasChanges = watchFileSystem.flush() || hasChanges;\n }\n }\n\n // Resume the compilation, wait for the compilation to complete, then suspend the watchers until the\n // next iteration. Even if there are no changes, the promise should resolve since resuming from a\n // suspended state invalidates the state of the watcher.\n if (hasChanges) {\n taskSession.logger.terminal.writeLine('Running incremental Webpack compilation');\n await webpackCompilationDonePromise;\n } else {\n taskSession.logger.terminal.writeLine(\n 'Webpack has not detected changes. Listing previous diagnostics.'\n );\n }\n\n this._emitErrors(taskSession.logger);\n }\n\n private _validateEnvironmentVariable(taskSession: IHeftTaskSession): void {\n if (!this._isServeMode && process.env[WEBPACK_DEV_SERVER_ENV_VAR_NAME]) {\n taskSession.logger.emitWarning(\n new Error(\n `The \"${WEBPACK_DEV_SERVER_ENV_VAR_NAME}\" environment variable is set, ` +\n 'which will cause problems when webpack is not running in serve mode. ' +\n `(Did a dependency inadvertently load the \"${WEBPACK_DEV_SERVER_PACKAGE_NAME}\" package?)`\n )\n );\n }\n }\n\n private _emitErrors(logger: IScopedLogger): void {\n for (const warning of this._warnings) {\n logger.emitWarning(warning);\n }\n for (const error of this._errors) {\n logger.emitError(error);\n }\n }\n\n private _recordErrors(stats: TWebpack.Stats | TWebpack.MultiStats, buildFolderPath: string): void {\n const errors: Error[] = this._errors;\n const warnings: Error[] = this._warnings;\n\n errors.length = 0;\n warnings.length = 0;\n\n if (stats.hasErrors() || stats.hasWarnings()) {\n const serializedStats: TWebpack.StatsCompilation[] = [stats.toJson('errors-warnings')];\n\n for (const compilationStats of serializedStats) {\n if (compilationStats.warnings) {\n for (const warning of compilationStats.warnings) {\n warnings.push(this._normalizeError(buildFolderPath, warning));\n }\n }\n\n if (compilationStats.errors) {\n for (const error of compilationStats.errors) {\n errors.push(this._normalizeError(buildFolderPath, error));\n }\n }\n\n if (compilationStats.children) {\n for (const child of compilationStats.children) {\n serializedStats.push(child);\n }\n }\n }\n }\n }\n\n private _normalizeError(buildFolderPath: string, error: TWebpack.StatsError): Error {\n if (error instanceof Error) {\n return error;\n } else if (error.moduleIdentifier) {\n let lineNumber: number | undefined;\n let columnNumber: number | undefined;\n if (error.loc) {\n // Format of \"<line>:<columnStart>-<columnEnd>\"\n // https://webpack.js.org/api/stats/#errors-and-warnings\n const [lineNumberRaw, columnRangeRaw] = error.loc.split(':');\n const [startColumnRaw] = columnRangeRaw.split('-');\n if (lineNumberRaw) {\n lineNumber = parseInt(lineNumberRaw, 10);\n if (isNaN(lineNumber)) {\n lineNumber = undefined;\n }\n }\n if (startColumnRaw) {\n columnNumber = parseInt(startColumnRaw, 10);\n if (isNaN(columnNumber)) {\n columnNumber = undefined;\n }\n }\n }\n\n return new FileError(error.message, {\n absolutePath: error.moduleIdentifier,\n projectFolder: buildFolderPath,\n line: lineNumber,\n column: columnNumber\n });\n } else {\n return new Error(error.message);\n }\n }\n}\n\n/**\n * @internal\n */\nexport function _createAccessorHooks(): IWebpackPluginAccessorHooks {\n return {\n onLoadConfiguration: new AsyncSeriesBailHook(),\n onConfigure: new AsyncSeriesHook(['webpackConfiguration']),\n onAfterConfigure: new AsyncParallelHook(['webpackConfiguration']),\n onEmitStats: new AsyncParallelHook(['webpackStats'])\n };\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WebpackConfigurationLoader.js","sourceRoot":"","sources":["../src/WebpackConfigurationLoader.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\r\n// See LICENSE in the project root for license information.\r\n\r\nimport * as path from 'path';\r\nimport type * as TWebpack from 'webpack';\r\nimport { FileSystem } from '@rushstack/node-core-library';\r\nimport type { IHeftTaskSession, HeftConfiguration } from '@rushstack/heft';\r\n\r\nimport type { IWebpackPluginOptions } from './Webpack5Plugin';\r\nimport {\r\n PLUGIN_NAME,\r\n STAGE_LOAD_LOCAL_CONFIG,\r\n type IWebpackConfiguration,\r\n type IWebpackConfigurationFnEnvironment,\r\n type IWebpackPluginAccessorHooks\r\n} from './shared';\r\n\r\ntype IWebpackConfigJsExport =\r\n | TWebpack.Configuration\r\n | TWebpack.Configuration[]\r\n | Promise<TWebpack.Configuration>\r\n | Promise<TWebpack.Configuration[]>\r\n | ((env: IWebpackConfigurationFnEnvironment) => TWebpack.Configuration | TWebpack.Configuration[])\r\n | ((env: IWebpackConfigurationFnEnvironment) => Promise<TWebpack.Configuration | TWebpack.Configuration[]>);\r\ntype IWebpackConfigJs = IWebpackConfigJsExport | { default: IWebpackConfigJsExport };\r\n\r\n/**\r\n * @internal\r\n */\r\nexport interface ILoadWebpackConfigurationOptions {\r\n taskSession: IHeftTaskSession;\r\n heftConfiguration: HeftConfiguration;\r\n serveMode: boolean;\r\n loadWebpackAsyncFn: () => Promise<typeof TWebpack>;\r\n hooks: Pick<IWebpackPluginAccessorHooks, 'onLoadConfiguration' | 'onConfigure' | 'onAfterConfigure'>;\r\n\r\n _tryLoadConfigFileAsync?: typeof tryLoadWebpackConfigurationFileAsync;\r\n}\r\n\r\nconst DEFAULT_WEBPACK_CONFIG_PATH: './webpack.config.js' = './webpack.config.js';\r\nconst DEFAULT_WEBPACK_DEV_CONFIG_PATH: './webpack.dev.config.js' = './webpack.dev.config.js';\r\n\r\n/**\r\n * @internal\r\n */\r\nexport async function tryLoadWebpackConfigurationAsync(\r\n options: ILoadWebpackConfigurationOptions,\r\n pluginOptions: IWebpackPluginOptions\r\n): Promise<IWebpackConfiguration | undefined> {\r\n const { taskSession, hooks, _tryLoadConfigFileAsync = tryLoadWebpackConfigurationFileAsync } = options;\r\n const { logger } = taskSession;\r\n const { terminal } = logger;\r\n\r\n // Apply default behavior. Due to the state of `this._webpackConfiguration`, this code\r\n // will execute exactly once.\r\n hooks.onLoadConfiguration.tapPromise(\r\n {\r\n name: PLUGIN_NAME,\r\n stage: STAGE_LOAD_LOCAL_CONFIG\r\n },\r\n async () => {\r\n terminal.writeVerboseLine(`Attempting to load Webpack configuration from local file`);\r\n const webpackConfiguration: IWebpackConfiguration | undefined = await _tryLoadConfigFileAsync(\r\n options,\r\n pluginOptions\r\n );\r\n\r\n if (webpackConfiguration) {\r\n terminal.writeVerboseLine(`Loaded Webpack configuration from local file.`);\r\n }\r\n\r\n return webpackConfiguration;\r\n }\r\n );\r\n\r\n // Obtain the webpack configuration by calling into the hook.\r\n // The local configuration is loaded at STAGE_LOAD_LOCAL_CONFIG\r\n terminal.writeVerboseLine('Attempting to load Webpack configuration');\r\n let webpackConfiguration: IWebpackConfiguration | false | undefined =\r\n await hooks.onLoadConfiguration.promise();\r\n\r\n if (webpackConfiguration === false) {\r\n terminal.writeLine('Webpack disabled by external plugin');\r\n webpackConfiguration = undefined;\r\n } else if (\r\n webpackConfiguration === undefined ||\r\n (Array.isArray(webpackConfiguration) && webpackConfiguration.length === 0)\r\n ) {\r\n terminal.writeLine('No Webpack configuration found');\r\n webpackConfiguration = undefined;\r\n } else {\r\n if (hooks.onConfigure.isUsed()) {\r\n // Allow for plugins to customise the configuration\r\n await hooks.onConfigure.promise(webpackConfiguration);\r\n }\r\n if (hooks.onAfterConfigure.isUsed()) {\r\n // Provide the finalized configuration\r\n await hooks.onAfterConfigure.promise(webpackConfiguration);\r\n }\r\n }\r\n return webpackConfiguration;\r\n}\r\n\r\n/**\r\n * @internal\r\n */\r\nexport async function tryLoadWebpackConfigurationFileAsync(\r\n options: ILoadWebpackConfigurationOptions,\r\n pluginOptions: IWebpackPluginOptions\r\n): Promise<IWebpackConfiguration | undefined> {\r\n // TODO: Eventually replace this custom logic with a call to this utility in in webpack-cli:\r\n // https://github.com/webpack/webpack-cli/blob/next/packages/webpack-cli/lib/groups/ConfigGroup.js\r\n\r\n const { taskSession, heftConfiguration, loadWebpackAsyncFn, serveMode } = options;\r\n const {\r\n logger,\r\n parameters: { production }\r\n } = taskSession;\r\n const { terminal } = logger;\r\n const { configurationPath, devConfigurationPath } = pluginOptions;\r\n let webpackConfigJs: IWebpackConfigJs | undefined;\r\n\r\n try {\r\n const buildFolderPath: string = heftConfiguration.buildFolderPath;\r\n if (serveMode) {\r\n const devConfigPath: string = path.resolve(\r\n buildFolderPath,\r\n devConfigurationPath || DEFAULT_WEBPACK_DEV_CONFIG_PATH\r\n );\r\n terminal.writeVerboseLine(`Attempting to load webpack configuration from \"${devConfigPath}\".`);\r\n webpackConfigJs = await _tryLoadWebpackConfigurationFileInnerAsync(devConfigPath);\r\n }\r\n\r\n if (!webpackConfigJs) {\r\n const configPath: string = path.resolve(\r\n buildFolderPath,\r\n configurationPath || DEFAULT_WEBPACK_CONFIG_PATH\r\n );\r\n terminal.writeVerboseLine(`Attempting to load webpack configuration from \"${configPath}\".`);\r\n webpackConfigJs = await _tryLoadWebpackConfigurationFileInnerAsync(configPath);\r\n }\r\n } catch (error) {\r\n logger.emitError(error as Error);\r\n }\r\n\r\n if (webpackConfigJs) {\r\n const webpackConfig: IWebpackConfigJsExport =\r\n (webpackConfigJs as { default: IWebpackConfigJsExport }).default || webpackConfigJs;\r\n\r\n if (typeof webpackConfig === 'function') {\r\n // Defer loading of webpack until we know for sure that we will need it\r\n return webpackConfig({\r\n prod: production,\r\n production,\r\n taskSession,\r\n heftConfiguration,\r\n webpack: await loadWebpackAsyncFn()\r\n });\r\n } else {\r\n return webpackConfig;\r\n }\r\n } else {\r\n return undefined;\r\n }\r\n}\r\n\r\n/**\r\n * @internal\r\n */\r\nexport async function _tryLoadWebpackConfigurationFileInnerAsync(\r\n configurationPath: string\r\n): Promise<IWebpackConfigJs | undefined> {\r\n const configExists: boolean = await FileSystem.existsAsync(configurationPath);\r\n if (configExists) {\r\n try {\r\n return await import(configurationPath);\r\n } catch (e) {\r\n const error: NodeJS.ErrnoException = e as NodeJS.ErrnoException;\r\n if (error.code === 'ERR_MODULE_NOT_FOUND') {\r\n // No configuration found, return undefined.\r\n return undefined;\r\n }\r\n throw new Error(`Error loading webpack configuration at \"${configurationPath}\": ${e}`);\r\n }\r\n } else {\r\n return undefined;\r\n }\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"WebpackConfigurationLoader.js","sourceRoot":"","sources":["../src/WebpackConfigurationLoader.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\n// See LICENSE in the project root for license information.\n\nimport * as path from 'path';\nimport type * as TWebpack from 'webpack';\nimport { FileSystem } from '@rushstack/node-core-library';\nimport type { IHeftTaskSession, HeftConfiguration } from '@rushstack/heft';\n\nimport type { IWebpackPluginOptions } from './Webpack5Plugin';\nimport {\n PLUGIN_NAME,\n STAGE_LOAD_LOCAL_CONFIG,\n type IWebpackConfiguration,\n type IWebpackConfigurationFnEnvironment,\n type IWebpackPluginAccessorHooks\n} from './shared';\n\ntype IWebpackConfigJsExport =\n | TWebpack.Configuration\n | TWebpack.Configuration[]\n | Promise<TWebpack.Configuration>\n | Promise<TWebpack.Configuration[]>\n | ((env: IWebpackConfigurationFnEnvironment) => TWebpack.Configuration | TWebpack.Configuration[])\n | ((env: IWebpackConfigurationFnEnvironment) => Promise<TWebpack.Configuration | TWebpack.Configuration[]>);\ntype IWebpackConfigJs = IWebpackConfigJsExport | { default: IWebpackConfigJsExport };\n\n/**\n * @internal\n */\nexport interface ILoadWebpackConfigurationOptions {\n taskSession: IHeftTaskSession;\n heftConfiguration: HeftConfiguration;\n serveMode: boolean;\n loadWebpackAsyncFn: () => Promise<typeof TWebpack>;\n hooks: Pick<IWebpackPluginAccessorHooks, 'onLoadConfiguration' | 'onConfigure' | 'onAfterConfigure'>;\n\n _tryLoadConfigFileAsync?: typeof tryLoadWebpackConfigurationFileAsync;\n}\n\nconst DEFAULT_WEBPACK_CONFIG_PATH: './webpack.config.js' = './webpack.config.js';\nconst DEFAULT_WEBPACK_DEV_CONFIG_PATH: './webpack.dev.config.js' = './webpack.dev.config.js';\n\n/**\n * @internal\n */\nexport async function tryLoadWebpackConfigurationAsync(\n options: ILoadWebpackConfigurationOptions,\n pluginOptions: IWebpackPluginOptions\n): Promise<IWebpackConfiguration | undefined> {\n const { taskSession, hooks, _tryLoadConfigFileAsync = tryLoadWebpackConfigurationFileAsync } = options;\n const { logger } = taskSession;\n const { terminal } = logger;\n\n // Apply default behavior. Due to the state of `this._webpackConfiguration`, this code\n // will execute exactly once.\n hooks.onLoadConfiguration.tapPromise(\n {\n name: PLUGIN_NAME,\n stage: STAGE_LOAD_LOCAL_CONFIG\n },\n async () => {\n terminal.writeVerboseLine(`Attempting to load Webpack configuration from local file`);\n const webpackConfiguration: IWebpackConfiguration | undefined = await _tryLoadConfigFileAsync(\n options,\n pluginOptions\n );\n\n if (webpackConfiguration) {\n terminal.writeVerboseLine(`Loaded Webpack configuration from local file.`);\n }\n\n return webpackConfiguration;\n }\n );\n\n // Obtain the webpack configuration by calling into the hook.\n // The local configuration is loaded at STAGE_LOAD_LOCAL_CONFIG\n terminal.writeVerboseLine('Attempting to load Webpack configuration');\n let webpackConfiguration: IWebpackConfiguration | false | undefined =\n await hooks.onLoadConfiguration.promise();\n\n if (webpackConfiguration === false) {\n terminal.writeLine('Webpack disabled by external plugin');\n webpackConfiguration = undefined;\n } else if (\n webpackConfiguration === undefined ||\n (Array.isArray(webpackConfiguration) && webpackConfiguration.length === 0)\n ) {\n terminal.writeLine('No Webpack configuration found');\n webpackConfiguration = undefined;\n } else {\n if (hooks.onConfigure.isUsed()) {\n // Allow for plugins to customise the configuration\n await hooks.onConfigure.promise(webpackConfiguration);\n }\n if (hooks.onAfterConfigure.isUsed()) {\n // Provide the finalized configuration\n await hooks.onAfterConfigure.promise(webpackConfiguration);\n }\n }\n return webpackConfiguration;\n}\n\n/**\n * @internal\n */\nexport async function tryLoadWebpackConfigurationFileAsync(\n options: ILoadWebpackConfigurationOptions,\n pluginOptions: IWebpackPluginOptions\n): Promise<IWebpackConfiguration | undefined> {\n // TODO: Eventually replace this custom logic with a call to this utility in in webpack-cli:\n // https://github.com/webpack/webpack-cli/blob/next/packages/webpack-cli/lib/groups/ConfigGroup.js\n\n const { taskSession, heftConfiguration, loadWebpackAsyncFn, serveMode } = options;\n const {\n logger,\n parameters: { production }\n } = taskSession;\n const { terminal } = logger;\n const { configurationPath, devConfigurationPath } = pluginOptions;\n let webpackConfigJs: IWebpackConfigJs | undefined;\n\n try {\n const buildFolderPath: string = heftConfiguration.buildFolderPath;\n if (serveMode) {\n const devConfigPath: string = path.resolve(\n buildFolderPath,\n devConfigurationPath || DEFAULT_WEBPACK_DEV_CONFIG_PATH\n );\n terminal.writeVerboseLine(`Attempting to load webpack configuration from \"${devConfigPath}\".`);\n webpackConfigJs = await _tryLoadWebpackConfigurationFileInnerAsync(devConfigPath);\n }\n\n if (!webpackConfigJs) {\n const configPath: string = path.resolve(\n buildFolderPath,\n configurationPath || DEFAULT_WEBPACK_CONFIG_PATH\n );\n terminal.writeVerboseLine(`Attempting to load webpack configuration from \"${configPath}\".`);\n webpackConfigJs = await _tryLoadWebpackConfigurationFileInnerAsync(configPath);\n }\n } catch (error) {\n logger.emitError(error as Error);\n }\n\n if (webpackConfigJs) {\n const webpackConfig: IWebpackConfigJsExport =\n (webpackConfigJs as { default: IWebpackConfigJsExport }).default || webpackConfigJs;\n\n if (typeof webpackConfig === 'function') {\n // Defer loading of webpack until we know for sure that we will need it\n return webpackConfig({\n prod: production,\n production,\n taskSession,\n heftConfiguration,\n webpack: await loadWebpackAsyncFn()\n });\n } else {\n return webpackConfig;\n }\n } else {\n return undefined;\n }\n}\n\n/**\n * @internal\n */\nexport async function _tryLoadWebpackConfigurationFileInnerAsync(\n configurationPath: string\n): Promise<IWebpackConfigJs | undefined> {\n const configExists: boolean = await FileSystem.existsAsync(configurationPath);\n if (configExists) {\n try {\n return await import(configurationPath);\n } catch (e) {\n const error: NodeJS.ErrnoException = e as NodeJS.ErrnoException;\n if (error.code === 'ERR_MODULE_NOT_FOUND') {\n // No configuration found, return undefined.\n return undefined;\n }\n throw new Error(`Error loading webpack configuration at \"${configurationPath}\": ${e}`);\n }\n } else {\n return undefined;\n }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WebpackConfigurationLoader.test.js","sourceRoot":"","sources":["../src/WebpackConfigurationLoader.test.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\r\n// See LICENSE in the project root for license information.\r\n\r\nimport type { HeftConfiguration, IHeftParameters, IHeftTaskSession, IScopedLogger } from '@rushstack/heft';\r\nimport { MockScopedLogger } from '@rushstack/heft/lib/pluginFramework/logging/MockScopedLogger';\r\nimport { type ITerminal, StringBufferTerminalProvider, Terminal } from '@rushstack/node-core-library';\r\n\r\nimport * as WebpackConfigurationLoader from './WebpackConfigurationLoader';\r\nimport { _createAccessorHooks } from './Webpack5Plugin';\r\nimport { type IWebpackConfiguration, STAGE_LOAD_LOCAL_CONFIG } from './shared';\r\n\r\ninterface IMockLoadWebpackConfigurationOptions\r\n extends WebpackConfigurationLoader.ILoadWebpackConfigurationOptions {\r\n loadWebpackAsyncFn: jest.Mock;\r\n _terminalProvider: StringBufferTerminalProvider;\r\n _tryLoadConfigFileAsync: jest.Mock;\r\n}\r\n\r\ndescribe(WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync.name, () => {\r\n function createOptions(production: boolean, serveMode: boolean): IMockLoadWebpackConfigurationOptions {\r\n const terminalProvider: StringBufferTerminalProvider = new StringBufferTerminalProvider(false);\r\n const terminal: ITerminal = new Terminal(terminalProvider);\r\n const logger: IScopedLogger = new MockScopedLogger(terminal);\r\n const buildFolderPath: string = __dirname;\r\n\r\n const parameters: Partial<IHeftParameters> = {\r\n production\r\n };\r\n\r\n const taskSession: IHeftTaskSession = {\r\n logger,\r\n parameters: parameters as unknown as IHeftParameters,\r\n // Other values unused during these tests\r\n hooks: undefined!,\r\n parsedCommandLine: undefined!,\r\n requestAccessToPluginByName: undefined!,\r\n taskName: 'webpack',\r\n tempFolderPath: `${__dirname}/temp`\r\n };\r\n\r\n const heftConfiguration: Partial<HeftConfiguration> = {\r\n buildFolderPath\r\n };\r\n\r\n return {\r\n taskSession,\r\n heftConfiguration: heftConfiguration as unknown as HeftConfiguration,\r\n hooks: _createAccessorHooks(),\r\n loadWebpackAsyncFn: jest.fn(),\r\n serveMode,\r\n\r\n _terminalProvider: terminalProvider,\r\n _tryLoadConfigFileAsync: jest.fn()\r\n };\r\n }\r\n\r\n it(`onLoadConfiguration can return false`, async () => {\r\n const options: IMockLoadWebpackConfigurationOptions = createOptions(false, false);\r\n\r\n const onLoadConfiguration: jest.Mock = jest.fn();\r\n const onConfigure: jest.Mock = jest.fn();\r\n const onAfterConfigure: jest.Mock = jest.fn();\r\n\r\n options.hooks.onLoadConfiguration.tap('test', onLoadConfiguration);\r\n options.hooks.onConfigure.tap('test', onConfigure);\r\n options.hooks.onAfterConfigure.tap('test', onAfterConfigure);\r\n\r\n onLoadConfiguration.mockReturnValue(false);\r\n\r\n const config: IWebpackConfiguration | undefined =\r\n await WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync(options, {});\r\n expect(config).toBeUndefined();\r\n expect(onLoadConfiguration).toHaveBeenCalledTimes(1);\r\n expect(options._tryLoadConfigFileAsync).toHaveBeenCalledTimes(0);\r\n expect(onConfigure).toHaveBeenCalledTimes(0);\r\n expect(onAfterConfigure).toHaveBeenCalledTimes(0);\r\n });\r\n\r\n it(`calls tryLoadWebpackConfigurationFileAsync`, async () => {\r\n const options: IMockLoadWebpackConfigurationOptions = createOptions(false, false);\r\n\r\n const onConfigure: jest.Mock = jest.fn();\r\n const onAfterConfigure: jest.Mock = jest.fn();\r\n\r\n options.hooks.onConfigure.tap('test', onConfigure);\r\n options.hooks.onAfterConfigure.tap('test', onAfterConfigure);\r\n\r\n options._tryLoadConfigFileAsync.mockReturnValue(Promise.resolve(undefined));\r\n\r\n const config: IWebpackConfiguration | undefined =\r\n await WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync(options, {});\r\n expect(config).toBeUndefined();\r\n expect(options._tryLoadConfigFileAsync).toHaveBeenCalledTimes(1);\r\n expect(onConfigure).toHaveBeenCalledTimes(0);\r\n expect(onAfterConfigure).toHaveBeenCalledTimes(0);\r\n });\r\n\r\n it(`can fall back`, async () => {\r\n const options: IMockLoadWebpackConfigurationOptions = createOptions(false, false);\r\n\r\n const onLoadConfiguration: jest.Mock = jest.fn();\r\n const onConfigure: jest.Mock = jest.fn();\r\n const onAfterConfigure: jest.Mock = jest.fn();\r\n\r\n options.hooks.onLoadConfiguration.tap(\r\n { name: 'test', stage: STAGE_LOAD_LOCAL_CONFIG + 1 },\r\n onLoadConfiguration\r\n );\r\n options.hooks.onConfigure.tap('test', onConfigure);\r\n options.hooks.onAfterConfigure.tap('test', onAfterConfigure);\r\n\r\n options._tryLoadConfigFileAsync.mockReturnValue(Promise.resolve(undefined));\r\n\r\n const mockConfig: IWebpackConfiguration = {};\r\n onLoadConfiguration.mockReturnValue(mockConfig);\r\n\r\n const config: IWebpackConfiguration | undefined =\r\n await WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync(options, {});\r\n expect(config).toBe(mockConfig);\r\n\r\n expect(options._tryLoadConfigFileAsync).toHaveBeenCalledTimes(1);\r\n expect(onLoadConfiguration).toHaveBeenCalledTimes(1);\r\n expect(onConfigure).toHaveBeenCalledTimes(1);\r\n expect(onAfterConfigure).toHaveBeenCalledTimes(1);\r\n\r\n expect(onConfigure).toHaveBeenCalledWith(mockConfig);\r\n expect(onAfterConfigure).toHaveBeenCalledWith(mockConfig);\r\n });\r\n\r\n it(`respects hook order`, async () => {\r\n const options: IMockLoadWebpackConfigurationOptions = createOptions(false, false);\r\n\r\n const onConfigure: jest.Mock = jest.fn();\r\n const onAfterConfigure: jest.Mock = jest.fn();\r\n\r\n options.hooks.onConfigure.tap('test', onConfigure);\r\n options.hooks.onAfterConfigure.tap('test', onAfterConfigure);\r\n\r\n const mockConfig: IWebpackConfiguration = {};\r\n\r\n options._tryLoadConfigFileAsync.mockReturnValue(Promise.resolve(mockConfig));\r\n\r\n const config: IWebpackConfiguration | undefined =\r\n await WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync(options, {});\r\n expect(config).toBe(mockConfig);\r\n expect(options._tryLoadConfigFileAsync).toHaveBeenCalledTimes(1);\r\n expect(onConfigure).toHaveBeenCalledTimes(1);\r\n expect(onConfigure).toHaveBeenCalledWith(mockConfig);\r\n expect(onAfterConfigure).toHaveBeenCalledTimes(1);\r\n expect(onAfterConfigure).toHaveBeenCalledWith(mockConfig);\r\n });\r\n});\r\n"]}
|
|
1
|
+
{"version":3,"file":"WebpackConfigurationLoader.test.js","sourceRoot":"","sources":["../src/WebpackConfigurationLoader.test.ts"],"names":[],"mappings":";AAAA,4FAA4F;AAC5F,2DAA2D;;;;;;;;;;;;;;;;;;;;;;;;;AAG3D,mGAAgG;AAChG,oEAAsG;AAEtG,yFAA2E;AAC3E,qDAAwD;AACxD,qCAA+E;AAS/E,QAAQ,CAAC,0BAA0B,CAAC,gCAAgC,CAAC,IAAI,EAAE,GAAG,EAAE;IAC9E,SAAS,aAAa,CAAC,UAAmB,EAAE,SAAkB;QAC5D,MAAM,gBAAgB,GAAiC,IAAI,gDAA4B,CAAC,KAAK,CAAC,CAAC;QAC/F,MAAM,QAAQ,GAAc,IAAI,4BAAQ,CAAC,gBAAgB,CAAC,CAAC;QAC3D,MAAM,MAAM,GAAkB,IAAI,mCAAgB,CAAC,QAAQ,CAAC,CAAC;QAC7D,MAAM,eAAe,GAAW,SAAS,CAAC;QAE1C,MAAM,UAAU,GAA6B;YAC3C,UAAU;SACX,CAAC;QAEF,MAAM,WAAW,GAAqB;YACpC,MAAM;YACN,UAAU,EAAE,UAAwC;YACpD,yCAAyC;YACzC,KAAK,EAAE,SAAU;YACjB,iBAAiB,EAAE,SAAU;YAC7B,2BAA2B,EAAE,SAAU;YACvC,QAAQ,EAAE,SAAS;YACnB,cAAc,EAAE,GAAG,SAAS,OAAO;SACpC,CAAC;QAEF,MAAM,iBAAiB,GAA+B;YACpD,eAAe;SAChB,CAAC;QAEF,OAAO;YACL,WAAW;YACX,iBAAiB,EAAE,iBAAiD;YACpE,KAAK,EAAE,IAAA,qCAAoB,GAAE;YAC7B,kBAAkB,EAAE,IAAI,CAAC,EAAE,EAAE;YAC7B,SAAS;YAET,iBAAiB,EAAE,gBAAgB;YACnC,uBAAuB,EAAE,IAAI,CAAC,EAAE,EAAE;SACnC,CAAC;IACJ,CAAC;IAED,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,OAAO,GAAyC,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAElF,MAAM,mBAAmB,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QACjD,MAAM,WAAW,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QACzC,MAAM,gBAAgB,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QAE9C,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;QACnE,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QACnD,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QAE7D,mBAAmB,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAE3C,MAAM,MAAM,GACV,MAAM,0BAA0B,CAAC,gCAAgC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACjF,MAAM,CAAC,MAAM,CAAC,CAAC,aAAa,EAAE,CAAC;QAC/B,MAAM,CAAC,mBAAmB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACjE,MAAM,CAAC,WAAW,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,gBAAgB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,OAAO,GAAyC,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAElF,MAAM,WAAW,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QACzC,MAAM,gBAAgB,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QAE9C,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QACnD,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QAE7D,OAAO,CAAC,uBAAuB,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;QAE5E,MAAM,MAAM,GACV,MAAM,0BAA0B,CAAC,gCAAgC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACjF,MAAM,CAAC,MAAM,CAAC,CAAC,aAAa,EAAE,CAAC;QAC/B,MAAM,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACjE,MAAM,CAAC,WAAW,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,gBAAgB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE;QAC7B,MAAM,OAAO,GAAyC,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAElF,MAAM,mBAAmB,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QACjD,MAAM,WAAW,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QACzC,MAAM,gBAAgB,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QAE9C,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,GAAG,CACnC,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,gCAAuB,GAAG,CAAC,EAAE,EACpD,mBAAmB,CACpB,CAAC;QACF,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QACnD,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QAE7D,OAAO,CAAC,uBAAuB,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;QAE5E,MAAM,UAAU,GAA0B,EAAE,CAAC;QAC7C,mBAAmB,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAEhD,MAAM,MAAM,GACV,MAAM,0BAA0B,CAAC,gCAAgC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACjF,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEhC,MAAM,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACjE,MAAM,CAAC,mBAAmB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,CAAC,WAAW,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,gBAAgB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAElD,MAAM,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;QACrD,MAAM,CAAC,gBAAgB,CAAC,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE,KAAK,IAAI,EAAE;QACnC,MAAM,OAAO,GAAyC,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAElF,MAAM,WAAW,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QACzC,MAAM,gBAAgB,GAAc,IAAI,CAAC,EAAE,EAAE,CAAC;QAE9C,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QACnD,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QAE7D,MAAM,UAAU,GAA0B,EAAE,CAAC;QAE7C,OAAO,CAAC,uBAAuB,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC;QAE7E,MAAM,MAAM,GACV,MAAM,0BAA0B,CAAC,gCAAgC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACjF,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChC,MAAM,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACjE,MAAM,CAAC,WAAW,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;QACrD,MAAM,CAAC,gBAAgB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,gBAAgB,CAAC,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\n// See LICENSE in the project root for license information.\n\nimport type { HeftConfiguration, IHeftParameters, IHeftTaskSession, IScopedLogger } from '@rushstack/heft';\nimport { MockScopedLogger } from '@rushstack/heft/lib/pluginFramework/logging/MockScopedLogger';\nimport { type ITerminal, StringBufferTerminalProvider, Terminal } from '@rushstack/node-core-library';\n\nimport * as WebpackConfigurationLoader from './WebpackConfigurationLoader';\nimport { _createAccessorHooks } from './Webpack5Plugin';\nimport { type IWebpackConfiguration, STAGE_LOAD_LOCAL_CONFIG } from './shared';\n\ninterface IMockLoadWebpackConfigurationOptions\n extends WebpackConfigurationLoader.ILoadWebpackConfigurationOptions {\n loadWebpackAsyncFn: jest.Mock;\n _terminalProvider: StringBufferTerminalProvider;\n _tryLoadConfigFileAsync: jest.Mock;\n}\n\ndescribe(WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync.name, () => {\n function createOptions(production: boolean, serveMode: boolean): IMockLoadWebpackConfigurationOptions {\n const terminalProvider: StringBufferTerminalProvider = new StringBufferTerminalProvider(false);\n const terminal: ITerminal = new Terminal(terminalProvider);\n const logger: IScopedLogger = new MockScopedLogger(terminal);\n const buildFolderPath: string = __dirname;\n\n const parameters: Partial<IHeftParameters> = {\n production\n };\n\n const taskSession: IHeftTaskSession = {\n logger,\n parameters: parameters as unknown as IHeftParameters,\n // Other values unused during these tests\n hooks: undefined!,\n parsedCommandLine: undefined!,\n requestAccessToPluginByName: undefined!,\n taskName: 'webpack',\n tempFolderPath: `${__dirname}/temp`\n };\n\n const heftConfiguration: Partial<HeftConfiguration> = {\n buildFolderPath\n };\n\n return {\n taskSession,\n heftConfiguration: heftConfiguration as unknown as HeftConfiguration,\n hooks: _createAccessorHooks(),\n loadWebpackAsyncFn: jest.fn(),\n serveMode,\n\n _terminalProvider: terminalProvider,\n _tryLoadConfigFileAsync: jest.fn()\n };\n }\n\n it(`onLoadConfiguration can return false`, async () => {\n const options: IMockLoadWebpackConfigurationOptions = createOptions(false, false);\n\n const onLoadConfiguration: jest.Mock = jest.fn();\n const onConfigure: jest.Mock = jest.fn();\n const onAfterConfigure: jest.Mock = jest.fn();\n\n options.hooks.onLoadConfiguration.tap('test', onLoadConfiguration);\n options.hooks.onConfigure.tap('test', onConfigure);\n options.hooks.onAfterConfigure.tap('test', onAfterConfigure);\n\n onLoadConfiguration.mockReturnValue(false);\n\n const config: IWebpackConfiguration | undefined =\n await WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync(options, {});\n expect(config).toBeUndefined();\n expect(onLoadConfiguration).toHaveBeenCalledTimes(1);\n expect(options._tryLoadConfigFileAsync).toHaveBeenCalledTimes(0);\n expect(onConfigure).toHaveBeenCalledTimes(0);\n expect(onAfterConfigure).toHaveBeenCalledTimes(0);\n });\n\n it(`calls tryLoadWebpackConfigurationFileAsync`, async () => {\n const options: IMockLoadWebpackConfigurationOptions = createOptions(false, false);\n\n const onConfigure: jest.Mock = jest.fn();\n const onAfterConfigure: jest.Mock = jest.fn();\n\n options.hooks.onConfigure.tap('test', onConfigure);\n options.hooks.onAfterConfigure.tap('test', onAfterConfigure);\n\n options._tryLoadConfigFileAsync.mockReturnValue(Promise.resolve(undefined));\n\n const config: IWebpackConfiguration | undefined =\n await WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync(options, {});\n expect(config).toBeUndefined();\n expect(options._tryLoadConfigFileAsync).toHaveBeenCalledTimes(1);\n expect(onConfigure).toHaveBeenCalledTimes(0);\n expect(onAfterConfigure).toHaveBeenCalledTimes(0);\n });\n\n it(`can fall back`, async () => {\n const options: IMockLoadWebpackConfigurationOptions = createOptions(false, false);\n\n const onLoadConfiguration: jest.Mock = jest.fn();\n const onConfigure: jest.Mock = jest.fn();\n const onAfterConfigure: jest.Mock = jest.fn();\n\n options.hooks.onLoadConfiguration.tap(\n { name: 'test', stage: STAGE_LOAD_LOCAL_CONFIG + 1 },\n onLoadConfiguration\n );\n options.hooks.onConfigure.tap('test', onConfigure);\n options.hooks.onAfterConfigure.tap('test', onAfterConfigure);\n\n options._tryLoadConfigFileAsync.mockReturnValue(Promise.resolve(undefined));\n\n const mockConfig: IWebpackConfiguration = {};\n onLoadConfiguration.mockReturnValue(mockConfig);\n\n const config: IWebpackConfiguration | undefined =\n await WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync(options, {});\n expect(config).toBe(mockConfig);\n\n expect(options._tryLoadConfigFileAsync).toHaveBeenCalledTimes(1);\n expect(onLoadConfiguration).toHaveBeenCalledTimes(1);\n expect(onConfigure).toHaveBeenCalledTimes(1);\n expect(onAfterConfigure).toHaveBeenCalledTimes(1);\n\n expect(onConfigure).toHaveBeenCalledWith(mockConfig);\n expect(onAfterConfigure).toHaveBeenCalledWith(mockConfig);\n });\n\n it(`respects hook order`, async () => {\n const options: IMockLoadWebpackConfigurationOptions = createOptions(false, false);\n\n const onConfigure: jest.Mock = jest.fn();\n const onAfterConfigure: jest.Mock = jest.fn();\n\n options.hooks.onConfigure.tap('test', onConfigure);\n options.hooks.onAfterConfigure.tap('test', onAfterConfigure);\n\n const mockConfig: IWebpackConfiguration = {};\n\n options._tryLoadConfigFileAsync.mockReturnValue(Promise.resolve(mockConfig));\n\n const config: IWebpackConfiguration | undefined =\n await WebpackConfigurationLoader.tryLoadWebpackConfigurationAsync(options, {});\n expect(config).toBe(mockConfig);\n expect(options._tryLoadConfigFileAsync).toHaveBeenCalledTimes(1);\n expect(onConfigure).toHaveBeenCalledTimes(1);\n expect(onConfigure).toHaveBeenCalledWith(mockConfig);\n expect(onAfterConfigure).toHaveBeenCalledTimes(1);\n expect(onAfterConfigure).toHaveBeenCalledWith(mockConfig);\n });\n});\n"]}
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA,4FAA4F;AAC5F,2DAA2D;;;AAE3D,mCAA8E;AAArE,oGAAA,WAAW,OAAc;AAAE,iHAAA,uBAAuB,OAAA","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA,4FAA4F;AAC5F,2DAA2D;;;AAE3D,mCAA8E;AAArE,oGAAA,WAAW,OAAc;AAAE,iHAAA,uBAAuB,OAAA","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\n// See LICENSE in the project root for license information.\n\nexport { PLUGIN_NAME as PluginName, STAGE_LOAD_LOCAL_CONFIG } from './shared';\n\nexport type {\n IWebpackConfigurationWithDevServer,\n IWebpackConfiguration,\n IWebpackConfigurationFnEnvironment,\n IWebpackPluginAccessor,\n IWebpackPluginAccessorHooks,\n IWebpackPluginAccessorParameters\n} from './shared';\n"]}
|
|
@@ -1,25 +1,25 @@
|
|
|
1
|
-
{
|
|
2
|
-
"$schema": "http://json-schema.org/draft-04/schema#",
|
|
3
|
-
"title": "Webpack 5 Plugin Configuration",
|
|
4
|
-
"description": "Defines options for Webpack 5 plugin execution.",
|
|
5
|
-
"type": "object",
|
|
6
|
-
|
|
7
|
-
"additionalProperties": false,
|
|
8
|
-
|
|
9
|
-
"properties": {
|
|
10
|
-
"$schema": {
|
|
11
|
-
"description": "Part of the JSON Schema standard, this optional keyword declares the URL of the schema that the file conforms to. Editors may download the schema and use it to perform syntax highlighting.",
|
|
12
|
-
"type": "string"
|
|
13
|
-
},
|
|
14
|
-
|
|
15
|
-
"devConfigurationPath": {
|
|
16
|
-
"description": "Specifies a relative path to the Webpack dev configuration, which is used in \"serve\" mode. The default value is \"./webpack.dev.config.js\".",
|
|
17
|
-
"type": "string"
|
|
18
|
-
},
|
|
19
|
-
|
|
20
|
-
"configurationPath": {
|
|
21
|
-
"description": "Specifies a relative path to the Webpack configuration. The default value is \"./webpack.config.js\".",
|
|
22
|
-
"type": "string"
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"$schema": "http://json-schema.org/draft-04/schema#",
|
|
3
|
+
"title": "Webpack 5 Plugin Configuration",
|
|
4
|
+
"description": "Defines options for Webpack 5 plugin execution.",
|
|
5
|
+
"type": "object",
|
|
6
|
+
|
|
7
|
+
"additionalProperties": false,
|
|
8
|
+
|
|
9
|
+
"properties": {
|
|
10
|
+
"$schema": {
|
|
11
|
+
"description": "Part of the JSON Schema standard, this optional keyword declares the URL of the schema that the file conforms to. Editors may download the schema and use it to perform syntax highlighting.",
|
|
12
|
+
"type": "string"
|
|
13
|
+
},
|
|
14
|
+
|
|
15
|
+
"devConfigurationPath": {
|
|
16
|
+
"description": "Specifies a relative path to the Webpack dev configuration, which is used in \"serve\" mode. The default value is \"./webpack.dev.config.js\".",
|
|
17
|
+
"type": "string"
|
|
18
|
+
},
|
|
19
|
+
|
|
20
|
+
"configurationPath": {
|
|
21
|
+
"description": "Specifies a relative path to the Webpack configuration. The default value is \"./webpack.config.js\".",
|
|
22
|
+
"type": "string"
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
package/lib/shared.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared.js","sourceRoot":"","sources":["../src/shared.ts"],"names":[],"mappings":";AAAA,4FAA4F;AAC5F,2DAA2D;;;AA6G3D;;;;GAIG;AACU,QAAA,uBAAuB,GAAS,IAAI,CAAC;AAElD;;GAEG;AACU,QAAA,WAAW,GAAsB,iBAAiB,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\
|
|
1
|
+
{"version":3,"file":"shared.js","sourceRoot":"","sources":["../src/shared.ts"],"names":[],"mappings":";AAAA,4FAA4F;AAC5F,2DAA2D;;;AA6G3D;;;;GAIG;AACU,QAAA,uBAAuB,GAAS,IAAI,CAAC;AAElD;;GAEG;AACU,QAAA,WAAW,GAAsB,iBAAiB,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.\n// See LICENSE in the project root for license information.\n\nimport type * as TWebpack from 'webpack';\nimport type { Configuration as WebpackDevServerConfiguration } from 'webpack-dev-server';\nimport type { AsyncParallelHook, AsyncSeriesBailHook, AsyncSeriesHook } from 'tapable';\nimport type { IHeftTaskSession, HeftConfiguration } from '@rushstack/heft';\n\n/**\n * The environment passed into the Webpack configuration function. Loosely based\n * on the default Webpack environment options, specified here:\n * https://webpack.js.org/api/cli/#environment-options\n *\n * @public\n */\nexport interface IWebpackConfigurationFnEnvironment {\n /**\n * Whether or not the run is in production mode. Synonym of\n * IWebpackConfigurationFnEnvironment.production.\n */\n prod: boolean;\n /**\n * Whether or not the run is in production mode. Synonym of\n * IWebpackConfigurationFnEnvironment.prod.\n */\n production: boolean;\n\n // Non-standard environment options\n /**\n * The task session provided to the plugin.\n */\n taskSession: IHeftTaskSession;\n /**\n * The Heft configuration provided to the plugin.\n */\n heftConfiguration: HeftConfiguration;\n /**\n * The resolved Webpack package.\n */\n webpack: typeof TWebpack;\n}\n\n/**\n * @public\n */\nexport interface IWebpackConfigurationWithDevServer extends TWebpack.Configuration {\n devServer?: WebpackDevServerConfiguration;\n}\n\n/**\n * @public\n */\nexport type IWebpackConfiguration = IWebpackConfigurationWithDevServer | IWebpackConfigurationWithDevServer[];\n\n/**\n * @public\n */\nexport interface IWebpackPluginAccessorHooks {\n /**\n * A hook that allows for loading custom configurations used by the Webpack\n * plugin. If a tap returns a value other than `undefined` before stage {@link STAGE_LOAD_LOCAL_CONFIG},\n * it will suppress loading from the webpack config file. To provide a fallback behavior in the\n * absence of a local config file, tap this hook with a `stage` value greater than {@link STAGE_LOAD_LOCAL_CONFIG}.\n *\n * @remarks\n * Tapable event handlers can return `false` instead of `undefined` to suppress\n * other handlers from creating a configuration object, and prevent webpack from running.\n */\n readonly onLoadConfiguration: AsyncSeriesBailHook<never, never, never, IWebpackConfiguration | false>;\n /**\n * A hook that allows for modification of the loaded configuration used by the Webpack\n * plugin. If no configuration was loaded, this hook will not be called.\n */\n readonly onConfigure: AsyncSeriesHook<IWebpackConfiguration, never, never>;\n /**\n * A hook that provides the finalized configuration that will be used by Webpack.\n * If no configuration was loaded, this hook will not be called.\n */\n readonly onAfterConfigure: AsyncParallelHook<IWebpackConfiguration, never, never>;\n /**\n * A hook that provides the stats output from Webpack. If no configuration is loaded,\n * this hook will not be called.\n */\n readonly onEmitStats: AsyncParallelHook<TWebpack.Stats | TWebpack.MultiStats, never, never>;\n}\n\n/**\n * @public\n */\nexport interface IWebpackPluginAccessorParameters {\n /**\n * Whether or not serve mode was enabled by passing the `--serve` flag.\n */\n readonly isServeMode: boolean;\n}\n\n/**\n * @public\n */\nexport interface IWebpackPluginAccessor {\n /**\n * Hooks that are called at various points in the Webpack plugin lifecycle.\n */\n readonly hooks: IWebpackPluginAccessorHooks;\n /**\n * Parameters that are provided by the Webpack plugin.\n */\n readonly parameters: IWebpackPluginAccessorParameters;\n}\n\n/**\n * The stage in the `onLoadConfiguration` hook at which the config will be loaded from the local\n * webpack config file.\n * @public\n */\nexport const STAGE_LOAD_LOCAL_CONFIG: 1000 = 1000;\n\n/**\n * @public\n */\nexport const PLUGIN_NAME: 'webpack5-plugin' = 'webpack5-plugin';\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rushstack/heft-webpack5-plugin",
|
|
3
|
-
"version": "0.9.
|
|
3
|
+
"version": "0.9.11",
|
|
4
4
|
"description": "Heft plugin for Webpack 5",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -12,7 +12,7 @@
|
|
|
12
12
|
"types": "dist/heft-webpack5-plugin.d.ts",
|
|
13
13
|
"license": "MIT",
|
|
14
14
|
"peerDependencies": {
|
|
15
|
-
"@rushstack/heft": "^0.63.
|
|
15
|
+
"@rushstack/heft": "^0.63.1",
|
|
16
16
|
"webpack": "~5.82.1"
|
|
17
17
|
},
|
|
18
18
|
"dependencies": {
|
|
@@ -20,13 +20,13 @@
|
|
|
20
20
|
"tapable": "1.1.3",
|
|
21
21
|
"watchpack": "2.4.0",
|
|
22
22
|
"webpack-dev-server": "~4.9.3",
|
|
23
|
-
"@rushstack/debug-certificate-manager": "1.3.
|
|
23
|
+
"@rushstack/debug-certificate-manager": "1.3.11",
|
|
24
24
|
"@rushstack/node-core-library": "3.61.0"
|
|
25
25
|
},
|
|
26
26
|
"devDependencies": {
|
|
27
27
|
"@types/watchpack": "2.4.0",
|
|
28
28
|
"webpack": "~5.82.1",
|
|
29
|
-
"@rushstack/heft": "0.63.
|
|
29
|
+
"@rushstack/heft": "0.63.1",
|
|
30
30
|
"local-node-rig": "1.0.0"
|
|
31
31
|
},
|
|
32
32
|
"scripts": {
|