dependency-cruiser 17.3.2 → 17.3.3-beta-2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (232) hide show
  1. package/bin/depcruise-baseline.mjs +43 -43
  2. package/bin/depcruise-fmt.mjs +89 -89
  3. package/bin/dependency-cruise.mjs +171 -171
  4. package/configs/plugins/3d-reporter-plugin.mjs +36 -36
  5. package/configs/plugins/stats-reporter-plugin.mjs +51 -51
  6. package/configs/recommended-strict.cjs +5 -5
  7. package/configs/recommended-warn-only.cjs +5 -5
  8. package/configs/recommended.cjs +22 -22
  9. package/configs/rules/no-circular.cjs +10 -10
  10. package/configs/rules/no-deprecated-core.cjs +10 -10
  11. package/configs/rules/no-duplicate-dependency-types.cjs +17 -17
  12. package/configs/rules/no-non-package-json.cjs +11 -11
  13. package/configs/rules/no-orphans.cjs +18 -18
  14. package/configs/rules/not-to-deprecated.cjs +10 -10
  15. package/configs/rules/not-to-unresolvable.cjs +10 -10
  16. package/package.json +170 -170
  17. package/src/cache/cache.mjs +139 -139
  18. package/src/cache/content-strategy.mjs +88 -88
  19. package/src/cache/find-content-changes.mjs +58 -58
  20. package/src/cache/helpers.mjs +52 -52
  21. package/src/cache/metadata-strategy.mjs +83 -83
  22. package/src/cache/options-compatible.mjs +56 -109
  23. package/src/cli/assert-node-environment-suitable.mjs +7 -7
  24. package/src/cli/defaults.mjs +5 -5
  25. package/src/cli/format-meta-info.mjs +22 -22
  26. package/src/cli/format.mjs +28 -28
  27. package/src/cli/index.mjs +145 -145
  28. package/src/cli/init-config/build-config.mjs +94 -94
  29. package/src/cli/init-config/environment-helpers.mjs +77 -77
  30. package/src/cli/init-config/find-extensions.mjs +27 -27
  31. package/src/cli/init-config/get-user-input.mjs +151 -151
  32. package/src/cli/init-config/index.mjs +88 -88
  33. package/src/cli/init-config/normalize-init-options.mjs +47 -47
  34. package/src/cli/init-config/utl.mjs +4 -4
  35. package/src/cli/init-config/validators.mjs +10 -10
  36. package/src/cli/init-config/write-config.mjs +21 -21
  37. package/src/cli/init-config/write-run-scripts-to-manifest.mjs +103 -107
  38. package/src/cli/listeners/cli-feedback.mjs +49 -49
  39. package/src/cli/listeners/ndjson.mjs +66 -66
  40. package/src/cli/listeners/performance-log/format-helpers.mjs +63 -63
  41. package/src/cli/listeners/performance-log/handlers.mjs +56 -56
  42. package/src/cli/listeners/performance-log/index.mjs +37 -37
  43. package/src/cli/normalize-cli-options.mjs +182 -182
  44. package/src/cli/tools/wrap-stream-in-html.mjs +37 -37
  45. package/src/cli/utl/assert-file-existence.mjs +7 -7
  46. package/src/cli/utl/io.mjs +28 -31
  47. package/src/config-utl/extract-babel-config.mjs +69 -69
  48. package/src/config-utl/extract-depcruise-config/index.mjs +54 -54
  49. package/src/config-utl/extract-depcruise-config/merge-configs.mjs +63 -63
  50. package/src/config-utl/extract-depcruise-config/read-config.mjs +9 -9
  51. package/src/config-utl/extract-depcruise-options.mjs +9 -9
  52. package/src/config-utl/extract-known-violations.mjs +49 -49
  53. package/src/config-utl/extract-ts-config.mjs +46 -48
  54. package/src/config-utl/extract-webpack-resolve-config.mjs +88 -88
  55. package/src/config-utl/make-absolute.mjs +5 -5
  56. package/src/enrich/add-validations.mjs +13 -13
  57. package/src/enrich/derive/circular.mjs +49 -49
  58. package/src/enrich/derive/dependents.mjs +27 -27
  59. package/src/enrich/derive/folders/aggregate-to-folders.mjs +104 -104
  60. package/src/enrich/derive/folders/index.mjs +19 -19
  61. package/src/enrich/derive/folders/utl.mjs +18 -18
  62. package/src/enrich/derive/metrics/get-module-metrics.mjs +27 -27
  63. package/src/enrich/derive/metrics/index.mjs +8 -8
  64. package/src/enrich/derive/module-utl.mjs +18 -18
  65. package/src/enrich/derive/orphan/index.mjs +18 -18
  66. package/src/enrich/derive/orphan/is-orphan.mjs +9 -9
  67. package/src/enrich/derive/reachable.mjs +165 -168
  68. package/src/enrich/enrich-modules.mjs +25 -25
  69. package/src/enrich/index.mjs +15 -15
  70. package/src/enrich/soften-known-violations.mjs +90 -90
  71. package/src/enrich/summarize/add-rule-set-used.mjs +13 -13
  72. package/src/enrich/summarize/get-stats.mjs +17 -17
  73. package/src/enrich/summarize/index.mjs +18 -18
  74. package/src/enrich/summarize/is-same-violation.mjs +30 -30
  75. package/src/enrich/summarize/summarize-folders.mjs +35 -35
  76. package/src/enrich/summarize/summarize-modules.mjs +97 -97
  77. package/src/enrich/summarize/summarize-options.mjs +71 -71
  78. package/src/extract/acorn/estree-helpers.mjs +66 -66
  79. package/src/extract/acorn/extract-amd-deps.mjs +63 -64
  80. package/src/extract/acorn/extract-cjs-deps.mjs +83 -83
  81. package/src/extract/acorn/extract-es6-deps.mjs +54 -54
  82. package/src/extract/acorn/extract-stats.mjs +4 -4
  83. package/src/extract/acorn/extract.mjs +28 -28
  84. package/src/extract/acorn/parse.mjs +37 -37
  85. package/src/extract/clear-caches.mjs +7 -7
  86. package/src/extract/extract-dependencies.mjs +109 -109
  87. package/src/extract/extract-stats.mjs +21 -21
  88. package/src/extract/gather-initial-sources.mjs +64 -64
  89. package/src/extract/helpers.mjs +73 -71
  90. package/src/extract/index.mjs +120 -120
  91. package/src/extract/resolve/determine-dependency-types.mjs +166 -169
  92. package/src/extract/resolve/external-module-helpers.mjs +76 -76
  93. package/src/extract/resolve/get-manifest.mjs +79 -79
  94. package/src/extract/resolve/index.mjs +175 -164
  95. package/src/extract/resolve/is-built-in.mjs +22 -24
  96. package/src/extract/resolve/merge-manifests.mjs +43 -43
  97. package/src/extract/resolve/module-classifiers.mjs +229 -229
  98. package/src/extract/resolve/resolve-amd.mjs +44 -44
  99. package/src/extract/resolve/resolve-cjs.mjs +40 -40
  100. package/src/extract/resolve/resolve-helpers.mjs +20 -20
  101. package/src/extract/resolve/resolve.mjs +26 -26
  102. package/src/extract/swc/dependency-visitor.mjs +211 -211
  103. package/src/extract/swc/extract-swc-deps.mjs +4 -4
  104. package/src/extract/swc/extract.mjs +7 -7
  105. package/src/extract/swc/parse.mjs +12 -12
  106. package/src/extract/transpile/babel-wrap.mjs +9 -9
  107. package/src/extract/transpile/coffeescript-wrap.mjs +21 -21
  108. package/src/extract/transpile/index.mjs +47 -47
  109. package/src/extract/transpile/javascript-wrap.mjs +6 -6
  110. package/src/extract/transpile/livescript-wrap.mjs +5 -5
  111. package/src/extract/transpile/meta.mjs +80 -80
  112. package/src/extract/transpile/svelte-preprocess.mjs +73 -73
  113. package/src/extract/transpile/svelte-wrap.mjs +19 -19
  114. package/src/extract/transpile/try-import-available.mjs +26 -27
  115. package/src/extract/transpile/typescript-wrap.mjs +39 -39
  116. package/src/extract/transpile/vue-template-wrap.cjs +43 -43
  117. package/src/extract/tsc/extract-stats.mjs +4 -4
  118. package/src/extract/tsc/extract-typescript-deps.mjs +429 -398
  119. package/src/extract/tsc/extract.mjs +22 -22
  120. package/src/extract/tsc/parse.mjs +21 -21
  121. package/src/graph-utl/add-focus.mjs +35 -35
  122. package/src/graph-utl/compare.mjs +24 -24
  123. package/src/graph-utl/consolidate-module-dependencies.mjs +35 -35
  124. package/src/graph-utl/consolidate-modules.mjs +33 -33
  125. package/src/graph-utl/consolidate-to-folder.mjs +13 -13
  126. package/src/graph-utl/consolidate-to-pattern.mjs +34 -34
  127. package/src/graph-utl/filter-bank.mjs +74 -69
  128. package/src/graph-utl/indexed-module-graph.mjs +227 -225
  129. package/src/graph-utl/match-facade.mjs +3 -3
  130. package/src/graph-utl/rule-set.mjs +20 -20
  131. package/src/graph-utl/strip-self-transitions.mjs +6 -6
  132. package/src/main/cruise.mjs +81 -81
  133. package/src/main/files-and-dirs/normalize.mjs +7 -7
  134. package/src/main/format.mjs +11 -14
  135. package/src/main/helpers.mjs +25 -25
  136. package/src/main/index.mjs +8 -8
  137. package/src/main/options/assert-validity.mjs +100 -100
  138. package/src/main/options/defaults.mjs +11 -11
  139. package/src/main/options/normalize.mjs +158 -160
  140. package/src/main/report-wrap.mjs +37 -37
  141. package/src/main/resolve-options/normalize.mjs +127 -128
  142. package/src/main/rule-set/assert-validity.mjs +67 -73
  143. package/src/main/rule-set/normalize.mjs +81 -79
  144. package/src/meta.cjs +15 -16
  145. package/src/report/anon/anonymize-path-element.mjs +20 -34
  146. package/src/report/anon/anonymize-path.mjs +11 -11
  147. package/src/report/anon/index.mjs +119 -119
  148. package/src/report/anon/random-string.mjs +23 -23
  149. package/src/report/azure-devops.mjs +75 -99
  150. package/src/report/baseline.mjs +9 -9
  151. package/src/report/csv.mjs +13 -13
  152. package/src/report/d2.mjs +105 -105
  153. package/src/report/dot/default-theme.mjs +152 -152
  154. package/src/report/dot/index.mjs +146 -146
  155. package/src/report/dot/module-utl.mjs +72 -72
  156. package/src/report/dot/prepare-custom-level.mjs +20 -20
  157. package/src/report/dot/prepare-flat-level.mjs +11 -11
  158. package/src/report/dot/prepare-folder-level.mjs +12 -13
  159. package/src/report/dot/theming.mjs +73 -73
  160. package/src/report/dot-webpage/dot-module.mjs +36 -36
  161. package/src/report/dot-webpage/svg-in-html-snippets/script.cjs +208 -210
  162. package/src/report/dot-webpage/svg-in-html-snippets/style.css +51 -51
  163. package/src/report/dot-webpage/wrap-in-html.mjs +7 -7
  164. package/src/report/error-html/index.mjs +49 -49
  165. package/src/report/error-html/utl.mjs +99 -99
  166. package/src/report/error-long.mjs +1 -1
  167. package/src/report/error.mjs +93 -93
  168. package/src/report/html/index.mjs +48 -48
  169. package/src/report/identity.mjs +4 -4
  170. package/src/report/index.mjs +33 -33
  171. package/src/report/json.mjs +4 -4
  172. package/src/report/markdown.mjs +120 -120
  173. package/src/report/mermaid.mjs +111 -111
  174. package/src/report/metrics.mjs +185 -185
  175. package/src/report/null.mjs +4 -4
  176. package/src/report/plugins.mjs +41 -41
  177. package/src/report/teamcity.mjs +150 -150
  178. package/src/report/text.mjs +42 -42
  179. package/src/report/utl/dependency-to-incidence-transformer.mjs +32 -32
  180. package/src/report/utl/index.mjs +53 -53
  181. package/src/schema/configuration.validate.mjs +1 -0
  182. package/src/schema/cruise-result.validate.mjs +1 -0
  183. package/src/schema/utl.mjs +6 -0
  184. package/src/utl/array-util.mjs +25 -25
  185. package/src/utl/bus.mjs +12 -12
  186. package/src/utl/extract-root-module-name.cjs +8 -8
  187. package/src/utl/find-all-files.mjs +54 -54
  188. package/src/utl/get-extension.mjs +2 -2
  189. package/src/utl/object-util.mjs +21 -22
  190. package/src/utl/path-to-posix.mjs +5 -5
  191. package/src/utl/regex-util.mjs +20 -20
  192. package/src/utl/try-import.mjs +42 -41
  193. package/src/utl/try-require.cjs +23 -23
  194. package/src/utl/wrap-and-indent.mjs +33 -33
  195. package/src/validate/index.mjs +65 -65
  196. package/src/validate/match-dependency-rule.mjs +47 -47
  197. package/src/validate/match-folder-dependency-rule.mjs +27 -27
  198. package/src/validate/match-module-rule-helpers.mjs +76 -76
  199. package/src/validate/match-module-rule.mjs +12 -12
  200. package/src/validate/matchers.mjs +162 -162
  201. package/src/validate/rule-classifiers.mjs +9 -9
  202. package/src/validate/violates-required-rule.mjs +23 -23
  203. package/types/cache-options.d.mts +27 -27
  204. package/types/config-utl/extract-babel-config.d.mts +1 -1
  205. package/types/config-utl/extract-depcruise-config.d.mts +3 -3
  206. package/types/config-utl/extract-depcruise-options.d.mts +1 -1
  207. package/types/config-utl/extract-ts-config.d.mts +1 -1
  208. package/types/config-utl/extract-webpack-resolve-config.d.mts +3 -3
  209. package/types/configuration.d.mts +10 -10
  210. package/types/cruise-result.d.mts +414 -414
  211. package/types/dependency-cruiser.d.mts +52 -52
  212. package/types/filter-types.d.mts +45 -45
  213. package/types/options.d.mts +430 -430
  214. package/types/plugins/3d-reporter-plugin.d.mts +9 -9
  215. package/types/plugins/mermaid-reporter-plugin.d.mts +10 -10
  216. package/types/plugins/stats-reporter-plugin.d.mts +9 -9
  217. package/types/reporter-options.d.mts +196 -196
  218. package/types/resolve-options.d.mts +23 -23
  219. package/types/restrictions.d.mts +174 -174
  220. package/types/rule-set.d.mts +132 -132
  221. package/types/rule-summary.d.mts +14 -14
  222. package/types/shared-types.d.mts +89 -89
  223. package/types/strict-filter-types.d.mts +52 -52
  224. package/types/strict-options.d.mts +34 -34
  225. package/types/strict-restrictions.d.mts +25 -25
  226. package/types/strict-rule-set.d.mts +36 -36
  227. package/types/violations.d.mts +40 -40
  228. package/src/schema/README.md +0 -5
  229. package/src/schema/baseline-violations.schema.mjs +0 -1
  230. package/src/schema/configuration.schema.mjs +0 -1
  231. package/src/schema/cruise-result.schema.mjs +0 -1
  232. package/types/README.md +0 -1
@@ -59,21 +59,21 @@ const TEMPLATE = `
59
59
  </html>`;
60
60
 
61
61
  function deriveGroup(pFileName) {
62
- let lReturnValue = "unknown";
63
- const lGroupPositionInRe = 2;
64
- const lMatch = path.dirname(pFileName).match(/^([^/]+)\/([^/]+)/);
65
- if (lMatch) {
66
- // eslint-disable-next-line security/detect-object-injection
67
- lReturnValue = lMatch[lGroupPositionInRe];
68
- }
69
- return lReturnValue;
62
+ let lReturnValue = "unknown";
63
+ const lGroupPositionInRe = 2;
64
+ const lMatch = path.dirname(pFileName).match(/^([^/]+)\/([^/]+)/);
65
+ if (lMatch) {
66
+ // eslint-disable-next-line security/detect-object-injection
67
+ lReturnValue = lMatch[lGroupPositionInRe];
68
+ }
69
+ return lReturnValue;
70
70
  }
71
71
 
72
72
  function formatFileName(pFileName) {
73
- return `${path.dirname(pFileName)}/<b>${path.basename(pFileName)}</b>`;
73
+ return `${path.dirname(pFileName)}/<b>${path.basename(pFileName)}</b>`;
74
74
  }
75
75
  function formatDependency(pFrom, pTo) {
76
- return `${formatFileName(pFrom)} →</br>${formatFileName(pTo)}`;
76
+ return `${formatFileName(pFrom)} →</br>${formatFileName(pTo)}`;
77
77
  }
78
78
 
79
79
  /**
@@ -81,31 +81,31 @@ function formatDependency(pFrom, pTo) {
81
81
  * @param {import('../../types/dependency-cruiser').ICruiseResult} pCruiseResult
82
82
  */
83
83
  function render3DThing(pCruiseResult) {
84
- const lNodes = pCruiseResult.modules.map((pModule) => {
85
- return {
86
- id: pModule.source,
87
- displayname: path.basename(pModule.source),
88
- dirname: path.dirname(pModule.source),
89
- label: formatFileName(pModule.source),
90
- group: deriveGroup(pModule.source),
91
- };
92
- });
93
- const lLinks = pCruiseResult.modules.reduce(
94
- (pAll, pCurrentModule) =>
95
- pAll.concat(
96
- pCurrentModule.dependencies.map((pDependency) => ({
97
- source: pCurrentModule.source,
98
- target: pDependency.resolved,
99
- label: formatDependency(pCurrentModule.source, pDependency.resolved),
100
- })),
101
- ),
102
- [],
103
- );
84
+ const lNodes = pCruiseResult.modules.map((pModule) => {
85
+ return {
86
+ id: pModule.source,
87
+ displayname: path.basename(pModule.source),
88
+ dirname: path.dirname(pModule.source),
89
+ label: formatFileName(pModule.source),
90
+ group: deriveGroup(pModule.source),
91
+ };
92
+ });
93
+ const lLinks = pCruiseResult.modules.reduce(
94
+ (pAll, pCurrentModule) =>
95
+ pAll.concat(
96
+ pCurrentModule.dependencies.map((pDependency) => ({
97
+ source: pCurrentModule.source,
98
+ target: pDependency.resolved,
99
+ label: formatDependency(pCurrentModule.source, pDependency.resolved),
100
+ })),
101
+ ),
102
+ [],
103
+ );
104
104
 
105
- return TEMPLATE.replace(/@@NODES@@/g, JSON.stringify(lNodes)).replace(
106
- /@@LINKS@@/g,
107
- JSON.stringify(lLinks),
108
- );
105
+ return TEMPLATE.replace(/@@NODES@@/g, JSON.stringify(lNodes)).replace(
106
+ /@@LINKS@@/g,
107
+ JSON.stringify(lLinks),
108
+ );
109
109
  }
110
110
 
111
111
  /**
@@ -119,6 +119,6 @@ function render3DThing(pCruiseResult) {
119
119
  * exitCode: 0
120
120
  */
121
121
  export default (pCruiseResult) => ({
122
- output: render3DThing(pCruiseResult),
123
- exitCode: 0,
122
+ output: render3DThing(pCruiseResult),
123
+ exitCode: 0,
124
124
  });
@@ -3,31 +3,31 @@ const P75 = 0.75;
3
3
  const DEFAULT_JSON_INDENT = 2;
4
4
 
5
5
  function doMagic(pCruiseResult) {
6
- let lReturnValue = {};
6
+ let lReturnValue = {};
7
7
 
8
- if (pCruiseResult.modules.some((pModule) => pModule.dependents)) {
9
- const lDependentCounts = pCruiseResult.modules
10
- .map((pModule) => pModule.dependents.length)
11
- .sort();
8
+ if (pCruiseResult.modules.some((pModule) => pModule.dependents)) {
9
+ const lDependentCounts = pCruiseResult.modules
10
+ .map((pModule) => pModule.dependents.length)
11
+ .sort();
12
12
 
13
- lReturnValue = {
14
- minDependentsPerModule: lDependentCounts[0] || 0,
15
- maxDependentsPerModule:
16
- lDependentCounts[Math.max(lDependentCounts.length - 1, 0)] || 0,
17
- meanDependentsPerModule:
18
- lDependentCounts.reduce((pAll, pCurrent) => pAll + pCurrent, 0) /
19
- pCruiseResult.summary.totalCruised,
20
- medianDependentsPerModule:
21
- lDependentCounts[
22
- Math.max(0, Math.floor(lDependentCounts.length * MEDIAN))
23
- ],
24
- p75DependentsPerModule:
25
- lDependentCounts[
26
- Math.max(0, Math.floor(lDependentCounts.length * P75))
27
- ],
28
- };
29
- }
30
- return lReturnValue;
13
+ lReturnValue = {
14
+ minDependentsPerModule: lDependentCounts[0] || 0,
15
+ maxDependentsPerModule:
16
+ lDependentCounts[Math.max(lDependentCounts.length - 1, 0)] || 0,
17
+ meanDependentsPerModule:
18
+ lDependentCounts.reduce((pAll, pCurrent) => pAll + pCurrent, 0) /
19
+ pCruiseResult.summary.totalCruised,
20
+ medianDependentsPerModule:
21
+ lDependentCounts[
22
+ Math.max(0, Math.floor(lDependentCounts.length * MEDIAN))
23
+ ],
24
+ p75DependentsPerModule:
25
+ lDependentCounts[
26
+ Math.max(0, Math.floor(lDependentCounts.length * P75))
27
+ ],
28
+ };
29
+ }
30
+ return lReturnValue;
31
31
  }
32
32
  /**
33
33
  * returns an object with some stats from the ICruiseResult pCruiseResult it
@@ -37,29 +37,29 @@ function doMagic(pCruiseResult) {
37
37
  * @return {string} an object with some stats
38
38
  */
39
39
  function samplePluginReporter(pCruiseResult) {
40
- const lDependencyCounts = pCruiseResult.modules
41
- .map((pModule) => pModule.dependencies.length)
42
- .sort();
40
+ const lDependencyCounts = pCruiseResult.modules
41
+ .map((pModule) => pModule.dependencies.length)
42
+ .sort();
43
43
 
44
- return {
45
- moduleCount: pCruiseResult.summary.totalCruised,
46
- dependencyCount: pCruiseResult.summary.totalDependenciesCruised,
47
- minDependenciesPerModule: lDependencyCounts[0] || 0,
48
- maxDependenciesPerModule:
49
- lDependencyCounts[Math.max(lDependencyCounts.length - 1, 0)] || 0,
50
- meanDependenciesPerModule:
51
- pCruiseResult.summary.totalDependenciesCruised /
52
- pCruiseResult.summary.totalCruised,
53
- medianDependenciesPerModule:
54
- lDependencyCounts[
55
- Math.max(0, Math.floor(lDependencyCounts.length * MEDIAN))
56
- ],
57
- p75DependenciesPerModule:
58
- lDependencyCounts[
59
- Math.max(0, Math.floor(lDependencyCounts.length * P75))
60
- ],
61
- ...doMagic(pCruiseResult),
62
- };
44
+ return {
45
+ moduleCount: pCruiseResult.summary.totalCruised,
46
+ dependencyCount: pCruiseResult.summary.totalDependenciesCruised,
47
+ minDependenciesPerModule: lDependencyCounts[0] || 0,
48
+ maxDependenciesPerModule:
49
+ lDependencyCounts[Math.max(lDependencyCounts.length - 1, 0)] || 0,
50
+ meanDependenciesPerModule:
51
+ pCruiseResult.summary.totalDependenciesCruised /
52
+ pCruiseResult.summary.totalCruised,
53
+ medianDependenciesPerModule:
54
+ lDependencyCounts[
55
+ Math.max(0, Math.floor(lDependencyCounts.length * MEDIAN))
56
+ ],
57
+ p75DependenciesPerModule:
58
+ lDependencyCounts[
59
+ Math.max(0, Math.floor(lDependencyCounts.length * P75))
60
+ ],
61
+ ...doMagic(pCruiseResult),
62
+ };
63
63
  }
64
64
 
65
65
  /**
@@ -73,10 +73,10 @@ function samplePluginReporter(pCruiseResult) {
73
73
  * exitCode: 0
74
74
  */
75
75
  export default (pCruiseResult) => ({
76
- output: JSON.stringify(
77
- samplePluginReporter(pCruiseResult),
78
- null,
79
- DEFAULT_JSON_INDENT,
80
- ),
81
- exitCode: 0,
76
+ output: JSON.stringify(
77
+ samplePluginReporter(pCruiseResult),
78
+ null,
79
+ DEFAULT_JSON_INDENT,
80
+ ),
81
+ exitCode: 0,
82
82
  });
@@ -1,9 +1,9 @@
1
1
  const recommended = require("./recommended.cjs");
2
2
 
3
3
  module.exports = {
4
- ...recommended,
5
- forbidden: recommended.forbidden.map((pRule) => {
6
- pRule.severity = "error";
7
- return pRule;
8
- }),
4
+ ...recommended,
5
+ forbidden: recommended.forbidden.map((pRule) => {
6
+ pRule.severity = "error";
7
+ return pRule;
8
+ }),
9
9
  };
@@ -1,9 +1,9 @@
1
1
  const recommended = require("./recommended.cjs");
2
2
 
3
3
  module.exports = {
4
- ...recommended,
5
- forbidden: recommended.forbidden.map((pRule) => {
6
- pRule.severity = "warn";
7
- return pRule;
8
- }),
4
+ ...recommended,
5
+ forbidden: recommended.forbidden.map((pRule) => {
6
+ pRule.severity = "warn";
7
+ return pRule;
8
+ }),
9
9
  };
@@ -7,26 +7,26 @@ const notToDeprecated = require("./rules/not-to-deprecated.cjs");
7
7
  const notToUnresolvable = require("./rules/not-to-unresolvable.cjs");
8
8
 
9
9
  module.exports = {
10
- forbidden: [
11
- noOrphans,
12
- noCircular,
13
- noDeprecatedCore,
14
- noDuplicateDependencyTypes,
15
- noNonPackageJson,
16
- notToDeprecated,
17
- notToUnresolvable,
18
- ],
19
- options: {
20
- doNotFollow: {
21
- path: "node_modules",
22
- dependencyTypes: [
23
- "npm",
24
- "npm-dev",
25
- "npm-optional",
26
- "npm-peer",
27
- "npm-bundled",
28
- "npm-no-pkg",
29
- ],
30
- },
31
- },
10
+ forbidden: [
11
+ noOrphans,
12
+ noCircular,
13
+ noDeprecatedCore,
14
+ noDuplicateDependencyTypes,
15
+ noNonPackageJson,
16
+ notToDeprecated,
17
+ notToUnresolvable,
18
+ ],
19
+ options: {
20
+ doNotFollow: {
21
+ path: "node_modules",
22
+ dependencyTypes: [
23
+ "npm",
24
+ "npm-dev",
25
+ "npm-optional",
26
+ "npm-peer",
27
+ "npm-bundled",
28
+ "npm-no-pkg",
29
+ ],
30
+ },
31
+ },
32
32
  };
@@ -1,12 +1,12 @@
1
1
  module.exports = {
2
- name: "no-circular",
3
- comment:
4
- "This dependency is part of a circular relationship. You might want to revise " +
5
- "your solution (i.e. use dependency inversion, make sure the modules have a " +
6
- "single responsibility) ",
7
- severity: "error",
8
- from: {},
9
- to: {
10
- circular: true,
11
- },
2
+ name: "no-circular",
3
+ comment:
4
+ "This dependency is part of a circular relationship. You might want to revise " +
5
+ "your solution (i.e. use dependency inversion, make sure the modules have a " +
6
+ "single responsibility) ",
7
+ severity: "error",
8
+ from: {},
9
+ to: {
10
+ circular: true,
11
+ },
12
12
  };
@@ -1,12 +1,12 @@
1
1
  module.exports = {
2
- name: "no-deprecated-core",
3
- comment:
4
- "This module depends on a node core module that has been deprecated. Find an " +
5
- "alternative - these are bound to exist - node doesn't deprecate lightly.",
6
- severity: "error",
7
- from: {},
8
- to: {
9
- dependencyTypes: ["core"],
10
- path: "^(?:punycode|domain|constants|sys|_linklist|_stream_wrap)$",
11
- },
2
+ name: "no-deprecated-core",
3
+ comment:
4
+ "This module depends on a node core module that has been deprecated. Find an " +
5
+ "alternative - these are bound to exist - node doesn't deprecate lightly.",
6
+ severity: "error",
7
+ from: {},
8
+ to: {
9
+ dependencyTypes: ["core"],
10
+ path: "^(?:punycode|domain|constants|sys|_linklist|_stream_wrap)$",
11
+ },
12
12
  };
@@ -1,19 +1,19 @@
1
1
  module.exports = {
2
- name: "no-duplicate-dep-types",
3
- comment:
4
- "Likely this module depends on an external ('npm') package that occurs more " +
5
- "than once in your package.json i.e. bot as a devDependencies and in dependencies. " +
6
- "This will cause maintenance problems later on. If it's intentional, you can " +
7
- "disable this rule by adding this override as a rule in the 'forbidden' section " +
8
- "of your dependency-cruiser configuration: " +
9
- '{"name": "no-duplicate-dep-types", "severity": "ignore"}',
10
- severity: "warn",
11
- from: {},
12
- to: {
13
- moreThanOneDependencyType: true,
14
- // as it's pretty common to have a type import be a type only import
15
- // _and_ (e.g.) a devDependency - don't consider type-only dependency
16
- // types for this rule
17
- dependencyTypesNot: ["type-only"],
18
- },
2
+ name: "no-duplicate-dep-types",
3
+ comment:
4
+ "Likely this module depends on an external ('npm') package that occurs more " +
5
+ "than once in your package.json i.e. bot as a devDependencies and in dependencies. " +
6
+ "This will cause maintenance problems later on. If it's intentional, you can " +
7
+ "disable this rule by adding this override as a rule in the 'forbidden' section " +
8
+ "of your dependency-cruiser configuration: " +
9
+ '{"name": "no-duplicate-dep-types", "severity": "ignore"}',
10
+ severity: "warn",
11
+ from: {},
12
+ to: {
13
+ moreThanOneDependencyType: true,
14
+ // as it's pretty common to have a type import be a type only import
15
+ // _and_ (e.g.) a devDependency - don't consider type-only dependency
16
+ // types for this rule
17
+ dependencyTypesNot: ["type-only"],
18
+ },
19
19
  };
@@ -1,13 +1,13 @@
1
1
  module.exports = {
2
- name: "no-non-package-json",
3
- severity: "error",
4
- comment:
5
- "This module depends on an npm package that isn't in the 'dependencies' section " +
6
- "of your package.json. That's problematic as the package either (1) won't be " +
7
- "available on live (2 - worse) will be available on live with an non-guaranteed " +
8
- "version. Fix it by adding the package to the dependencies in your package.json.",
9
- from: {},
10
- to: {
11
- dependencyTypes: ["npm-no-pkg", "npm-unknown"],
12
- },
2
+ name: "no-non-package-json",
3
+ severity: "error",
4
+ comment:
5
+ "This module depends on an npm package that isn't in the 'dependencies' section " +
6
+ "of your package.json. That's problematic as the package either (1) won't be " +
7
+ "available on live (2 - worse) will be available on live with an non-guaranteed " +
8
+ "version. Fix it by adding the package to the dependencies in your package.json.",
9
+ from: {},
10
+ to: {
11
+ dependencyTypes: ["npm-no-pkg", "npm-unknown"],
12
+ },
13
13
  };
@@ -2,27 +2,27 @@ const DOT_FILE_PATTERN = "(^|/)\\.[^/]+\\.(js|cjs|mjs|ts|json)$";
2
2
  const TS_DECLARATION_FILE_PATTERN = "\\.d\\.(c|m)?ts$";
3
3
  const TS_CONFIG_FILE_PATTERN = "(^|/)tsconfig\\.json$";
4
4
  const OTHER_CONFIG_FILES_PATTERN =
5
- "(^|/)(?:babel|webpack)\\.config\\.(?:js|cjs|mjs|ts|json)$";
5
+ "(^|/)(?:babel|webpack)\\.config\\.(?:js|cjs|mjs|ts|json)$";
6
6
 
7
7
  const KNOWN_CONFIG_FILE_PATTERNS = [
8
- DOT_FILE_PATTERN,
9
- TS_DECLARATION_FILE_PATTERN,
10
- TS_CONFIG_FILE_PATTERN,
11
- OTHER_CONFIG_FILES_PATTERN,
8
+ DOT_FILE_PATTERN,
9
+ TS_DECLARATION_FILE_PATTERN,
10
+ TS_CONFIG_FILE_PATTERN,
11
+ OTHER_CONFIG_FILES_PATTERN,
12
12
  ].join("|");
13
13
 
14
14
  module.exports = {
15
- name: "no-orphans",
16
- comment:
17
- "This is an orphan module - it's likely not used (anymore?). Either use it or " +
18
- "remove it. If it's logical this module is an orphan (i.e. it's a config file), " +
19
- "add an exception for it in your dependency-cruiser configuration. By default " +
20
- "this rule does not scrutinize dotfiles (e.g. .eslintrc.js), TypeScript declaration " +
21
- "files (.d.ts/ .d.cts/ .d.mts), tsconfig.json and some of the babel and webpack configs.",
22
- severity: "warn",
23
- from: {
24
- orphan: true,
25
- pathNot: KNOWN_CONFIG_FILE_PATTERNS,
26
- },
27
- to: {},
15
+ name: "no-orphans",
16
+ comment:
17
+ "This is an orphan module - it's likely not used (anymore?). Either use it or " +
18
+ "remove it. If it's logical this module is an orphan (i.e. it's a config file), " +
19
+ "add an exception for it in your dependency-cruiser configuration. By default " +
20
+ "this rule does not scrutinize dotfiles (e.g. .eslintrc.js), TypeScript declaration " +
21
+ "files (.d.ts/ .d.cts/ .d.mts), tsconfig.json and some of the babel and webpack configs.",
22
+ severity: "warn",
23
+ from: {
24
+ orphan: true,
25
+ pathNot: KNOWN_CONFIG_FILE_PATTERNS,
26
+ },
27
+ to: {},
28
28
  };
@@ -1,12 +1,12 @@
1
1
  module.exports = {
2
- name: "not-to-deprecated",
3
- comment:
4
- "This module uses a (version of an) npm module that has been deprecated. Either " +
5
- "upgrade to a later version of that module, or find an alternative. Deprecated " +
6
- "modules are a security risk.",
7
- severity: "warn",
8
- from: {},
9
- to: {
10
- dependencyTypes: ["deprecated"],
11
- },
2
+ name: "not-to-deprecated",
3
+ comment:
4
+ "This module uses a (version of an) npm module that has been deprecated. Either " +
5
+ "upgrade to a later version of that module, or find an alternative. Deprecated " +
6
+ "modules are a security risk.",
7
+ severity: "warn",
8
+ from: {},
9
+ to: {
10
+ dependencyTypes: ["deprecated"],
11
+ },
12
12
  };
@@ -1,12 +1,12 @@
1
1
  module.exports = {
2
- name: "not-to-unresolvable",
3
- comment:
4
- "This module depends on a module that cannot be found ('resolved to disk'). " +
5
- "If it's an npm module: add it to your package.json. In all other cases you " +
6
- "likely already know what to do.",
7
- severity: "error",
8
- from: {},
9
- to: {
10
- couldNotResolve: true,
11
- },
2
+ name: "not-to-unresolvable",
3
+ comment:
4
+ "This module depends on a module that cannot be found ('resolved to disk'). " +
5
+ "If it's an npm module: add it to your package.json. In all other cases you " +
6
+ "likely already know what to do.",
7
+ severity: "error",
8
+ from: {},
9
+ to: {
10
+ couldNotResolve: true,
11
+ },
12
12
  };