@atlaspack/utils 2.14.5-canary.14 → 2.14.5-canary.140

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 (147) hide show
  1. package/CHANGELOG.md +146 -0
  2. package/benchmark.js +23 -0
  3. package/lib/DefaultMap.d.ts +13 -0
  4. package/lib/DefaultMap.js +42 -0
  5. package/lib/Deferred.d.ts +8 -0
  6. package/lib/Deferred.js +30 -0
  7. package/lib/PromiseQueue.d.ts +25 -0
  8. package/lib/PromiseQueue.js +112 -0
  9. package/lib/TapStream.d.ts +6 -0
  10. package/lib/TapStream.js +34 -0
  11. package/lib/alternatives.d.ts +3 -0
  12. package/lib/alternatives.js +116 -0
  13. package/lib/ansi-html.d.ts +1 -0
  14. package/lib/ansi-html.js +20 -0
  15. package/lib/blob.d.ts +4 -0
  16. package/lib/blob.js +40 -0
  17. package/lib/bundle-url.d.ts +4 -0
  18. package/lib/bundle-url.js +34 -0
  19. package/lib/collection.d.ts +33 -0
  20. package/lib/collection.js +111 -0
  21. package/lib/config.d.ts +17 -0
  22. package/lib/config.js +174 -0
  23. package/lib/countLines.d.ts +1 -0
  24. package/lib/countLines.js +15 -0
  25. package/lib/debounce.d.ts +1 -0
  26. package/lib/debounce.js +18 -0
  27. package/lib/debug-tools.d.ts +6 -0
  28. package/lib/debug-tools.js +37 -0
  29. package/lib/dependency-location.d.ts +14 -0
  30. package/lib/dependency-location.js +21 -0
  31. package/lib/escape-html.d.ts +1 -0
  32. package/lib/escape-html.js +22 -0
  33. package/lib/generateBuildMetrics.d.ts +18 -0
  34. package/lib/generateBuildMetrics.js +121 -0
  35. package/lib/generateCertificate.d.ts +5 -0
  36. package/lib/generateCertificate.js +129 -0
  37. package/lib/getCertificate.d.ts +6 -0
  38. package/lib/getCertificate.js +18 -0
  39. package/lib/getExisting.d.ts +8 -0
  40. package/lib/getExisting.js +25 -0
  41. package/lib/getModuleParts.d.ts +4 -0
  42. package/lib/getModuleParts.js +30 -0
  43. package/lib/getRootDir.d.ts +2 -0
  44. package/lib/getRootDir.js +52 -0
  45. package/lib/glob.d.ts +10 -0
  46. package/lib/glob.js +118 -0
  47. package/lib/hash.d.ts +7 -0
  48. package/lib/hash.js +50 -0
  49. package/lib/http-server.d.ts +19 -0
  50. package/lib/http-server.js +85 -0
  51. package/lib/index.d.ts +48 -0
  52. package/lib/index.js +635 -37310
  53. package/lib/is-url.d.ts +1 -0
  54. package/lib/is-url.js +24 -0
  55. package/lib/isDirectoryInside.d.ts +2 -0
  56. package/lib/isDirectoryInside.js +18 -0
  57. package/lib/objectHash.d.ts +3 -0
  58. package/lib/objectHash.js +26 -0
  59. package/lib/openInBrowser.d.ts +1 -0
  60. package/lib/openInBrowser.js +74 -0
  61. package/lib/parseCSSImport.d.ts +1 -0
  62. package/lib/parseCSSImport.js +15 -0
  63. package/lib/path.d.ts +8 -0
  64. package/lib/path.js +39 -0
  65. package/lib/prettifyTime.d.ts +1 -0
  66. package/lib/prettifyTime.js +9 -0
  67. package/lib/prettyDiagnostic.d.ts +17 -0
  68. package/lib/prettyDiagnostic.js +134 -0
  69. package/lib/progress-message.d.ts +3 -0
  70. package/lib/progress-message.js +36 -0
  71. package/lib/relativeBundlePath.d.ts +4 -0
  72. package/lib/relativeBundlePath.js +22 -0
  73. package/lib/relativeUrl.d.ts +1 -0
  74. package/lib/relativeUrl.js +24 -0
  75. package/lib/replaceBundleReferences.d.ts +39 -0
  76. package/lib/replaceBundleReferences.js +199 -0
  77. package/lib/schema.d.ts +107 -0
  78. package/lib/schema.js +355 -0
  79. package/lib/shared-buffer.d.ts +2 -0
  80. package/lib/shared-buffer.js +31 -0
  81. package/lib/sourcemap.d.ts +16 -0
  82. package/lib/sourcemap.js +127 -0
  83. package/lib/stream.d.ts +8 -0
  84. package/lib/stream.js +76 -0
  85. package/lib/throttle.d.ts +1 -0
  86. package/lib/throttle.js +15 -0
  87. package/lib/urlJoin.d.ts +5 -0
  88. package/lib/urlJoin.js +35 -0
  89. package/package.json +24 -17
  90. package/src/{DefaultMap.js → DefaultMap.ts} +8 -12
  91. package/src/Deferred.ts +26 -0
  92. package/src/{PromiseQueue.js → PromiseQueue.ts} +40 -35
  93. package/src/{TapStream.js → TapStream.ts} +8 -7
  94. package/src/{alternatives.js → alternatives.ts} +14 -15
  95. package/src/{ansi-html.js → ansi-html.ts} +1 -1
  96. package/src/{blob.js → blob.ts} +2 -4
  97. package/src/{bundle-url.js → bundle-url.ts} +3 -5
  98. package/src/{collection.js → collection.ts} +23 -20
  99. package/src/{config.js → config.ts} +18 -19
  100. package/src/{countLines.js → countLines.ts} +0 -2
  101. package/src/{debounce.js → debounce.ts} +3 -5
  102. package/src/debug-tools.ts +43 -0
  103. package/src/{dependency-location.js → dependency-location.ts} +15 -11
  104. package/src/{escape-html.js → escape-html.ts} +5 -3
  105. package/src/{generateBuildMetrics.js → generateBuildMetrics.ts} +16 -18
  106. package/src/{generateCertificate.js → generateCertificate.ts} +7 -5
  107. package/src/{getCertificate.js → getCertificate.ts} +5 -3
  108. package/src/{getExisting.js → getExisting.ts} +4 -3
  109. package/src/{getModuleParts.js → getModuleParts.ts} +3 -2
  110. package/src/{getRootDir.js → getRootDir.ts} +0 -2
  111. package/src/{glob.js → glob.ts} +14 -10
  112. package/src/{hash.js → hash.ts} +22 -17
  113. package/src/{http-server.js → http-server.ts} +32 -38
  114. package/src/{index.js → index.ts} +13 -9
  115. package/src/{is-url.js → is-url.ts} +1 -2
  116. package/src/{isDirectoryInside.js → isDirectoryInside.ts} +0 -1
  117. package/src/{objectHash.js → objectHash.ts} +1 -4
  118. package/src/{openInBrowser.js → openInBrowser.ts} +2 -4
  119. package/src/{parseCSSImport.js → parseCSSImport.ts} +0 -2
  120. package/src/{path.js → path.ts} +1 -3
  121. package/src/{prettifyTime.js → prettifyTime.ts} +0 -2
  122. package/src/{prettyDiagnostic.js → prettyDiagnostic.ts} +22 -20
  123. package/src/progress-message.ts +38 -0
  124. package/src/{relativeBundlePath.js → relativeBundlePath.ts} +3 -3
  125. package/src/{relativeUrl.js → relativeUrl.ts} +0 -1
  126. package/src/{replaceBundleReferences.js → replaceBundleReferences.ts} +54 -36
  127. package/src/{schema.js → schema.ts} +158 -141
  128. package/src/{shared-buffer.js → shared-buffer.ts} +5 -3
  129. package/src/{sourcemap.js → sourcemap.ts} +16 -6
  130. package/src/{stream.js → stream.ts} +29 -21
  131. package/src/throttle.ts +13 -0
  132. package/src/{urlJoin.js → urlJoin.ts} +1 -3
  133. package/test/{DefaultMap.test.js → DefaultMap.test.ts} +4 -6
  134. package/test/{PromiseQueue.test.js → PromiseQueue.test.ts} +5 -6
  135. package/test/{collection.test.js → collection.test.ts} +0 -2
  136. package/test/{config.test.js → config.test.ts} +0 -3
  137. package/test/{objectHash.test.js → objectHash.test.ts} +4 -5
  138. package/test/{prettifyTime.test.js → prettifyTime.test.ts} +0 -1
  139. package/test/{replaceBundleReferences.test.js → replaceBundleReferences.test.ts} +0 -32
  140. package/test/{sourcemap.test.js → sourcemap.test.ts} +0 -1
  141. package/test/{throttle.test.js → throttle.test.ts} +1 -3
  142. package/test/{urlJoin.test.js → urlJoin.test.ts} +0 -2
  143. package/tsconfig.json +4 -0
  144. package/lib/index.js.map +0 -1
  145. package/src/Deferred.js +0 -23
  146. package/src/progress-message.js +0 -22
  147. package/src/throttle.js +0 -15
package/CHANGELOG.md CHANGED
@@ -1,5 +1,151 @@
1
1
  # @atlaspack/utils
2
2
 
3
+ ## 2.17.3
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies [[`069de47`](https://github.com/atlassian-labs/atlaspack/commit/069de478e64fb5889f6f2ce023eb510782767fbd)]:
8
+ - @atlaspack/feature-flags@2.20.0
9
+
10
+ ## 2.17.2
11
+
12
+ ### Patch Changes
13
+
14
+ - Updated dependencies [[`1c7865a`](https://github.com/atlassian-labs/atlaspack/commit/1c7865a64451116d94015e248302435839d347c0), [`a0b959f`](https://github.com/atlassian-labs/atlaspack/commit/a0b959fbf61fc3f820ff03c7e8988945fe40a91a)]:
15
+ - @atlaspack/feature-flags@2.19.2
16
+
17
+ ## 2.17.1
18
+
19
+ ### Patch Changes
20
+
21
+ - Updated dependencies [[`13aef17`](https://github.com/atlassian-labs/atlaspack/commit/13aef177eea289a6e40d2113b5ec1ac9be18a33d)]:
22
+ - @atlaspack/feature-flags@2.19.1
23
+
24
+ ## 2.17.0
25
+
26
+ ### Minor Changes
27
+
28
+ - [#640](https://github.com/atlassian-labs/atlaspack/pull/640) [`dbb4072`](https://github.com/atlassian-labs/atlaspack/commit/dbb40721ebeb45990a14ba04e6b44e7f836fb32d) Thanks [@JakeLane](https://github.com/JakeLane)! - Clean up conditional bundling feature flags
29
+
30
+ - [#693](https://github.com/atlassian-labs/atlaspack/pull/693) [`18a57cf`](https://github.com/atlassian-labs/atlaspack/commit/18a57cf8a4789b2de5ad8e2676f317a26cc91417) Thanks [@mattcompiles](https://github.com/mattcompiles)! - These packages should have been bumped in [pull request 691](https://github.com/atlassian-labs/atlaspack/pull/691).
31
+
32
+ Rectifying by creating a new changeset now.
33
+
34
+ ### Patch Changes
35
+
36
+ - [#645](https://github.com/atlassian-labs/atlaspack/pull/645) [`de23e0c`](https://github.com/atlassian-labs/atlaspack/commit/de23e0ce49d5504fe3947ac26640a3d951087da3) Thanks [@alshdavid](https://github.com/alshdavid)! - Updated build system and added some extra test-specific code
37
+
38
+ - [#682](https://github.com/atlassian-labs/atlaspack/pull/682) [`a5ed1b4`](https://github.com/atlassian-labs/atlaspack/commit/a5ed1b414498560f393ff491af4da25b6e8dde56) Thanks [@alshdavid](https://github.com/alshdavid)! - Updating build system
39
+
40
+ - Updated dependencies [[`dbb4072`](https://github.com/atlassian-labs/atlaspack/commit/dbb40721ebeb45990a14ba04e6b44e7f836fb32d), [`becf977`](https://github.com/atlassian-labs/atlaspack/commit/becf977f625d5ee46dae3d4c679f173bf5f40cc0), [`becf977`](https://github.com/atlassian-labs/atlaspack/commit/becf977f625d5ee46dae3d4c679f173bf5f40cc0), [`c4415a4`](https://github.com/atlassian-labs/atlaspack/commit/c4415a455543d984ca28452c2cb87a794d22497c), [`f0f7c71`](https://github.com/atlassian-labs/atlaspack/commit/f0f7c7168a1d3d18c6f30d2daed611275692b7c5), [`de23e0c`](https://github.com/atlassian-labs/atlaspack/commit/de23e0ce49d5504fe3947ac26640a3d951087da3), [`18a57cf`](https://github.com/atlassian-labs/atlaspack/commit/18a57cf8a4789b2de5ad8e2676f317a26cc91417), [`a5ed1b4`](https://github.com/atlassian-labs/atlaspack/commit/a5ed1b414498560f393ff491af4da25b6e8dde56)]:
41
+ - @atlaspack/feature-flags@2.19.0
42
+ - @atlaspack/rust@3.4.1
43
+ - @atlaspack/codeframe@2.13.4
44
+ - @atlaspack/logger@2.14.13
45
+
46
+ ## 2.16.1
47
+
48
+ ### Patch Changes
49
+
50
+ - Updated dependencies [[`c75bf55`](https://github.com/atlassian-labs/atlaspack/commit/c75bf553fff4decc285b5fd499a275853b18f8f2)]:
51
+ - @atlaspack/rust@3.4.0
52
+ - @atlaspack/logger@2.14.12
53
+
54
+ ## 2.16.0
55
+
56
+ ### Minor Changes
57
+
58
+ - [#659](https://github.com/atlassian-labs/atlaspack/pull/659) [`30ee2cf`](https://github.com/atlassian-labs/atlaspack/commit/30ee2cfcd34cf2646ded0eda13fdb80a2a5de529) Thanks [@benjervis](https://github.com/benjervis)! - Add the debug-tools system for altering the behaviour when attempting to identify issues.
59
+
60
+ ### Patch Changes
61
+
62
+ - Updated dependencies [[`e8a60ff`](https://github.com/atlassian-labs/atlaspack/commit/e8a60ffbea41caef265786bbf73349771760081c)]:
63
+ - @atlaspack/feature-flags@2.18.4
64
+
65
+ ## 2.15.3
66
+
67
+ ### Patch Changes
68
+
69
+ - Updated dependencies [[`5ded263`](https://github.com/atlassian-labs/atlaspack/commit/5ded263c7f11b866e8885b81c73e20dd060b25be)]:
70
+ - @atlaspack/feature-flags@2.18.3
71
+
72
+ ## 2.15.2
73
+
74
+ ### Patch Changes
75
+
76
+ - Updated dependencies [[`644b157`](https://github.com/atlassian-labs/atlaspack/commit/644b157dee72a871acc2d0facf0b87b8eea51956)]:
77
+ - @atlaspack/feature-flags@2.18.2
78
+
79
+ ## 2.15.1
80
+
81
+ ### Patch Changes
82
+
83
+ - Updated dependencies [[`ef3d622`](https://github.com/atlassian-labs/atlaspack/commit/ef3d6228f4e006702198a19c61e051d194d325cb), [`26aa9c5`](https://github.com/atlassian-labs/atlaspack/commit/26aa9c599d2be45ce1438a74c5fa22f39b9b554b), [`0501255`](https://github.com/atlassian-labs/atlaspack/commit/05012550da35b05ce7d356a8cc29311e7f9afdca)]:
84
+ - @atlaspack/logger@2.14.11
85
+ - @atlaspack/feature-flags@2.18.1
86
+
87
+ ## 2.15.0
88
+
89
+ ### Minor Changes
90
+
91
+ - [#622](https://github.com/atlassian-labs/atlaspack/pull/622) [`e39c6cf`](https://github.com/atlassian-labs/atlaspack/commit/e39c6cf05f7e95ce5420dbcea66f401b1cbd397c) Thanks [@benjervis](https://github.com/benjervis)! - Add the `setIntersectStatic` method that doesn't mutate the passed in Sets
92
+
93
+ ### Patch Changes
94
+
95
+ - Updated dependencies [[`10fbcfb`](https://github.com/atlassian-labs/atlaspack/commit/10fbcfbfa49c7a83da5d7c40983e36e87f524a75), [`85c52d3`](https://github.com/atlassian-labs/atlaspack/commit/85c52d3f7717b3c84a118d18ab98cfbfd71dcbd2)]:
96
+ - @atlaspack/feature-flags@2.18.0
97
+
98
+ ## 2.14.11
99
+
100
+ ### Patch Changes
101
+
102
+ - Updated dependencies [[`73ea3c4`](https://github.com/atlassian-labs/atlaspack/commit/73ea3c4d85d4401fdd15abcbf988237e890e7ad3), [`b1b3693`](https://github.com/atlassian-labs/atlaspack/commit/b1b369317c66f8a431c170df2ebba4fa5b2e38ef)]:
103
+ - @atlaspack/feature-flags@2.17.0
104
+
105
+ ## 2.14.10
106
+
107
+ ### Patch Changes
108
+
109
+ - Updated dependencies [[`35fdd4b`](https://github.com/atlassian-labs/atlaspack/commit/35fdd4b52da0af20f74667f7b8adfb2f90279b7c), [`6dd4ccb`](https://github.com/atlassian-labs/atlaspack/commit/6dd4ccb753541de32322d881f973d571dd57e4ca)]:
110
+ - @atlaspack/rust@3.3.5
111
+ - @atlaspack/logger@2.14.10
112
+
113
+ ## 2.14.9
114
+
115
+ ### Patch Changes
116
+
117
+ - Updated dependencies [[`124b7ff`](https://github.com/atlassian-labs/atlaspack/commit/124b7fff44f71aac9fbad289a9a9509b3dfc9aaa), [`e052521`](https://github.com/atlassian-labs/atlaspack/commit/e0525210850ed1606146eb86991049cf567c5dec), [`15c6d70`](https://github.com/atlassian-labs/atlaspack/commit/15c6d7000bd89da876bc590aa75b17a619a41896), [`e4d966c`](https://github.com/atlassian-labs/atlaspack/commit/e4d966c3c9c4292c5013372ae65b10d19d4bacc6), [`209692f`](https://github.com/atlassian-labs/atlaspack/commit/209692ffb11eae103a0d65c5e1118a5aa1625818), [`42a775d`](https://github.com/atlassian-labs/atlaspack/commit/42a775de8eec638ad188f3271964170d8c04d84b), [`29c2f10`](https://github.com/atlassian-labs/atlaspack/commit/29c2f106de9679adfb5afa04e1910471dc65a427), [`f4da1e1`](https://github.com/atlassian-labs/atlaspack/commit/f4da1e120e73eeb5e8b8927f05e88f04d6148c7b), [`1ef91fc`](https://github.com/atlassian-labs/atlaspack/commit/1ef91fcc863fdd2831511937083dbbc1263b3d9d)]:
118
+ - @atlaspack/rust@3.3.4
119
+ - @atlaspack/feature-flags@2.16.0
120
+ - @atlaspack/logger@2.14.9
121
+
122
+ ## 2.14.8
123
+
124
+ ### Patch Changes
125
+
126
+ - Updated dependencies [[`30f6017`](https://github.com/atlassian-labs/atlaspack/commit/30f60175ba4d272c5fc193973c63bc298584775b), [`1ab0a27`](https://github.com/atlassian-labs/atlaspack/commit/1ab0a275aeca40350415e2b03e7440d1dddc6228), [`b8a4ae8`](https://github.com/atlassian-labs/atlaspack/commit/b8a4ae8f83dc0a83d8b145c5f729936ce52080a3)]:
127
+ - @atlaspack/feature-flags@2.15.1
128
+ - @atlaspack/rust@3.3.3
129
+ - @atlaspack/logger@2.14.8
130
+
131
+ ## 2.14.7
132
+
133
+ ### Patch Changes
134
+
135
+ - Updated dependencies [[`a1773d2`](https://github.com/atlassian-labs/atlaspack/commit/a1773d2a62d0ef7805ac7524621dcabcc1afe929), [`556d6ab`](https://github.com/atlassian-labs/atlaspack/commit/556d6ab8ede759fa7f37fcd3f4da336ef1c55e8f)]:
136
+ - @atlaspack/feature-flags@2.15.0
137
+ - @atlaspack/logger@2.14.7
138
+ - @atlaspack/rust@3.3.2
139
+
140
+ ## 2.14.6
141
+
142
+ ### Patch Changes
143
+
144
+ - Updated dependencies [[`e0f5337`](https://github.com/atlassian-labs/atlaspack/commit/e0f533757bd1019dbd108a04952c87da15286e09)]:
145
+ - @atlaspack/feature-flags@2.14.4
146
+ - @atlaspack/rust@3.3.1
147
+ - @atlaspack/logger@2.14.6
148
+
3
149
  ## 2.14.5
4
150
 
5
151
  ### Patch Changes
package/benchmark.js ADDED
@@ -0,0 +1,23 @@
1
+ require('@atlaspack/babel-register');
2
+ const b = require('benny');
3
+
4
+ const {setIntersect, setIntersectStatic} = require('./src/collection.js');
5
+
6
+ const setA = new Set([
7
+ 23, 25, 29, 29, 12, 16, 14, 23, 18, 19, 16, 24, 9, 29, 26,
8
+ ]);
9
+ const setB = new Set([24, 1, 3, 6, 1, 3, 1, 5, 20, 15, 21, 23, 13, 16, 6]);
10
+
11
+ b.suite(
12
+ 'Collection - set intersection',
13
+ b.add('Control', () => {
14
+ const setClone = new Set(setA);
15
+ return () => setIntersect(setClone, setB);
16
+ }),
17
+ b.add('setIntersectStatic', () => {
18
+ setIntersectStatic(setA, setB);
19
+ }),
20
+ b.configure({minSamples: 100}),
21
+ b.cycle(),
22
+ b.complete(),
23
+ );
@@ -0,0 +1,13 @@
1
+ export declare class DefaultMap<K, V> extends Map<K, V> {
2
+ _getDefault: (arg1: K) => V;
3
+ constructor(getDefault: (arg1: K) => V, entries?: Iterable<[K, V]>);
4
+ get(key: K): V;
5
+ }
6
+ interface Key {
7
+ }
8
+ export declare class DefaultWeakMap<K extends Key, V> extends WeakMap<K, V> {
9
+ _getDefault: (arg1: K) => V;
10
+ constructor(getDefault: (arg1: K) => V, entries?: Iterable<[K, V]>);
11
+ get(key: K): V;
12
+ }
13
+ export {};
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.DefaultWeakMap = exports.DefaultMap = void 0;
7
+ class DefaultMap extends Map {
8
+ constructor(getDefault, entries) {
9
+ super(entries);
10
+ this._getDefault = getDefault;
11
+ }
12
+ get(key) {
13
+ let ret;
14
+ if (this.has(key)) {
15
+ ret = super.get(key);
16
+ } else {
17
+ ret = this._getDefault(key);
18
+ this.set(key, ret);
19
+ }
20
+ return ret;
21
+ }
22
+ }
23
+ exports.DefaultMap = DefaultMap;
24
+ // Duplicated from DefaultMap implementation for Flow
25
+ // Roughly mirrors https://github.com/facebook/flow/blob/2eb5a78d92c167117ba9caae070afd2b9f598599/lib/core.js#L617
26
+ class DefaultWeakMap extends WeakMap {
27
+ constructor(getDefault, entries) {
28
+ super(entries);
29
+ this._getDefault = getDefault;
30
+ }
31
+ get(key) {
32
+ let ret;
33
+ if (this.has(key)) {
34
+ ret = super.get(key);
35
+ } else {
36
+ ret = this._getDefault(key);
37
+ this.set(key, ret);
38
+ }
39
+ return ret;
40
+ }
41
+ }
42
+ exports.DefaultWeakMap = DefaultWeakMap;
@@ -0,0 +1,8 @@
1
+ export type Deferred<T> = {
2
+ resolve(arg1: T): void;
3
+ reject(arg1: unknown): void;
4
+ };
5
+ export declare function makeDeferredWithPromise<T>(): {
6
+ deferred: Deferred<T>;
7
+ promise: Promise<T>;
8
+ };
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.makeDeferredWithPromise = makeDeferredWithPromise;
7
+ function _assert() {
8
+ const data = _interopRequireDefault(require("assert"));
9
+ _assert = function () {
10
+ return data;
11
+ };
12
+ return data;
13
+ }
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
+ function makeDeferredWithPromise() {
16
+ let deferred;
17
+ let promise = new Promise((resolve, reject) => {
18
+ deferred = {
19
+ resolve,
20
+ reject
21
+ };
22
+ });
23
+
24
+ // Promise constructor callback executes synchronously, so this is defined
25
+ (0, _assert().default)(deferred != null);
26
+ return {
27
+ deferred,
28
+ promise
29
+ };
30
+ }
@@ -0,0 +1,25 @@
1
+ import { type Deferred } from './Deferred';
2
+ type PromiseQueueOpts = {
3
+ maxConcurrent: number;
4
+ };
5
+ export default class PromiseQueue<T> {
6
+ _deferred: Deferred<Array<T>> | null | undefined;
7
+ _maxConcurrent: number;
8
+ _numRunning: number;
9
+ _queue: Array<() => Promise<void>>;
10
+ _runPromise: Promise<Array<T>> | null | undefined;
11
+ _error: unknown;
12
+ _count: number;
13
+ _results: Array<T>;
14
+ _addSubscriptions: Set<() => void>;
15
+ constructor(opts?: PromiseQueueOpts);
16
+ getNumWaiting(): number;
17
+ add(fn: () => Promise<T>): void;
18
+ subscribeToAdd(fn: () => void): () => void;
19
+ run(): Promise<Array<T>>;
20
+ _next(): Promise<void>;
21
+ _runFn(fn: () => unknown): Promise<void>;
22
+ _resetState(): void;
23
+ _done(): void;
24
+ }
25
+ export {};
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _Deferred = require("./Deferred");
8
+ class PromiseQueue {
9
+ _numRunning = 0;
10
+ _queue = [];
11
+ _runPromise = null;
12
+ _count = 0;
13
+ _results = [];
14
+ _addSubscriptions = new Set();
15
+ constructor(opts = {
16
+ maxConcurrent: Infinity
17
+ }) {
18
+ if (opts.maxConcurrent <= 0) {
19
+ throw new TypeError('maxConcurrent must be a positive, non-zero value');
20
+ }
21
+ this._maxConcurrent = opts.maxConcurrent;
22
+ }
23
+ getNumWaiting() {
24
+ return this._queue.length;
25
+ }
26
+ add(fn) {
27
+ new Promise((resolve, reject) => {
28
+ let i = this._count++;
29
+ let wrapped = () => fn().then(result => {
30
+ this._results[i] = result;
31
+ resolve(result);
32
+ }, err => {
33
+ reject(err);
34
+ throw err;
35
+ });
36
+ this._queue.push(wrapped);
37
+ for (const addFn of this._addSubscriptions) {
38
+ addFn();
39
+ }
40
+ if (this._numRunning > 0 && this._numRunning < this._maxConcurrent) {
41
+ this._next();
42
+ }
43
+ }).catch(() => {});
44
+ }
45
+ subscribeToAdd(fn) {
46
+ this._addSubscriptions.add(fn);
47
+ return () => {
48
+ this._addSubscriptions.delete(fn);
49
+ };
50
+ }
51
+ run() {
52
+ if (this._runPromise != null) {
53
+ return this._runPromise;
54
+ }
55
+ if (this._queue.length === 0) {
56
+ return Promise.resolve([]);
57
+ }
58
+ let {
59
+ deferred,
60
+ promise
61
+ } = (0, _Deferred.makeDeferredWithPromise)();
62
+ this._deferred = deferred;
63
+ this._runPromise = promise;
64
+ while (this._queue.length && this._numRunning < this._maxConcurrent) {
65
+ this._next();
66
+ }
67
+ return promise;
68
+ }
69
+ async _next() {
70
+ let fn = this._queue.shift();
71
+ await this._runFn(fn);
72
+ if (this._queue.length) {
73
+ this._next();
74
+ } else if (this._numRunning === 0) {
75
+ this._done();
76
+ }
77
+ }
78
+ async _runFn(fn) {
79
+ this._numRunning++;
80
+ try {
81
+ await fn();
82
+ } catch (e) {
83
+ // Only store the first error that occurs.
84
+ // We don't reject immediately so that any other concurrent
85
+ // requests have time to complete.
86
+ if (this._error == null) {
87
+ this._error = e;
88
+ }
89
+ } finally {
90
+ this._numRunning--;
91
+ }
92
+ }
93
+ _resetState() {
94
+ this._queue = [];
95
+ this._count = 0;
96
+ this._results = [];
97
+ this._runPromise = null;
98
+ this._numRunning = 0;
99
+ this._deferred = null;
100
+ }
101
+ _done() {
102
+ if (this._deferred != null) {
103
+ if (this._error != null) {
104
+ this._deferred.reject(this._error);
105
+ } else {
106
+ this._deferred.resolve(this._results);
107
+ }
108
+ }
109
+ this._resetState();
110
+ }
111
+ }
112
+ exports.default = PromiseQueue;
@@ -0,0 +1,6 @@
1
+ import { Transform } from 'stream';
2
+ export default class TapStream extends Transform {
3
+ _tap: (arg1: Buffer) => unknown;
4
+ constructor(tap: (arg1: Buffer) => unknown, options: unknown);
5
+ _transform(chunk: Buffer | string, encoding: string, callback: (err?: Error | null | undefined, chunk?: Buffer | string) => unknown): void;
6
+ }
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ function _stream() {
8
+ const data = require("stream");
9
+ _stream = function () {
10
+ return data;
11
+ };
12
+ return data;
13
+ }
14
+ /*
15
+ * "Taps" into the contents of a flowing stream, yielding chunks to the passed
16
+ * callback. Continues to pass data chunks down the stream.
17
+ */
18
+ class TapStream extends _stream().Transform {
19
+ constructor(tap, options) {
20
+ super({
21
+ ...options
22
+ });
23
+ this._tap = tap;
24
+ }
25
+ _transform(chunk, encoding, callback) {
26
+ try {
27
+ this._tap(Buffer.from(chunk));
28
+ callback(null, chunk);
29
+ } catch (err) {
30
+ callback(err);
31
+ }
32
+ }
33
+ }
34
+ exports.default = TapStream;
@@ -0,0 +1,3 @@
1
+ import type { FileSystem } from '@atlaspack/types';
2
+ export declare function findAlternativeNodeModules(fs: FileSystem, moduleName: string, dir: string): Promise<Array<string>>;
3
+ export declare function findAlternativeFiles(fs: FileSystem, fileSpecifier: string, dir: string, projectRoot: string, leadingDotSlash?: boolean, includeDirectories?: boolean, includeExtension?: boolean): Promise<Array<string>>;
@@ -0,0 +1,116 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.findAlternativeFiles = findAlternativeFiles;
7
+ exports.findAlternativeNodeModules = findAlternativeNodeModules;
8
+ function _path() {
9
+ const data = _interopRequireDefault(require("path"));
10
+ _path = function () {
11
+ return data;
12
+ };
13
+ return data;
14
+ }
15
+ var _schema = require("./schema");
16
+ var _path2 = require("./path");
17
+ var _config = require("./config");
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+ async function findAlternativeNodeModules(fs, moduleName, dir) {
20
+ let potentialModules = [];
21
+ let root = _path().default.parse(dir).root;
22
+ let isOrganisationModule = moduleName.startsWith('@');
23
+ while (dir !== root) {
24
+ // Skip node_modules directories
25
+ if (_path().default.basename(dir) === 'node_modules') {
26
+ dir = _path().default.dirname(dir);
27
+ }
28
+ try {
29
+ let modulesDir = _path().default.join(dir, 'node_modules');
30
+ let stats = await fs.stat(modulesDir);
31
+ if (stats.isDirectory()) {
32
+ let dirContent = (await fs.readdir(modulesDir)).sort();
33
+
34
+ // Filter out the modules that interest us
35
+ let modules = dirContent.filter(i => isOrganisationModule ? i.startsWith('@') : !i.startsWith('@'));
36
+
37
+ // If it's an organisation module, loop through all the modules of that organisation
38
+ if (isOrganisationModule) {
39
+ await Promise.all(modules.map(async item => {
40
+ let orgDirPath = _path().default.join(modulesDir, item);
41
+ let orgDirContent = (await fs.readdir(orgDirPath)).sort();
42
+
43
+ // Add all org packages
44
+ potentialModules.push(...orgDirContent.map(i => `${item}/${i}`));
45
+ }));
46
+ } else {
47
+ potentialModules.push(...modules);
48
+ }
49
+ }
50
+ } catch (err) {
51
+ // ignore
52
+ }
53
+
54
+ // Move up a directory
55
+ dir = _path().default.dirname(dir);
56
+ }
57
+ return (0, _schema.fuzzySearch)(potentialModules.sort(), moduleName).slice(0, 2);
58
+ }
59
+ async function findAllFilesUp({
60
+ fs,
61
+ dir,
62
+ root,
63
+ basedir,
64
+ maxlength,
65
+ collected,
66
+ leadingDotSlash = true,
67
+ includeDirectories = true
68
+ }) {
69
+ let dirContent = (await fs.readdir(dir)).sort();
70
+ return Promise.all(dirContent.map(async item => {
71
+ let fullPath = _path().default.join(dir, item);
72
+ let relativeFilePath = (0, _path2.relativePath)(basedir, fullPath, leadingDotSlash);
73
+ if (relativeFilePath.length < maxlength) {
74
+ let stats = await fs.stat(fullPath);
75
+ let isDir = stats.isDirectory();
76
+ if (isDir && includeDirectories || stats.isFile()) {
77
+ collected.push(relativeFilePath);
78
+ }
79
+
80
+ // If it's a directory, run over each item within said directory...
81
+ if (isDir) {
82
+ return findAllFilesUp({
83
+ fs,
84
+ dir: fullPath,
85
+ root,
86
+ basedir,
87
+ maxlength,
88
+ collected
89
+ });
90
+ }
91
+ }
92
+ }));
93
+ }
94
+ async function findAlternativeFiles(fs, fileSpecifier, dir, projectRoot, leadingDotSlash = true, includeDirectories = true, includeExtension = false) {
95
+ let potentialFiles = [];
96
+ // Find our root, we won't recommend files above the package root as that's bad practise
97
+ let pkg = await (0, _config.resolveConfig)(fs, _path().default.join(dir, 'index'), ['package.json'], projectRoot);
98
+ let pkgRoot = pkg ? _path().default.dirname(pkg) : projectRoot;
99
+ await findAllFilesUp({
100
+ fs,
101
+ dir: pkgRoot,
102
+ root: pkgRoot,
103
+ basedir: dir,
104
+ maxlength: fileSpecifier.length + 10,
105
+ collected: potentialFiles,
106
+ leadingDotSlash,
107
+ includeDirectories
108
+ });
109
+ if (_path().default.extname(fileSpecifier) === '' && !includeExtension) {
110
+ potentialFiles = potentialFiles.map(p => {
111
+ let ext = _path().default.extname(p);
112
+ return ext.length > 0 ? p.slice(0, -ext.length) : p;
113
+ });
114
+ }
115
+ return (0, _schema.fuzzySearch)(potentialFiles.sort(), fileSpecifier).slice(0, 2);
116
+ }
@@ -0,0 +1 @@
1
+ export declare function ansiHtml(ansi: string): string;
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.ansiHtml = ansiHtml;
7
+ function _ansiHtmlCommunity() {
8
+ const data = _interopRequireDefault(require("ansi-html-community"));
9
+ _ansiHtmlCommunity = function () {
10
+ return data;
11
+ };
12
+ return data;
13
+ }
14
+ var _escapeHtml = require("./escape-html");
15
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
+ // @ts-expect-error ansi-html-community is not typed
17
+
18
+ function ansiHtml(ansi) {
19
+ return (0, _ansiHtmlCommunity().default)((0, _escapeHtml.escapeHTML)(ansi));
20
+ }
package/lib/blob.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ import type { Blob } from '@atlaspack/types';
2
+ import { Buffer } from 'buffer';
3
+ export declare function blobToBuffer(blob: Blob): Promise<Buffer>;
4
+ export declare function blobToString(blob: Blob): Promise<string>;
package/lib/blob.js ADDED
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.blobToBuffer = blobToBuffer;
7
+ exports.blobToString = blobToString;
8
+ function _buffer() {
9
+ const data = require("buffer");
10
+ _buffer = function () {
11
+ return data;
12
+ };
13
+ return data;
14
+ }
15
+ var _ = require("./");
16
+ function _stream() {
17
+ const data = require("stream");
18
+ _stream = function () {
19
+ return data;
20
+ };
21
+ return data;
22
+ }
23
+ function blobToBuffer(blob) {
24
+ if (blob instanceof _stream().Readable) {
25
+ return (0, _.bufferStream)(blob);
26
+ } else if (blob instanceof _buffer().Buffer) {
27
+ return Promise.resolve(_buffer().Buffer.from(blob));
28
+ } else {
29
+ return Promise.resolve(_buffer().Buffer.from(blob, 'utf8'));
30
+ }
31
+ }
32
+ async function blobToString(blob) {
33
+ if (blob instanceof _stream().Readable) {
34
+ return (await (0, _.bufferStream)(blob)).toString();
35
+ } else if (blob instanceof _buffer().Buffer) {
36
+ return blob.toString();
37
+ } else {
38
+ return blob;
39
+ }
40
+ }
@@ -0,0 +1,4 @@
1
+ declare function getBundleURLCached(): string;
2
+ export declare function getBaseURL(url?: string | null): string;
3
+ export declare const getBundleURL: typeof getBundleURLCached;
4
+ export {};