@parcel/utils 2.0.0-beta.1 → 2.0.0-nightly.1002

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 (93) hide show
  1. package/.eslintrc.js +6 -6
  2. package/lib/index.js +35850 -337
  3. package/lib/index.js.map +1 -0
  4. package/package.json +42 -20
  5. package/src/DefaultMap.js +1 -1
  6. package/src/PromiseQueue.js +16 -12
  7. package/src/alternatives.js +143 -0
  8. package/src/ansi-html.js +2 -2
  9. package/src/blob.js +2 -1
  10. package/src/bundle-url.js +1 -1
  11. package/src/collection.js +14 -14
  12. package/src/config.js +93 -53
  13. package/src/countLines.js +5 -2
  14. package/src/debounce.js +1 -1
  15. package/src/dependency-location.js +11 -6
  16. package/src/generateBuildMetrics.js +5 -5
  17. package/src/generateCertificate.js +1 -1
  18. package/src/getCertificate.js +1 -1
  19. package/src/getExisting.js +1 -4
  20. package/src/getRootDir.js +1 -2
  21. package/src/glob.js +36 -5
  22. package/src/hash.js +34 -0
  23. package/src/http-server.js +4 -11
  24. package/src/index.js +47 -20
  25. package/src/is-url.js +1 -1
  26. package/src/isDirectoryInside.js +4 -1
  27. package/src/openInBrowser.js +3 -1
  28. package/src/path.js +17 -2
  29. package/src/prettyDiagnostic.js +39 -27
  30. package/src/relativeBundlePath.js +5 -7
  31. package/src/replaceBundleReferences.js +50 -34
  32. package/src/schema.js +96 -42
  33. package/src/shared-buffer.js +24 -0
  34. package/src/sourcemap.js +84 -10
  35. package/src/urlJoin.js +3 -1
  36. package/test/DefaultMap.test.js +7 -4
  37. package/test/config.test.js +50 -0
  38. package/test/input/config/config.json +3 -0
  39. package/test/input/config/empty.json +0 -0
  40. package/test/input/config/empty.toml +0 -0
  41. package/test/input/sourcemap/referenced-min.js +1 -1
  42. package/test/replaceBundleReferences.test.js +268 -0
  43. package/test/sourcemap.test.js +5 -9
  44. package/test/throttle.test.js +1 -2
  45. package/test/urlJoin.test.js +37 -0
  46. package/lib/DefaultMap.js +0 -64
  47. package/lib/Deferred.js +0 -26
  48. package/lib/PromiseQueue.js +0 -133
  49. package/lib/TapStream.js +0 -38
  50. package/lib/ansi-html.js +0 -16
  51. package/lib/blob.js +0 -31
  52. package/lib/bundle-url.js +0 -43
  53. package/lib/collection.js +0 -62
  54. package/lib/config.js +0 -109
  55. package/lib/countLines.js +0 -18
  56. package/lib/debounce.js +0 -20
  57. package/lib/dependency-location.js +0 -21
  58. package/lib/escape-html.js +0 -24
  59. package/lib/escape-markdown.js +0 -15
  60. package/lib/generateBuildMetrics.js +0 -124
  61. package/lib/generateCertificate.js +0 -124
  62. package/lib/getCertificate.js +0 -19
  63. package/lib/getExisting.js +0 -23
  64. package/lib/getRootDir.js +0 -55
  65. package/lib/glob.js +0 -69
  66. package/lib/http-server.js +0 -81
  67. package/lib/is-url.js +0 -17
  68. package/lib/isDirectoryInside.js +0 -16
  69. package/lib/md5.js +0 -40
  70. package/lib/objectHash.js +0 -26
  71. package/lib/openInBrowser.js +0 -70
  72. package/lib/parseCSSImport.js +0 -16
  73. package/lib/path.js +0 -30
  74. package/lib/prettifyTime.js +0 -10
  75. package/lib/prettyDiagnostic.js +0 -75
  76. package/lib/promisify.js +0 -13
  77. package/lib/relativeBundlePath.js +0 -18
  78. package/lib/relativeUrl.js +0 -16
  79. package/lib/replaceBundleReferences.js +0 -166
  80. package/lib/resolve.js +0 -108
  81. package/lib/schema.js +0 -321
  82. package/lib/serializeObject.js +0 -28
  83. package/lib/sourcemap.js +0 -58
  84. package/lib/stream.js +0 -78
  85. package/lib/throttle.js +0 -16
  86. package/lib/urlJoin.js +0 -27
  87. package/src/.babelrc +0 -3
  88. package/src/escape-markdown.js +0 -10
  89. package/src/md5.js +0 -49
  90. package/src/promisify.js +0 -13
  91. package/src/resolve.js +0 -216
  92. package/src/serializeObject.js +0 -22
  93. package/test/escapeMarkdown.test.js +0 -29
package/lib/bundle-url.js DELETED
@@ -1,43 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.getBaseURL = getBaseURL;
7
- exports.getBundleURL = void 0;
8
- let bundleURL = null;
9
-
10
- function getBundleURLCached() {
11
- if (bundleURL == null) {
12
- bundleURL = _getBundleURL();
13
- }
14
-
15
- return bundleURL;
16
- }
17
-
18
- function _getBundleURL() {
19
- // Attempt to find the URL of the current script and use that as the base URL
20
- try {
21
- throw new Error();
22
- } catch (err) {
23
- let stack = typeof err.stack === 'string' ? err.stack : '';
24
- let matches = stack.match(/(https?|file|ftp):\/\/[^)\n]+/g);
25
-
26
- if (matches) {
27
- return getBaseURL(matches[0]);
28
- }
29
- }
30
-
31
- return '/';
32
- }
33
-
34
- function getBaseURL(url) {
35
- if (url == null) {
36
- return '/';
37
- }
38
-
39
- return url.replace(/^((?:https?|file|ftp):\/\/.+)\/[^/]+$/, '$1') + '/';
40
- }
41
-
42
- const getBundleURL = getBundleURLCached;
43
- exports.getBundleURL = getBundleURL;
package/lib/collection.js DELETED
@@ -1,62 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.unique = unique;
7
- exports.flatMap = flatMap;
8
- exports.objectSortedEntries = objectSortedEntries;
9
- exports.objectSortedEntriesDeep = objectSortedEntriesDeep;
10
- exports.setDifference = setDifference;
11
-
12
- function unique(array) {
13
- return [...new Set(array)];
14
- }
15
-
16
- function flatMap(array, projectFn) {
17
- let out = [];
18
-
19
- for (let arr of array.map(projectFn)) {
20
- out.push(...arr);
21
- }
22
-
23
- return out;
24
- }
25
-
26
- function objectSortedEntries(obj) {
27
- return Object.entries(obj).sort(([keyA], [keyB]) => keyA.localeCompare(keyB));
28
- }
29
-
30
- function objectSortedEntriesDeep(object) {
31
- let sortedEntries = objectSortedEntries(object);
32
-
33
- for (let i = 0; i < sortedEntries.length; i++) {
34
- sortedEntries[i][1] = sortEntry(sortedEntries[i][1]);
35
- }
36
-
37
- return sortedEntries;
38
- }
39
-
40
- function sortEntry(entry) {
41
- if (Array.isArray(entry)) {
42
- return entry.map(sortEntry);
43
- }
44
-
45
- if (typeof entry === 'object' && entry != null) {
46
- return objectSortedEntriesDeep(entry);
47
- }
48
-
49
- return entry;
50
- }
51
-
52
- function setDifference(a, b) {
53
- let difference = new Set();
54
-
55
- for (let e of a) {
56
- if (!b.has(e)) {
57
- difference.add(e);
58
- }
59
- }
60
-
61
- return difference;
62
- }
package/lib/config.js DELETED
@@ -1,109 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.resolveConfig = resolveConfig;
7
- exports.resolveConfigSync = resolveConfigSync;
8
- exports.loadConfig = loadConfig;
9
-
10
- var _path = _interopRequireDefault(require("path"));
11
-
12
- var _clone = _interopRequireDefault(require("clone"));
13
-
14
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
-
16
- const PARSERS = {
17
- json: require('json5').parse,
18
- toml: require('@iarna/toml').parse
19
- };
20
-
21
- async function resolveConfig(fs, filepath, filenames, opts, root = _path.default.parse(filepath).root) {
22
- filepath = await fs.realpath(_path.default.dirname(filepath)); // Don't traverse above the module root
23
-
24
- if (_path.default.basename(filepath) === 'node_modules') {
25
- return null;
26
- }
27
-
28
- for (const filename of filenames) {
29
- let file = _path.default.join(filepath, filename);
30
-
31
- if ((await fs.exists(file)) && (await fs.stat(file)).isFile()) {
32
- return file;
33
- }
34
- }
35
-
36
- if (filepath === root) {
37
- return null;
38
- }
39
-
40
- return resolveConfig(fs, filepath, filenames, opts);
41
- }
42
-
43
- function resolveConfigSync(fs, filepath, filenames, opts, root = _path.default.parse(filepath).root) {
44
- filepath = fs.realpathSync(_path.default.dirname(filepath)); // Don't traverse above the module root
45
-
46
- if (filepath === root || _path.default.basename(filepath) === 'node_modules') {
47
- return null;
48
- }
49
-
50
- for (const filename of filenames) {
51
- let file = _path.default.join(filepath, filename);
52
-
53
- if (fs.existsSync(file) && fs.statSync(file).isFile()) {
54
- return file;
55
- }
56
- }
57
-
58
- return resolveConfigSync(fs, filepath, filenames, opts);
59
- }
60
-
61
- async function loadConfig(fs, filepath, filenames, opts) {
62
- let configFile = await resolveConfig(fs, filepath, filenames, opts);
63
-
64
- if (configFile) {
65
- try {
66
- let extname = _path.default.extname(configFile).slice(1);
67
-
68
- if (extname === 'js') {
69
- return {
70
- // $FlowFixMe
71
- config: (0, _clone.default)(require(configFile)),
72
- files: [{
73
- filePath: configFile
74
- }]
75
- };
76
- }
77
-
78
- let configContent = await fs.readFile(configFile, 'utf8');
79
-
80
- if (!configContent) {
81
- return null;
82
- }
83
-
84
- let config;
85
-
86
- if (opts && opts.parse === false) {
87
- config = configContent;
88
- } else {
89
- let parse = PARSERS[extname] || PARSERS.json;
90
- config = parse(configContent);
91
- }
92
-
93
- return {
94
- config: config,
95
- files: [{
96
- filePath: configFile
97
- }]
98
- };
99
- } catch (err) {
100
- if (err.code === 'MODULE_NOT_FOUND' || err.code === 'ENOENT') {
101
- return null;
102
- }
103
-
104
- throw err;
105
- }
106
- }
107
-
108
- return null;
109
- }
package/lib/countLines.js DELETED
@@ -1,18 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = countLines;
7
-
8
- function countLines(string) {
9
- let lines = 1;
10
-
11
- for (let i = 0; i < string.length; i++) {
12
- if (string.charAt(i) === '\n') {
13
- lines++;
14
- }
15
- }
16
-
17
- return lines;
18
- }
package/lib/debounce.js DELETED
@@ -1,20 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = debounce;
7
-
8
- function debounce(fn, delay) {
9
- let timeout;
10
- return function (...args) {
11
- if (timeout) {
12
- clearTimeout(timeout);
13
- }
14
-
15
- timeout = setTimeout(() => {
16
- timeout = null;
17
- fn(...args);
18
- }, delay);
19
- };
20
- }
@@ -1,21 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = createDependencyLocation;
7
-
8
- function createDependencyLocation(start, moduleSpecifier, lineOffset = 0, columnOffset = 0, // Imports are usually wrapped in quotes
9
- importWrapperLength = 2) {
10
- return {
11
- filePath: moduleSpecifier,
12
- start: {
13
- line: start.line + lineOffset,
14
- column: start.column + columnOffset
15
- },
16
- end: {
17
- line: start.line + lineOffset,
18
- column: start.column + moduleSpecifier.length - 1 + importWrapperLength + columnOffset
19
- }
20
- };
21
- }
@@ -1,24 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.escapeHTML = escapeHTML;
7
- // Based on _.escape https://github.com/lodash/lodash/blob/master/escape.js
8
- const reUnescapedHtml = /[&<>"']/g;
9
- const reHasUnescapedHtml = RegExp(reUnescapedHtml.source);
10
- const htmlEscapes = {
11
- '&': '&amp;',
12
- '<': '&lt;',
13
- '>': '&gt;',
14
- '"': '&quot;',
15
- "'": '&#39;'
16
- };
17
-
18
- function escapeHTML(s) {
19
- if (reHasUnescapedHtml.test(s)) {
20
- return s.replace(reUnescapedHtml, c => htmlEscapes[c]);
21
- }
22
-
23
- return s;
24
- }
@@ -1,15 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.escapeMarkdown = escapeMarkdown;
7
- const escapeCharacters = ['\\', '*', '_', '~'];
8
-
9
- function escapeMarkdown(s) {
10
- for (const char of escapeCharacters) {
11
- s = s.replace(new RegExp(`\\${char}`, 'g'), `\\${char}`);
12
- }
13
-
14
- return s;
15
- }
@@ -1,124 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = generateBuildMetrics;
7
-
8
- var _sourceMap = _interopRequireDefault(require("@parcel/source-map"));
9
-
10
- var _nullthrows = _interopRequireDefault(require("nullthrows"));
11
-
12
- var _path = _interopRequireDefault(require("path"));
13
-
14
- var _ = require("./");
15
-
16
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
-
18
- async function getSourcemapSizes(filePath, fs, projectRoot) {
19
- let bundleContents = await fs.readFile(filePath, 'utf-8');
20
- let mapUrlData = await (0, _.loadSourceMapUrl)(fs, filePath, bundleContents);
21
-
22
- if (!mapUrlData) {
23
- return null;
24
- }
25
-
26
- let rawMap = mapUrlData.map;
27
- let sourceMap = new _sourceMap.default();
28
- sourceMap.addRawMappings(rawMap);
29
- let parsedMapData = sourceMap.getMap();
30
-
31
- if (parsedMapData.mappings.length > 2) {
32
- let sources = parsedMapData.sources.map(s => _path.default.normalize(_path.default.join(projectRoot, s)));
33
- let currLine = 1;
34
- let currColumn = 0;
35
- let currMappingIndex = 0;
36
- let currMapping = parsedMapData.mappings[currMappingIndex];
37
- let nextMapping = parsedMapData.mappings[currMappingIndex + 1];
38
- let sourceSizes = new Array(sources.length).fill(0);
39
- let unknownOrigin = 0;
40
-
41
- for (let i = 0; i < bundleContents.length; i++) {
42
- let character = bundleContents[i];
43
-
44
- while (nextMapping && nextMapping.generated.line === currLine && nextMapping.generated.column <= currColumn) {
45
- currMappingIndex++;
46
- currMapping = parsedMapData.mappings[currMappingIndex];
47
- nextMapping = parsedMapData.mappings[currMappingIndex + 1];
48
- }
49
-
50
- let currentSource = currMapping.source;
51
- let charSize = Buffer.byteLength(character, 'utf8');
52
-
53
- if (currentSource != null && currMapping.generated.line === currLine && currMapping.generated.column <= currColumn) {
54
- sourceSizes[currentSource] += charSize;
55
- } else {
56
- unknownOrigin += charSize;
57
- }
58
-
59
- if (character === '\n') {
60
- currColumn = 0;
61
- currLine++;
62
- } else {
63
- currColumn++;
64
- }
65
- }
66
-
67
- let sizeMap = new Map();
68
-
69
- for (let i = 0; i < sourceSizes.length; i++) {
70
- sizeMap.set(sources[i], sourceSizes[i]);
71
- }
72
-
73
- sizeMap.set('', unknownOrigin);
74
- return sizeMap;
75
- }
76
- }
77
-
78
- async function createBundleStats(bundle, fs, projectRoot) {
79
- let filePath = bundle.filePath;
80
- let sourcemapSizes = await getSourcemapSizes(filePath, fs, projectRoot);
81
- let assets = new Map();
82
- bundle.traverseAssets(asset => {
83
- let filePath = _path.default.normalize(asset.filePath);
84
-
85
- assets.set(filePath, {
86
- filePath,
87
- size: asset.stats.size,
88
- originalSize: asset.stats.size,
89
- time: asset.stats.time
90
- });
91
- });
92
- let assetsReport = [];
93
-
94
- if (sourcemapSizes && sourcemapSizes.size) {
95
- assetsReport = Array.from(sourcemapSizes.keys()).map(filePath => {
96
- let foundSize = sourcemapSizes.get(filePath) || 0;
97
- let stats = assets.get(filePath) || {
98
- filePath,
99
- size: foundSize,
100
- originalSize: foundSize,
101
- time: 0
102
- };
103
- return { ...stats,
104
- size: foundSize
105
- };
106
- });
107
- } else {
108
- assetsReport = Array.from(assets.values());
109
- }
110
-
111
- return {
112
- filePath: (0, _nullthrows.default)(bundle.filePath),
113
- size: bundle.stats.size,
114
- time: bundle.stats.time,
115
- assets: assetsReport.sort((a, b) => b.size - a.size)
116
- };
117
- }
118
-
119
- async function generateBuildMetrics(bundles, fs, projectRoot) {
120
- bundles.sort((a, b) => b.stats.size - a.stats.size).filter(b => !!b.filePath);
121
- return {
122
- bundles: (await Promise.all(bundles.map(b => createBundleStats(b, fs, projectRoot)))).filter(e => !!e)
123
- };
124
- }
@@ -1,124 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = generateCertificate;
7
-
8
- var _nodeForge = _interopRequireDefault(require("node-forge"));
9
-
10
- var _path = _interopRequireDefault(require("path"));
11
-
12
- var _logger = _interopRequireDefault(require("@parcel/logger"));
13
-
14
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
-
16
- async function generateCertificate(fs, cacheDir, host) {
17
- let certDirectory = cacheDir;
18
-
19
- const privateKeyPath = _path.default.join(certDirectory, 'private.pem');
20
-
21
- const certPath = _path.default.join(certDirectory, 'primary.crt');
22
-
23
- const cachedKey = (await fs.exists(privateKeyPath)) && (await fs.readFile(privateKeyPath));
24
- const cachedCert = (await fs.exists(certPath)) && (await fs.readFile(certPath));
25
-
26
- if (cachedKey && cachedCert) {
27
- return {
28
- key: cachedKey,
29
- cert: cachedCert
30
- };
31
- }
32
-
33
- _logger.default.progress('Generating SSL Certificate...');
34
-
35
- const pki = _nodeForge.default.pki;
36
- const keys = pki.rsa.generateKeyPair(2048);
37
- const cert = pki.createCertificate();
38
- cert.publicKey = keys.publicKey;
39
- cert.serialNumber = Date.now().toString();
40
- cert.validity.notBefore = new Date();
41
- cert.validity.notAfter = new Date();
42
- cert.validity.notAfter.setFullYear(cert.validity.notBefore.getFullYear() + 1);
43
- const attrs = [{
44
- name: 'commonName',
45
- value: 'parceljs.org'
46
- }, {
47
- name: 'countryName',
48
- value: 'US'
49
- }, {
50
- shortName: 'ST',
51
- value: 'Virginia'
52
- }, {
53
- name: 'localityName',
54
- value: 'Blacksburg'
55
- }, {
56
- name: 'organizationName',
57
- value: 'parcelBundler'
58
- }, {
59
- shortName: 'OU',
60
- value: 'Test'
61
- }];
62
- let altNames = [{
63
- type: 2,
64
- // DNS
65
- value: 'localhost'
66
- }, {
67
- type: 7,
68
- // IP
69
- ip: '127.0.0.1'
70
- }];
71
-
72
- if (host) {
73
- altNames.push({
74
- type: 2,
75
- // DNS
76
- value: host
77
- });
78
- }
79
-
80
- cert.setSubject(attrs);
81
- cert.setIssuer(attrs);
82
- cert.setExtensions([{
83
- name: 'basicConstraints',
84
- cA: false
85
- }, {
86
- name: 'keyUsage',
87
- keyCertSign: true,
88
- digitalSignature: true,
89
- nonRepudiation: true,
90
- keyEncipherment: true,
91
- dataEncipherment: true
92
- }, {
93
- name: 'extKeyUsage',
94
- serverAuth: true,
95
- clientAuth: true,
96
- codeSigning: true,
97
- emailProtection: true,
98
- timeStamping: true
99
- }, {
100
- name: 'nsCertType',
101
- client: true,
102
- server: true,
103
- email: true,
104
- objsign: true,
105
- sslCA: true,
106
- emailCA: true,
107
- objCA: true
108
- }, {
109
- name: 'subjectAltName',
110
- altNames
111
- }, {
112
- name: 'subjectKeyIdentifier'
113
- }]);
114
- cert.sign(keys.privateKey, _nodeForge.default.md.sha256.create());
115
- const privPem = pki.privateKeyToPem(keys.privateKey);
116
- const certPem = pki.certificateToPem(cert);
117
- await fs.mkdirp(certDirectory);
118
- await fs.writeFile(privateKeyPath, privPem);
119
- await fs.writeFile(certPath, certPem);
120
- return {
121
- key: privPem,
122
- cert: certPem
123
- };
124
- }
@@ -1,19 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = getCertificate;
7
-
8
- async function getCertificate(fs, options) {
9
- try {
10
- let cert = await fs.readFile(options.cert);
11
- let key = await fs.readFile(options.key);
12
- return {
13
- key,
14
- cert
15
- };
16
- } catch (err) {
17
- throw new Error('Certificate and/or key not found');
18
- }
19
- }
@@ -1,23 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = getExisting;
7
-
8
- var _fs = _interopRequireDefault(require("fs"));
9
-
10
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
-
12
- /**
13
- * Creates an object that contains both source and minified (using the source as a fallback).
14
- * e.g. builtins.min.js and builtins.js.
15
- */
16
- function getExisting(minifiedPath, sourcePath) {
17
- let source = _fs.default.readFileSync(sourcePath, 'utf8').trim();
18
-
19
- return {
20
- source,
21
- minified: _fs.default.existsSync(minifiedPath) ? _fs.default.readFileSync(minifiedPath, 'utf8').trim().replace(/;$/, '') : source
22
- };
23
- }
package/lib/getRootDir.js DELETED
@@ -1,55 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = getRootDir;
7
-
8
- var _glob = require("./glob");
9
-
10
- const path = require('path');
11
-
12
- function getRootDir(files) {
13
- let cur = null;
14
-
15
- for (let file of files) {
16
- let parsed = path.parse(file);
17
- parsed.dir = findGlobRoot(parsed.dir);
18
-
19
- if (!cur) {
20
- cur = parsed;
21
- } else if (parsed.root !== cur.root) {
22
- // bail out. there is no common root.
23
- // this can happen on windows, e.g. C:\foo\bar vs. D:\foo\bar
24
- return process.cwd();
25
- } else {
26
- // find the common path parts.
27
- let curParts = cur.dir.split(path.sep);
28
- let newParts = parsed.dir.split(path.sep);
29
- let len = Math.min(curParts.length, newParts.length);
30
- let i = 0;
31
-
32
- while (i < len && curParts[i] === newParts[i]) {
33
- i++;
34
- }
35
-
36
- cur.dir = i > 1 ? curParts.slice(0, i).join(path.sep) : cur.root;
37
- }
38
- }
39
-
40
- return cur ? cur.dir : process.cwd();
41
- } // Transforms a path like `packages/*/src/index.js` to the root of the glob, `packages/`
42
-
43
-
44
- function findGlobRoot(dir) {
45
- let parts = dir.split(path.sep);
46
- let last = parts.length;
47
-
48
- for (let i = parts.length - 1; i >= 0; i--) {
49
- if ((0, _glob.isGlob)(parts[i])) {
50
- last = i;
51
- }
52
- }
53
-
54
- return parts.slice(0, last).join(path.sep);
55
- }