@parcel/utils 2.0.0-beta.3 → 2.0.0-dev.1510

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 (79) hide show
  1. package/lib/index.js +37516 -542
  2. package/lib/index.js.map +1 -0
  3. package/package.json +41 -18
  4. package/src/DefaultMap.js +1 -1
  5. package/src/PromiseQueue.js +13 -0
  6. package/src/alternatives.js +21 -6
  7. package/src/ansi-html.js +1 -1
  8. package/src/blob.js +1 -0
  9. package/src/collection.js +35 -3
  10. package/src/config.js +77 -22
  11. package/src/debounce.js +1 -1
  12. package/src/dependency-location.js +5 -5
  13. package/src/getExisting.js +1 -4
  14. package/src/getModuleParts.js +23 -0
  15. package/src/glob.js +26 -3
  16. package/src/hash.js +49 -0
  17. package/src/http-server.js +19 -7
  18. package/src/index.js +25 -10
  19. package/src/path.js +11 -1
  20. package/src/prettyDiagnostic.js +90 -40
  21. package/src/progress-message.js +22 -0
  22. package/src/replaceBundleReferences.js +49 -25
  23. package/src/schema.js +20 -19
  24. package/src/shared-buffer.js +23 -0
  25. package/src/sourcemap.js +13 -7
  26. package/src/urlJoin.js +3 -1
  27. package/test/DefaultMap.test.js +7 -4
  28. package/test/PromiseQueue.test.js +28 -0
  29. package/test/collection.test.js +13 -1
  30. package/test/config.test.js +98 -0
  31. package/test/input/config/.testrc +3 -0
  32. package/test/input/config/config.cjs +3 -0
  33. package/test/input/config/config.js +3 -0
  34. package/test/input/config/config.json +3 -0
  35. package/test/input/config/empty.json +0 -0
  36. package/test/input/config/empty.toml +0 -0
  37. package/test/replaceBundleReferences.test.js +88 -4
  38. package/test/throttle.test.js +1 -1
  39. package/test/urlJoin.test.js +11 -0
  40. package/lib/DefaultMap.js +0 -64
  41. package/lib/Deferred.js +0 -34
  42. package/lib/PromiseQueue.js +0 -144
  43. package/lib/TapStream.js +0 -46
  44. package/lib/alternatives.js +0 -151
  45. package/lib/ansi-html.js +0 -32
  46. package/lib/blob.js +0 -47
  47. package/lib/bundle-url.js +0 -43
  48. package/lib/collection.js +0 -51
  49. package/lib/config.js +0 -159
  50. package/lib/countLines.js +0 -18
  51. package/lib/debounce.js +0 -20
  52. package/lib/dependency-location.js +0 -21
  53. package/lib/escape-html.js +0 -24
  54. package/lib/generateBuildMetrics.js +0 -156
  55. package/lib/generateCertificate.js +0 -149
  56. package/lib/getCertificate.js +0 -19
  57. package/lib/getExisting.js +0 -31
  58. package/lib/getRootDir.js +0 -74
  59. package/lib/glob.js +0 -118
  60. package/lib/http-server.js +0 -110
  61. package/lib/is-url.js +0 -27
  62. package/lib/isDirectoryInside.js +0 -24
  63. package/lib/md5.js +0 -61
  64. package/lib/objectHash.js +0 -34
  65. package/lib/openInBrowser.js +0 -94
  66. package/lib/parseCSSImport.js +0 -16
  67. package/lib/path.js +0 -44
  68. package/lib/prettifyTime.js +0 -10
  69. package/lib/prettyDiagnostic.js +0 -119
  70. package/lib/relativeBundlePath.js +0 -38
  71. package/lib/relativeUrl.js +0 -32
  72. package/lib/replaceBundleReferences.js +0 -184
  73. package/lib/schema.js +0 -391
  74. package/lib/sourcemap.js +0 -155
  75. package/lib/stream.js +0 -86
  76. package/lib/throttle.js +0 -16
  77. package/lib/urlJoin.js +0 -43
  78. package/src/.babelrc +0 -3
  79. package/src/md5.js +0 -56
@@ -1,156 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = generateBuildMetrics;
7
-
8
- function _sourceMap() {
9
- const data = _interopRequireDefault(require("@parcel/source-map"));
10
-
11
- _sourceMap = function () {
12
- return data;
13
- };
14
-
15
- return data;
16
- }
17
-
18
- function _nullthrows() {
19
- const data = _interopRequireDefault(require("nullthrows"));
20
-
21
- _nullthrows = function () {
22
- return data;
23
- };
24
-
25
- return data;
26
- }
27
-
28
- function _path() {
29
- const data = _interopRequireDefault(require("path"));
30
-
31
- _path = function () {
32
- return data;
33
- };
34
-
35
- return data;
36
- }
37
-
38
- function _() {
39
- const data = require("./");
40
-
41
- _ = function () {
42
- return data;
43
- };
44
-
45
- return data;
46
- }
47
-
48
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
49
-
50
- async function getSourcemapSizes(filePath, fs, projectRoot) {
51
- let bundleContents = await fs.readFile(filePath, 'utf-8');
52
- let mapUrlData = await (0, _().loadSourceMapUrl)(fs, filePath, bundleContents);
53
-
54
- if (!mapUrlData) {
55
- return null;
56
- }
57
-
58
- let rawMap = mapUrlData.map;
59
- let sourceMap = new (_sourceMap().default)(projectRoot);
60
- sourceMap.addVLQMap(rawMap);
61
- let parsedMapData = sourceMap.getMap();
62
-
63
- if (parsedMapData.mappings.length > 2) {
64
- let sources = parsedMapData.sources.map(s => _path().default.normalize(_path().default.join(projectRoot, s)));
65
- let currLine = 1;
66
- let currColumn = 0;
67
- let currMappingIndex = 0;
68
- let currMapping = parsedMapData.mappings[currMappingIndex];
69
- let nextMapping = parsedMapData.mappings[currMappingIndex + 1];
70
- let sourceSizes = new Array(sources.length).fill(0);
71
- let unknownOrigin = 0;
72
-
73
- for (let i = 0; i < bundleContents.length; i++) {
74
- let character = bundleContents[i];
75
-
76
- while (nextMapping && nextMapping.generated.line === currLine && nextMapping.generated.column <= currColumn) {
77
- currMappingIndex++;
78
- currMapping = parsedMapData.mappings[currMappingIndex];
79
- nextMapping = parsedMapData.mappings[currMappingIndex + 1];
80
- }
81
-
82
- let currentSource = currMapping.source;
83
- let charSize = Buffer.byteLength(character, 'utf8');
84
-
85
- if (currentSource != null && currMapping.generated.line === currLine && currMapping.generated.column <= currColumn) {
86
- sourceSizes[currentSource] += charSize;
87
- } else {
88
- unknownOrigin += charSize;
89
- }
90
-
91
- if (character === '\n') {
92
- currColumn = 0;
93
- currLine++;
94
- } else {
95
- currColumn++;
96
- }
97
- }
98
-
99
- let sizeMap = new Map();
100
-
101
- for (let i = 0; i < sourceSizes.length; i++) {
102
- sizeMap.set(sources[i], sourceSizes[i]);
103
- }
104
-
105
- sizeMap.set('', unknownOrigin);
106
- return sizeMap;
107
- }
108
- }
109
-
110
- async function createBundleStats(bundle, fs, projectRoot) {
111
- let filePath = bundle.filePath;
112
- let sourcemapSizes = await getSourcemapSizes(filePath, fs, projectRoot);
113
- let assets = new Map();
114
- bundle.traverseAssets(asset => {
115
- let filePath = _path().default.normalize(asset.filePath);
116
-
117
- assets.set(filePath, {
118
- filePath,
119
- size: asset.stats.size,
120
- originalSize: asset.stats.size,
121
- time: asset.stats.time
122
- });
123
- });
124
- let assetsReport = [];
125
-
126
- if (sourcemapSizes && sourcemapSizes.size) {
127
- assetsReport = Array.from(sourcemapSizes.keys()).map(filePath => {
128
- let foundSize = sourcemapSizes.get(filePath) || 0;
129
- let stats = assets.get(filePath) || {
130
- filePath,
131
- size: foundSize,
132
- originalSize: foundSize,
133
- time: 0
134
- };
135
- return { ...stats,
136
- size: foundSize
137
- };
138
- });
139
- } else {
140
- assetsReport = Array.from(assets.values());
141
- }
142
-
143
- return {
144
- filePath: (0, _nullthrows().default)(bundle.filePath),
145
- size: bundle.stats.size,
146
- time: bundle.stats.time,
147
- assets: assetsReport.sort((a, b) => b.size - a.size)
148
- };
149
- }
150
-
151
- async function generateBuildMetrics(bundles, fs, projectRoot) {
152
- bundles.sort((a, b) => b.stats.size - a.stats.size).filter(b => !!b.filePath);
153
- return {
154
- bundles: (await Promise.all(bundles.map(b => createBundleStats(b, fs, projectRoot)))).filter(e => !!e)
155
- };
156
- }
@@ -1,149 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = generateCertificate;
7
-
8
- function _nodeForge() {
9
- const data = _interopRequireDefault(require("node-forge"));
10
-
11
- _nodeForge = function () {
12
- return data;
13
- };
14
-
15
- return data;
16
- }
17
-
18
- function _path() {
19
- const data = _interopRequireDefault(require("path"));
20
-
21
- _path = function () {
22
- return data;
23
- };
24
-
25
- return data;
26
- }
27
-
28
- function _logger() {
29
- const data = _interopRequireDefault(require("@parcel/logger"));
30
-
31
- _logger = function () {
32
- return data;
33
- };
34
-
35
- return data;
36
- }
37
-
38
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
39
-
40
- async function generateCertificate(fs, cacheDir, host) {
41
- let certDirectory = cacheDir;
42
-
43
- const privateKeyPath = _path().default.join(certDirectory, 'private.pem');
44
-
45
- const certPath = _path().default.join(certDirectory, 'primary.crt');
46
-
47
- const cachedKey = (await fs.exists(privateKeyPath)) && (await fs.readFile(privateKeyPath));
48
- const cachedCert = (await fs.exists(certPath)) && (await fs.readFile(certPath));
49
-
50
- if (cachedKey && cachedCert) {
51
- return {
52
- key: cachedKey,
53
- cert: cachedCert
54
- };
55
- }
56
-
57
- _logger().default.progress('Generating SSL Certificate...');
58
-
59
- const pki = _nodeForge().default.pki;
60
-
61
- const keys = pki.rsa.generateKeyPair(2048);
62
- const cert = pki.createCertificate();
63
- cert.publicKey = keys.publicKey;
64
- cert.serialNumber = Date.now().toString();
65
- cert.validity.notBefore = new Date();
66
- cert.validity.notAfter = new Date();
67
- cert.validity.notAfter.setFullYear(cert.validity.notBefore.getFullYear() + 1);
68
- const attrs = [{
69
- name: 'commonName',
70
- value: 'parceljs.org'
71
- }, {
72
- name: 'countryName',
73
- value: 'US'
74
- }, {
75
- shortName: 'ST',
76
- value: 'Virginia'
77
- }, {
78
- name: 'localityName',
79
- value: 'Blacksburg'
80
- }, {
81
- name: 'organizationName',
82
- value: 'parcelBundler'
83
- }, {
84
- shortName: 'OU',
85
- value: 'Test'
86
- }];
87
- let altNames = [{
88
- type: 2,
89
- // DNS
90
- value: 'localhost'
91
- }, {
92
- type: 7,
93
- // IP
94
- ip: '127.0.0.1'
95
- }];
96
-
97
- if (host) {
98
- altNames.push({
99
- type: 2,
100
- // DNS
101
- value: host
102
- });
103
- }
104
-
105
- cert.setSubject(attrs);
106
- cert.setIssuer(attrs);
107
- cert.setExtensions([{
108
- name: 'basicConstraints',
109
- cA: false
110
- }, {
111
- name: 'keyUsage',
112
- keyCertSign: true,
113
- digitalSignature: true,
114
- nonRepudiation: true,
115
- keyEncipherment: true,
116
- dataEncipherment: true
117
- }, {
118
- name: 'extKeyUsage',
119
- serverAuth: true,
120
- clientAuth: true,
121
- codeSigning: true,
122
- emailProtection: true,
123
- timeStamping: true
124
- }, {
125
- name: 'nsCertType',
126
- client: true,
127
- server: true,
128
- email: true,
129
- objsign: true,
130
- sslCA: true,
131
- emailCA: true,
132
- objCA: true
133
- }, {
134
- name: 'subjectAltName',
135
- altNames
136
- }, {
137
- name: 'subjectKeyIdentifier'
138
- }]);
139
- cert.sign(keys.privateKey, _nodeForge().default.md.sha256.create());
140
- const privPem = pki.privateKeyToPem(keys.privateKey);
141
- const certPem = pki.certificateToPem(cert);
142
- await fs.mkdirp(certDirectory);
143
- await fs.writeFile(privateKeyPath, privPem);
144
- await fs.writeFile(certPath, certPem);
145
- return {
146
- key: privPem,
147
- cert: certPem
148
- };
149
- }
@@ -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,31 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = getExisting;
7
-
8
- function _fs() {
9
- const data = _interopRequireDefault(require("fs"));
10
-
11
- _fs = function () {
12
- return data;
13
- };
14
-
15
- return data;
16
- }
17
-
18
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
-
20
- /**
21
- * Creates an object that contains both source and minified (using the source as a fallback).
22
- * e.g. builtins.min.js and builtins.js.
23
- */
24
- function getExisting(minifiedPath, sourcePath) {
25
- let source = _fs().default.readFileSync(sourcePath, 'utf8').trim();
26
-
27
- return {
28
- source,
29
- minified: _fs().default.existsSync(minifiedPath) ? _fs().default.readFileSync(minifiedPath, 'utf8').trim().replace(/;$/, '') : source
30
- };
31
- }
package/lib/getRootDir.js DELETED
@@ -1,74 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = getRootDir;
7
-
8
- function _glob() {
9
- const data = require("./glob");
10
-
11
- _glob = function () {
12
- return data;
13
- };
14
-
15
- return data;
16
- }
17
-
18
- function _path() {
19
- const data = _interopRequireDefault(require("path"));
20
-
21
- _path = function () {
22
- return data;
23
- };
24
-
25
- return data;
26
- }
27
-
28
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
29
-
30
- function getRootDir(files) {
31
- let cur = null;
32
-
33
- for (let file of files) {
34
- let parsed = _path().default.parse(file);
35
-
36
- parsed.dir = findGlobRoot(parsed.dir);
37
-
38
- if (!cur) {
39
- cur = parsed;
40
- } else if (parsed.root !== cur.root) {
41
- // bail out. there is no common root.
42
- // this can happen on windows, e.g. C:\foo\bar vs. D:\foo\bar
43
- return process.cwd();
44
- } else {
45
- // find the common path parts.
46
- let curParts = cur.dir.split(_path().default.sep);
47
- let newParts = parsed.dir.split(_path().default.sep);
48
- let len = Math.min(curParts.length, newParts.length);
49
- let i = 0;
50
-
51
- while (i < len && curParts[i] === newParts[i]) {
52
- i++;
53
- }
54
-
55
- cur.dir = i > 1 ? curParts.slice(0, i).join(_path().default.sep) : cur.root;
56
- }
57
- }
58
-
59
- return cur ? cur.dir : process.cwd();
60
- } // Transforms a path like `packages/*/src/index.js` to the root of the glob, `packages/`
61
-
62
-
63
- function findGlobRoot(dir) {
64
- let parts = dir.split(_path().default.sep);
65
- let last = parts.length;
66
-
67
- for (let i = parts.length - 1; i >= 0; i--) {
68
- if ((0, _glob().isGlob)(parts[i])) {
69
- last = i;
70
- }
71
- }
72
-
73
- return parts.slice(0, last).join(_path().default.sep);
74
- }
package/lib/glob.js DELETED
@@ -1,118 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.isGlob = isGlob;
7
- exports.isGlobMatch = isGlobMatch;
8
- exports.globSync = globSync;
9
- exports.glob = glob;
10
-
11
- function _isGlob2() {
12
- const data = _interopRequireDefault(require("is-glob"));
13
-
14
- _isGlob2 = function () {
15
- return data;
16
- };
17
-
18
- return data;
19
- }
20
-
21
- function _fastGlob() {
22
- const data = _interopRequireDefault(require("fast-glob"));
23
-
24
- _fastGlob = function () {
25
- return data;
26
- };
27
-
28
- return data;
29
- }
30
-
31
- function _micromatch() {
32
- const data = require("micromatch");
33
-
34
- _micromatch = function () {
35
- return data;
36
- };
37
-
38
- return data;
39
- }
40
-
41
- function _path() {
42
- const data = require("./path");
43
-
44
- _path = function () {
45
- return data;
46
- };
47
-
48
- return data;
49
- }
50
-
51
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
52
-
53
- function isGlob(p) {
54
- return (0, _isGlob2().default)((0, _path().normalizeSeparators)(p));
55
- }
56
-
57
- function isGlobMatch(filePath, glob) {
58
- return (0, _micromatch().isMatch)(filePath, (0, _path().normalizeSeparators)(glob));
59
- }
60
-
61
- function globSync(p, fs, options) {
62
- // $FlowFixMe
63
- options = { ...options,
64
- fs: {
65
- statSync: p => {
66
- return fs.statSync(p);
67
- },
68
- lstatSync: p => {
69
- // Our FileSystem interface doesn't have lstat support at the moment,
70
- // but this is fine for our purposes since we follow symlinks by default.
71
- return fs.statSync(p);
72
- },
73
- readdirSync: (p, opts) => {
74
- return fs.readdirSync(p, opts);
75
- }
76
- }
77
- }; // $FlowFixMe
78
-
79
- return _fastGlob().default.sync((0, _path().normalizeSeparators)(p), options);
80
- }
81
-
82
- function glob(p, fs, options) {
83
- // $FlowFixMe
84
- options = { ...options,
85
- fs: {
86
- stat: async (p, cb) => {
87
- try {
88
- cb(null, await fs.stat(p));
89
- } catch (err) {
90
- cb(err);
91
- }
92
- },
93
- lstat: async (p, cb) => {
94
- // Our FileSystem interface doesn't have lstat support at the moment,
95
- // but this is fine for our purposes since we follow symlinks by default.
96
- try {
97
- cb(null, await fs.stat(p));
98
- } catch (err) {
99
- cb(err);
100
- }
101
- },
102
- readdir: async (p, opts, cb) => {
103
- if (typeof opts === 'function') {
104
- cb = opts;
105
- opts = null;
106
- }
107
-
108
- try {
109
- cb(null, await fs.readdir(p, opts));
110
- } catch (err) {
111
- cb(err);
112
- }
113
- }
114
- }
115
- }; // $FlowFixMe Added in Flow 0.121.0 upgrade in #4381
116
-
117
- return (0, _fastGlob().default)((0, _path().normalizeSeparators)(p), options);
118
- }
@@ -1,110 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.createHTTPServer = createHTTPServer;
7
-
8
- function _http() {
9
- const data = _interopRequireDefault(require("http"));
10
-
11
- _http = function () {
12
- return data;
13
- };
14
-
15
- return data;
16
- }
17
-
18
- function _https() {
19
- const data = _interopRequireDefault(require("https"));
20
-
21
- _https = function () {
22
- return data;
23
- };
24
-
25
- return data;
26
- }
27
-
28
- function _nullthrows() {
29
- const data = _interopRequireDefault(require("nullthrows"));
30
-
31
- _nullthrows = function () {
32
- return data;
33
- };
34
-
35
- return data;
36
- }
37
-
38
- function _() {
39
- const data = require("./");
40
-
41
- _ = function () {
42
- return data;
43
- };
44
-
45
- return data;
46
- }
47
-
48
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
49
-
50
- // Creates either an http or https server with an awaitable dispose
51
- // that closes any connections
52
- async function createHTTPServer(options) {
53
- let server;
54
-
55
- if (!options.https) {
56
- server = _http().default.createServer(options.listener);
57
- } else if (options.https === true) {
58
- let {
59
- cert,
60
- key
61
- } = await (0, _().generateCertificate)(options.outputFS, options.cacheDir, options.host);
62
- server = _https().default.createServer({
63
- cert,
64
- key
65
- }, options.listener);
66
- } else {
67
- let {
68
- cert,
69
- key
70
- } = await (0, _().getCertificate)(options.inputFS, options.https);
71
- server = _https().default.createServer({
72
- cert,
73
- key
74
- }, options.listener);
75
- } // HTTPServer#close only stops accepting new connections, and does not close existing ones.
76
- // Before closing, destroy any active connections through their sockets. Additionally, remove sockets when they close:
77
- // https://stackoverflow.com/questions/18874689/force-close-all-connections-in-a-node-js-http-server
78
- // https://stackoverflow.com/questions/14626636/how-do-i-shutdown-a-node-js-https-server-immediately/14636625#14636625
79
-
80
-
81
- let sockets = new Set();
82
- server.on('connection', socket => {
83
- (0, _nullthrows().default)(sockets).add(socket);
84
- socket.on('close', () => {
85
- (0, _nullthrows().default)(sockets).delete(socket);
86
- });
87
- });
88
- return {
89
- server,
90
-
91
- stop() {
92
- return new Promise((resolve, reject) => {
93
- for (let socket of (0, _nullthrows().default)(sockets)) {
94
- socket.destroy();
95
- }
96
-
97
- sockets = new Set();
98
- server.close(err => {
99
- if (err != null) {
100
- reject(err);
101
- return;
102
- }
103
-
104
- resolve();
105
- });
106
- });
107
- }
108
-
109
- };
110
- }
package/lib/is-url.js DELETED
@@ -1,27 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = isURL;
7
-
8
- function _isUrl() {
9
- const data = _interopRequireDefault(require("is-url"));
10
-
11
- _isUrl = function () {
12
- return data;
13
- };
14
-
15
- return data;
16
- }
17
-
18
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
-
20
- // Matches anchor (ie: #raptors)
21
- const ANCHOR_REGEXP = /^#/; // Matches scheme (ie: tel:, mailto:, data:, itms-apps:)
22
-
23
- const SCHEME_REGEXP = /^[a-z][a-z0-9\-+.]*:/i;
24
-
25
- function isURL(url) {
26
- return (0, _isUrl().default)(url) || ANCHOR_REGEXP.test(url) || SCHEME_REGEXP.test(url);
27
- }
@@ -1,24 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = isDirectoryInside;
7
-
8
- function _path() {
9
- const data = _interopRequireDefault(require("path"));
10
-
11
- _path = function () {
12
- return data;
13
- };
14
-
15
- return data;
16
- }
17
-
18
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
-
20
- function isDirectoryInside(child, parent) {
21
- const relative = _path().default.relative(parent, child);
22
-
23
- return !relative.startsWith('..') && !_path().default.isAbsolute(relative);
24
- }