@rollup/plugin-node-resolve 14.0.1 → 14.1.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.
package/README.md CHANGED
@@ -75,7 +75,14 @@ If `true`, instructs the plugin to use the browser module resolutions in `packag
75
75
  Type: `Array[...String]`<br>
76
76
  Default: `['node_modules']`
77
77
 
78
- One or more directories in which to recursively look for modules.
78
+ A list of directory names in which to recursively look for modules.
79
+
80
+ ### `modulePaths`
81
+
82
+ Type: `Array[...String]`<br>
83
+ Default: `[]`
84
+
85
+ A list of absolute paths to additional locations to search for modules. [This is analogous to setting the `NODE_PATH` environment variable for node](https://nodejs.org/api/modules.html#loading-from-the-global-folders).
79
86
 
80
87
  ### `dedupe`
81
88
 
@@ -214,7 +221,7 @@ export default ({
214
221
  })
215
222
  ```
216
223
 
217
- ## Resolving require statements
224
+ ## Resolving Require Statements
218
225
 
219
226
  According to [NodeJS module resolution](https://nodejs.org/api/packages.html#packages_package_entry_points) `require` statements should resolve using the `require` condition in the package exports field, while es modules should use the `import` condition.
220
227
 
package/dist/cjs/index.js CHANGED
@@ -21,7 +21,7 @@ var isModule__default = /*#__PURE__*/_interopDefaultLegacy(isModule);
21
21
  var fs__default = /*#__PURE__*/_interopDefaultLegacy(fs);
22
22
  var resolve__default = /*#__PURE__*/_interopDefaultLegacy(resolve);
23
23
 
24
- var version = "14.0.1";
24
+ var version = "14.1.0";
25
25
 
26
26
  util.promisify(fs__default["default"].access);
27
27
  const readFile$1 = util.promisify(fs__default["default"].readFile);
@@ -643,6 +643,7 @@ async function resolveIdClassic({
643
643
  useBrowserOverrides,
644
644
  baseDir,
645
645
  moduleDirectories,
646
+ modulePaths,
646
647
  rootDir,
647
648
  ignoreSideEffectsForRoot
648
649
  }) {
@@ -677,6 +678,7 @@ async function resolveIdClassic({
677
678
  extensions,
678
679
  includeCoreModules: false,
679
680
  moduleDirectory: moduleDirectories,
681
+ paths: modulePaths,
680
682
  preserveSymlinks,
681
683
  packageFilter: filter
682
684
  };
@@ -711,6 +713,7 @@ async function resolveWithExportMap({
711
713
  useBrowserOverrides,
712
714
  baseDir,
713
715
  moduleDirectories,
716
+ modulePaths,
714
717
  rootDir,
715
718
  ignoreSideEffectsForRoot
716
719
  }) {
@@ -730,7 +733,8 @@ async function resolveWithExportMap({
730
733
  preserveSymlinks,
731
734
  useBrowserOverrides,
732
735
  baseDir,
733
- moduleDirectories
736
+ moduleDirectories,
737
+ modulePaths
734
738
  });
735
739
  }
736
740
  });
@@ -780,6 +784,7 @@ async function resolveWithExportMap({
780
784
  extensions,
781
785
  includeCoreModules: false,
782
786
  moduleDirectory: moduleDirectories,
787
+ paths: modulePaths,
783
788
  preserveSymlinks,
784
789
  packageFilter: filter
785
790
  };
@@ -830,6 +835,7 @@ async function resolveWithClassic({
830
835
  useBrowserOverrides,
831
836
  baseDir,
832
837
  moduleDirectories,
838
+ modulePaths,
833
839
  rootDir,
834
840
  ignoreSideEffectsForRoot
835
841
  }) {
@@ -847,6 +853,7 @@ async function resolveWithClassic({
847
853
  useBrowserOverrides,
848
854
  baseDir,
849
855
  moduleDirectories,
856
+ modulePaths,
850
857
  rootDir,
851
858
  ignoreSideEffectsForRoot
852
859
  });
@@ -875,6 +882,7 @@ async function resolveImportSpecifiers({
875
882
  useBrowserOverrides,
876
883
  baseDir,
877
884
  moduleDirectories,
885
+ modulePaths,
878
886
  rootDir,
879
887
  ignoreSideEffectsForRoot
880
888
  }) {
@@ -890,6 +898,7 @@ async function resolveImportSpecifiers({
890
898
  useBrowserOverrides,
891
899
  baseDir,
892
900
  moduleDirectories,
901
+ modulePaths,
893
902
  rootDir,
894
903
  ignoreSideEffectsForRoot
895
904
  });
@@ -915,6 +924,7 @@ async function resolveImportSpecifiers({
915
924
  useBrowserOverrides,
916
925
  baseDir,
917
926
  moduleDirectories,
927
+ modulePaths,
918
928
  rootDir,
919
929
  ignoreSideEffectsForRoot
920
930
  });
@@ -953,7 +963,7 @@ function nodeResolve(opts = {}) {
953
963
  const { warnings } = handleDeprecatedOptions(opts);
954
964
 
955
965
  const options = { ...defaults, ...opts };
956
- const { extensions, jail, moduleDirectories, ignoreSideEffectsForRoot } = options;
966
+ const { extensions, jail, moduleDirectories, modulePaths, ignoreSideEffectsForRoot } = options;
957
967
  const conditionsEsm = [...baseConditionsEsm, ...(options.exportConditions || [])];
958
968
  const conditionsCjs = [...baseConditionsCjs, ...(options.exportConditions || [])];
959
969
  const packageInfoCache = new Map();
@@ -966,6 +976,12 @@ function nodeResolve(opts = {}) {
966
976
  let { dedupe } = options;
967
977
  let rollupOptions;
968
978
 
979
+ if (moduleDirectories.some((name) => name.includes('/'))) {
980
+ throw new Error(
981
+ '`moduleDirectories` option must only contain directory names. If you want to load modules from somewhere not supported by the default module resolution algorithm, see `modulePaths`.'
982
+ );
983
+ }
984
+
969
985
  if (typeof dedupe !== 'function') {
970
986
  dedupe = (importee) =>
971
987
  options.dedupe.includes(importee) || options.dedupe.includes(getPackageName(importee));
@@ -1076,6 +1092,7 @@ function nodeResolve(opts = {}) {
1076
1092
  useBrowserOverrides,
1077
1093
  baseDir,
1078
1094
  moduleDirectories,
1095
+ modulePaths,
1079
1096
  rootDir,
1080
1097
  ignoreSideEffectsForRoot
1081
1098
  });
package/dist/es/index.js CHANGED
@@ -8,7 +8,7 @@ import { pathToFileURL, fileURLToPath } from 'url';
8
8
  import resolve$1 from 'resolve';
9
9
  import { createFilter } from '@rollup/pluginutils';
10
10
 
11
- var version = "14.0.1";
11
+ var version = "14.1.0";
12
12
 
13
13
  promisify(fs.access);
14
14
  const readFile$1 = promisify(fs.readFile);
@@ -630,6 +630,7 @@ async function resolveIdClassic({
630
630
  useBrowserOverrides,
631
631
  baseDir,
632
632
  moduleDirectories,
633
+ modulePaths,
633
634
  rootDir,
634
635
  ignoreSideEffectsForRoot
635
636
  }) {
@@ -664,6 +665,7 @@ async function resolveIdClassic({
664
665
  extensions,
665
666
  includeCoreModules: false,
666
667
  moduleDirectory: moduleDirectories,
668
+ paths: modulePaths,
667
669
  preserveSymlinks,
668
670
  packageFilter: filter
669
671
  };
@@ -698,6 +700,7 @@ async function resolveWithExportMap({
698
700
  useBrowserOverrides,
699
701
  baseDir,
700
702
  moduleDirectories,
703
+ modulePaths,
701
704
  rootDir,
702
705
  ignoreSideEffectsForRoot
703
706
  }) {
@@ -717,7 +720,8 @@ async function resolveWithExportMap({
717
720
  preserveSymlinks,
718
721
  useBrowserOverrides,
719
722
  baseDir,
720
- moduleDirectories
723
+ moduleDirectories,
724
+ modulePaths
721
725
  });
722
726
  }
723
727
  });
@@ -767,6 +771,7 @@ async function resolveWithExportMap({
767
771
  extensions,
768
772
  includeCoreModules: false,
769
773
  moduleDirectory: moduleDirectories,
774
+ paths: modulePaths,
770
775
  preserveSymlinks,
771
776
  packageFilter: filter
772
777
  };
@@ -817,6 +822,7 @@ async function resolveWithClassic({
817
822
  useBrowserOverrides,
818
823
  baseDir,
819
824
  moduleDirectories,
825
+ modulePaths,
820
826
  rootDir,
821
827
  ignoreSideEffectsForRoot
822
828
  }) {
@@ -834,6 +840,7 @@ async function resolveWithClassic({
834
840
  useBrowserOverrides,
835
841
  baseDir,
836
842
  moduleDirectories,
843
+ modulePaths,
837
844
  rootDir,
838
845
  ignoreSideEffectsForRoot
839
846
  });
@@ -862,6 +869,7 @@ async function resolveImportSpecifiers({
862
869
  useBrowserOverrides,
863
870
  baseDir,
864
871
  moduleDirectories,
872
+ modulePaths,
865
873
  rootDir,
866
874
  ignoreSideEffectsForRoot
867
875
  }) {
@@ -877,6 +885,7 @@ async function resolveImportSpecifiers({
877
885
  useBrowserOverrides,
878
886
  baseDir,
879
887
  moduleDirectories,
888
+ modulePaths,
880
889
  rootDir,
881
890
  ignoreSideEffectsForRoot
882
891
  });
@@ -902,6 +911,7 @@ async function resolveImportSpecifiers({
902
911
  useBrowserOverrides,
903
912
  baseDir,
904
913
  moduleDirectories,
914
+ modulePaths,
905
915
  rootDir,
906
916
  ignoreSideEffectsForRoot
907
917
  });
@@ -940,7 +950,7 @@ function nodeResolve(opts = {}) {
940
950
  const { warnings } = handleDeprecatedOptions(opts);
941
951
 
942
952
  const options = { ...defaults, ...opts };
943
- const { extensions, jail, moduleDirectories, ignoreSideEffectsForRoot } = options;
953
+ const { extensions, jail, moduleDirectories, modulePaths, ignoreSideEffectsForRoot } = options;
944
954
  const conditionsEsm = [...baseConditionsEsm, ...(options.exportConditions || [])];
945
955
  const conditionsCjs = [...baseConditionsCjs, ...(options.exportConditions || [])];
946
956
  const packageInfoCache = new Map();
@@ -953,6 +963,12 @@ function nodeResolve(opts = {}) {
953
963
  let { dedupe } = options;
954
964
  let rollupOptions;
955
965
 
966
+ if (moduleDirectories.some((name) => name.includes('/'))) {
967
+ throw new Error(
968
+ '`moduleDirectories` option must only contain directory names. If you want to load modules from somewhere not supported by the default module resolution algorithm, see `modulePaths`.'
969
+ );
970
+ }
971
+
956
972
  if (typeof dedupe !== 'function') {
957
973
  dedupe = (importee) =>
958
974
  options.dedupe.includes(importee) || options.dedupe.includes(getPackageName(importee));
@@ -1063,6 +1079,7 @@ function nodeResolve(opts = {}) {
1063
1079
  useBrowserOverrides,
1064
1080
  baseDir,
1065
1081
  moduleDirectories,
1082
+ modulePaths,
1066
1083
  rootDir,
1067
1084
  ignoreSideEffectsForRoot
1068
1085
  });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rollup/plugin-node-resolve",
3
- "version": "14.0.1",
3
+ "version": "14.1.0",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
package/types/index.d.ts CHANGED
@@ -31,11 +31,18 @@ export interface RollupNodeResolveOptions {
31
31
  browser?: boolean;
32
32
 
33
33
  /**
34
- * One or more directories in which to recursively look for modules.
34
+ * A list of directory names in which to recursively look for modules.
35
35
  * @default ['node_modules']
36
36
  */
37
37
  moduleDirectories?: string[];
38
38
 
39
+ /**
40
+ * A list of absolute paths to additional locations to search for modules.
41
+ * This is analogous to setting the `NODE_PATH` environment variable for node.
42
+ * @default []
43
+ */
44
+ modulePaths?: string[];
45
+
39
46
  /**
40
47
  * An `Array` of modules names, which instructs the plugin to force resolving for the
41
48
  * specified modules to the root `node_modules`. Helps to prevent bundling the same