knip 5.52.0 → 5.54.0

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 (105) hide show
  1. package/dist/ConfigurationChief.d.ts +1 -0
  2. package/dist/IssueFixer.d.ts +1 -1
  3. package/dist/IssueFixer.js +13 -3
  4. package/dist/PrincipalFactory.js +3 -17
  5. package/dist/ProjectPrincipal.d.ts +2 -2
  6. package/dist/ProjectPrincipal.js +14 -3
  7. package/dist/WorkspaceWorker.d.ts +0 -1
  8. package/dist/WorkspaceWorker.js +4 -19
  9. package/dist/cli.js +10 -6
  10. package/dist/compilers/index.d.ts +10 -0
  11. package/dist/graph/build.js +12 -7
  12. package/dist/index.js +15 -4
  13. package/dist/plugins/ava/index.d.ts +1 -2
  14. package/dist/plugins/ava/index.js +2 -7
  15. package/dist/plugins/bun/index.d.ts +2 -2
  16. package/dist/plugins/bun/index.js +2 -2
  17. package/dist/plugins/cucumber/index.d.ts +1 -2
  18. package/dist/plugins/cucumber/index.js +2 -5
  19. package/dist/plugins/cypress/index.d.ts +1 -2
  20. package/dist/plugins/cypress/index.js +6 -9
  21. package/dist/plugins/cypress/types.d.ts +8 -0
  22. package/dist/plugins/eleventy/helpers.d.ts +10 -2
  23. package/dist/plugins/eleventy/index.d.ts +3 -6
  24. package/dist/plugins/eleventy/index.js +11 -16
  25. package/dist/plugins/eleventy/types.d.ts +9 -7
  26. package/dist/plugins/expo/index.d.ts +2 -5
  27. package/dist/plugins/expo/index.js +4 -6
  28. package/dist/plugins/github-action/index.d.ts +2 -2
  29. package/dist/plugins/github-action/index.js +2 -2
  30. package/dist/plugins/index.d.ts +20 -28
  31. package/dist/plugins/index.js +2 -0
  32. package/dist/plugins/jest/index.d.ts +1 -2
  33. package/dist/plugins/jest/index.js +4 -12
  34. package/dist/plugins/karma/index.d.ts +1 -3
  35. package/dist/plugins/karma/index.js +0 -10
  36. package/dist/plugins/ladle/index.d.ts +1 -2
  37. package/dist/plugins/ladle/index.js +4 -7
  38. package/dist/plugins/metro/index.d.ts +2 -3
  39. package/dist/plugins/metro/index.js +17 -14
  40. package/dist/plugins/mocha/index.d.ts +1 -2
  41. package/dist/plugins/mocha/index.js +2 -6
  42. package/dist/plugins/msw/index.d.ts +2 -2
  43. package/dist/plugins/msw/index.js +2 -2
  44. package/dist/plugins/netlify/index.d.ts +1 -2
  45. package/dist/plugins/netlify/index.js +4 -7
  46. package/dist/plugins/node/index.d.ts +2 -2
  47. package/dist/plugins/node/index.js +2 -2
  48. package/dist/plugins/nuxt/index.d.ts +2 -2
  49. package/dist/plugins/nuxt/index.js +2 -2
  50. package/dist/plugins/playwright/index.d.ts +1 -3
  51. package/dist/plugins/playwright/index.js +5 -7
  52. package/dist/plugins/playwright-ct/index.d.ts +0 -1
  53. package/dist/plugins/playwright-ct/index.js +1 -2
  54. package/dist/plugins/postcss/index.js +3 -1
  55. package/dist/plugins/preconstruct/index.d.ts +1 -1
  56. package/dist/plugins/preconstruct/index.js +2 -2
  57. package/dist/plugins/react-cosmos/index.d.ts +1 -2
  58. package/dist/plugins/react-cosmos/index.js +4 -6
  59. package/dist/plugins/react-router/index.d.ts +2 -2
  60. package/dist/plugins/react-router/index.js +2 -2
  61. package/dist/plugins/relay/index.d.ts +2 -2
  62. package/dist/plugins/relay/index.js +2 -2
  63. package/dist/plugins/rspack/index.js +2 -3
  64. package/dist/plugins/size-limit/index.d.ts +2 -1
  65. package/dist/plugins/size-limit/index.js +10 -0
  66. package/dist/plugins/storybook/index.d.ts +1 -2
  67. package/dist/plugins/storybook/index.js +2 -5
  68. package/dist/plugins/svelte/index.d.ts +2 -1
  69. package/dist/plugins/svelte/index.js +7 -0
  70. package/dist/plugins/svgo/index.d.ts +8 -0
  71. package/dist/plugins/svgo/index.js +11 -0
  72. package/dist/plugins/vite/index.d.ts +0 -1
  73. package/dist/plugins/vite/index.js +1 -2
  74. package/dist/plugins/vitest/index.d.ts +1 -3
  75. package/dist/plugins/vitest/index.js +35 -24
  76. package/dist/plugins/vitest/types.d.ts +12 -0
  77. package/dist/plugins/vue/index.js +2 -5
  78. package/dist/plugins/webpack/index.d.ts +1 -5
  79. package/dist/plugins/webpack/index.js +36 -17
  80. package/dist/plugins/wrangler/index.d.ts +2 -2
  81. package/dist/plugins/wrangler/index.js +2 -2
  82. package/dist/plugins.js +1 -1
  83. package/dist/reporters/watch.js +1 -1
  84. package/dist/schema/configuration.d.ts +56 -0
  85. package/dist/schema/plugins.d.ts +23 -0
  86. package/dist/schema/plugins.js +1 -0
  87. package/dist/types/PluginNames.d.ts +2 -2
  88. package/dist/types/PluginNames.js +1 -0
  89. package/dist/types/cli.d.ts +1 -0
  90. package/dist/types/config.d.ts +0 -2
  91. package/dist/types/project.d.ts +0 -1
  92. package/dist/util/Performance.d.ts +25 -7
  93. package/dist/util/Performance.js +70 -34
  94. package/dist/util/cli-arguments.d.ts +4 -1
  95. package/dist/util/cli-arguments.js +7 -1
  96. package/dist/util/glob-core.d.ts +5 -6
  97. package/dist/util/glob-core.js +30 -29
  98. package/dist/util/input.d.ts +7 -1
  99. package/dist/util/input.js +7 -0
  100. package/dist/util/string.d.ts +1 -0
  101. package/dist/util/string.js +10 -0
  102. package/dist/version.d.ts +1 -1
  103. package/dist/version.js +1 -1
  104. package/package.json +2 -2
  105. package/schema.json +4 -0
@@ -9,16 +9,17 @@ const enablers = ['@11ty/eleventy'];
9
9
  const isEnabled = ({ dependencies }) => hasDependency(dependencies, enablers);
10
10
  const config = ['.eleventy.js', 'eleventy.config.{js,cjs,mjs}'];
11
11
  const production = ['posts/**/*.11tydata.js', '_data/**/*.{js,cjs,mjs}'];
12
- const resolveEntryPaths = async (localConfig, options) => {
12
+ const resolveConfig = async (localConfig, options) => {
13
13
  const { configFileDir } = options;
14
14
  const dummyUserConfig = new DummyEleventyConfig();
15
15
  if (typeof localConfig === 'function')
16
- localConfig = await localConfig(dummyUserConfig);
16
+ localConfig = (await localConfig(dummyUserConfig));
17
17
  const inputDir = localConfig?.dir?.input || defaultEleventyConfig.dir.input;
18
18
  const dataDir = localConfig?.dir?.data || defaultEleventyConfig.dir.data;
19
19
  const templateFormats = localConfig.templateFormats || defaultEleventyConfig.templateFormats;
20
20
  const exts = DEFAULT_EXTENSIONS.map(extname => extname.slice(1)).join(',');
21
21
  const copiedEntries = new Set();
22
+ const copiedPackages = new Set();
22
23
  for (const path of Object.keys(dummyUserConfig.passthroughCopies)) {
23
24
  const isDir = !path.includes('*') && isDirectory(join(configFileDir, path));
24
25
  if (isDir) {
@@ -28,23 +29,18 @@ const resolveEntryPaths = async (localConfig, options) => {
28
29
  copiedEntries.add(path);
29
30
  }
30
31
  }
31
- return [
32
- join(inputDir, dataDir, '**/*.{js,cjs,mjs}'),
33
- join(inputDir, `**/*.{${typeof templateFormats === 'string' ? templateFormats : templateFormats.join(',')}}`),
34
- join(inputDir, '**/*.11tydata.js'),
35
- ...copiedEntries,
36
- ].map(id => toProductionEntry(id));
37
- };
38
- const resolveConfig = async (localConfig) => {
39
- const dummyUserConfig = new DummyEleventyConfig();
40
- if (typeof localConfig === 'function')
41
- localConfig = await localConfig(dummyUserConfig);
42
- const copiedPackages = new Set();
43
32
  for (const path of Object.keys(dummyUserConfig.passthroughCopies)) {
44
33
  if (isInNodeModules(path))
45
34
  copiedPackages.add(path);
46
35
  }
47
- return [...copiedPackages].map(id => toDeferResolve(id));
36
+ return Array.from(copiedPackages)
37
+ .map(id => toDeferResolve(id))
38
+ .concat([
39
+ join(inputDir, dataDir, '**/*.{js,cjs,mjs}'),
40
+ join(inputDir, `**/*.{${typeof templateFormats === 'string' ? templateFormats : templateFormats.join(',')}}`),
41
+ join(inputDir, '**/*.11tydata.js'),
42
+ ...copiedEntries,
43
+ ].map(id => toProductionEntry(id)));
48
44
  };
49
45
  export default {
50
46
  title,
@@ -52,6 +48,5 @@ export default {
52
48
  isEnabled,
53
49
  config,
54
50
  production,
55
- resolveEntryPaths,
56
51
  resolveConfig,
57
52
  };
@@ -1,10 +1,12 @@
1
+ import type { DummyEleventyConfig } from './helpers.js';
1
2
  export type EleventyConfig = {
2
- dir: {
3
- input: string;
4
- output: string;
5
- includes: string;
6
- layouts: string;
7
- data: string;
3
+ dir?: {
4
+ input?: string;
5
+ output?: string;
6
+ includes?: string;
7
+ layouts?: string;
8
+ data?: string;
8
9
  };
9
- templateFormats: string | string[];
10
+ templateFormats?: string | string[];
10
11
  };
12
+ export type EleventyConfigOrFn = Partial<EleventyConfig> | ((arg: DummyEleventyConfig) => Promise<Partial<EleventyConfig>>);
@@ -1,14 +1,11 @@
1
- import type { IsPluginEnabled, ResolveConfig, ResolveEntryPaths } from '../../types/config.js';
1
+ import type { IsPluginEnabled, ResolveConfig } from '../../types/config.js';
2
2
  import type { ExpoConfig } from './types.js';
3
- export declare const docs: {
4
- production: string[];
5
- };
6
3
  declare const _default: {
7
4
  title: string;
8
5
  enablers: string[];
9
6
  isEnabled: IsPluginEnabled;
10
7
  config: string[];
11
- resolveEntryPaths: ResolveEntryPaths<ExpoConfig>;
8
+ production: string[];
12
9
  resolveConfig: ResolveConfig<ExpoConfig>;
13
10
  };
14
11
  export default _default;
@@ -7,8 +7,7 @@ const enablers = ['expo'];
7
7
  const isEnabled = ({ dependencies }) => hasDependency(dependencies, enablers);
8
8
  const config = ['app.json', 'app.config.{ts,js}'];
9
9
  const production = ['app/**/*.{js,jsx,ts,tsx}', 'src/app/**/*.{js,jsx,ts,tsx}'];
10
- export const docs = { production };
11
- const resolveEntryPaths = async (localConfig, options) => {
10
+ const resolveConfig = async (localConfig, options) => {
12
11
  const { manifest } = options;
13
12
  const config = getConfig(localConfig, options);
14
13
  if (manifest.main === 'expo-router/entry') {
@@ -21,16 +20,15 @@ const resolveEntryPaths = async (localConfig, options) => {
21
20
  patterns = [join(options.root, '**/*.{js,jsx,ts,tsx}')];
22
21
  }
23
22
  }
24
- return patterns.map(entry => toProductionEntry(entry));
23
+ return patterns.map(entry => toProductionEntry(entry)).concat(await getDependencies(localConfig, options));
25
24
  }
26
- return production.map(entry => toProductionEntry(entry));
25
+ return production.map(entry => toProductionEntry(entry)).concat(await getDependencies(localConfig, options));
27
26
  };
28
- const resolveConfig = async (expoConfig, options) => getDependencies(expoConfig, options);
29
27
  export default {
30
28
  title,
31
29
  enablers,
32
30
  isEnabled,
33
31
  config,
34
- resolveEntryPaths,
32
+ production,
35
33
  resolveConfig,
36
34
  };
@@ -1,9 +1,9 @@
1
- import type { IsPluginEnabled, ResolveEntryPaths } from '../../types/config.js';
1
+ import type { IsPluginEnabled, ResolveConfig } from '../../types/config.js';
2
2
  declare const _default: {
3
3
  title: string;
4
4
  enablers: string[];
5
5
  isEnabled: IsPluginEnabled;
6
6
  config: string[];
7
- resolveEntryPaths: ResolveEntryPaths;
7
+ resolveConfig: ResolveConfig;
8
8
  };
9
9
  export default _default;
@@ -7,7 +7,7 @@ const enablers = ['@actions/core'];
7
7
  const isEnabled = ({ dependencies }) => hasDependency(dependencies, enablers);
8
8
  const config = ['action.{yml,yaml}'];
9
9
  const isAssumeArtifact = (specifier) => /^(dist|build)\//.test(specifier);
10
- const resolveEntryPaths = async (config, options) => {
10
+ const resolveConfig = async (config, options) => {
11
11
  const inputs = [];
12
12
  const filePaths = getActionDependencies(config, options);
13
13
  for (const filePath of new Set(filePaths)) {
@@ -24,5 +24,5 @@ export default {
24
24
  enablers,
25
25
  isEnabled,
26
26
  config,
27
- resolveEntryPaths,
27
+ resolveConfig,
28
28
  };
@@ -21,7 +21,6 @@ export declare const Plugins: {
21
21
  isEnabled: import("../types/config.js").IsPluginEnabled;
22
22
  config: string[];
23
23
  entry: string[];
24
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./ava/types.js").AvaConfig>;
25
24
  resolveConfig: import("../types/config.js").ResolveConfig<import("./ava/types.js").AvaConfig>;
26
25
  };
27
26
  babel: {
@@ -37,7 +36,7 @@ export declare const Plugins: {
37
36
  isEnabled: () => boolean;
38
37
  config: string[];
39
38
  packageJsonPath: (id: import("../types/package-json.js").PackageJson) => import("../types/package-json.js").PackageJson;
40
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("../types/package-json.js").PackageJson>;
39
+ resolveConfig: import("../types/config.js").ResolveConfig<import("../types/package-json.js").PackageJson>;
41
40
  };
42
41
  c8: {
43
42
  title: string;
@@ -97,7 +96,6 @@ export declare const Plugins: {
97
96
  isEnabled: import("../types/config.js").IsPluginEnabled;
98
97
  config: string[];
99
98
  entry: string[];
100
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./cucumber/types.js").CucumberConfig>;
101
99
  resolveConfig: import("../types/config.js").ResolveConfig<import("./cucumber/types.js").CucumberConfig>;
102
100
  };
103
101
  cypress: {
@@ -106,7 +104,6 @@ export declare const Plugins: {
106
104
  isEnabled: import("../types/config.js").IsPluginEnabled;
107
105
  config: string[];
108
106
  entry: string[];
109
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths;
110
107
  resolveConfig: import("../types/config.js").ResolveConfig<import("./cypress/types.js").CypressConfig>;
111
108
  };
112
109
  'dependency-cruiser': {
@@ -138,8 +135,7 @@ export declare const Plugins: {
138
135
  isEnabled: import("../types/config.js").IsPluginEnabled;
139
136
  config: string[];
140
137
  production: string[];
141
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<Partial<import("./eleventy/types.js").EleventyConfig> | ((arg: import("./eleventy/helpers.js").DummyEleventyConfig) => Promise<Partial<import("./eleventy/types.js").EleventyConfig>>)>;
142
- resolveConfig: import("../types/config.js").ResolveConfig<Partial<import("./eleventy/types.js").EleventyConfig> | ((arg: import("./eleventy/helpers.js").DummyEleventyConfig) => Promise<Partial<import("./eleventy/types.js").EleventyConfig>>)>;
138
+ resolveConfig: import("../types/config.js").ResolveConfig<import("./eleventy/types.js").EleventyConfigOrFn>;
143
139
  };
144
140
  eslint: {
145
141
  title: string;
@@ -155,7 +151,7 @@ export declare const Plugins: {
155
151
  enablers: string[];
156
152
  isEnabled: import("../types/config.js").IsPluginEnabled;
157
153
  config: string[];
158
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./expo/types.js").ExpoConfig>;
154
+ production: string[];
159
155
  resolveConfig: import("../types/config.js").ResolveConfig<import("./expo/types.js").ExpoConfig>;
160
156
  };
161
157
  gatsby: {
@@ -171,7 +167,7 @@ export declare const Plugins: {
171
167
  enablers: string[];
172
168
  isEnabled: import("../types/config.js").IsPluginEnabled;
173
169
  config: string[];
174
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths;
170
+ resolveConfig: import("../types/config.js").ResolveConfig;
175
171
  };
176
172
  'github-actions': {
177
173
  title: string;
@@ -224,7 +220,6 @@ export declare const Plugins: {
224
220
  isEnabled: import("../types/config.js").IsPluginEnabled;
225
221
  config: string[];
226
222
  entry: string[];
227
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./jest/types.js").JestConfig>;
228
223
  resolveConfig: import("../types/config.js").ResolveConfig<import("./jest/types.js").JestConfig>;
229
224
  args: {
230
225
  config: boolean;
@@ -235,9 +230,7 @@ export declare const Plugins: {
235
230
  enablers: string[];
236
231
  isEnabled: import("../types/config.js").IsPluginEnabled;
237
232
  config: string[];
238
- entry: string[];
239
233
  resolveConfig: import("../types/config.js").ResolveConfig<import("./karma/helpers.js").ConfigFile>;
240
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./karma/helpers.js").ConfigFile>;
241
234
  };
242
235
  ladle: {
243
236
  title: string;
@@ -246,7 +239,6 @@ export declare const Plugins: {
246
239
  config: string[];
247
240
  entry: string[];
248
241
  project: string[];
249
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./ladle/types.js").LadleConfig>;
250
242
  resolveConfig: import("../types/config.js").ResolveConfig<import("./ladle/types.js").LadleConfig>;
251
243
  };
252
244
  lefthook: {
@@ -295,7 +287,7 @@ export declare const Plugins: {
295
287
  enablers: string[];
296
288
  isEnabled: import("../types/config.js").IsPluginEnabled;
297
289
  config: string[];
298
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./metro/types.js").MetroConfig>;
290
+ production: string[];
299
291
  resolveConfig: import("../types/config.js").ResolveConfig<import("./metro/types.js").MetroConfig>;
300
292
  };
301
293
  mocha: {
@@ -305,7 +297,6 @@ export declare const Plugins: {
305
297
  config: string[];
306
298
  entry: string[];
307
299
  resolveConfig: import("../types/config.js").ResolveConfig<import("./mocha/types.js").MochaConfig>;
308
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./mocha/types.js").MochaConfig>;
309
300
  args: {
310
301
  nodeImportArgs: boolean;
311
302
  };
@@ -324,7 +315,7 @@ export declare const Plugins: {
324
315
  isEnabled: import("../types/config.js").IsPluginEnabled;
325
316
  config: string[];
326
317
  entry: string[];
327
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./msw/types.js").MSWConfig>;
318
+ resolveConfig: import("../types/config.js").ResolveConfig<import("./msw/types.js").MSWConfig>;
328
319
  };
329
320
  'nano-staged': {
330
321
  title: string;
@@ -346,7 +337,6 @@ export declare const Plugins: {
346
337
  isEnabled: import("../types/config.js").IsPluginEnabled;
347
338
  config: string[];
348
339
  production: string[];
349
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./netlify/types.js").NetlifyConfig>;
350
340
  resolveConfig: import("../types/config.js").ResolveConfig<import("./netlify/types.js").NetlifyConfig>;
351
341
  };
352
342
  next: {
@@ -362,7 +352,7 @@ export declare const Plugins: {
362
352
  isEnabled: import("../types/config.js").IsPluginEnabled;
363
353
  packageJsonPath: (id: import("../types/package-json.js").PackageJson) => import("../types/package-json.js").PackageJson;
364
354
  config: string[];
365
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("../types/package-json.js").PackageJson>;
355
+ resolveConfig: import("../types/config.js").ResolveConfig<import("../types/package-json.js").PackageJson>;
366
356
  args: {
367
357
  positional: boolean;
368
358
  nodeImportArgs: boolean;
@@ -393,7 +383,7 @@ export declare const Plugins: {
393
383
  isEnabled: import("../types/config.js").IsPluginEnabled;
394
384
  config: string[];
395
385
  production: string[];
396
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./nuxt/types.js").NuxtConfig>;
386
+ resolveConfig: import("../types/config.js").ResolveConfig<import("./nuxt/types.js").NuxtConfig>;
397
387
  };
398
388
  nx: {
399
389
  title: string;
@@ -436,7 +426,6 @@ export declare const Plugins: {
436
426
  config: string[];
437
427
  entry: string[];
438
428
  resolveConfig: import("../types/config.js").ResolveConfig<import("./playwright/types.js").PlaywrightTestConfig>;
439
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./playwright/types.js").PlaywrightTestConfig>;
440
429
  args: {
441
430
  binaries: string[];
442
431
  positional: boolean;
@@ -450,7 +439,6 @@ export declare const Plugins: {
450
439
  isEnabled: import("../types/config.js").IsPluginEnabled;
451
440
  config: string[];
452
441
  entry: string[];
453
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./playwright/types.js").PlaywrightTestConfig>;
454
442
  resolveConfig: import("../types/config.js").ResolveConfig<import("./playwright/types.js").PlaywrightTestConfig>;
455
443
  };
456
444
  'playwright-test': {
@@ -482,7 +470,7 @@ export declare const Plugins: {
482
470
  enablers: string[];
483
471
  isEnabled: import("../types/config.js").IsPluginEnabled;
484
472
  config: string[];
485
- resolveEntryPaths: import("../types/config.js").ResolveConfig<import("./preconstruct/types.js").PreconstructConfig>;
473
+ resolveConfig: import("../types/config.js").ResolveConfig<import("./preconstruct/types.js").PreconstructConfig>;
486
474
  };
487
475
  prettier: {
488
476
  title: string;
@@ -498,21 +486,20 @@ export declare const Plugins: {
498
486
  config: string[];
499
487
  entry: string[];
500
488
  resolveConfig: import("../types/config.js").ResolveConfig<import("./react-cosmos/types.js").ReactCosmosConfig>;
501
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./react-cosmos/types.js").ReactCosmosConfig>;
502
489
  };
503
490
  'react-router': {
504
491
  title: string;
505
492
  enablers: string[];
506
493
  isEnabled: import("../types/config.js").IsPluginEnabled;
507
494
  config: string[];
508
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./react-router/types.js").PluginConfig>;
495
+ resolveConfig: import("../types/config.js").ResolveConfig<import("./react-router/types.js").PluginConfig>;
509
496
  };
510
497
  relay: {
511
498
  title: string;
512
499
  enablers: string[];
513
500
  isEnabled: import("../types/config.js").IsPluginEnabled;
514
501
  config: string[];
515
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./relay/types.js").RelayConfig>;
502
+ resolveConfig: import("../types/config.js").ResolveConfig<import("./relay/types.js").RelayConfig>;
516
503
  args: {
517
504
  binaries: string[];
518
505
  args: (args: string[]) => string[];
@@ -589,6 +576,7 @@ export declare const Plugins: {
589
576
  enablers: string[];
590
577
  isEnabled: import("../types/config.js").IsPluginEnabled;
591
578
  config: string[];
579
+ resolve: import("../types/config.js").Resolve;
592
580
  };
593
581
  sst: {
594
582
  title: string;
@@ -611,7 +599,6 @@ export declare const Plugins: {
611
599
  config: string[];
612
600
  entry: string[];
613
601
  project: string[];
614
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./storybook/types.js").StorybookConfig>;
615
602
  resolveConfig: import("../types/config.js").ResolveConfig<import("./storybook/types.js").StorybookConfig>;
616
603
  };
617
604
  stryker: {
@@ -634,6 +621,13 @@ export declare const Plugins: {
634
621
  isEnabled: import("../types/config.js").IsPluginEnabled;
635
622
  entry: string[];
636
623
  production: string[];
624
+ resolve: import("../types/config.js").Resolve;
625
+ };
626
+ svgo: {
627
+ title: string;
628
+ enablers: string[];
629
+ isEnabled: import("../types/config.js").IsPluginEnabled;
630
+ entry: string[];
637
631
  };
638
632
  syncpack: {
639
633
  title: string;
@@ -745,7 +739,6 @@ export declare const Plugins: {
745
739
  enablers: string[];
746
740
  isEnabled: import("../types/config.js").IsPluginEnabled;
747
741
  config: string[];
748
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./vitest/types.js").ViteConfigOrFn | import("./vitest/types.js").VitestWorkspaceConfig>;
749
742
  resolveConfig: import("../types/config.js").ResolveConfig<import("./vitest/types.js").ViteConfigOrFn | import("./vitest/types.js").VitestWorkspaceConfig>;
750
743
  };
751
744
  vitest: {
@@ -754,7 +747,6 @@ export declare const Plugins: {
754
747
  isEnabled: import("../types/config.js").IsPluginEnabled;
755
748
  config: string[];
756
749
  entry: string[];
757
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./vitest/types.js").ViteConfigOrFn | import("./vitest/types.js").VitestWorkspaceConfig>;
758
750
  resolveConfig: import("../types/config.js").ResolveConfig<import("./vitest/types.js").ViteConfigOrFn | import("./vitest/types.js").VitestWorkspaceConfig>;
759
751
  args: {
760
752
  config: boolean;
@@ -797,7 +789,7 @@ export declare const Plugins: {
797
789
  enablers: string[];
798
790
  isEnabled: import("../types/config.js").IsPluginEnabled;
799
791
  config: string[];
800
- resolveEntryPaths: import("../types/config.js").ResolveEntryPaths<import("./wrangler/types.js").WranglerConfig>;
792
+ resolveConfig: import("../types/config.js").ResolveConfig<import("./wrangler/types.js").WranglerConfig>;
801
793
  };
802
794
  xo: {
803
795
  title: string;
@@ -76,6 +76,7 @@ import { default as storybook } from './storybook/index.js';
76
76
  import { default as stryker } from './stryker/index.js';
77
77
  import { default as stylelint } from './stylelint/index.js';
78
78
  import { default as svelte } from './svelte/index.js';
79
+ import { default as svgo } from './svgo/index.js';
79
80
  import { default as syncpack } from './syncpack/index.js';
80
81
  import { default as tailwind } from './tailwind/index.js';
81
82
  import { default as travis } from './travis/index.js';
@@ -177,6 +178,7 @@ export const Plugins = {
177
178
  stryker,
178
179
  stylelint,
179
180
  svelte,
181
+ svgo,
180
182
  syncpack,
181
183
  tailwind,
182
184
  travis,
@@ -1,4 +1,4 @@
1
- import type { IsPluginEnabled, ResolveConfig, ResolveEntryPaths } from '../../types/config.js';
1
+ import type { IsPluginEnabled, ResolveConfig } from '../../types/config.js';
2
2
  import type { JestConfig } from './types.js';
3
3
  declare const _default: {
4
4
  title: string;
@@ -6,7 +6,6 @@ declare const _default: {
6
6
  isEnabled: IsPluginEnabled;
7
7
  config: string[];
8
8
  entry: string[];
9
- resolveEntryPaths: ResolveEntryPaths<JestConfig>;
10
9
  resolveConfig: ResolveConfig<JestConfig>;
11
10
  args: {
12
11
  config: boolean;
@@ -74,16 +74,6 @@ const resolveDependencies = async (config, options) => {
74
74
  ...globalTeardown,
75
75
  ].map(id => (typeof id === 'string' ? toDeferResolve(id) : id));
76
76
  };
77
- const resolveEntryPaths = async (localConfig, options) => {
78
- const { configFileDir } = options;
79
- if (typeof localConfig === 'function')
80
- localConfig = await localConfig();
81
- const rootDir = localConfig.rootDir ?? configFileDir;
82
- const replaceRootDir = (name) => name.replace(/<rootDir>/, rootDir);
83
- if (localConfig.testMatch)
84
- return localConfig.testMatch.map(replaceRootDir).map(id => toEntry(id));
85
- return entry.map(id => toEntry(id));
86
- };
87
77
  const resolveConfig = async (localConfig, options) => {
88
78
  const { configFileDir } = options;
89
79
  if (typeof localConfig === 'function')
@@ -91,11 +81,14 @@ const resolveConfig = async (localConfig, options) => {
91
81
  const rootDir = localConfig.rootDir ?? configFileDir;
92
82
  const replaceRootDir = (name) => name.replace(/<rootDir>/, rootDir);
93
83
  const inputs = await resolveDependencies(localConfig, options);
84
+ const entries = localConfig.testMatch
85
+ ? localConfig.testMatch.map(replaceRootDir).map(id => toEntry(id))
86
+ : entry.map(id => toEntry(id));
94
87
  const result = inputs.map(dependency => {
95
88
  dependency.specifier = replaceRootDir(dependency.specifier);
96
89
  return dependency;
97
90
  });
98
- return result;
91
+ return entries.concat(result);
99
92
  };
100
93
  const args = {
101
94
  config: true,
@@ -106,7 +99,6 @@ export default {
106
99
  isEnabled,
107
100
  config,
108
101
  entry,
109
- resolveEntryPaths,
110
102
  resolveConfig,
111
103
  args,
112
104
  };
@@ -1,12 +1,10 @@
1
- import type { IsPluginEnabled, ResolveConfig, ResolveEntryPaths } from '../../types/config.js';
1
+ import type { IsPluginEnabled, ResolveConfig } from '../../types/config.js';
2
2
  import { type ConfigFile } from './helpers.js';
3
3
  declare const _default: {
4
4
  title: string;
5
5
  enablers: string[];
6
6
  isEnabled: IsPluginEnabled;
7
7
  config: string[];
8
- entry: string[];
9
8
  resolveConfig: ResolveConfig<ConfigFile>;
10
- resolveEntryPaths: ResolveEntryPaths<ConfigFile>;
11
9
  };
12
10
  export default _default;
@@ -6,7 +6,6 @@ const title = 'Karma';
6
6
  const enablers = ['karma'];
7
7
  const isEnabled = ({ dependencies }) => hasDependency(dependencies, enablers);
8
8
  const config = configFiles;
9
- const entry = [];
10
9
  const resolveConfig = async (localConfig, options) => {
11
10
  const inputs = new Set();
12
11
  const config = loadConfig(localConfig);
@@ -16,13 +15,6 @@ const resolveConfig = async (localConfig, options) => {
16
15
  inputsFromFrameworks(config.frameworks).forEach(inputs.add, inputs);
17
16
  }
18
17
  inputsFromPlugins(config.plugins, options.manifest.devDependencies).forEach(inputs.add, inputs);
19
- return Array.from(inputs);
20
- };
21
- const resolveEntryPaths = (localConfig, options) => {
22
- const inputs = new Set();
23
- const config = loadConfig(localConfig);
24
- if (!config)
25
- return [];
26
18
  const basePath = config.basePath ?? '';
27
19
  if (config.files) {
28
20
  for (const fileOrPatternObj of config.files) {
@@ -42,7 +34,5 @@ export default {
42
34
  enablers,
43
35
  isEnabled,
44
36
  config,
45
- entry,
46
37
  resolveConfig,
47
- resolveEntryPaths,
48
38
  };
@@ -1,4 +1,4 @@
1
- import type { IsPluginEnabled, ResolveConfig, ResolveEntryPaths } from '../../types/config.js';
1
+ import type { IsPluginEnabled, ResolveConfig } from '../../types/config.js';
2
2
  import type { LadleConfig } from './types.js';
3
3
  declare const _default: {
4
4
  title: string;
@@ -7,7 +7,6 @@ declare const _default: {
7
7
  config: string[];
8
8
  entry: string[];
9
9
  project: string[];
10
- resolveEntryPaths: ResolveEntryPaths<LadleConfig>;
11
10
  resolveConfig: ResolveConfig<LadleConfig>;
12
11
  };
13
12
  export default _default;
@@ -10,19 +10,17 @@ const stories = ['src/**/*.stories.{js,jsx,ts,tsx,mdx}'];
10
10
  const restEntry = ['.ladle/components.{js,jsx,ts,tsx}'];
11
11
  const entry = [...restEntry, ...stories];
12
12
  const project = ['.ladle/**/*.{js,jsx,ts,tsx}'];
13
- const resolveEntryPaths = (localConfig, options) => {
13
+ const resolveConfig = async (localConfig, options) => {
14
14
  const localStories = typeof localConfig.stories === 'string' ? [localConfig.stories] : localConfig.stories;
15
15
  const viteConfig = localConfig.viteConfig ? [toAbsolute(localConfig.viteConfig, options.cwd)] : [];
16
16
  const patterns = [...restEntry, ...(localStories ?? stories), ...viteConfig];
17
- return patterns.map(id => toEntry(id));
18
- };
19
- const resolveConfig = async (localConfig, options) => {
17
+ const entries = patterns.map(id => toEntry(id));
20
18
  if (localConfig.viteConfig) {
21
19
  const viteConfigPath = toAbsolute(localConfig.viteConfig, options.cwd);
22
20
  const viteConfig = await load(viteConfigPath);
23
- return resolveVitestConfig(viteConfig, options);
21
+ return entries.concat(await resolveVitestConfig(viteConfig, options));
24
22
  }
25
- return [];
23
+ return entries;
26
24
  };
27
25
  export default {
28
26
  title,
@@ -31,6 +29,5 @@ export default {
31
29
  config,
32
30
  entry,
33
31
  project,
34
- resolveEntryPaths,
35
32
  resolveConfig,
36
33
  };
@@ -1,15 +1,14 @@
1
- import type { IsPluginEnabled, ResolveConfig, ResolveEntryPaths } from '../../types/config.js';
1
+ import type { IsPluginEnabled, ResolveConfig } from '../../types/config.js';
2
2
  import type { MetroConfig } from './types.js';
3
3
  export declare const docs: {
4
4
  note: string;
5
- production: string[];
6
5
  };
7
6
  declare const _default: {
8
7
  title: string;
9
8
  enablers: string[];
10
9
  isEnabled: IsPluginEnabled;
11
10
  config: string[];
12
- resolveEntryPaths: ResolveEntryPaths<MetroConfig>;
11
+ production: string[];
13
12
  resolveConfig: ResolveConfig<MetroConfig>;
14
13
  };
15
14
  export default _default;
@@ -10,20 +10,23 @@ const DEFAULT_PLATFORMS = ['ios', 'android', 'windows', 'web'];
10
10
  const PLATFORMS = [...DEFAULT_PLATFORMS, 'native', 'default'];
11
11
  const DEFAULT_EXTENSIONS = ['js', 'jsx', 'json', 'ts', 'tsx'];
12
12
  const production = [`src/**/*.{${PLATFORMS.join(',')}}.{${DEFAULT_EXTENSIONS.join(',')}}`];
13
- const resolveEntryPaths = async (config) => {
14
- const platformEntryPatterns = compact(PLATFORMS.concat(config.resolver?.platforms ?? []));
15
- const sourceExts = config.resolver?.sourceExts ?? DEFAULT_EXTENSIONS;
16
- const pattern = `src/**/*.{${platformEntryPatterns.join(',')}}.{${sourceExts.join(',')}}`;
17
- if (!config.projectRoot)
18
- return [toProductionEntry(pattern)];
19
- const entryFilePattern = 'index.{js,jsx,ts,tsx}';
20
- const entryFilePath = join(config.projectRoot, entryFilePattern);
21
- const entryFilePaths = join(config.projectRoot, pattern);
22
- return [toProductionEntry(entryFilePath), toProductionEntry(entryFilePaths)];
23
- };
24
13
  const resolveConfig = async (config) => {
25
14
  const { transformerPath, transformer } = config;
15
+ const i = new Set();
26
16
  const inputs = [];
17
+ const platformEntryPatterns = compact(PLATFORMS.concat(config.resolver?.platforms ?? []));
18
+ const sourceExts = config.resolver?.sourceExts ?? DEFAULT_EXTENSIONS;
19
+ const pattern = `src/**/*.{${platformEntryPatterns.join(',')}}.{${sourceExts.join(',')}}`;
20
+ if (!config.projectRoot) {
21
+ i.add(toProductionEntry(pattern));
22
+ }
23
+ else {
24
+ const entryFilePattern = 'index.{js,jsx,ts,tsx}';
25
+ const entryFilePath = join(config.projectRoot, entryFilePattern);
26
+ const entryFilePaths = join(config.projectRoot, pattern);
27
+ i.add(toProductionEntry(entryFilePath));
28
+ i.add(toProductionEntry(entryFilePaths));
29
+ }
27
30
  if (transformerPath)
28
31
  inputs.push(transformerPath);
29
32
  if (transformer?.assetPlugins)
@@ -32,16 +35,16 @@ const resolveConfig = async (config) => {
32
35
  inputs.push(transformer.minifierPath);
33
36
  if (transformer?.babelTransformerPath)
34
37
  inputs.push(transformer.babelTransformerPath);
35
- return [...inputs].map(toDeferResolve);
38
+ return Array.from(i).concat([...inputs].map(toDeferResolve));
36
39
  };
37
40
  const note = `False positives for platform-specific unused files?
38
41
  Override the default \`entry\` patterns to match platforms and extensions.`;
39
- export const docs = { note, production };
42
+ export const docs = { note };
40
43
  export default {
41
44
  title,
42
45
  enablers,
43
46
  isEnabled,
44
47
  config,
45
- resolveEntryPaths,
48
+ production,
46
49
  resolveConfig,
47
50
  };
@@ -1,4 +1,4 @@
1
- import type { IsPluginEnabled, ResolveConfig, ResolveEntryPaths } from '../../types/config.js';
1
+ import type { IsPluginEnabled, ResolveConfig } from '../../types/config.js';
2
2
  import type { MochaConfig } from './types.js';
3
3
  declare const _default: {
4
4
  title: string;
@@ -7,7 +7,6 @@ declare const _default: {
7
7
  config: string[];
8
8
  entry: string[];
9
9
  resolveConfig: ResolveConfig<MochaConfig>;
10
- resolveEntryPaths: ResolveEntryPaths<MochaConfig>;
11
10
  args: {
12
11
  nodeImportArgs: boolean;
13
12
  };