@parcel/utils 2.0.0-nightly.92 → 2.0.0-nightly.926

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/DefaultMap.js +26 -5
  3. package/lib/Deferred.js +10 -2
  4. package/lib/PromiseQueue.js +21 -30
  5. package/lib/TapStream.js +10 -10
  6. package/lib/alternatives.js +134 -0
  7. package/lib/ansi-html.js +10 -2
  8. package/lib/blob.js +14 -6
  9. package/lib/collection.js +0 -11
  10. package/lib/config.js +107 -34
  11. package/lib/countLines.js +2 -2
  12. package/lib/dependency-location.js +3 -3
  13. package/lib/generateBuildMetrics.js +148 -0
  14. package/lib/generateCertificate.js +33 -8
  15. package/lib/getExisting.js +11 -3
  16. package/lib/getRootDir.js +18 -7
  17. package/lib/glob.js +53 -19
  18. package/lib/hash.js +44 -0
  19. package/lib/http-server.js +48 -10
  20. package/lib/index.js +280 -222
  21. package/lib/is-url.js +12 -2
  22. package/lib/isDirectoryInside.js +24 -0
  23. package/lib/objectHash.js +10 -2
  24. package/lib/openInBrowser.js +94 -0
  25. package/lib/path.js +33 -6
  26. package/lib/prettyDiagnostic.js +107 -25
  27. package/lib/relativeBundlePath.js +13 -7
  28. package/lib/relativeUrl.js +19 -3
  29. package/lib/replaceBundleReferences.js +91 -35
  30. package/lib/schema.js +104 -33
  31. package/lib/sourcemap.js +147 -0
  32. package/lib/stream.js +38 -3
  33. package/lib/urlJoin.js +25 -6
  34. package/package.json +22 -16
  35. package/src/DefaultMap.js +25 -1
  36. package/src/PromiseQueue.js +16 -12
  37. package/src/alternatives.js +143 -0
  38. package/src/ansi-html.js +2 -2
  39. package/src/blob.js +3 -3
  40. package/src/bundle-url.js +1 -1
  41. package/src/collection.js +2 -14
  42. package/src/config.js +67 -34
  43. package/src/countLines.js +5 -2
  44. package/src/debounce.js +1 -1
  45. package/src/dependency-location.js +11 -6
  46. package/src/generateBuildMetrics.js +158 -0
  47. package/src/generateCertificate.js +1 -1
  48. package/src/getCertificate.js +1 -1
  49. package/src/getExisting.js +1 -4
  50. package/src/getRootDir.js +1 -2
  51. package/src/glob.js +29 -11
  52. package/src/hash.js +34 -0
  53. package/src/http-server.js +10 -12
  54. package/src/index.js +49 -23
  55. package/src/is-url.js +1 -1
  56. package/src/isDirectoryInside.js +11 -0
  57. package/src/openInBrowser.js +64 -0
  58. package/src/path.js +38 -6
  59. package/src/prettyDiagnostic.js +59 -28
  60. package/src/relativeBundlePath.js +8 -13
  61. package/src/replaceBundleReferences.js +75 -39
  62. package/src/schema.js +101 -44
  63. package/src/sourcemap.js +135 -0
  64. package/src/stream.js +31 -1
  65. package/src/urlJoin.js +3 -1
  66. package/test/DefaultMap.test.js +8 -5
  67. package/test/input/sourcemap/referenced-min.js +2 -0
  68. package/test/input/sourcemap/referenced-min.js.map +6 -0
  69. package/test/input/sourcemap/source-root.js +2 -0
  70. package/test/input/sourcemap/source-root.js.map +7 -0
  71. package/test/objectHash.test.js +33 -0
  72. package/test/prettifyTime.test.js +17 -0
  73. package/test/replaceBundleReferences.test.js +268 -0
  74. package/test/sourcemap.test.js +207 -0
  75. package/test/throttle.test.js +1 -2
  76. package/test/urlJoin.test.js +37 -0
  77. package/lib/generateBundleReport.js +0 -38
  78. package/lib/loadSourceMapUrl.js +0 -33
  79. package/lib/md5.js +0 -35
  80. package/lib/prettyError.js +0 -43
  81. package/lib/promisify.js +0 -13
  82. package/lib/resolve.js +0 -93
  83. package/lib/serializeObject.js +0 -28
  84. package/src/generateBundleReport.js +0 -51
  85. package/src/loadSourceMapUrl.js +0 -33
  86. package/src/md5.js +0 -44
  87. package/src/prettyError.js +0 -54
  88. package/src/promisify.js +0 -13
  89. package/src/resolve.js +0 -123
  90. package/src/serializeObject.js +0 -22
  91. package/test/input/sourcemap/referenced.js +0 -7
  92. package/test/loadSourceMapUrl.test.js +0 -37
  93. package/test/prettyError.test.js +0 -104
package/lib/resolve.js DELETED
@@ -1,93 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.resolve = resolve;
7
- exports.resolveSync = resolveSync;
8
-
9
- var _promisify = _interopRequireDefault(require("./promisify"));
10
-
11
- var _resolve2 = _interopRequireDefault(require("resolve"));
12
-
13
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
-
15
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
16
-
17
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
18
-
19
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
20
-
21
- const resolveAsync = (0, _promisify.default)(_resolve2.default);
22
-
23
- async function resolve(fs, id, opts) {
24
- let res = await resolveAsync(id, _objectSpread({}, opts, {
25
- async readFile(filename, callback) {
26
- try {
27
- let res = await fs.readFile(filename);
28
- callback(null, res);
29
- } catch (err) {
30
- callback(err);
31
- }
32
- },
33
-
34
- async isFile(file, callback) {
35
- try {
36
- let stat = await fs.stat(file);
37
- callback(null, stat.isFile());
38
- } catch (err) {
39
- callback(null, false);
40
- }
41
- },
42
-
43
- async isDirectory(file, callback) {
44
- try {
45
- let stat = await fs.stat(file);
46
- callback(null, stat.isDirectory());
47
- } catch (err) {
48
- callback(null, false);
49
- }
50
- }
51
-
52
- }));
53
-
54
- if (typeof res === 'string') {
55
- return {
56
- resolved: res
57
- };
58
- }
59
-
60
- return {
61
- resolved: res[0],
62
- pkg: res[1]
63
- };
64
- }
65
-
66
- function resolveSync(fs, id, opts) {
67
- // $FlowFixMe
68
- let res = _resolve2.default.sync(id, _objectSpread({}, opts, {
69
- readFileSync: (...args) => {
70
- return fs.readFileSync(...args);
71
- },
72
- isFile: file => {
73
- try {
74
- let stat = fs.statSync(file);
75
- return stat.isFile();
76
- } catch (err) {
77
- return false;
78
- }
79
- },
80
- isDirectory: file => {
81
- try {
82
- let stat = fs.statSync(file);
83
- return stat.isDirectory();
84
- } catch (err) {
85
- return false;
86
- }
87
- }
88
- }));
89
-
90
- return {
91
- resolved: res
92
- };
93
- }
@@ -1,28 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = serializeObject;
7
-
8
- var _terser = require("terser");
9
-
10
- var _serializeToJs = _interopRequireDefault(require("serialize-to-js"));
11
-
12
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
-
14
- function serializeObject(obj, shouldMinify = false) {
15
- let code = `module.exports = ${(0, _serializeToJs.default)(obj)};`;
16
-
17
- if (shouldMinify) {
18
- let minified = (0, _terser.minify)(code);
19
-
20
- if (minified.error) {
21
- throw minified.error;
22
- }
23
-
24
- code = minified.code;
25
- }
26
-
27
- return code;
28
- }
@@ -1,51 +0,0 @@
1
- // @flow strict-local
2
-
3
- import type {Asset, BundleGraph} from '@parcel/types';
4
- import nullthrows from 'nullthrows';
5
-
6
- export type BundleReport = {|
7
- bundles: Array<{|
8
- filePath: string,
9
- size: number,
10
- time: number,
11
- largestAssets: Array<{|
12
- filePath: string,
13
- size: number,
14
- time: number,
15
- |}>,
16
- totalAssets: number,
17
- |}>,
18
- |};
19
-
20
- export default function generateBundleReport(
21
- bundleGraph: BundleGraph,
22
- largestAssetCount: number = 10,
23
- ): BundleReport {
24
- let bundles = [];
25
- bundleGraph.traverseBundles(bundle => {
26
- bundles.push(bundle);
27
- });
28
- bundles.sort((a, b) => b.stats.size - a.stats.size);
29
-
30
- return {
31
- bundles: bundles.map(bundle => {
32
- let assets: Array<Asset> = [];
33
- bundle.traverseAssets(asset => {
34
- assets.push(asset);
35
- });
36
- assets.sort((a, b) => b.stats.size - a.stats.size);
37
-
38
- return {
39
- filePath: nullthrows(bundle.filePath),
40
- size: bundle.stats.size,
41
- time: bundle.stats.time,
42
- largestAssets: assets.slice(0, largestAssetCount).map(asset => ({
43
- filePath: asset.filePath,
44
- size: asset.stats.size,
45
- time: asset.stats.time,
46
- })),
47
- totalAssets: assets.length,
48
- };
49
- }),
50
- };
51
- }
@@ -1,33 +0,0 @@
1
- // @flow
2
- import type {FileSystem} from '@parcel/fs';
3
- import path from 'path';
4
-
5
- const SOURCEMAP_RE = /(?:\/\*|\/\/)\s*[@#]\s*sourceMappingURL\s*=\s*([^\s*]+)(?:\s*\*\/)?\s*$/;
6
- const DATA_URL_RE = /^data:[^;]+(?:;charset=[^;]+)?;base64,(.*)/;
7
-
8
- export function matchSourceMappingURL(contents: string) {
9
- return contents.match(SOURCEMAP_RE);
10
- }
11
-
12
- export default async function loadSourceMapUrl(
13
- fs: FileSystem,
14
- filename: string,
15
- contents: string,
16
- ) {
17
- let match = matchSourceMappingURL(contents);
18
- if (match) {
19
- let url = match[1].trim();
20
- let dataURLMatch = url.match(DATA_URL_RE);
21
- filename = dataURLMatch ? filename : path.join(path.dirname(filename), url);
22
-
23
- return {
24
- url,
25
- filename,
26
- map: JSON.parse(
27
- dataURLMatch
28
- ? Buffer.from(dataURLMatch[1], 'base64').toString()
29
- : await fs.readFile(filename, 'utf8'),
30
- ),
31
- };
32
- }
33
- }
package/src/md5.js DELETED
@@ -1,44 +0,0 @@
1
- // @flow strict-local
2
-
3
- import type {Readable} from 'stream';
4
- import type {FileSystem} from '@parcel/fs';
5
-
6
- import crypto from 'crypto';
7
- import {objectSortedEntriesDeep} from './collection';
8
-
9
- type StringHashEncoding = 'hex' | 'latin1' | 'binary' | 'base64';
10
-
11
- export function md5FromString(
12
- string: string | Buffer,
13
- encoding: StringHashEncoding = 'hex',
14
- ): string {
15
- return crypto
16
- .createHash('md5')
17
- .update(string)
18
- .digest(encoding);
19
- }
20
-
21
- export function md5FromReadableStream(stream: Readable): Promise<string> {
22
- return new Promise((resolve, reject) => {
23
- stream
24
- .pipe(crypto.createHash('md5').setEncoding('hex'))
25
- .on('finish', function() {
26
- resolve(this.read());
27
- })
28
- .on('error', reject);
29
- });
30
- }
31
-
32
- export function md5FromObject(
33
- obj: {+[string]: mixed, ...},
34
- encoding: StringHashEncoding = 'hex',
35
- ): string {
36
- return md5FromString(JSON.stringify(objectSortedEntriesDeep(obj)), encoding);
37
- }
38
-
39
- export function md5FromFilePath(
40
- fs: FileSystem,
41
- filePath: string,
42
- ): Promise<string> {
43
- return md5FromReadableStream(fs.createReadStream(filePath));
44
- }
@@ -1,54 +0,0 @@
1
- // @flow strict-local
2
-
3
- export type PrintableError =
4
- | string
5
- | (Error & {
6
- codeFrame?: string,
7
- highlightedCodeFrame?: string,
8
- loc?: {|
9
- column: number,
10
- line: number,
11
- |},
12
- ...
13
- });
14
-
15
- export type PrettyErrorOpts = {color?: boolean, ...};
16
-
17
- export type PrettyError = {|
18
- message: string,
19
- stack?: string,
20
- |};
21
-
22
- export default function prettyError(
23
- err: PrintableError,
24
- opts: PrettyErrorOpts = {},
25
- ): PrettyError {
26
- if (typeof err === 'string') {
27
- return {
28
- message: err,
29
- };
30
- }
31
-
32
- let message = err.message;
33
- if (!message) {
34
- message = 'Unknown error';
35
- }
36
-
37
- if (err.fileName != null) {
38
- let fileName = err.fileName;
39
- if (err.loc) {
40
- fileName += `:${err.loc.line}:${err.loc.column}`;
41
- }
42
-
43
- message = `${fileName}: ${message}`;
44
- }
45
-
46
- let stack;
47
- if (err.codeFrame != null && err.codeFrame !== '') {
48
- stack = (opts.color === true && err.highlightedCodeFrame) || err.codeFrame;
49
- } else if (err.stack) {
50
- stack = err.stack.slice(err.stack.indexOf('\n') + 1);
51
- }
52
-
53
- return {message, stack};
54
- }
package/src/promisify.js DELETED
@@ -1,13 +0,0 @@
1
- module.exports = function(fn) {
2
- return function(...args) {
3
- return new Promise(function(resolve, reject) {
4
- fn(...args, function(err, ...res) {
5
- if (err) return reject(err);
6
-
7
- if (res.length === 1) return resolve(res[0]);
8
-
9
- resolve(res);
10
- });
11
- });
12
- };
13
- };
package/src/resolve.js DELETED
@@ -1,123 +0,0 @@
1
- // @flow strict-local
2
-
3
- import type {PackageJSON, FilePath, ModuleSpecifier} from '@parcel/types';
4
- import type {ResolveOptions} from 'resolve';
5
- import type {FileSystem} from '@parcel/fs';
6
-
7
- // $FlowFixMe TODO: Type promisify
8
- import promisify from './promisify';
9
- import _resolve from 'resolve';
10
-
11
- const resolveAsync = promisify(_resolve);
12
-
13
- export type ResolveResult = {|
14
- resolved: FilePath | ModuleSpecifier,
15
- pkg?: ?PackageJSON,
16
- |};
17
-
18
- export async function resolve(
19
- fs: FileSystem,
20
- id: string,
21
- opts?: ResolveOptions,
22
- ): Promise<ResolveResult> {
23
- if (process.env.PARCEL_BUILD_ENV !== 'production') {
24
- // $FlowFixMe
25
- opts = opts || {};
26
- // $FlowFixMe
27
- opts.packageFilter = pkg => {
28
- if (pkg.name.startsWith('@parcel/') && pkg.name !== '@parcel/watcher') {
29
- if (pkg.source) {
30
- pkg.main = pkg.source;
31
- }
32
- }
33
- return pkg;
34
- };
35
- }
36
-
37
- let res = await resolveAsync(id, {
38
- ...opts,
39
- async readFile(filename, callback) {
40
- try {
41
- let res = await fs.readFile(filename);
42
- callback(null, res);
43
- } catch (err) {
44
- callback(err);
45
- }
46
- },
47
- async isFile(file, callback) {
48
- try {
49
- let stat = await fs.stat(file);
50
- callback(null, stat.isFile());
51
- } catch (err) {
52
- callback(null, false);
53
- }
54
- },
55
- async isDirectory(file, callback) {
56
- try {
57
- let stat = await fs.stat(file);
58
- callback(null, stat.isDirectory());
59
- } catch (err) {
60
- callback(null, false);
61
- }
62
- },
63
- });
64
-
65
- if (typeof res === 'string') {
66
- return {
67
- resolved: res,
68
- };
69
- }
70
-
71
- return {
72
- resolved: res[0],
73
- pkg: res[1],
74
- };
75
- }
76
-
77
- export function resolveSync(
78
- fs: FileSystem,
79
- id: string,
80
- opts?: ResolveOptions,
81
- ): ResolveResult {
82
- if (process.env.PARCEL_BUILD_ENV !== 'production') {
83
- // $FlowFixMe
84
- opts = opts || {};
85
- // $FlowFixMe
86
- opts.packageFilter = pkg => {
87
- if (pkg.name.startsWith('@parcel/') && pkg.name !== '@parcel/watcher') {
88
- if (pkg.source) {
89
- pkg.main = pkg.source;
90
- }
91
- }
92
- return pkg;
93
- };
94
- }
95
-
96
- // $FlowFixMe
97
- let res = _resolve.sync(id, {
98
- ...opts,
99
- readFileSync: (...args) => {
100
- return fs.readFileSync(...args);
101
- },
102
- isFile: file => {
103
- try {
104
- let stat = fs.statSync(file);
105
- return stat.isFile();
106
- } catch (err) {
107
- return false;
108
- }
109
- },
110
- isDirectory: file => {
111
- try {
112
- let stat = fs.statSync(file);
113
- return stat.isDirectory();
114
- } catch (err) {
115
- return false;
116
- }
117
- },
118
- });
119
-
120
- return {
121
- resolved: res,
122
- };
123
- }
@@ -1,22 +0,0 @@
1
- // @flow
2
-
3
- import {minify} from 'terser';
4
- import serialize from 'serialize-to-js';
5
-
6
- export default function serializeObject(
7
- obj: mixed,
8
- shouldMinify: boolean = false,
9
- ) {
10
- let code = `module.exports = ${serialize(obj)};`;
11
-
12
- if (shouldMinify) {
13
- let minified = minify(code);
14
- if (minified.error) {
15
- throw minified.error;
16
- }
17
-
18
- code = minified.code;
19
- }
20
-
21
- return code;
22
- }
@@ -1,7 +0,0 @@
1
- function hello() {
2
- var l = 'Hello',
3
- o = 'world';
4
- console.log(l + ' ' + o + '!');
5
- }
6
- hello();
7
- //# sourceMappingURL=main.min.js.map
@@ -1,37 +0,0 @@
1
- import assert from 'assert';
2
- import {matchSourceMappingURL} from '../src/loadSourceMapUrl';
3
- import fs from 'fs';
4
- import path from 'path';
5
-
6
- describe('loadSourceMap', () => {
7
- it('should not match sourceMappingURL when not at the end of the bundle', () => {
8
- // Code example taken from livescript.js (issue #2408 in parcel-bundler)
9
- // This snippet lead to JSAsset.js being mislead and incorrectly trying to
10
- // load (due to false-positive match) sourcemap before fix was introduced
11
- let code = fs.readFileSync(
12
- path.join(__dirname, './input/sourcemap/no-sourcemap.js'),
13
- 'utf-8',
14
- );
15
-
16
- assert(!matchSourceMappingURL(code));
17
- });
18
-
19
- it('should match referenced sourceMappingURL when correctly inserted at end of the bundle', () => {
20
- let code = fs.readFileSync(
21
- path.join(__dirname, './input/sourcemap/referenced.js'),
22
- 'utf-8',
23
- );
24
-
25
- assert(!!matchSourceMappingURL(code));
26
- });
27
-
28
- it('should match inline sourceMappingURL when correctly inserted at end of the bundle', () => {
29
- // inline source map taken from https://github.com/thlorenz/inline-source-map
30
- let code = fs.readFileSync(
31
- path.join(__dirname, './input/sourcemap/inline.js'),
32
- 'utf-8',
33
- );
34
-
35
- assert(!!matchSourceMappingURL(code));
36
- });
37
- });
@@ -1,104 +0,0 @@
1
- import assert from 'assert';
2
- import prettyError from '../src/prettyError';
3
-
4
- const message = 'Error Message!';
5
- const fileName = 'Test.js';
6
- const codeFrame = '<code>frame</code>';
7
- const stack =
8
- 'Error: Uh-oh. Something went wrong. Line 88. \n Oh no. Something else went wrong. Line 77 \n';
9
-
10
- describe('prettyError', () => {
11
- it('should handle passing error as string', () => {
12
- const err = prettyError(message);
13
-
14
- assert.equal(err.message, message);
15
- assert.equal(err.stack, undefined);
16
- });
17
-
18
- it('should handle passing error as object', () => {
19
- const err = prettyError({message});
20
-
21
- assert.equal(err.message, message);
22
- assert.equal(err.stack, undefined);
23
- });
24
-
25
- it('should handle unknown input', () => {
26
- const err = prettyError(Number.NaN);
27
-
28
- assert(err.message.length); // non-empty error message
29
- assert.equal(err.stack, undefined);
30
- });
31
-
32
- it('should prepend fileName', () => {
33
- const err = prettyError({
34
- message,
35
- fileName,
36
- });
37
-
38
- assert(err.message.startsWith(fileName));
39
- assert.equal(err.stack, undefined);
40
- });
41
-
42
- it('should prepend line and column location', () => {
43
- const err = prettyError({
44
- message,
45
- fileName,
46
- loc: {
47
- line: 1,
48
- column: 10,
49
- },
50
- });
51
-
52
- assert(err.message.startsWith(`${fileName}:1:10`));
53
- assert.equal(err.stack, undefined);
54
- });
55
-
56
- it('should support providing a codeFrame as stack', () => {
57
- const err = prettyError({
58
- message,
59
- stack,
60
- codeFrame: codeFrame,
61
- });
62
-
63
- assert.equal(err.message, message);
64
- assert.equal(err.stack, codeFrame);
65
- });
66
-
67
- it('should support highlightedCodeFrame when opts.color is true', () => {
68
- let err = prettyError(
69
- {
70
- message,
71
- stack,
72
- codeFrame: '<not>a code frame</not>',
73
- highlightedCodeFrame: codeFrame,
74
- },
75
- {color: true},
76
- );
77
-
78
- assert.equal(err.message, message);
79
- assert.equal(err.stack, codeFrame);
80
-
81
- err = prettyError(
82
- {
83
- message,
84
- stack,
85
- codeFrame: codeFrame,
86
- highlightedCodeFrame: '<not>a code frame</not>',
87
- },
88
- {color: false},
89
- );
90
-
91
- assert.equal(err.message, message);
92
- assert.equal(err.stack, codeFrame);
93
- });
94
-
95
- it('should support stack', () => {
96
- const err = prettyError({
97
- message,
98
- stack,
99
- });
100
-
101
- assert.equal(err.message, message);
102
- assert(err.stack.includes('Line'));
103
- });
104
- });