@rsdoctor/core 1.2.3 → 1.2.4-beta.1
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/dist/build-utils/{common/trans-utils/transStats.js → build/chunks/assetsModules.cjs} +9 -12
- package/dist/build-utils/build/chunks/assetsModules.d.ts +0 -1
- package/dist/build-utils/build/chunks/assetsModules.js +7 -39
- package/dist/build-utils/build/chunks/chunkTransform.cjs +39 -0
- package/dist/build-utils/build/chunks/chunkTransform.d.ts +0 -1
- package/dist/build-utils/build/chunks/chunkTransform.js +5 -37
- package/dist/build-utils/{common/chunks/index.js → build/chunks/index.cjs} +8 -8
- package/dist/build-utils/build/chunks/index.d.ts +0 -1
- package/dist/build-utils/build/chunks/index.js +5 -78
- package/dist/build-utils/build/chunks/rspack/transform.cjs +80 -0
- package/dist/build-utils/build/chunks/rspack/transform.d.ts +0 -1
- package/dist/build-utils/build/chunks/rspack/transform.js +7 -42
- package/dist/build-utils/{common/index.js → build/index.cjs} +14 -14
- package/dist/build-utils/build/index.d.ts +0 -1
- package/dist/build-utils/build/index.js +8 -52
- package/dist/build-utils/build/loader/index.cjs +69 -0
- package/dist/build-utils/build/loader/index.d.ts +1 -1
- package/dist/build-utils/build/loader/index.js +4 -60
- package/dist/build-utils/build/loader/probeLoader.cjs +90 -0
- package/dist/build-utils/build/loader/probeLoader.d.ts +0 -1
- package/dist/build-utils/build/loader/probeLoader.js +12 -57
- package/dist/build-utils/build/loader/probeLoaderPlugin.cjs +65 -0
- package/dist/build-utils/build/loader/probeLoaderPlugin.d.ts +0 -1
- package/dist/build-utils/build/loader/probeLoaderPlugin.js +11 -43
- package/dist/build-utils/build/module-graph/index.cjs +87 -0
- package/dist/build-utils/build/module-graph/index.d.ts +0 -1
- package/dist/build-utils/build/module-graph/index.js +6 -87
- package/dist/build-utils/build/module-graph/parser.cjs +46 -0
- package/dist/build-utils/build/module-graph/parser.d.ts +0 -1
- package/dist/build-utils/build/module-graph/parser.js +7 -39
- package/dist/build-utils/build/module-graph/rspack/transform.cjs +110 -0
- package/dist/build-utils/build/module-graph/rspack/transform.d.ts +0 -1
- package/dist/build-utils/build/module-graph/rspack/transform.js +12 -50
- package/dist/build-utils/build/module-graph/transform.cjs +40 -0
- package/dist/build-utils/build/module-graph/transform.d.ts +0 -1
- package/dist/build-utils/build/module-graph/transform.js +6 -38
- package/dist/build-utils/build/module-graph/treeShaking.cjs +107 -0
- package/dist/build-utils/build/module-graph/treeShaking.d.ts +0 -1
- package/dist/build-utils/build/module-graph/treeShaking.js +15 -49
- package/dist/build-utils/build/module-graph/utils.cjs +97 -0
- package/dist/build-utils/build/module-graph/utils.d.ts +0 -1
- package/dist/build-utils/build/module-graph/utils.js +15 -50
- package/dist/build-utils/build/module-graph/webpack/transform.cjs +171 -0
- package/dist/build-utils/build/module-graph/webpack/transform.d.ts +0 -1
- package/dist/build-utils/build/module-graph/webpack/transform.js +31 -57
- package/dist/build-utils/{common/module-graph/index.js → build/utils/index.cjs} +15 -15
- package/dist/build-utils/build/utils/index.d.ts +0 -2
- package/dist/build-utils/build/utils/index.js +5 -87
- package/dist/build-utils/build/utils/loader.cjs +356 -0
- package/dist/build-utils/build/utils/loader.d.ts +1 -3
- package/dist/build-utils/build/utils/loader.js +44 -90
- package/dist/build-utils/build/utils/parseBundle.cjs +284 -0
- package/dist/build-utils/build/utils/parseBundle.d.ts +1 -2
- package/dist/build-utils/build/utils/parseBundle.js +19 -61
- package/dist/build-utils/build/utils/plugin.cjs +61 -0
- package/dist/build-utils/build/utils/plugin.d.ts +0 -1
- package/dist/build-utils/build/utils/plugin.js +5 -43
- package/dist/build-utils/index.cjs +36 -0
- package/dist/build-utils/index.d.ts +0 -2
- package/dist/build-utils/index.js +4 -40
- package/dist/index.cjs +85 -0
- package/dist/index.d.ts +0 -1
- package/dist/index.js +6 -85
- package/dist/inner-plugins/constants.cjs +64 -0
- package/dist/inner-plugins/constants.d.ts +0 -1
- package/dist/inner-plugins/constants.js +3 -47
- package/dist/{build-utils/common/trans-utils/index.js → inner-plugins/index.cjs} +14 -5
- package/dist/inner-plugins/index.d.ts +0 -1
- package/dist/inner-plugins/index.js +4 -69
- package/dist/inner-plugins/loaders/proxy.cjs +90 -0
- package/dist/inner-plugins/loaders/proxy.d.ts +4 -2
- package/dist/inner-plugins/loaders/proxy.js +19 -22
- package/dist/inner-plugins/plugins/base.cjs +53 -0
- package/dist/inner-plugins/plugins/base.d.ts +3 -5
- package/dist/inner-plugins/plugins/base.js +6 -38
- package/dist/inner-plugins/plugins/bundle.cjs +121 -0
- package/dist/inner-plugins/plugins/bundle.d.ts +1 -1
- package/dist/inner-plugins/plugins/bundle.js +33 -49
- package/dist/inner-plugins/plugins/bundleTagPlugin.cjs +93 -0
- package/dist/inner-plugins/plugins/bundleTagPlugin.d.ts +0 -1
- package/dist/inner-plugins/plugins/bundleTagPlugin.js +12 -44
- package/dist/inner-plugins/plugins/ensureModulesChunkGraph.cjs +166 -0
- package/dist/inner-plugins/plugins/ensureModulesChunkGraph.d.ts +0 -1
- package/dist/inner-plugins/plugins/ensureModulesChunkGraph.js +42 -70
- package/dist/inner-plugins/plugins/errors.cjs +98 -0
- package/dist/inner-plugins/plugins/errors.d.ts +0 -1
- package/dist/inner-plugins/plugins/errors.js +20 -52
- package/dist/inner-plugins/plugins/index.cjs +141 -0
- package/dist/inner-plugins/plugins/index.d.ts +0 -1
- package/dist/inner-plugins/plugins/index.js +12 -141
- package/dist/inner-plugins/plugins/loader.cjs +155 -0
- package/dist/inner-plugins/plugins/loader.d.ts +0 -1
- package/dist/inner-plugins/plugins/loader.js +29 -57
- package/dist/inner-plugins/plugins/plugins.cjs +73 -0
- package/dist/inner-plugins/plugins/plugins.d.ts +0 -1
- package/dist/inner-plugins/plugins/plugins.js +18 -50
- package/dist/inner-plugins/plugins/progress.cjs +70 -0
- package/dist/inner-plugins/plugins/progress.d.ts +0 -1
- package/dist/inner-plugins/plugins/progress.js +9 -41
- package/dist/inner-plugins/plugins/rspack.cjs +117 -0
- package/dist/inner-plugins/plugins/rspack.d.ts +0 -1
- package/dist/inner-plugins/plugins/rspack.js +24 -56
- package/dist/inner-plugins/plugins/rules.cjs +97 -0
- package/dist/inner-plugins/plugins/rules.d.ts +0 -1
- package/dist/inner-plugins/plugins/rules.js +19 -51
- package/dist/inner-plugins/plugins/sourcemapTool.cjs +213 -0
- package/dist/inner-plugins/plugins/sourcemapTool.d.ts +0 -1
- package/dist/inner-plugins/plugins/sourcemapTool.js +23 -67
- package/dist/inner-plugins/plugins/summary.cjs +125 -0
- package/dist/inner-plugins/plugins/summary.d.ts +0 -1
- package/dist/inner-plugins/plugins/summary.js +28 -60
- package/dist/inner-plugins/utils/circleDetect.cjs +49 -0
- package/dist/inner-plugins/utils/circleDetect.d.ts +0 -1
- package/dist/inner-plugins/utils/circleDetect.js +3 -35
- package/dist/inner-plugins/utils/config.cjs +177 -0
- package/dist/inner-plugins/utils/config.d.ts +3 -8
- package/dist/inner-plugins/utils/config.js +43 -116
- package/dist/inner-plugins/utils/index.cjs +124 -0
- package/dist/inner-plugins/utils/index.d.ts +4 -1
- package/dist/inner-plugins/utils/index.js +9 -96
- package/dist/inner-plugins/utils/loader.cjs +231 -0
- package/dist/inner-plugins/utils/loader.d.ts +4 -4
- package/dist/inner-plugins/utils/loader.js +39 -97
- package/dist/inner-plugins/utils/normalize-config.cjs +122 -0
- package/dist/inner-plugins/utils/normalize-config.d.ts +40 -0
- package/dist/inner-plugins/utils/normalize-config.js +78 -0
- package/dist/inner-plugins/utils/plugin-common.cjs +73 -0
- package/dist/inner-plugins/utils/plugin-common.d.ts +6 -0
- package/dist/inner-plugins/utils/plugin-common.js +28 -0
- package/dist/inner-plugins/utils/plugin.cjs +107 -0
- package/dist/inner-plugins/utils/plugin.d.ts +2 -4
- package/dist/inner-plugins/utils/plugin.js +5 -40
- package/dist/inner-plugins/utils/sdk.cjs +55 -0
- package/dist/inner-plugins/utils/sdk.d.ts +8 -4
- package/dist/inner-plugins/utils/sdk.js +9 -42
- package/dist/rules/index.cjs +85 -0
- package/dist/rules/index.d.ts +0 -1
- package/dist/rules/index.js +6 -85
- package/dist/rules/linter.cjs +71 -0
- package/dist/rules/linter.d.ts +0 -1
- package/dist/rules/linter.js +11 -46
- package/dist/rules/rule.cjs +137 -0
- package/dist/rules/rule.d.ts +1 -2
- package/dist/rules/rule.js +20 -55
- package/dist/rules/rules/cross-chunks-package/index.cjs +73 -0
- package/dist/rules/rules/cross-chunks-package/index.d.ts +0 -1
- package/dist/rules/rules/cross-chunks-package/index.js +10 -42
- package/dist/rules/rules/cross-chunks-package/types.d.ts +0 -1
- package/dist/rules/rules/cross-chunks-package/types.js +2 -18
- package/dist/rules/rules/cross-chunks-package/utils.cjs +40 -0
- package/dist/rules/rules/cross-chunks-package/utils.d.ts +1 -2
- package/dist/rules/rules/cross-chunks-package/utils.js +4 -36
- package/dist/rules/rules/default-import-check/index.cjs +116 -0
- package/dist/rules/rules/default-import-check/index.d.ts +0 -1
- package/dist/rules/rules/default-import-check/index.js +17 -49
- package/dist/rules/rules/default-import-check/types.cjs +18 -0
- package/dist/rules/rules/default-import-check/types.d.ts +0 -1
- package/dist/rules/rules/default-import-check/types.js +2 -18
- package/dist/rules/rules/default-import-check/utils.cjs +98 -0
- package/dist/rules/rules/default-import-check/utils.d.ts +0 -1
- package/dist/rules/rules/default-import-check/utils.js +9 -53
- package/dist/rules/rules/duplicate-package/index.cjs +71 -0
- package/dist/rules/rules/duplicate-package/index.d.ts +0 -1
- package/dist/rules/rules/duplicate-package/index.js +15 -47
- package/dist/rules/rules/duplicate-package/types.cjs +60 -0
- package/dist/rules/rules/duplicate-package/types.d.ts +0 -1
- package/dist/rules/rules/duplicate-package/types.js +5 -40
- package/dist/rules/rules/duplicate-package/utils.cjs +84 -0
- package/dist/rules/rules/duplicate-package/utils.d.ts +0 -1
- package/dist/rules/rules/duplicate-package/utils.js +6 -51
- package/dist/rules/rules/ecma-version-check/index.cjs +97 -0
- package/dist/rules/rules/ecma-version-check/index.d.ts +0 -1
- package/dist/rules/rules/ecma-version-check/index.js +16 -58
- package/dist/rules/rules/ecma-version-check/types.cjs +18 -0
- package/dist/rules/rules/ecma-version-check/types.d.ts +0 -1
- package/dist/rules/rules/ecma-version-check/types.js +2 -18
- package/dist/rules/rules/ecma-version-check/utils.cjs +39 -0
- package/dist/rules/rules/ecma-version-check/utils.d.ts +0 -1
- package/dist/rules/rules/ecma-version-check/utils.js +3 -35
- package/dist/rules/rules/index.cjs +47 -0
- package/dist/rules/rules/index.d.ts +0 -1
- package/dist/rules/rules/index.js +13 -45
- package/dist/rules/rules/loader-performance-optimization/index.cjs +119 -0
- package/dist/rules/rules/loader-performance-optimization/index.d.ts +0 -1
- package/dist/rules/rules/loader-performance-optimization/index.js +14 -46
- package/dist/rules/rules/loader-performance-optimization/types.cjs +18 -0
- package/dist/rules/rules/loader-performance-optimization/types.d.ts +0 -1
- package/dist/rules/rules/loader-performance-optimization/types.js +2 -18
- package/dist/{build-utils/common/chunks/assetsContent.js → rules/rules/loader-performance-optimization/utils.cjs} +9 -10
- package/dist/rules/rules/loader-performance-optimization/utils.d.ts +0 -1
- package/dist/rules/rules/loader-performance-optimization/utils.js +3 -35
- package/dist/rules/utils.cjs +46 -0
- package/dist/rules/utils.d.ts +0 -1
- package/dist/rules/utils.js +6 -41
- package/dist/types/chunks.cjs +18 -0
- package/dist/types/chunks.d.ts +1 -7
- package/dist/types/chunks.js +2 -18
- package/dist/types/index.cjs +87 -0
- package/dist/types/index.d.ts +0 -2
- package/dist/types/index.js +6 -96
- package/dist/types/loader.cjs +18 -0
- package/dist/types/loader.d.ts +0 -1
- package/dist/types/loader.js +2 -18
- package/dist/types/plugin.cjs +18 -0
- package/dist/types/plugin.d.ts +7 -108
- package/dist/types/plugin.js +2 -18
- package/dist/types/rules.cjs +18 -0
- package/dist/types/rules.d.ts +0 -1
- package/dist/types/rules.js +2 -18
- package/package.json +33 -34
- package/dist/build-utils/build/chunks/assetsModules.d.ts.map +0 -1
- package/dist/build-utils/build/chunks/chunkTransform.d.ts.map +0 -1
- package/dist/build-utils/build/chunks/index.d.ts.map +0 -1
- package/dist/build-utils/build/chunks/rspack/transform.d.ts.map +0 -1
- package/dist/build-utils/build/index.d.ts.map +0 -1
- package/dist/build-utils/build/loader/index.d.ts.map +0 -1
- package/dist/build-utils/build/loader/probeLoader.d.ts.map +0 -1
- package/dist/build-utils/build/loader/probeLoaderPlugin.d.ts.map +0 -1
- package/dist/build-utils/build/module-graph/index.d.ts.map +0 -1
- package/dist/build-utils/build/module-graph/parser.d.ts.map +0 -1
- package/dist/build-utils/build/module-graph/rspack/transform.d.ts.map +0 -1
- package/dist/build-utils/build/module-graph/transform.d.ts.map +0 -1
- package/dist/build-utils/build/module-graph/treeShaking.d.ts.map +0 -1
- package/dist/build-utils/build/module-graph/utils.d.ts.map +0 -1
- package/dist/build-utils/build/module-graph/webpack/transform.d.ts.map +0 -1
- package/dist/build-utils/build/utils/index.d.ts.map +0 -1
- package/dist/build-utils/build/utils/loader.d.ts.map +0 -1
- package/dist/build-utils/build/utils/parseBundle.d.ts.map +0 -1
- package/dist/build-utils/build/utils/plugin.d.ts.map +0 -1
- package/dist/build-utils/common/chunks/assetsContent.d.ts +0 -6
- package/dist/build-utils/common/chunks/assetsContent.d.ts.map +0 -1
- package/dist/build-utils/common/chunks/assetsModules.d.ts +0 -23
- package/dist/build-utils/common/chunks/assetsModules.d.ts.map +0 -1
- package/dist/build-utils/common/chunks/assetsModules.js +0 -155
- package/dist/build-utils/common/chunks/chunkTransform.d.ts +0 -6
- package/dist/build-utils/common/chunks/chunkTransform.d.ts.map +0 -1
- package/dist/build-utils/common/chunks/chunkTransform.js +0 -74
- package/dist/build-utils/common/chunks/index.d.ts +0 -4
- package/dist/build-utils/common/chunks/index.d.ts.map +0 -1
- package/dist/build-utils/common/index.d.ts +0 -6
- package/dist/build-utils/common/index.d.ts.map +0 -1
- package/dist/build-utils/common/module-graph/compatible.d.ts +0 -9
- package/dist/build-utils/common/module-graph/compatible.d.ts.map +0 -1
- package/dist/build-utils/common/module-graph/compatible.js +0 -73
- package/dist/build-utils/common/module-graph/index.d.ts +0 -4
- package/dist/build-utils/common/module-graph/index.d.ts.map +0 -1
- package/dist/build-utils/common/module-graph/transform.d.ts +0 -8
- package/dist/build-utils/common/module-graph/transform.d.ts.map +0 -1
- package/dist/build-utils/common/module-graph/transform.js +0 -181
- package/dist/build-utils/common/module-graph/utils.d.ts +0 -14
- package/dist/build-utils/common/module-graph/utils.d.ts.map +0 -1
- package/dist/build-utils/common/module-graph/utils.js +0 -58
- package/dist/build-utils/common/trans-utils/index.d.ts +0 -2
- package/dist/build-utils/common/trans-utils/index.d.ts.map +0 -1
- package/dist/build-utils/common/trans-utils/transStats.d.ts +0 -11
- package/dist/build-utils/common/trans-utils/transStats.d.ts.map +0 -1
- package/dist/build-utils/common/webpack/compatible.d.ts +0 -18
- package/dist/build-utils/common/webpack/compatible.d.ts.map +0 -1
- package/dist/build-utils/common/webpack/compatible.js +0 -156
- package/dist/build-utils/index.d.ts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/inner-plugins/constants.d.ts.map +0 -1
- package/dist/inner-plugins/index.d.ts.map +0 -1
- package/dist/inner-plugins/loaders/proxy.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/base.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/bundle.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/bundleTagPlugin.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/ensureModulesChunkGraph.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/errors.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/index.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/loader.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/plugins.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/progress.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/rspack.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/rules.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/sourcemapTool.d.ts.map +0 -1
- package/dist/inner-plugins/plugins/summary.d.ts.map +0 -1
- package/dist/inner-plugins/utils/circleDetect.d.ts.map +0 -1
- package/dist/inner-plugins/utils/config.d.ts.map +0 -1
- package/dist/inner-plugins/utils/index.d.ts.map +0 -1
- package/dist/inner-plugins/utils/loader.d.ts.map +0 -1
- package/dist/inner-plugins/utils/plugin.d.ts.map +0 -1
- package/dist/inner-plugins/utils/sdk.d.ts.map +0 -1
- package/dist/rules/index.d.ts.map +0 -1
- package/dist/rules/linter.d.ts.map +0 -1
- package/dist/rules/rule.d.ts.map +0 -1
- package/dist/rules/rules/cross-chunks-package/index.d.ts.map +0 -1
- package/dist/rules/rules/cross-chunks-package/types.d.ts.map +0 -1
- package/dist/rules/rules/cross-chunks-package/utils.d.ts.map +0 -1
- package/dist/rules/rules/default-import-check/index.d.ts.map +0 -1
- package/dist/rules/rules/default-import-check/types.d.ts.map +0 -1
- package/dist/rules/rules/default-import-check/utils.d.ts.map +0 -1
- package/dist/rules/rules/duplicate-package/index.d.ts.map +0 -1
- package/dist/rules/rules/duplicate-package/types.d.ts.map +0 -1
- package/dist/rules/rules/duplicate-package/utils.d.ts.map +0 -1
- package/dist/rules/rules/ecma-version-check/index.d.ts.map +0 -1
- package/dist/rules/rules/ecma-version-check/types.d.ts.map +0 -1
- package/dist/rules/rules/ecma-version-check/utils.d.ts.map +0 -1
- package/dist/rules/rules/index.d.ts.map +0 -1
- package/dist/rules/rules/loader-performance-optimization/index.d.ts.map +0 -1
- package/dist/rules/rules/loader-performance-optimization/types.d.ts.map +0 -1
- package/dist/rules/rules/loader-performance-optimization/utils.d.ts.map +0 -1
- package/dist/rules/utils.d.ts.map +0 -1
- package/dist/types/chunks.d.ts.map +0 -1
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/loader.d.ts.map +0 -1
- package/dist/types/plugin.d.ts.map +0 -1
- package/dist/types/rules.d.ts.map +0 -1
- package/dist/types/webpack.d.ts +0 -15
- package/dist/types/webpack.d.ts.map +0 -1
- /package/dist/{types/webpack.js → rules/rules/cross-chunks-package/types.cjs} +0 -0
|
@@ -1,52 +1,26 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
};
|
|
10
|
-
})();
|
|
11
|
-
(()=>{
|
|
12
|
-
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
-
})();
|
|
14
|
-
(()=>{
|
|
15
|
-
__webpack_require__.r = (exports1)=>{
|
|
16
|
-
if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
-
value: 'Module'
|
|
18
|
-
});
|
|
19
|
-
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
-
value: true
|
|
21
|
-
});
|
|
22
|
-
};
|
|
23
|
-
})();
|
|
24
|
-
var __webpack_exports__ = {};
|
|
25
|
-
__webpack_require__.r(__webpack_exports__);
|
|
26
|
-
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
-
InternalRulesPlugin: ()=>InternalRulesPlugin
|
|
28
|
-
});
|
|
29
|
-
const external_base_js_namespaceObject = require("./base.js");
|
|
30
|
-
const index_js_namespaceObject = require("../../rules/index.js");
|
|
31
|
-
const error_namespaceObject = require("@rsdoctor/utils/error");
|
|
32
|
-
const external_lodash_namespaceObject = require("lodash");
|
|
33
|
-
const logger_namespaceObject = require("@rsdoctor/utils/logger");
|
|
34
|
-
class InternalRulesPlugin extends external_base_js_namespaceObject.InternalBasePlugin {
|
|
1
|
+
import 'module';
|
|
2
|
+
/*#__PURE__*/ import.meta.url;
|
|
3
|
+
import { InternalBasePlugin } from "./base.js";
|
|
4
|
+
import { Linter } from "../../rules/index.js";
|
|
5
|
+
import { DevToolError } from "@rsdoctor/utils/error";
|
|
6
|
+
import { pull } from "lodash-es";
|
|
7
|
+
import { time, timeEnd } from "@rsdoctor/utils/logger";
|
|
8
|
+
class InternalRulesPlugin extends InternalBasePlugin {
|
|
35
9
|
apply(compiler) {
|
|
36
|
-
|
|
10
|
+
time('InternalRulesPlugin.apply');
|
|
37
11
|
try {
|
|
38
12
|
compiler.hooks.done.tapPromise(this.tapPreOptions, this.done);
|
|
39
13
|
} finally{
|
|
40
|
-
|
|
14
|
+
timeEnd('InternalRulesPlugin.apply');
|
|
41
15
|
}
|
|
42
16
|
}
|
|
43
17
|
async lint(compilation) {
|
|
44
|
-
|
|
18
|
+
time('InternalRulesPlugin.lint');
|
|
45
19
|
try {
|
|
46
20
|
const options = this.options ?? {};
|
|
47
|
-
const linter = new
|
|
21
|
+
const linter = new Linter(options.linter);
|
|
48
22
|
const result = await linter.validate(this.sdk.getRuleContext({}));
|
|
49
|
-
const validateErrors = result.errors.map((err)=>
|
|
23
|
+
const validateErrors = result.errors.map((err)=>DevToolError.from(err, {
|
|
50
24
|
detail: err.detail,
|
|
51
25
|
controller: {
|
|
52
26
|
noColor: true
|
|
@@ -56,8 +30,8 @@ class InternalRulesPlugin extends external_base_js_namespaceObject.InternalBaseP
|
|
|
56
30
|
const warnings = validateErrors.filter((item)=>'Warn' === item.level);
|
|
57
31
|
const toWebpackError = (err)=>err.toError();
|
|
58
32
|
result.replace.forEach((item)=>{
|
|
59
|
-
if (Array.isArray(compilation.errors) && compilation.errors.includes(item))
|
|
60
|
-
if (Array.isArray(compilation.warnings) && compilation.warnings.includes(item))
|
|
33
|
+
if (Array.isArray(compilation.errors) && compilation.errors.includes(item)) pull(compilation.errors, item);
|
|
34
|
+
if (Array.isArray(compilation.warnings) && compilation.warnings.includes(item)) pull(compilation.warnings, item);
|
|
61
35
|
});
|
|
62
36
|
if (Array.isArray(compilation.errors)) errors.forEach((err)=>{
|
|
63
37
|
compilation.warnings.push(toWebpackError(err));
|
|
@@ -74,24 +48,18 @@ class InternalRulesPlugin extends external_base_js_namespaceObject.InternalBaseP
|
|
|
74
48
|
}
|
|
75
49
|
});
|
|
76
50
|
} finally{
|
|
77
|
-
|
|
51
|
+
timeEnd('InternalRulesPlugin.lint');
|
|
78
52
|
}
|
|
79
53
|
}
|
|
80
54
|
constructor(...args){
|
|
81
55
|
super(...args), this.name = 'rules', this.done = async (stats)=>{
|
|
82
|
-
|
|
56
|
+
time('InternalRulesPlugin.done');
|
|
83
57
|
try {
|
|
84
58
|
await this.lint(stats.compilation);
|
|
85
59
|
} finally{
|
|
86
|
-
|
|
60
|
+
timeEnd('InternalRulesPlugin.done');
|
|
87
61
|
}
|
|
88
62
|
};
|
|
89
63
|
}
|
|
90
64
|
}
|
|
91
|
-
|
|
92
|
-
for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
93
|
-
"InternalRulesPlugin"
|
|
94
|
-
].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
|
|
95
|
-
Object.defineProperty(exports, '__esModule', {
|
|
96
|
-
value: true
|
|
97
|
-
});
|
|
65
|
+
export { InternalRulesPlugin };
|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
UNASSIGNED: ()=>UNASSIGNED,
|
|
28
|
+
collectSourceMaps: ()=>collectSourceMaps,
|
|
29
|
+
bindContextCache: ()=>bindContextCache,
|
|
30
|
+
handleAfterEmitAssets: ()=>handleAfterEmitAssets,
|
|
31
|
+
handleEmitAssets: ()=>handleEmitAssets
|
|
32
|
+
});
|
|
33
|
+
const common_namespaceObject = require("@rsdoctor/utils/common");
|
|
34
|
+
const logger_namespaceObject = require("@rsdoctor/utils/logger");
|
|
35
|
+
const external_path_namespaceObject = require("path");
|
|
36
|
+
const external_source_map_namespaceObject = require("source-map");
|
|
37
|
+
const UNASSIGNED = '[unassigned]';
|
|
38
|
+
function bindContextCache(context, namespace, cache) {
|
|
39
|
+
cache = cache || new Map();
|
|
40
|
+
return (source, sourceMapFilenameRegex)=>{
|
|
41
|
+
if (cache.has(source)) return cache.get(source);
|
|
42
|
+
let resolved = UNASSIGNED;
|
|
43
|
+
if (source.startsWith('file://')) resolved = (0, external_path_namespaceObject.resolve)(context, source.replace(/^file:\/\//, ''));
|
|
44
|
+
else if (source.startsWith('webpack://')) {
|
|
45
|
+
const match = source.match(sourceMapFilenameRegex);
|
|
46
|
+
const filePath = null == match ? void 0 : match[1];
|
|
47
|
+
const hasNamespace = namespace && source.startsWith(`webpack://${namespace}`) || namespace && source.startsWith(`file://${namespace}`);
|
|
48
|
+
const baseDir = hasNamespace ? process.cwd() : context;
|
|
49
|
+
resolved = filePath ? (0, external_path_namespaceObject.resolve)(baseDir, `./${filePath}`) : UNASSIGNED;
|
|
50
|
+
} else resolved = (0, external_path_namespaceObject.resolve)(context, source);
|
|
51
|
+
cache.set(source, resolved);
|
|
52
|
+
return resolved;
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
async function collectSourceMaps(map, assetLinesCodeList, _compilation, _this, sourceMapFilenameRegex, namespace) {
|
|
56
|
+
if (map) {
|
|
57
|
+
const consumer = await new external_source_map_namespaceObject.SourceMapConsumer(map);
|
|
58
|
+
const getRealSourcePath = bindContextCache(_this.sdk.root || process.cwd(), namespace, _this._realSourcePathCache);
|
|
59
|
+
const lineMappings = new Map();
|
|
60
|
+
consumer.eachMapping((m)=>{
|
|
61
|
+
if (!lineMappings.has(m.generatedLine)) lineMappings.set(m.generatedLine, []);
|
|
62
|
+
lineMappings.get(m.generatedLine).push(m);
|
|
63
|
+
});
|
|
64
|
+
for (const [lineNum, mappings] of lineMappings.entries()){
|
|
65
|
+
mappings.sort((a, b)=>a.generatedColumn - b.generatedColumn);
|
|
66
|
+
const lineIdx = lineNum - 1;
|
|
67
|
+
if (lineIdx < 0 || lineIdx >= assetLinesCodeList.length) continue;
|
|
68
|
+
const line = assetLinesCodeList[lineIdx];
|
|
69
|
+
for(let i = 0; i < mappings.length; i++){
|
|
70
|
+
const m = mappings[i];
|
|
71
|
+
if (!m.source) continue;
|
|
72
|
+
let realSource = m.source.split('!').pop();
|
|
73
|
+
if (((null == realSource ? void 0 : realSource.startsWith('webpack://')) || (null == realSource ? void 0 : realSource.startsWith('file://'))) && sourceMapFilenameRegex) realSource = getRealSourcePath(realSource, sourceMapFilenameRegex);
|
|
74
|
+
if (!realSource) continue;
|
|
75
|
+
const next = mappings[i + 1];
|
|
76
|
+
const start = m.generatedColumn;
|
|
77
|
+
const end = next ? next.generatedColumn : line.length;
|
|
78
|
+
const codeSegment = line.slice(start, end);
|
|
79
|
+
const prev = _this.sourceMapSets.get(realSource) || '';
|
|
80
|
+
_this.sourceMapSets.set(realSource, prev.concat(codeSegment));
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
async function handleAfterEmitAssets(compilation, _this, sourceMapFilenameRegex, namespace) {
|
|
86
|
+
if ('rspack' in compilation.compiler) {
|
|
87
|
+
_this.sourceMapSets = new Map();
|
|
88
|
+
(0, logger_namespaceObject.time)('ensureModulesChunkGraph.afterEmit.start');
|
|
89
|
+
const assets = [
|
|
90
|
+
...compilation.getAssets()
|
|
91
|
+
];
|
|
92
|
+
for (const asset of assets){
|
|
93
|
+
const { assetLinesCodeList, map: mapFromAsset } = parseAsset(asset, assets, 'js/css');
|
|
94
|
+
let map = mapFromAsset;
|
|
95
|
+
if (!map) {
|
|
96
|
+
var _asset_info_related;
|
|
97
|
+
let sourceMapFile = null == (_asset_info_related = asset.info.related) ? void 0 : _asset_info_related.sourceMap;
|
|
98
|
+
let sourceMapFileAssetName = null == sourceMapFile ? void 0 : sourceMapFile.replace(/(\.[^.]+)(\.[^.]+)?$/, '$1');
|
|
99
|
+
if (!sourceMapFile) continue;
|
|
100
|
+
{
|
|
101
|
+
let sourceMapAsset = assets.find((asset)=>asset.name === sourceMapFile);
|
|
102
|
+
if (!sourceMapAsset && sourceMapFileAssetName) {
|
|
103
|
+
const baseNameWithoutHash = common_namespaceObject.Graph.formatAssetName(sourceMapFileAssetName, 'string' == typeof compilation.options.output.filename ? compilation.options.output.filename : void 0);
|
|
104
|
+
sourceMapAsset = assets.find((asset)=>{
|
|
105
|
+
const assetBaseName = common_namespaceObject.Graph.formatAssetName(asset.name, 'string' == typeof compilation.options.output.filename ? compilation.options.output.filename : void 0);
|
|
106
|
+
return assetBaseName.includes(baseNameWithoutHash) && asset.name.endsWith('.map');
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
if (sourceMapAsset) map = JSON.parse(sourceMapAsset.source.source().toString());
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
try {
|
|
113
|
+
await collectSourceMaps(map, assetLinesCodeList, compilation, _this, sourceMapFilenameRegex, namespace);
|
|
114
|
+
} catch (e) {
|
|
115
|
+
logger_namespaceObject.logger.debug(e);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
(0, logger_namespaceObject.timeEnd)('ensureModulesChunkGraph.afterEmit.start');
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
async function handleEmitAssets(options) {
|
|
122
|
+
const { compilation, pluginInstance, sourceMapFilenameRegex, namespace } = options;
|
|
123
|
+
if (!('rspack' in compilation.compiler)) {
|
|
124
|
+
pluginInstance.sourceMapSets = new Map();
|
|
125
|
+
(0, logger_namespaceObject.time)('ensureModulesChunkGraph.afterEmit.start');
|
|
126
|
+
const assets = Object.values(compilation.getAssets()).map((asset, index)=>({
|
|
127
|
+
name: index.toString(),
|
|
128
|
+
source: asset,
|
|
129
|
+
info: asset.info || {}
|
|
130
|
+
}));
|
|
131
|
+
for (const asset of assets){
|
|
132
|
+
const { assetLinesCodeList, map } = parseAsset(asset, assets, 'map');
|
|
133
|
+
if (map) try {
|
|
134
|
+
await collectSourceMaps(map, assetLinesCodeList, compilation, pluginInstance, sourceMapFilenameRegex, namespace);
|
|
135
|
+
} catch (e) {
|
|
136
|
+
logger_namespaceObject.logger.debug(e);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
(0, logger_namespaceObject.timeEnd)('ensureModulesChunkGraph.afterEmit.start');
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
function parseAsset(asset, assets, type) {
|
|
143
|
+
var _asset_source;
|
|
144
|
+
const assetName = (null == (_asset_source = asset.source) ? void 0 : _asset_source.name) || asset.name;
|
|
145
|
+
let assetContent = '';
|
|
146
|
+
let assetLinesCodeList = [];
|
|
147
|
+
let map = null;
|
|
148
|
+
try {
|
|
149
|
+
if ('map' === type && assetName.endsWith('.map') && !asset.name.includes('d.ts')) {
|
|
150
|
+
var _asset_source_source_source, _asset_source_source, _asset_source1, _bundledAsset_source_source_source, _bundledAsset_source_source, _bundledAsset_source;
|
|
151
|
+
assetContent = (null == (_asset_source1 = asset.source) ? void 0 : null == (_asset_source_source = _asset_source1.source) ? void 0 : null == (_asset_source_source_source = _asset_source_source.source) ? void 0 : _asset_source_source_source.call(_asset_source_source)) || '';
|
|
152
|
+
if (!assetContent) {
|
|
153
|
+
logger_namespaceObject.logger.debug(`Failed to get source content for asset: ${assetName}`);
|
|
154
|
+
return {
|
|
155
|
+
assetName,
|
|
156
|
+
assetContent: '',
|
|
157
|
+
assetLinesCodeList: [],
|
|
158
|
+
map: null
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
map = JSON.parse(assetContent);
|
|
162
|
+
const bundledAsset = assets.find((asset2)=>{
|
|
163
|
+
var _asset2_source;
|
|
164
|
+
return (null == (_asset2_source = asset2.source) ? void 0 : _asset2_source.name) === map.file;
|
|
165
|
+
});
|
|
166
|
+
const bundledCode = (null == bundledAsset ? void 0 : null == (_bundledAsset_source = bundledAsset.source) ? void 0 : null == (_bundledAsset_source_source = _bundledAsset_source.source) ? void 0 : null == (_bundledAsset_source_source_source = _bundledAsset_source_source.source) ? void 0 : _bundledAsset_source_source_source.call(_bundledAsset_source_source)) || '';
|
|
167
|
+
if (!bundledCode) {
|
|
168
|
+
logger_namespaceObject.logger.debug(`Failed to get bundled code for asset: ${map.file}`);
|
|
169
|
+
return {
|
|
170
|
+
assetName,
|
|
171
|
+
assetContent,
|
|
172
|
+
assetLinesCodeList: [],
|
|
173
|
+
map
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
assetLinesCodeList = bundledCode.split(/\r?\n/);
|
|
177
|
+
} else if ('js/css' === type && (assetName.endsWith('.js') || assetName.endsWith('.css'))) {
|
|
178
|
+
var _asset_source_source1, _asset_source2, _asset_source_sourceAndMap, _asset_source_sourceAndMap1, _asset_source3;
|
|
179
|
+
assetContent = (null == (_asset_source2 = asset.source) ? void 0 : null == (_asset_source_source1 = _asset_source2.source) ? void 0 : _asset_source_source1.call(_asset_source2)) || '';
|
|
180
|
+
assetLinesCodeList = assetContent.split(/\r?\n/);
|
|
181
|
+
map = (null == (_asset_source3 = asset.source) ? void 0 : null == (_asset_source_sourceAndMap1 = _asset_source3.sourceAndMap) ? void 0 : null == (_asset_source_sourceAndMap = _asset_source_sourceAndMap1.call(_asset_source3)) ? void 0 : _asset_source_sourceAndMap.map) || null;
|
|
182
|
+
}
|
|
183
|
+
} catch (error) {
|
|
184
|
+
logger_namespaceObject.logger.debug(`Error parsing asset ${assetName}:`, error);
|
|
185
|
+
return {
|
|
186
|
+
assetName,
|
|
187
|
+
assetContent: '',
|
|
188
|
+
assetLinesCodeList: [],
|
|
189
|
+
map: null
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
return {
|
|
193
|
+
assetName,
|
|
194
|
+
assetContent,
|
|
195
|
+
assetLinesCodeList,
|
|
196
|
+
map
|
|
197
|
+
};
|
|
198
|
+
}
|
|
199
|
+
exports.UNASSIGNED = __webpack_exports__.UNASSIGNED;
|
|
200
|
+
exports.bindContextCache = __webpack_exports__.bindContextCache;
|
|
201
|
+
exports.collectSourceMaps = __webpack_exports__.collectSourceMaps;
|
|
202
|
+
exports.handleAfterEmitAssets = __webpack_exports__.handleAfterEmitAssets;
|
|
203
|
+
exports.handleEmitAssets = __webpack_exports__.handleEmitAssets;
|
|
204
|
+
for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
205
|
+
"UNASSIGNED",
|
|
206
|
+
"bindContextCache",
|
|
207
|
+
"collectSourceMaps",
|
|
208
|
+
"handleAfterEmitAssets",
|
|
209
|
+
"handleEmitAssets"
|
|
210
|
+
].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
|
|
211
|
+
Object.defineProperty(exports, '__esModule', {
|
|
212
|
+
value: true
|
|
213
|
+
});
|
|
@@ -1,61 +1,31 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
get: definition[key]
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
|
-
})();
|
|
11
|
-
(()=>{
|
|
12
|
-
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
-
})();
|
|
14
|
-
(()=>{
|
|
15
|
-
__webpack_require__.r = (exports1)=>{
|
|
16
|
-
if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
-
value: 'Module'
|
|
18
|
-
});
|
|
19
|
-
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
-
value: true
|
|
21
|
-
});
|
|
22
|
-
};
|
|
23
|
-
})();
|
|
24
|
-
var __webpack_exports__ = {};
|
|
25
|
-
__webpack_require__.r(__webpack_exports__);
|
|
26
|
-
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
-
UNASSIGNED: ()=>UNASSIGNED,
|
|
28
|
-
collectSourceMaps: ()=>collectSourceMaps,
|
|
29
|
-
bindContextCache: ()=>bindContextCache,
|
|
30
|
-
handleAfterEmitAssets: ()=>handleAfterEmitAssets,
|
|
31
|
-
handleEmitAssets: ()=>handleEmitAssets
|
|
32
|
-
});
|
|
33
|
-
const common_namespaceObject = require("@rsdoctor/utils/common");
|
|
34
|
-
const logger_namespaceObject = require("@rsdoctor/utils/logger");
|
|
35
|
-
const external_path_namespaceObject = require("path");
|
|
36
|
-
const external_source_map_namespaceObject = require("source-map");
|
|
1
|
+
import 'module';
|
|
2
|
+
/*#__PURE__*/ import.meta.url;
|
|
3
|
+
import { Graph } from "@rsdoctor/utils/common";
|
|
4
|
+
import { logger, time, timeEnd } from "@rsdoctor/utils/logger";
|
|
5
|
+
import { resolve } from "path";
|
|
6
|
+
import { SourceMapConsumer } from "source-map";
|
|
37
7
|
const UNASSIGNED = '[unassigned]';
|
|
38
8
|
function bindContextCache(context, namespace, cache) {
|
|
39
9
|
cache = cache || new Map();
|
|
40
10
|
return (source, sourceMapFilenameRegex)=>{
|
|
41
11
|
if (cache.has(source)) return cache.get(source);
|
|
42
12
|
let resolved = UNASSIGNED;
|
|
43
|
-
if (source.startsWith('file://')) resolved =
|
|
13
|
+
if (source.startsWith('file://')) resolved = resolve(context, source.replace(/^file:\/\//, ''));
|
|
44
14
|
else if (source.startsWith('webpack://')) {
|
|
45
15
|
const match = source.match(sourceMapFilenameRegex);
|
|
46
16
|
const filePath = null == match ? void 0 : match[1];
|
|
47
17
|
const hasNamespace = namespace && source.startsWith(`webpack://${namespace}`) || namespace && source.startsWith(`file://${namespace}`);
|
|
48
18
|
const baseDir = hasNamespace ? process.cwd() : context;
|
|
49
|
-
resolved = filePath ?
|
|
50
|
-
} else resolved =
|
|
19
|
+
resolved = filePath ? resolve(baseDir, `./${filePath}`) : UNASSIGNED;
|
|
20
|
+
} else resolved = resolve(context, source);
|
|
51
21
|
cache.set(source, resolved);
|
|
52
22
|
return resolved;
|
|
53
23
|
};
|
|
54
24
|
}
|
|
55
25
|
async function collectSourceMaps(map, assetLinesCodeList, _compilation, _this, sourceMapFilenameRegex, namespace) {
|
|
56
26
|
if (map) {
|
|
57
|
-
const consumer = await new
|
|
58
|
-
const getRealSourcePath = bindContextCache(_this.sdk.
|
|
27
|
+
const consumer = await new SourceMapConsumer(map);
|
|
28
|
+
const getRealSourcePath = bindContextCache(_this.sdk.root || process.cwd(), namespace, _this._realSourcePathCache);
|
|
59
29
|
const lineMappings = new Map();
|
|
60
30
|
consumer.eachMapping((m)=>{
|
|
61
31
|
if (!lineMappings.has(m.generatedLine)) lineMappings.set(m.generatedLine, []);
|
|
@@ -85,7 +55,7 @@ async function collectSourceMaps(map, assetLinesCodeList, _compilation, _this, s
|
|
|
85
55
|
async function handleAfterEmitAssets(compilation, _this, sourceMapFilenameRegex, namespace) {
|
|
86
56
|
if ('rspack' in compilation.compiler) {
|
|
87
57
|
_this.sourceMapSets = new Map();
|
|
88
|
-
|
|
58
|
+
time('ensureModulesChunkGraph.afterEmit.start');
|
|
89
59
|
const assets = [
|
|
90
60
|
...compilation.getAssets()
|
|
91
61
|
];
|
|
@@ -100,9 +70,9 @@ async function handleAfterEmitAssets(compilation, _this, sourceMapFilenameRegex,
|
|
|
100
70
|
{
|
|
101
71
|
let sourceMapAsset = assets.find((asset)=>asset.name === sourceMapFile);
|
|
102
72
|
if (!sourceMapAsset && sourceMapFileAssetName) {
|
|
103
|
-
const baseNameWithoutHash =
|
|
73
|
+
const baseNameWithoutHash = Graph.formatAssetName(sourceMapFileAssetName, 'string' == typeof compilation.options.output.filename ? compilation.options.output.filename : void 0);
|
|
104
74
|
sourceMapAsset = assets.find((asset)=>{
|
|
105
|
-
const assetBaseName =
|
|
75
|
+
const assetBaseName = Graph.formatAssetName(asset.name, 'string' == typeof compilation.options.output.filename ? compilation.options.output.filename : void 0);
|
|
106
76
|
return assetBaseName.includes(baseNameWithoutHash) && asset.name.endsWith('.map');
|
|
107
77
|
});
|
|
108
78
|
}
|
|
@@ -112,17 +82,17 @@ async function handleAfterEmitAssets(compilation, _this, sourceMapFilenameRegex,
|
|
|
112
82
|
try {
|
|
113
83
|
await collectSourceMaps(map, assetLinesCodeList, compilation, _this, sourceMapFilenameRegex, namespace);
|
|
114
84
|
} catch (e) {
|
|
115
|
-
|
|
85
|
+
logger.debug(e);
|
|
116
86
|
}
|
|
117
87
|
}
|
|
118
|
-
|
|
88
|
+
timeEnd('ensureModulesChunkGraph.afterEmit.start');
|
|
119
89
|
}
|
|
120
90
|
}
|
|
121
91
|
async function handleEmitAssets(options) {
|
|
122
92
|
const { compilation, pluginInstance, sourceMapFilenameRegex, namespace } = options;
|
|
123
93
|
if (!('rspack' in compilation.compiler)) {
|
|
124
94
|
pluginInstance.sourceMapSets = new Map();
|
|
125
|
-
|
|
95
|
+
time('ensureModulesChunkGraph.afterEmit.start');
|
|
126
96
|
const assets = Object.values(compilation.getAssets()).map((asset, index)=>({
|
|
127
97
|
name: index.toString(),
|
|
128
98
|
source: asset,
|
|
@@ -133,10 +103,10 @@ async function handleEmitAssets(options) {
|
|
|
133
103
|
if (map) try {
|
|
134
104
|
await collectSourceMaps(map, assetLinesCodeList, compilation, pluginInstance, sourceMapFilenameRegex, namespace);
|
|
135
105
|
} catch (e) {
|
|
136
|
-
|
|
106
|
+
logger.debug(e);
|
|
137
107
|
}
|
|
138
108
|
}
|
|
139
|
-
|
|
109
|
+
timeEnd('ensureModulesChunkGraph.afterEmit.start');
|
|
140
110
|
}
|
|
141
111
|
}
|
|
142
112
|
function parseAsset(asset, assets, type) {
|
|
@@ -150,7 +120,7 @@ function parseAsset(asset, assets, type) {
|
|
|
150
120
|
var _asset_source_source_source, _asset_source_source, _asset_source1, _bundledAsset_source_source_source, _bundledAsset_source_source, _bundledAsset_source;
|
|
151
121
|
assetContent = (null == (_asset_source1 = asset.source) ? void 0 : null == (_asset_source_source = _asset_source1.source) ? void 0 : null == (_asset_source_source_source = _asset_source_source.source) ? void 0 : _asset_source_source_source.call(_asset_source_source)) || '';
|
|
152
122
|
if (!assetContent) {
|
|
153
|
-
|
|
123
|
+
logger.debug(`Failed to get source content for asset: ${assetName}`);
|
|
154
124
|
return {
|
|
155
125
|
assetName,
|
|
156
126
|
assetContent: '',
|
|
@@ -165,7 +135,7 @@ function parseAsset(asset, assets, type) {
|
|
|
165
135
|
});
|
|
166
136
|
const bundledCode = (null == bundledAsset ? void 0 : null == (_bundledAsset_source = bundledAsset.source) ? void 0 : null == (_bundledAsset_source_source = _bundledAsset_source.source) ? void 0 : null == (_bundledAsset_source_source_source = _bundledAsset_source_source.source) ? void 0 : _bundledAsset_source_source_source.call(_bundledAsset_source_source)) || '';
|
|
167
137
|
if (!bundledCode) {
|
|
168
|
-
|
|
138
|
+
logger.debug(`Failed to get bundled code for asset: ${map.file}`);
|
|
169
139
|
return {
|
|
170
140
|
assetName,
|
|
171
141
|
assetContent,
|
|
@@ -181,7 +151,7 @@ function parseAsset(asset, assets, type) {
|
|
|
181
151
|
map = (null == (_asset_source3 = asset.source) ? void 0 : null == (_asset_source_sourceAndMap1 = _asset_source3.sourceAndMap) ? void 0 : null == (_asset_source_sourceAndMap = _asset_source_sourceAndMap1.call(_asset_source3)) ? void 0 : _asset_source_sourceAndMap.map) || null;
|
|
182
152
|
}
|
|
183
153
|
} catch (error) {
|
|
184
|
-
|
|
154
|
+
logger.debug(`Error parsing asset ${assetName}:`, error);
|
|
185
155
|
return {
|
|
186
156
|
assetName,
|
|
187
157
|
assetContent: '',
|
|
@@ -196,18 +166,4 @@ function parseAsset(asset, assets, type) {
|
|
|
196
166
|
map
|
|
197
167
|
};
|
|
198
168
|
}
|
|
199
|
-
|
|
200
|
-
exports.bindContextCache = __webpack_exports__.bindContextCache;
|
|
201
|
-
exports.collectSourceMaps = __webpack_exports__.collectSourceMaps;
|
|
202
|
-
exports.handleAfterEmitAssets = __webpack_exports__.handleAfterEmitAssets;
|
|
203
|
-
exports.handleEmitAssets = __webpack_exports__.handleEmitAssets;
|
|
204
|
-
for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
205
|
-
"UNASSIGNED",
|
|
206
|
-
"bindContextCache",
|
|
207
|
-
"collectSourceMaps",
|
|
208
|
-
"handleAfterEmitAssets",
|
|
209
|
-
"handleEmitAssets"
|
|
210
|
-
].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
|
|
211
|
-
Object.defineProperty(exports, '__esModule', {
|
|
212
|
-
value: true
|
|
213
|
-
});
|
|
169
|
+
export { UNASSIGNED, bindContextCache, collectSourceMaps, handleAfterEmitAssets, handleEmitAssets };
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
InternalSummaryPlugin: ()=>InternalSummaryPlugin
|
|
28
|
+
});
|
|
29
|
+
const common_namespaceObject = require("@rsdoctor/utils/common");
|
|
30
|
+
const external_lodash_es_namespaceObject = require("lodash-es");
|
|
31
|
+
const external_base_cjs_namespaceObject = require("./base.cjs");
|
|
32
|
+
const logger_namespaceObject = require("@rsdoctor/utils/logger");
|
|
33
|
+
class InternalSummaryPlugin extends external_base_cjs_namespaceObject.InternalBasePlugin {
|
|
34
|
+
apply(compiler) {
|
|
35
|
+
(0, logger_namespaceObject.time)('InternalSummaryPlugin.apply');
|
|
36
|
+
try {
|
|
37
|
+
compiler.hooks.beforeCompile.tapPromise(this.tapPostOptions, this.beforeCompile);
|
|
38
|
+
compiler.hooks.afterCompile.tapPromise(this.tapPreOptions, this.afterCompile);
|
|
39
|
+
compiler.hooks.done.tapPromise(this.tapPostOptions, this.done.bind(this, compiler));
|
|
40
|
+
} finally{
|
|
41
|
+
(0, logger_namespaceObject.timeEnd)('InternalSummaryPlugin.apply');
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
mark(key, type) {
|
|
45
|
+
const now = Date.now();
|
|
46
|
+
switch(type){
|
|
47
|
+
case 'pre':
|
|
48
|
+
this.preTimes.set(key, now);
|
|
49
|
+
break;
|
|
50
|
+
case 'post':
|
|
51
|
+
this.postTimes.set(key, now);
|
|
52
|
+
break;
|
|
53
|
+
default:
|
|
54
|
+
break;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
report(name, start) {
|
|
58
|
+
this.times.set(name, start);
|
|
59
|
+
this.sdk.reportSummaryData({
|
|
60
|
+
costs: [
|
|
61
|
+
{
|
|
62
|
+
name,
|
|
63
|
+
startAt: start,
|
|
64
|
+
costs: Date.now() - start
|
|
65
|
+
}
|
|
66
|
+
]
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
constructor(...args){
|
|
70
|
+
super(...args), this.name = 'summary', this.times = new Map(), this.preTimes = new Map(), this.postTimes = new Map(), this.beforeCompile = async ()=>{
|
|
71
|
+
(0, logger_namespaceObject.time)('InternalSummaryPlugin.beforeCompile');
|
|
72
|
+
try {
|
|
73
|
+
if (!this.times.has(common_namespaceObject.Summary.SummaryCostsDataName.Bootstrap)) {
|
|
74
|
+
const costs = Math.floor(1000 * process.uptime());
|
|
75
|
+
const startAt = Date.now() - costs;
|
|
76
|
+
this.report(common_namespaceObject.Summary.SummaryCostsDataName.Bootstrap, startAt);
|
|
77
|
+
this.mark(common_namespaceObject.Summary.SummaryCostsDataName.Bootstrap, 'post');
|
|
78
|
+
}
|
|
79
|
+
} finally{
|
|
80
|
+
(0, logger_namespaceObject.timeEnd)('InternalSummaryPlugin.beforeCompile');
|
|
81
|
+
}
|
|
82
|
+
}, this.afterCompile = async (compilation)=>{
|
|
83
|
+
(0, logger_namespaceObject.time)('InternalSummaryPlugin.afterCompile');
|
|
84
|
+
try {
|
|
85
|
+
if (!this.times.has(common_namespaceObject.Summary.SummaryCostsDataName.Compile) && !compilation.compiler.isChild()) {
|
|
86
|
+
const start = this.postTimes.get(common_namespaceObject.Summary.SummaryCostsDataName.Bootstrap);
|
|
87
|
+
this.report(common_namespaceObject.Summary.SummaryCostsDataName.Compile, start);
|
|
88
|
+
this.mark(common_namespaceObject.Summary.SummaryCostsDataName.Compile, 'post');
|
|
89
|
+
}
|
|
90
|
+
} finally{
|
|
91
|
+
(0, logger_namespaceObject.timeEnd)('InternalSummaryPlugin.afterCompile');
|
|
92
|
+
}
|
|
93
|
+
}, this.done = async (compiler)=>{
|
|
94
|
+
(0, logger_namespaceObject.time)('InternalSummaryPlugin.done');
|
|
95
|
+
try {
|
|
96
|
+
const start = this.postTimes.get(common_namespaceObject.Summary.SummaryCostsDataName.Compile);
|
|
97
|
+
this.report(common_namespaceObject.Summary.SummaryCostsDataName.Done, start);
|
|
98
|
+
if (false !== compiler.options.optimization.minimize) {
|
|
99
|
+
const pluginData = this.sdk.getStoreData().plugin;
|
|
100
|
+
const minifyHookData = [
|
|
101
|
+
...pluginData.processAssets || []
|
|
102
|
+
];
|
|
103
|
+
minifyHookData.length && this.sdk.reportSummaryData({
|
|
104
|
+
costs: [
|
|
105
|
+
{
|
|
106
|
+
name: common_namespaceObject.Summary.SummaryCostsDataName.Minify,
|
|
107
|
+
startAt: (0, external_lodash_es_namespaceObject.minBy)(minifyHookData, (e)=>e.startAt).startAt,
|
|
108
|
+
costs: (0, external_lodash_es_namespaceObject.sumBy)(minifyHookData, (e)=>e.costs)
|
|
109
|
+
}
|
|
110
|
+
]
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
} finally{
|
|
114
|
+
(0, logger_namespaceObject.timeEnd)('InternalSummaryPlugin.done');
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
exports.InternalSummaryPlugin = __webpack_exports__.InternalSummaryPlugin;
|
|
120
|
+
for(var __webpack_i__ in __webpack_exports__)if (-1 === [
|
|
121
|
+
"InternalSummaryPlugin"
|
|
122
|
+
].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
|
|
123
|
+
Object.defineProperty(exports, '__esModule', {
|
|
124
|
+
value: true
|
|
125
|
+
});
|