@basemaps/lambda-tiler 6.20.0 → 6.21.1

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 (618) hide show
  1. package/CHANGELOG.md +37 -0
  2. package/build/__test__/tile.set.cache.test.js +4 -10
  3. package/build/cli/validate.js +2 -1
  4. package/build/index.d.ts.map +1 -1
  5. package/build/index.js +8 -1
  6. package/build/routes/__test__/attribution.test.js +3 -13
  7. package/build/routes/attribution.d.ts.map +1 -1
  8. package/build/routes/attribution.js +7 -20
  9. package/build/routes/tile.wmts.js +2 -2
  10. package/build/source.tracer.d.ts +17 -0
  11. package/build/source.tracer.d.ts.map +1 -0
  12. package/build/source.tracer.js +22 -0
  13. package/build/tile.set.cache.js +3 -3
  14. package/build/tile.set.d.ts +0 -16
  15. package/build/tile.set.d.ts.map +1 -1
  16. package/build/tile.set.js +1 -20
  17. package/build/tile.set.raster.d.ts +7 -4
  18. package/build/tile.set.raster.d.ts.map +1 -1
  19. package/build/tile.set.raster.js +14 -5
  20. package/build/tile.set.vector.d.ts +10 -4
  21. package/build/tile.set.vector.d.ts.map +1 -1
  22. package/build/tile.set.vector.js +17 -7
  23. package/bundle.sh +2 -2
  24. package/package.json +11 -11
  25. package/scripts/create.deployment.package.mjs +34 -0
  26. package/src/__test__/tile.set.cache.test.ts +4 -12
  27. package/src/cli/validate.ts +2 -1
  28. package/src/index.ts +11 -1
  29. package/src/routes/__test__/attribution.test.ts +3 -13
  30. package/src/routes/attribution.ts +6 -17
  31. package/src/routes/tile.wmts.ts +2 -2
  32. package/src/source.tracer.ts +34 -0
  33. package/src/tile.set.cache.ts +3 -3
  34. package/src/tile.set.raster.ts +28 -6
  35. package/src/tile.set.ts +0 -40
  36. package/src/tile.set.vector.ts +25 -6
  37. package/tsconfig.tsbuildinfo +1 -1
  38. package/dist/index.js +0 -30702
  39. package/dist/node_modules/ansi-regex/index.js +0 -4
  40. package/dist/node_modules/ansi-regex/license +0 -21
  41. package/dist/node_modules/ansi-regex/package.json +0 -108
  42. package/dist/node_modules/ansi-regex/readme.md +0 -39
  43. package/dist/node_modules/aproba/LICENSE +0 -14
  44. package/dist/node_modules/aproba/README.md +0 -94
  45. package/dist/node_modules/aproba/index.js +0 -105
  46. package/dist/node_modules/aproba/package.json +0 -62
  47. package/dist/node_modules/are-we-there-yet/CHANGES.md +0 -37
  48. package/dist/node_modules/are-we-there-yet/LICENSE +0 -5
  49. package/dist/node_modules/are-we-there-yet/README.md +0 -195
  50. package/dist/node_modules/are-we-there-yet/index.js +0 -4
  51. package/dist/node_modules/are-we-there-yet/package.json +0 -63
  52. package/dist/node_modules/are-we-there-yet/tracker-base.js +0 -11
  53. package/dist/node_modules/are-we-there-yet/tracker-group.js +0 -107
  54. package/dist/node_modules/are-we-there-yet/tracker-stream.js +0 -36
  55. package/dist/node_modules/are-we-there-yet/tracker.js +0 -30
  56. package/dist/node_modules/base64-js/LICENSE +0 -21
  57. package/dist/node_modules/base64-js/README.md +0 -34
  58. package/dist/node_modules/base64-js/base64js.min.js +0 -1
  59. package/dist/node_modules/base64-js/index.d.ts +0 -3
  60. package/dist/node_modules/base64-js/index.js +0 -150
  61. package/dist/node_modules/base64-js/package.json +0 -75
  62. package/dist/node_modules/bl/.travis.yml +0 -17
  63. package/dist/node_modules/bl/BufferList.js +0 -396
  64. package/dist/node_modules/bl/LICENSE.md +0 -13
  65. package/dist/node_modules/bl/README.md +0 -247
  66. package/dist/node_modules/bl/bl.js +0 -84
  67. package/dist/node_modules/bl/node_modules/readable-stream/CONTRIBUTING.md +0 -38
  68. package/dist/node_modules/bl/node_modules/readable-stream/GOVERNANCE.md +0 -136
  69. package/dist/node_modules/bl/node_modules/readable-stream/LICENSE +0 -47
  70. package/dist/node_modules/bl/node_modules/readable-stream/README.md +0 -106
  71. package/dist/node_modules/bl/node_modules/readable-stream/errors-browser.js +0 -127
  72. package/dist/node_modules/bl/node_modules/readable-stream/errors.js +0 -116
  73. package/dist/node_modules/bl/node_modules/readable-stream/experimentalWarning.js +0 -17
  74. package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_duplex.js +0 -139
  75. package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_passthrough.js +0 -39
  76. package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_readable.js +0 -1124
  77. package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_transform.js +0 -201
  78. package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_writable.js +0 -697
  79. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/async_iterator.js +0 -207
  80. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/buffer_list.js +0 -210
  81. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -105
  82. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +0 -104
  83. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/from-browser.js +0 -3
  84. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/from.js +0 -64
  85. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/pipeline.js +0 -97
  86. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/state.js +0 -27
  87. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
  88. package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
  89. package/dist/node_modules/bl/node_modules/readable-stream/package.json +0 -97
  90. package/dist/node_modules/bl/node_modules/readable-stream/readable-browser.js +0 -9
  91. package/dist/node_modules/bl/node_modules/readable-stream/readable.js +0 -16
  92. package/dist/node_modules/bl/package.json +0 -69
  93. package/dist/node_modules/bl/test/convert.js +0 -21
  94. package/dist/node_modules/bl/test/indexOf.js +0 -492
  95. package/dist/node_modules/bl/test/isBufferList.js +0 -32
  96. package/dist/node_modules/bl/test/test.js +0 -869
  97. package/dist/node_modules/buffer/AUTHORS.md +0 -70
  98. package/dist/node_modules/buffer/LICENSE +0 -21
  99. package/dist/node_modules/buffer/README.md +0 -410
  100. package/dist/node_modules/buffer/index.d.ts +0 -186
  101. package/dist/node_modules/buffer/index.js +0 -1817
  102. package/dist/node_modules/buffer/package.json +0 -127
  103. package/dist/node_modules/chownr/LICENSE +0 -15
  104. package/dist/node_modules/chownr/README.md +0 -3
  105. package/dist/node_modules/chownr/chownr.js +0 -167
  106. package/dist/node_modules/chownr/package.json +0 -62
  107. package/dist/node_modules/code-point-at/index.js +0 -32
  108. package/dist/node_modules/code-point-at/license +0 -21
  109. package/dist/node_modules/code-point-at/package.json +0 -70
  110. package/dist/node_modules/code-point-at/readme.md +0 -32
  111. package/dist/node_modules/color/LICENSE +0 -21
  112. package/dist/node_modules/color/README.md +0 -123
  113. package/dist/node_modules/color/index.js +0 -497
  114. package/dist/node_modules/color/package.json +0 -74
  115. package/dist/node_modules/color-convert/CHANGELOG.md +0 -54
  116. package/dist/node_modules/color-convert/LICENSE +0 -21
  117. package/dist/node_modules/color-convert/README.md +0 -68
  118. package/dist/node_modules/color-convert/conversions.js +0 -839
  119. package/dist/node_modules/color-convert/index.js +0 -81
  120. package/dist/node_modules/color-convert/package.json +0 -83
  121. package/dist/node_modules/color-convert/route.js +0 -97
  122. package/dist/node_modules/color-name/LICENSE +0 -8
  123. package/dist/node_modules/color-name/README.md +0 -11
  124. package/dist/node_modules/color-name/index.js +0 -152
  125. package/dist/node_modules/color-name/package.json +0 -57
  126. package/dist/node_modules/color-string/LICENSE +0 -21
  127. package/dist/node_modules/color-string/README.md +0 -62
  128. package/dist/node_modules/color-string/index.js +0 -242
  129. package/dist/node_modules/color-string/package.json +0 -81
  130. package/dist/node_modules/console-control-strings/LICENSE +0 -13
  131. package/dist/node_modules/console-control-strings/README.md +0 -145
  132. package/dist/node_modules/console-control-strings/README.md~ +0 -140
  133. package/dist/node_modules/console-control-strings/index.js +0 -125
  134. package/dist/node_modules/console-control-strings/package.json +0 -61
  135. package/dist/node_modules/core-util-is/LICENSE +0 -19
  136. package/dist/node_modules/core-util-is/README.md +0 -3
  137. package/dist/node_modules/core-util-is/lib/util.js +0 -107
  138. package/dist/node_modules/core-util-is/package.json +0 -68
  139. package/dist/node_modules/decompress-response/index.d.ts +0 -22
  140. package/dist/node_modules/decompress-response/index.js +0 -58
  141. package/dist/node_modules/decompress-response/license +0 -9
  142. package/dist/node_modules/decompress-response/package.json +0 -88
  143. package/dist/node_modules/decompress-response/readme.md +0 -48
  144. package/dist/node_modules/deep-extend/CHANGELOG.md +0 -46
  145. package/dist/node_modules/deep-extend/LICENSE +0 -20
  146. package/dist/node_modules/deep-extend/README.md +0 -91
  147. package/dist/node_modules/deep-extend/index.js +0 -1
  148. package/dist/node_modules/deep-extend/lib/deep-extend.js +0 -150
  149. package/dist/node_modules/deep-extend/package.json +0 -92
  150. package/dist/node_modules/delegates/History.md +0 -22
  151. package/dist/node_modules/delegates/License +0 -20
  152. package/dist/node_modules/delegates/Makefile +0 -8
  153. package/dist/node_modules/delegates/Readme.md +0 -94
  154. package/dist/node_modules/delegates/index.js +0 -121
  155. package/dist/node_modules/delegates/package.json +0 -48
  156. package/dist/node_modules/delegates/test/index.js +0 -94
  157. package/dist/node_modules/detect-libc/LICENSE +0 -201
  158. package/dist/node_modules/detect-libc/README.md +0 -78
  159. package/dist/node_modules/detect-libc/bin/detect-libc.js +0 -18
  160. package/dist/node_modules/detect-libc/lib/detect-libc.js +0 -92
  161. package/dist/node_modules/detect-libc/package.json +0 -70
  162. package/dist/node_modules/end-of-stream/LICENSE +0 -21
  163. package/dist/node_modules/end-of-stream/README.md +0 -54
  164. package/dist/node_modules/end-of-stream/index.js +0 -94
  165. package/dist/node_modules/end-of-stream/package.json +0 -66
  166. package/dist/node_modules/expand-template/.travis.yml +0 -6
  167. package/dist/node_modules/expand-template/LICENSE +0 -21
  168. package/dist/node_modules/expand-template/README.md +0 -43
  169. package/dist/node_modules/expand-template/index.js +0 -26
  170. package/dist/node_modules/expand-template/package.json +0 -60
  171. package/dist/node_modules/expand-template/test.js +0 -67
  172. package/dist/node_modules/fs-constants/LICENSE +0 -21
  173. package/dist/node_modules/fs-constants/README.md +0 -26
  174. package/dist/node_modules/fs-constants/browser.js +0 -1
  175. package/dist/node_modules/fs-constants/index.js +0 -1
  176. package/dist/node_modules/fs-constants/package.json +0 -47
  177. package/dist/node_modules/gauge/CHANGELOG.md +0 -160
  178. package/dist/node_modules/gauge/LICENSE +0 -13
  179. package/dist/node_modules/gauge/README.md +0 -399
  180. package/dist/node_modules/gauge/base-theme.js +0 -14
  181. package/dist/node_modules/gauge/error.js +0 -24
  182. package/dist/node_modules/gauge/has-color.js +0 -12
  183. package/dist/node_modules/gauge/index.js +0 -233
  184. package/dist/node_modules/gauge/package.json +0 -91
  185. package/dist/node_modules/gauge/plumbing.js +0 -48
  186. package/dist/node_modules/gauge/process.js +0 -3
  187. package/dist/node_modules/gauge/progress-bar.js +0 -35
  188. package/dist/node_modules/gauge/render-template.js +0 -181
  189. package/dist/node_modules/gauge/set-immediate.js +0 -7
  190. package/dist/node_modules/gauge/set-interval.js +0 -3
  191. package/dist/node_modules/gauge/spin.js +0 -5
  192. package/dist/node_modules/gauge/template-item.js +0 -73
  193. package/dist/node_modules/gauge/theme-set.js +0 -115
  194. package/dist/node_modules/gauge/themes.js +0 -54
  195. package/dist/node_modules/gauge/wide-truncate.js +0 -25
  196. package/dist/node_modules/github-from-package/.travis.yml +0 -4
  197. package/dist/node_modules/github-from-package/LICENSE +0 -18
  198. package/dist/node_modules/github-from-package/example/package.json +0 -8
  199. package/dist/node_modules/github-from-package/example/url.js +0 -3
  200. package/dist/node_modules/github-from-package/index.js +0 -17
  201. package/dist/node_modules/github-from-package/package.json +0 -58
  202. package/dist/node_modules/github-from-package/readme.markdown +0 -53
  203. package/dist/node_modules/github-from-package/test/a.json +0 -8
  204. package/dist/node_modules/github-from-package/test/b.json +0 -5
  205. package/dist/node_modules/github-from-package/test/c.json +0 -5
  206. package/dist/node_modules/github-from-package/test/d.json +0 -7
  207. package/dist/node_modules/github-from-package/test/e.json +0 -5
  208. package/dist/node_modules/github-from-package/test/url.js +0 -19
  209. package/dist/node_modules/has-unicode/LICENSE +0 -14
  210. package/dist/node_modules/has-unicode/README.md +0 -43
  211. package/dist/node_modules/has-unicode/index.js +0 -16
  212. package/dist/node_modules/has-unicode/package.json +0 -58
  213. package/dist/node_modules/ieee754/LICENSE +0 -11
  214. package/dist/node_modules/ieee754/README.md +0 -51
  215. package/dist/node_modules/ieee754/index.d.ts +0 -10
  216. package/dist/node_modules/ieee754/index.js +0 -85
  217. package/dist/node_modules/ieee754/package.json +0 -84
  218. package/dist/node_modules/inherits/LICENSE +0 -16
  219. package/dist/node_modules/inherits/README.md +0 -42
  220. package/dist/node_modules/inherits/inherits.js +0 -9
  221. package/dist/node_modules/inherits/inherits_browser.js +0 -27
  222. package/dist/node_modules/inherits/package.json +0 -65
  223. package/dist/node_modules/ini/LICENSE +0 -15
  224. package/dist/node_modules/ini/README.md +0 -102
  225. package/dist/node_modules/ini/ini.js +0 -206
  226. package/dist/node_modules/ini/package.json +0 -66
  227. package/dist/node_modules/is-arrayish/LICENSE +0 -21
  228. package/dist/node_modules/is-arrayish/README.md +0 -16
  229. package/dist/node_modules/is-arrayish/index.js +0 -9
  230. package/dist/node_modules/is-arrayish/package.json +0 -77
  231. package/dist/node_modules/is-arrayish/yarn-error.log +0 -1443
  232. package/dist/node_modules/is-fullwidth-code-point/index.js +0 -46
  233. package/dist/node_modules/is-fullwidth-code-point/license +0 -21
  234. package/dist/node_modules/is-fullwidth-code-point/package.json +0 -77
  235. package/dist/node_modules/is-fullwidth-code-point/readme.md +0 -39
  236. package/dist/node_modules/isarray/.travis.yml +0 -4
  237. package/dist/node_modules/isarray/Makefile +0 -6
  238. package/dist/node_modules/isarray/README.md +0 -60
  239. package/dist/node_modules/isarray/component.json +0 -19
  240. package/dist/node_modules/isarray/index.js +0 -5
  241. package/dist/node_modules/isarray/package.json +0 -73
  242. package/dist/node_modules/isarray/test.js +0 -20
  243. package/dist/node_modules/lru-cache/LICENSE +0 -15
  244. package/dist/node_modules/lru-cache/README.md +0 -166
  245. package/dist/node_modules/lru-cache/index.js +0 -334
  246. package/dist/node_modules/lru-cache/package.json +0 -69
  247. package/dist/node_modules/mimic-response/index.d.ts +0 -17
  248. package/dist/node_modules/mimic-response/index.js +0 -77
  249. package/dist/node_modules/mimic-response/license +0 -9
  250. package/dist/node_modules/mimic-response/package.json +0 -74
  251. package/dist/node_modules/mimic-response/readme.md +0 -78
  252. package/dist/node_modules/minimist/.travis.yml +0 -8
  253. package/dist/node_modules/minimist/LICENSE +0 -18
  254. package/dist/node_modules/minimist/example/parse.js +0 -2
  255. package/dist/node_modules/minimist/index.js +0 -245
  256. package/dist/node_modules/minimist/package.json +0 -74
  257. package/dist/node_modules/minimist/readme.markdown +0 -95
  258. package/dist/node_modules/minimist/test/all_bool.js +0 -32
  259. package/dist/node_modules/minimist/test/bool.js +0 -178
  260. package/dist/node_modules/minimist/test/dash.js +0 -31
  261. package/dist/node_modules/minimist/test/default_bool.js +0 -35
  262. package/dist/node_modules/minimist/test/dotted.js +0 -22
  263. package/dist/node_modules/minimist/test/kv_short.js +0 -16
  264. package/dist/node_modules/minimist/test/long.js +0 -31
  265. package/dist/node_modules/minimist/test/num.js +0 -36
  266. package/dist/node_modules/minimist/test/parse.js +0 -197
  267. package/dist/node_modules/minimist/test/parse_modified.js +0 -9
  268. package/dist/node_modules/minimist/test/proto.js +0 -44
  269. package/dist/node_modules/minimist/test/short.js +0 -67
  270. package/dist/node_modules/minimist/test/stop_early.js +0 -15
  271. package/dist/node_modules/minimist/test/unknown.js +0 -102
  272. package/dist/node_modules/minimist/test/whitespace.js +0 -8
  273. package/dist/node_modules/mkdirp-classic/LICENSE +0 -21
  274. package/dist/node_modules/mkdirp-classic/README.md +0 -18
  275. package/dist/node_modules/mkdirp-classic/index.js +0 -98
  276. package/dist/node_modules/mkdirp-classic/package.json +0 -47
  277. package/dist/node_modules/napi-build-utils/LICENSE +0 -21
  278. package/dist/node_modules/napi-build-utils/README.md +0 -48
  279. package/dist/node_modules/napi-build-utils/index.js +0 -213
  280. package/dist/node_modules/napi-build-utils/index.md +0 -81
  281. package/dist/node_modules/napi-build-utils/package.json +0 -68
  282. package/dist/node_modules/node-abi/.circleci/config.yml +0 -63
  283. package/dist/node_modules/node-abi/.github/workflows/update-abi.yml +0 -41
  284. package/dist/node_modules/node-abi/.releaserc.json +0 -9
  285. package/dist/node_modules/node-abi/CODE_OF_CONDUCT.md +0 -73
  286. package/dist/node_modules/node-abi/CONTRIBUTING.md +0 -53
  287. package/dist/node_modules/node-abi/LICENSE +0 -21
  288. package/dist/node_modules/node-abi/README.md +0 -50
  289. package/dist/node_modules/node-abi/abi_registry.json +0 -179
  290. package/dist/node_modules/node-abi/index.js +0 -179
  291. package/dist/node_modules/node-abi/package.json +0 -66
  292. package/dist/node_modules/node-abi/scripts/update-abi-registry.js +0 -119
  293. package/dist/node_modules/node-abi/test/index.js +0 -166
  294. package/dist/node_modules/node-addon-api/LICENSE.md +0 -13
  295. package/dist/node_modules/node-addon-api/README.md +0 -293
  296. package/dist/node_modules/node-addon-api/common.gypi +0 -21
  297. package/dist/node_modules/node-addon-api/except.gypi +0 -25
  298. package/dist/node_modules/node-addon-api/index.js +0 -11
  299. package/dist/node_modules/node-addon-api/napi-inl.deprecated.h +0 -192
  300. package/dist/node_modules/node-addon-api/napi-inl.h +0 -6209
  301. package/dist/node_modules/node-addon-api/napi.h +0 -2983
  302. package/dist/node_modules/node-addon-api/node_api.gyp +0 -9
  303. package/dist/node_modules/node-addon-api/noexcept.gypi +0 -26
  304. package/dist/node_modules/node-addon-api/nothing.c +0 -0
  305. package/dist/node_modules/node-addon-api/package-support.json +0 -21
  306. package/dist/node_modules/node-addon-api/package.json +0 -422
  307. package/dist/node_modules/node-addon-api/tools/README.md +0 -73
  308. package/dist/node_modules/node-addon-api/tools/check-napi.js +0 -100
  309. package/dist/node_modules/node-addon-api/tools/clang-format.js +0 -68
  310. package/dist/node_modules/node-addon-api/tools/conversion.js +0 -309
  311. package/dist/node_modules/node-addon-api/tools/eslint-format.js +0 -71
  312. package/dist/node_modules/npmlog/CHANGELOG.md +0 -49
  313. package/dist/node_modules/npmlog/LICENSE +0 -15
  314. package/dist/node_modules/npmlog/README.md +0 -216
  315. package/dist/node_modules/npmlog/log.js +0 -309
  316. package/dist/node_modules/npmlog/package.json +0 -61
  317. package/dist/node_modules/number-is-nan/index.js +0 -4
  318. package/dist/node_modules/number-is-nan/license +0 -21
  319. package/dist/node_modules/number-is-nan/package.json +0 -67
  320. package/dist/node_modules/number-is-nan/readme.md +0 -28
  321. package/dist/node_modules/object-assign/index.js +0 -90
  322. package/dist/node_modules/object-assign/license +0 -21
  323. package/dist/node_modules/object-assign/package.json +0 -74
  324. package/dist/node_modules/object-assign/readme.md +0 -61
  325. package/dist/node_modules/once/LICENSE +0 -15
  326. package/dist/node_modules/once/README.md +0 -79
  327. package/dist/node_modules/once/once.js +0 -42
  328. package/dist/node_modules/once/package.json +0 -68
  329. package/dist/node_modules/prebuild-install/CHANGELOG.md +0 -98
  330. package/dist/node_modules/prebuild-install/CONTRIBUTING.md +0 -6
  331. package/dist/node_modules/prebuild-install/LICENSE +0 -21
  332. package/dist/node_modules/prebuild-install/README.md +0 -159
  333. package/dist/node_modules/prebuild-install/asset.js +0 -44
  334. package/dist/node_modules/prebuild-install/bin.js +0 -78
  335. package/dist/node_modules/prebuild-install/download.js +0 -142
  336. package/dist/node_modules/prebuild-install/error.js +0 -14
  337. package/dist/node_modules/prebuild-install/help.txt +0 -16
  338. package/dist/node_modules/prebuild-install/index.js +0 -1
  339. package/dist/node_modules/prebuild-install/log.js +0 -25
  340. package/dist/node_modules/prebuild-install/node_modules/detect-libc/LICENSE +0 -201
  341. package/dist/node_modules/prebuild-install/node_modules/detect-libc/README.md +0 -160
  342. package/dist/node_modules/prebuild-install/node_modules/detect-libc/index.d.ts +0 -11
  343. package/dist/node_modules/prebuild-install/node_modules/detect-libc/lib/detect-libc.js +0 -178
  344. package/dist/node_modules/prebuild-install/node_modules/detect-libc/lib/process.js +0 -16
  345. package/dist/node_modules/prebuild-install/node_modules/detect-libc/package.json +0 -71
  346. package/dist/node_modules/prebuild-install/package.json +0 -126
  347. package/dist/node_modules/prebuild-install/proxy.js +0 -35
  348. package/dist/node_modules/prebuild-install/rc.js +0 -60
  349. package/dist/node_modules/prebuild-install/util.js +0 -143
  350. package/dist/node_modules/process-nextick-args/index.js +0 -45
  351. package/dist/node_modules/process-nextick-args/license.md +0 -19
  352. package/dist/node_modules/process-nextick-args/package.json +0 -50
  353. package/dist/node_modules/process-nextick-args/readme.md +0 -18
  354. package/dist/node_modules/pump/.travis.yml +0 -5
  355. package/dist/node_modules/pump/LICENSE +0 -21
  356. package/dist/node_modules/pump/README.md +0 -65
  357. package/dist/node_modules/pump/index.js +0 -82
  358. package/dist/node_modules/pump/package.json +0 -60
  359. package/dist/node_modules/pump/test-browser.js +0 -66
  360. package/dist/node_modules/pump/test-node.js +0 -53
  361. package/dist/node_modules/rc/LICENSE.APACHE2 +0 -15
  362. package/dist/node_modules/rc/LICENSE.BSD +0 -26
  363. package/dist/node_modules/rc/LICENSE.MIT +0 -24
  364. package/dist/node_modules/rc/README.md +0 -227
  365. package/dist/node_modules/rc/browser.js +0 -7
  366. package/dist/node_modules/rc/cli.js +0 -4
  367. package/dist/node_modules/rc/index.js +0 -53
  368. package/dist/node_modules/rc/lib/utils.js +0 -104
  369. package/dist/node_modules/rc/package.json +0 -64
  370. package/dist/node_modules/rc/test/ini.js +0 -16
  371. package/dist/node_modules/rc/test/nested-env-vars.js +0 -50
  372. package/dist/node_modules/rc/test/test.js +0 -59
  373. package/dist/node_modules/readable-stream/.travis.yml +0 -34
  374. package/dist/node_modules/readable-stream/CONTRIBUTING.md +0 -38
  375. package/dist/node_modules/readable-stream/GOVERNANCE.md +0 -136
  376. package/dist/node_modules/readable-stream/LICENSE +0 -47
  377. package/dist/node_modules/readable-stream/README.md +0 -58
  378. package/dist/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md +0 -60
  379. package/dist/node_modules/readable-stream/duplex-browser.js +0 -1
  380. package/dist/node_modules/readable-stream/duplex.js +0 -1
  381. package/dist/node_modules/readable-stream/lib/_stream_duplex.js +0 -131
  382. package/dist/node_modules/readable-stream/lib/_stream_passthrough.js +0 -47
  383. package/dist/node_modules/readable-stream/lib/_stream_readable.js +0 -1019
  384. package/dist/node_modules/readable-stream/lib/_stream_transform.js +0 -214
  385. package/dist/node_modules/readable-stream/lib/_stream_writable.js +0 -687
  386. package/dist/node_modules/readable-stream/lib/internal/streams/BufferList.js +0 -79
  387. package/dist/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -74
  388. package/dist/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
  389. package/dist/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
  390. package/dist/node_modules/readable-stream/package.json +0 -81
  391. package/dist/node_modules/readable-stream/passthrough.js +0 -1
  392. package/dist/node_modules/readable-stream/readable-browser.js +0 -7
  393. package/dist/node_modules/readable-stream/readable.js +0 -19
  394. package/dist/node_modules/readable-stream/transform.js +0 -1
  395. package/dist/node_modules/readable-stream/writable-browser.js +0 -1
  396. package/dist/node_modules/readable-stream/writable.js +0 -8
  397. package/dist/node_modules/safe-buffer/LICENSE +0 -21
  398. package/dist/node_modules/safe-buffer/README.md +0 -584
  399. package/dist/node_modules/safe-buffer/index.d.ts +0 -187
  400. package/dist/node_modules/safe-buffer/index.js +0 -62
  401. package/dist/node_modules/safe-buffer/package.json +0 -64
  402. package/dist/node_modules/semver/CHANGELOG.md +0 -111
  403. package/dist/node_modules/semver/LICENSE +0 -15
  404. package/dist/node_modules/semver/README.md +0 -566
  405. package/dist/node_modules/semver/bin/semver.js +0 -173
  406. package/dist/node_modules/semver/classes/comparator.js +0 -135
  407. package/dist/node_modules/semver/classes/index.js +0 -5
  408. package/dist/node_modules/semver/classes/range.js +0 -510
  409. package/dist/node_modules/semver/classes/semver.js +0 -287
  410. package/dist/node_modules/semver/functions/clean.js +0 -6
  411. package/dist/node_modules/semver/functions/cmp.js +0 -48
  412. package/dist/node_modules/semver/functions/coerce.js +0 -51
  413. package/dist/node_modules/semver/functions/compare-build.js +0 -7
  414. package/dist/node_modules/semver/functions/compare-loose.js +0 -3
  415. package/dist/node_modules/semver/functions/compare.js +0 -5
  416. package/dist/node_modules/semver/functions/diff.js +0 -23
  417. package/dist/node_modules/semver/functions/eq.js +0 -3
  418. package/dist/node_modules/semver/functions/gt.js +0 -3
  419. package/dist/node_modules/semver/functions/gte.js +0 -3
  420. package/dist/node_modules/semver/functions/inc.js +0 -15
  421. package/dist/node_modules/semver/functions/lt.js +0 -3
  422. package/dist/node_modules/semver/functions/lte.js +0 -3
  423. package/dist/node_modules/semver/functions/major.js +0 -3
  424. package/dist/node_modules/semver/functions/minor.js +0 -3
  425. package/dist/node_modules/semver/functions/neq.js +0 -3
  426. package/dist/node_modules/semver/functions/parse.js +0 -33
  427. package/dist/node_modules/semver/functions/patch.js +0 -3
  428. package/dist/node_modules/semver/functions/prerelease.js +0 -6
  429. package/dist/node_modules/semver/functions/rcompare.js +0 -3
  430. package/dist/node_modules/semver/functions/rsort.js +0 -3
  431. package/dist/node_modules/semver/functions/satisfies.js +0 -10
  432. package/dist/node_modules/semver/functions/sort.js +0 -3
  433. package/dist/node_modules/semver/functions/valid.js +0 -6
  434. package/dist/node_modules/semver/index.js +0 -48
  435. package/dist/node_modules/semver/internal/constants.js +0 -17
  436. package/dist/node_modules/semver/internal/debug.js +0 -9
  437. package/dist/node_modules/semver/internal/identifiers.js +0 -23
  438. package/dist/node_modules/semver/internal/parse-options.js +0 -11
  439. package/dist/node_modules/semver/internal/re.js +0 -182
  440. package/dist/node_modules/semver/package.json +0 -74
  441. package/dist/node_modules/semver/preload.js +0 -2
  442. package/dist/node_modules/semver/range.bnf +0 -16
  443. package/dist/node_modules/semver/ranges/gtr.js +0 -4
  444. package/dist/node_modules/semver/ranges/intersects.js +0 -7
  445. package/dist/node_modules/semver/ranges/ltr.js +0 -4
  446. package/dist/node_modules/semver/ranges/max-satisfying.js +0 -25
  447. package/dist/node_modules/semver/ranges/min-satisfying.js +0 -24
  448. package/dist/node_modules/semver/ranges/min-version.js +0 -60
  449. package/dist/node_modules/semver/ranges/outside.js +0 -80
  450. package/dist/node_modules/semver/ranges/simplify.js +0 -44
  451. package/dist/node_modules/semver/ranges/subset.js +0 -222
  452. package/dist/node_modules/semver/ranges/to-comparators.js +0 -8
  453. package/dist/node_modules/semver/ranges/valid.js +0 -11
  454. package/dist/node_modules/set-blocking/CHANGELOG.md +0 -26
  455. package/dist/node_modules/set-blocking/LICENSE.txt +0 -14
  456. package/dist/node_modules/set-blocking/README.md +0 -31
  457. package/dist/node_modules/set-blocking/index.js +0 -7
  458. package/dist/node_modules/set-blocking/package.json +0 -70
  459. package/dist/node_modules/sharp/LICENSE +0 -191
  460. package/dist/node_modules/sharp/README.md +0 -117
  461. package/dist/node_modules/sharp/binding.gyp +0 -233
  462. package/dist/node_modules/sharp/build/Release/sharp-linux-x64.node +0 -0
  463. package/dist/node_modules/sharp/install/can-compile.js +0 -11
  464. package/dist/node_modules/sharp/install/dll-copy.js +0 -37
  465. package/dist/node_modules/sharp/install/libvips.js +0 -176
  466. package/dist/node_modules/sharp/lib/agent.js +0 -40
  467. package/dist/node_modules/sharp/lib/channel.js +0 -171
  468. package/dist/node_modules/sharp/lib/colour.js +0 -171
  469. package/dist/node_modules/sharp/lib/composite.js +0 -178
  470. package/dist/node_modules/sharp/lib/constructor.js +0 -379
  471. package/dist/node_modules/sharp/lib/index.js +0 -13
  472. package/dist/node_modules/sharp/lib/input.js +0 -471
  473. package/dist/node_modules/sharp/lib/is.js +0 -143
  474. package/dist/node_modules/sharp/lib/libvips.js +0 -108
  475. package/dist/node_modules/sharp/lib/operation.js +0 -671
  476. package/dist/node_modules/sharp/lib/output.js +0 -1166
  477. package/dist/node_modules/sharp/lib/platform.js +0 -25
  478. package/dist/node_modules/sharp/lib/resize.js +0 -454
  479. package/dist/node_modules/sharp/lib/sharp.js +0 -31
  480. package/dist/node_modules/sharp/lib/utility.js +0 -180
  481. package/dist/node_modules/sharp/package.json +0 -436
  482. package/dist/node_modules/sharp/src/common.cc +0 -883
  483. package/dist/node_modules/sharp/src/common.h +0 -328
  484. package/dist/node_modules/sharp/src/libvips/cplusplus/VConnection.cpp +0 -152
  485. package/dist/node_modules/sharp/src/libvips/cplusplus/VError.cpp +0 -50
  486. package/dist/node_modules/sharp/src/libvips/cplusplus/VImage.cpp +0 -1505
  487. package/dist/node_modules/sharp/src/libvips/cplusplus/VInterpolate.cpp +0 -63
  488. package/dist/node_modules/sharp/src/libvips/cplusplus/vips-operators.cpp +0 -3710
  489. package/dist/node_modules/sharp/src/metadata.cc +0 -285
  490. package/dist/node_modules/sharp/src/metadata.h +0 -91
  491. package/dist/node_modules/sharp/src/operations.cc +0 -311
  492. package/dist/node_modules/sharp/src/operations.h +0 -113
  493. package/dist/node_modules/sharp/src/pipeline.cc +0 -1584
  494. package/dist/node_modules/sharp/src/pipeline.h +0 -345
  495. package/dist/node_modules/sharp/src/sharp.cc +0 -52
  496. package/dist/node_modules/sharp/src/stats.cc +0 -193
  497. package/dist/node_modules/sharp/src/stats.h +0 -70
  498. package/dist/node_modules/sharp/src/utilities.cc +0 -243
  499. package/dist/node_modules/sharp/src/utilities.h +0 -29
  500. package/dist/node_modules/sharp/vendor/8.11.3/linux-x64/THIRD-PARTY-NOTICES.md +0 -41
  501. package/dist/node_modules/sharp/vendor/8.11.3/linux-x64/lib/libvips-cpp.so.42 +0 -0
  502. package/dist/node_modules/sharp/vendor/8.11.3/linux-x64/platform.json +0 -1
  503. package/dist/node_modules/sharp/vendor/8.11.3/linux-x64/versions.json +0 -30
  504. package/dist/node_modules/signal-exit/LICENSE.txt +0 -16
  505. package/dist/node_modules/signal-exit/README.md +0 -39
  506. package/dist/node_modules/signal-exit/index.js +0 -200
  507. package/dist/node_modules/signal-exit/package.json +0 -66
  508. package/dist/node_modules/signal-exit/signals.js +0 -53
  509. package/dist/node_modules/simple-concat/.travis.yml +0 -3
  510. package/dist/node_modules/simple-concat/LICENSE +0 -20
  511. package/dist/node_modules/simple-concat/README.md +0 -44
  512. package/dist/node_modules/simple-concat/index.js +0 -15
  513. package/dist/node_modules/simple-concat/package.json +0 -72
  514. package/dist/node_modules/simple-concat/test/basic.js +0 -41
  515. package/dist/node_modules/simple-get/.github/dependabot.yml +0 -15
  516. package/dist/node_modules/simple-get/.github/workflows/ci.yml +0 -23
  517. package/dist/node_modules/simple-get/LICENSE +0 -20
  518. package/dist/node_modules/simple-get/README.md +0 -333
  519. package/dist/node_modules/simple-get/index.js +0 -108
  520. package/dist/node_modules/simple-get/package.json +0 -93
  521. package/dist/node_modules/simple-swizzle/LICENSE +0 -21
  522. package/dist/node_modules/simple-swizzle/README.md +0 -39
  523. package/dist/node_modules/simple-swizzle/index.js +0 -29
  524. package/dist/node_modules/simple-swizzle/package.json +0 -71
  525. package/dist/node_modules/string-width/index.js +0 -37
  526. package/dist/node_modules/string-width/license +0 -21
  527. package/dist/node_modules/string-width/package.json +0 -89
  528. package/dist/node_modules/string-width/readme.md +0 -42
  529. package/dist/node_modules/string_decoder/.travis.yml +0 -50
  530. package/dist/node_modules/string_decoder/LICENSE +0 -48
  531. package/dist/node_modules/string_decoder/README.md +0 -47
  532. package/dist/node_modules/string_decoder/lib/string_decoder.js +0 -296
  533. package/dist/node_modules/string_decoder/package.json +0 -61
  534. package/dist/node_modules/strip-ansi/index.js +0 -6
  535. package/dist/node_modules/strip-ansi/license +0 -21
  536. package/dist/node_modules/strip-ansi/package.json +0 -102
  537. package/dist/node_modules/strip-ansi/readme.md +0 -33
  538. package/dist/node_modules/strip-json-comments/index.js +0 -70
  539. package/dist/node_modules/strip-json-comments/license +0 -21
  540. package/dist/node_modules/strip-json-comments/package.json +0 -74
  541. package/dist/node_modules/strip-json-comments/readme.md +0 -64
  542. package/dist/node_modules/tar-fs/.travis.yml +0 -6
  543. package/dist/node_modules/tar-fs/LICENSE +0 -21
  544. package/dist/node_modules/tar-fs/README.md +0 -165
  545. package/dist/node_modules/tar-fs/index.js +0 -351
  546. package/dist/node_modules/tar-fs/package.json +0 -69
  547. package/dist/node_modules/tar-fs/test/fixtures/a/hello.txt +0 -1
  548. package/dist/node_modules/tar-fs/test/fixtures/b/a/test.txt +0 -1
  549. package/dist/node_modules/tar-fs/test/fixtures/d/file1 +0 -0
  550. package/dist/node_modules/tar-fs/test/fixtures/d/file2 +0 -0
  551. package/dist/node_modules/tar-fs/test/fixtures/d/sub-dir/file5 +0 -0
  552. package/dist/node_modules/tar-fs/test/fixtures/d/sub-files/file3 +0 -0
  553. package/dist/node_modules/tar-fs/test/fixtures/d/sub-files/file4 +0 -0
  554. package/dist/node_modules/tar-fs/test/fixtures/e/directory/.ignore +0 -0
  555. package/dist/node_modules/tar-fs/test/fixtures/e/file +0 -0
  556. package/dist/node_modules/tar-fs/test/fixtures/invalid.tar +0 -0
  557. package/dist/node_modules/tar-fs/test/index.js +0 -346
  558. package/dist/node_modules/tar-stream/LICENSE +0 -21
  559. package/dist/node_modules/tar-stream/README.md +0 -168
  560. package/dist/node_modules/tar-stream/extract.js +0 -257
  561. package/dist/node_modules/tar-stream/headers.js +0 -295
  562. package/dist/node_modules/tar-stream/index.js +0 -2
  563. package/dist/node_modules/tar-stream/node_modules/readable-stream/CONTRIBUTING.md +0 -38
  564. package/dist/node_modules/tar-stream/node_modules/readable-stream/GOVERNANCE.md +0 -136
  565. package/dist/node_modules/tar-stream/node_modules/readable-stream/LICENSE +0 -47
  566. package/dist/node_modules/tar-stream/node_modules/readable-stream/README.md +0 -106
  567. package/dist/node_modules/tar-stream/node_modules/readable-stream/errors-browser.js +0 -127
  568. package/dist/node_modules/tar-stream/node_modules/readable-stream/errors.js +0 -116
  569. package/dist/node_modules/tar-stream/node_modules/readable-stream/experimentalWarning.js +0 -17
  570. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_duplex.js +0 -139
  571. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_passthrough.js +0 -39
  572. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_readable.js +0 -1124
  573. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_transform.js +0 -201
  574. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_writable.js +0 -697
  575. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/async_iterator.js +0 -207
  576. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/buffer_list.js +0 -210
  577. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -105
  578. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +0 -104
  579. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/from-browser.js +0 -3
  580. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/from.js +0 -64
  581. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/pipeline.js +0 -97
  582. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/state.js +0 -27
  583. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
  584. package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
  585. package/dist/node_modules/tar-stream/node_modules/readable-stream/package.json +0 -97
  586. package/dist/node_modules/tar-stream/node_modules/readable-stream/readable-browser.js +0 -9
  587. package/dist/node_modules/tar-stream/node_modules/readable-stream/readable.js +0 -16
  588. package/dist/node_modules/tar-stream/pack.js +0 -255
  589. package/dist/node_modules/tar-stream/package.json +0 -90
  590. package/dist/node_modules/tar-stream/sandbox.js +0 -11
  591. package/dist/node_modules/tunnel-agent/LICENSE +0 -55
  592. package/dist/node_modules/tunnel-agent/README.md +0 -4
  593. package/dist/node_modules/tunnel-agent/index.js +0 -244
  594. package/dist/node_modules/tunnel-agent/package.json +0 -56
  595. package/dist/node_modules/util-deprecate/History.md +0 -16
  596. package/dist/node_modules/util-deprecate/LICENSE +0 -24
  597. package/dist/node_modules/util-deprecate/README.md +0 -53
  598. package/dist/node_modules/util-deprecate/browser.js +0 -67
  599. package/dist/node_modules/util-deprecate/node.js +0 -6
  600. package/dist/node_modules/util-deprecate/package.json +0 -58
  601. package/dist/node_modules/wide-align/LICENSE +0 -14
  602. package/dist/node_modules/wide-align/README.md +0 -47
  603. package/dist/node_modules/wide-align/align.js +0 -65
  604. package/dist/node_modules/wide-align/package.json +0 -66
  605. package/dist/node_modules/wrappy/LICENSE +0 -15
  606. package/dist/node_modules/wrappy/README.md +0 -36
  607. package/dist/node_modules/wrappy/package.json +0 -58
  608. package/dist/node_modules/wrappy/wrappy.js +0 -33
  609. package/dist/node_modules/yallist/LICENSE +0 -15
  610. package/dist/node_modules/yallist/README.md +0 -204
  611. package/dist/node_modules/yallist/iterator.js +0 -8
  612. package/dist/node_modules/yallist/package.json +0 -62
  613. package/dist/node_modules/yallist/yallist.js +0 -426
  614. package/dist/package-lock.json +0 -507
  615. package/dist/package.json +0 -63
  616. package/dist/static/expected_tile_2193_153_255_z7.png +0 -0
  617. package/dist/static/expected_tile_NZTM2000Quad_30_33_z6.png +0 -0
  618. package/dist/static/expected_tile_WebMercatorQuad_252_156_z8.png +0 -0
@@ -1,1124 +0,0 @@
1
- // Copyright Joyent, Inc. and other Node contributors.
2
- //
3
- // Permission is hereby granted, free of charge, to any person obtaining a
4
- // copy of this software and associated documentation files (the
5
- // "Software"), to deal in the Software without restriction, including
6
- // without limitation the rights to use, copy, modify, merge, publish,
7
- // distribute, sublicense, and/or sell copies of the Software, and to permit
8
- // persons to whom the Software is furnished to do so, subject to the
9
- // following conditions:
10
- //
11
- // The above copyright notice and this permission notice shall be included
12
- // in all copies or substantial portions of the Software.
13
- //
14
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
15
- // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
- // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
17
- // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
18
- // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
19
- // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
20
- // USE OR OTHER DEALINGS IN THE SOFTWARE.
21
- 'use strict';
22
-
23
- module.exports = Readable;
24
- /*<replacement>*/
25
-
26
- var Duplex;
27
- /*</replacement>*/
28
-
29
- Readable.ReadableState = ReadableState;
30
- /*<replacement>*/
31
-
32
- var EE = require('events').EventEmitter;
33
-
34
- var EElistenerCount = function EElistenerCount(emitter, type) {
35
- return emitter.listeners(type).length;
36
- };
37
- /*</replacement>*/
38
-
39
- /*<replacement>*/
40
-
41
-
42
- var Stream = require('./internal/streams/stream');
43
- /*</replacement>*/
44
-
45
-
46
- var Buffer = require('buffer').Buffer;
47
-
48
- var OurUint8Array = global.Uint8Array || function () {};
49
-
50
- function _uint8ArrayToBuffer(chunk) {
51
- return Buffer.from(chunk);
52
- }
53
-
54
- function _isUint8Array(obj) {
55
- return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;
56
- }
57
- /*<replacement>*/
58
-
59
-
60
- var debugUtil = require('util');
61
-
62
- var debug;
63
-
64
- if (debugUtil && debugUtil.debuglog) {
65
- debug = debugUtil.debuglog('stream');
66
- } else {
67
- debug = function debug() {};
68
- }
69
- /*</replacement>*/
70
-
71
-
72
- var BufferList = require('./internal/streams/buffer_list');
73
-
74
- var destroyImpl = require('./internal/streams/destroy');
75
-
76
- var _require = require('./internal/streams/state'),
77
- getHighWaterMark = _require.getHighWaterMark;
78
-
79
- var _require$codes = require('../errors').codes,
80
- ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,
81
- ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,
82
- ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,
83
- ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT; // Lazy loaded to improve the startup performance.
84
-
85
-
86
- var StringDecoder;
87
- var createReadableStreamAsyncIterator;
88
- var from;
89
-
90
- require('inherits')(Readable, Stream);
91
-
92
- var errorOrDestroy = destroyImpl.errorOrDestroy;
93
- var kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];
94
-
95
- function prependListener(emitter, event, fn) {
96
- // Sadly this is not cacheable as some libraries bundle their own
97
- // event emitter implementation with them.
98
- if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn); // This is a hack to make sure that our error handler is attached before any
99
- // userland ones. NEVER DO THIS. This is here only because this code needs
100
- // to continue to work with older versions of Node.js that do not include
101
- // the prependListener() method. The goal is to eventually remove this hack.
102
-
103
- if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];
104
- }
105
-
106
- function ReadableState(options, stream, isDuplex) {
107
- Duplex = Duplex || require('./_stream_duplex');
108
- options = options || {}; // Duplex streams are both readable and writable, but share
109
- // the same options object.
110
- // However, some cases require setting options to different
111
- // values for the readable and the writable sides of the duplex stream.
112
- // These options can be provided separately as readableXXX and writableXXX.
113
-
114
- if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex; // object stream flag. Used to make read(n) ignore n and to
115
- // make all the buffer merging and length checks go away
116
-
117
- this.objectMode = !!options.objectMode;
118
- if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer
119
- // Note: 0 is a valid value, means "don't call _read preemptively ever"
120
-
121
- this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex); // A linked list is used to store data chunks instead of an array because the
122
- // linked list can remove elements from the beginning faster than
123
- // array.shift()
124
-
125
- this.buffer = new BufferList();
126
- this.length = 0;
127
- this.pipes = null;
128
- this.pipesCount = 0;
129
- this.flowing = null;
130
- this.ended = false;
131
- this.endEmitted = false;
132
- this.reading = false; // a flag to be able to tell if the event 'readable'/'data' is emitted
133
- // immediately, or on a later tick. We set this to true at first, because
134
- // any actions that shouldn't happen until "later" should generally also
135
- // not happen before the first read call.
136
-
137
- this.sync = true; // whenever we return null, then we set a flag to say
138
- // that we're awaiting a 'readable' event emission.
139
-
140
- this.needReadable = false;
141
- this.emittedReadable = false;
142
- this.readableListening = false;
143
- this.resumeScheduled = false;
144
- this.paused = true; // Should close be emitted on destroy. Defaults to true.
145
-
146
- this.emitClose = options.emitClose !== false; // Should .destroy() be called after 'end' (and potentially 'finish')
147
-
148
- this.autoDestroy = !!options.autoDestroy; // has it been destroyed
149
-
150
- this.destroyed = false; // Crypto is kind of old and crusty. Historically, its default string
151
- // encoding is 'binary' so we have to make this configurable.
152
- // Everything else in the universe uses 'utf8', though.
153
-
154
- this.defaultEncoding = options.defaultEncoding || 'utf8'; // the number of writers that are awaiting a drain event in .pipe()s
155
-
156
- this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled
157
-
158
- this.readingMore = false;
159
- this.decoder = null;
160
- this.encoding = null;
161
-
162
- if (options.encoding) {
163
- if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;
164
- this.decoder = new StringDecoder(options.encoding);
165
- this.encoding = options.encoding;
166
- }
167
- }
168
-
169
- function Readable(options) {
170
- Duplex = Duplex || require('./_stream_duplex');
171
- if (!(this instanceof Readable)) return new Readable(options); // Checking for a Stream.Duplex instance is faster here instead of inside
172
- // the ReadableState constructor, at least with V8 6.5
173
-
174
- var isDuplex = this instanceof Duplex;
175
- this._readableState = new ReadableState(options, this, isDuplex); // legacy
176
-
177
- this.readable = true;
178
-
179
- if (options) {
180
- if (typeof options.read === 'function') this._read = options.read;
181
- if (typeof options.destroy === 'function') this._destroy = options.destroy;
182
- }
183
-
184
- Stream.call(this);
185
- }
186
-
187
- Object.defineProperty(Readable.prototype, 'destroyed', {
188
- // making it explicit this property is not enumerable
189
- // because otherwise some prototype manipulation in
190
- // userland will fail
191
- enumerable: false,
192
- get: function get() {
193
- if (this._readableState === undefined) {
194
- return false;
195
- }
196
-
197
- return this._readableState.destroyed;
198
- },
199
- set: function set(value) {
200
- // we ignore the value if the stream
201
- // has not been initialized yet
202
- if (!this._readableState) {
203
- return;
204
- } // backward compatibility, the user is explicitly
205
- // managing destroyed
206
-
207
-
208
- this._readableState.destroyed = value;
209
- }
210
- });
211
- Readable.prototype.destroy = destroyImpl.destroy;
212
- Readable.prototype._undestroy = destroyImpl.undestroy;
213
-
214
- Readable.prototype._destroy = function (err, cb) {
215
- cb(err);
216
- }; // Manually shove something into the read() buffer.
217
- // This returns true if the highWaterMark has not been hit yet,
218
- // similar to how Writable.write() returns true if you should
219
- // write() some more.
220
-
221
-
222
- Readable.prototype.push = function (chunk, encoding) {
223
- var state = this._readableState;
224
- var skipChunkCheck;
225
-
226
- if (!state.objectMode) {
227
- if (typeof chunk === 'string') {
228
- encoding = encoding || state.defaultEncoding;
229
-
230
- if (encoding !== state.encoding) {
231
- chunk = Buffer.from(chunk, encoding);
232
- encoding = '';
233
- }
234
-
235
- skipChunkCheck = true;
236
- }
237
- } else {
238
- skipChunkCheck = true;
239
- }
240
-
241
- return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);
242
- }; // Unshift should *always* be something directly out of read()
243
-
244
-
245
- Readable.prototype.unshift = function (chunk) {
246
- return readableAddChunk(this, chunk, null, true, false);
247
- };
248
-
249
- function readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {
250
- debug('readableAddChunk', chunk);
251
- var state = stream._readableState;
252
-
253
- if (chunk === null) {
254
- state.reading = false;
255
- onEofChunk(stream, state);
256
- } else {
257
- var er;
258
- if (!skipChunkCheck) er = chunkInvalid(state, chunk);
259
-
260
- if (er) {
261
- errorOrDestroy(stream, er);
262
- } else if (state.objectMode || chunk && chunk.length > 0) {
263
- if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {
264
- chunk = _uint8ArrayToBuffer(chunk);
265
- }
266
-
267
- if (addToFront) {
268
- if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);
269
- } else if (state.ended) {
270
- errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());
271
- } else if (state.destroyed) {
272
- return false;
273
- } else {
274
- state.reading = false;
275
-
276
- if (state.decoder && !encoding) {
277
- chunk = state.decoder.write(chunk);
278
- if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);
279
- } else {
280
- addChunk(stream, state, chunk, false);
281
- }
282
- }
283
- } else if (!addToFront) {
284
- state.reading = false;
285
- maybeReadMore(stream, state);
286
- }
287
- } // We can push more data if we are below the highWaterMark.
288
- // Also, if we have no data yet, we can stand some more bytes.
289
- // This is to work around cases where hwm=0, such as the repl.
290
-
291
-
292
- return !state.ended && (state.length < state.highWaterMark || state.length === 0);
293
- }
294
-
295
- function addChunk(stream, state, chunk, addToFront) {
296
- if (state.flowing && state.length === 0 && !state.sync) {
297
- state.awaitDrain = 0;
298
- stream.emit('data', chunk);
299
- } else {
300
- // update the buffer info.
301
- state.length += state.objectMode ? 1 : chunk.length;
302
- if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);
303
- if (state.needReadable) emitReadable(stream);
304
- }
305
-
306
- maybeReadMore(stream, state);
307
- }
308
-
309
- function chunkInvalid(state, chunk) {
310
- var er;
311
-
312
- if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {
313
- er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);
314
- }
315
-
316
- return er;
317
- }
318
-
319
- Readable.prototype.isPaused = function () {
320
- return this._readableState.flowing === false;
321
- }; // backwards compatibility.
322
-
323
-
324
- Readable.prototype.setEncoding = function (enc) {
325
- if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;
326
- var decoder = new StringDecoder(enc);
327
- this._readableState.decoder = decoder; // If setEncoding(null), decoder.encoding equals utf8
328
-
329
- this._readableState.encoding = this._readableState.decoder.encoding; // Iterate over current buffer to convert already stored Buffers:
330
-
331
- var p = this._readableState.buffer.head;
332
- var content = '';
333
-
334
- while (p !== null) {
335
- content += decoder.write(p.data);
336
- p = p.next;
337
- }
338
-
339
- this._readableState.buffer.clear();
340
-
341
- if (content !== '') this._readableState.buffer.push(content);
342
- this._readableState.length = content.length;
343
- return this;
344
- }; // Don't raise the hwm > 1GB
345
-
346
-
347
- var MAX_HWM = 0x40000000;
348
-
349
- function computeNewHighWaterMark(n) {
350
- if (n >= MAX_HWM) {
351
- // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.
352
- n = MAX_HWM;
353
- } else {
354
- // Get the next highest power of 2 to prevent increasing hwm excessively in
355
- // tiny amounts
356
- n--;
357
- n |= n >>> 1;
358
- n |= n >>> 2;
359
- n |= n >>> 4;
360
- n |= n >>> 8;
361
- n |= n >>> 16;
362
- n++;
363
- }
364
-
365
- return n;
366
- } // This function is designed to be inlinable, so please take care when making
367
- // changes to the function body.
368
-
369
-
370
- function howMuchToRead(n, state) {
371
- if (n <= 0 || state.length === 0 && state.ended) return 0;
372
- if (state.objectMode) return 1;
373
-
374
- if (n !== n) {
375
- // Only flow one buffer at a time
376
- if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;
377
- } // If we're asking for more than the current hwm, then raise the hwm.
378
-
379
-
380
- if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);
381
- if (n <= state.length) return n; // Don't have enough
382
-
383
- if (!state.ended) {
384
- state.needReadable = true;
385
- return 0;
386
- }
387
-
388
- return state.length;
389
- } // you can override either this method, or the async _read(n) below.
390
-
391
-
392
- Readable.prototype.read = function (n) {
393
- debug('read', n);
394
- n = parseInt(n, 10);
395
- var state = this._readableState;
396
- var nOrig = n;
397
- if (n !== 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we
398
- // already have a bunch of data in the buffer, then just trigger
399
- // the 'readable' event and move on.
400
-
401
- if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {
402
- debug('read: emitReadable', state.length, state.ended);
403
- if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);
404
- return null;
405
- }
406
-
407
- n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up.
408
-
409
- if (n === 0 && state.ended) {
410
- if (state.length === 0) endReadable(this);
411
- return null;
412
- } // All the actual chunk generation logic needs to be
413
- // *below* the call to _read. The reason is that in certain
414
- // synthetic stream cases, such as passthrough streams, _read
415
- // may be a completely synchronous operation which may change
416
- // the state of the read buffer, providing enough data when
417
- // before there was *not* enough.
418
- //
419
- // So, the steps are:
420
- // 1. Figure out what the state of things will be after we do
421
- // a read from the buffer.
422
- //
423
- // 2. If that resulting state will trigger a _read, then call _read.
424
- // Note that this may be asynchronous, or synchronous. Yes, it is
425
- // deeply ugly to write APIs this way, but that still doesn't mean
426
- // that the Readable class should behave improperly, as streams are
427
- // designed to be sync/async agnostic.
428
- // Take note if the _read call is sync or async (ie, if the read call
429
- // has returned yet), so that we know whether or not it's safe to emit
430
- // 'readable' etc.
431
- //
432
- // 3. Actually pull the requested chunks out of the buffer and return.
433
- // if we need a readable event, then we need to do some reading.
434
-
435
-
436
- var doRead = state.needReadable;
437
- debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some
438
-
439
- if (state.length === 0 || state.length - n < state.highWaterMark) {
440
- doRead = true;
441
- debug('length less than watermark', doRead);
442
- } // however, if we've ended, then there's no point, and if we're already
443
- // reading, then it's unnecessary.
444
-
445
-
446
- if (state.ended || state.reading) {
447
- doRead = false;
448
- debug('reading or ended', doRead);
449
- } else if (doRead) {
450
- debug('do read');
451
- state.reading = true;
452
- state.sync = true; // if the length is currently zero, then we *need* a readable event.
453
-
454
- if (state.length === 0) state.needReadable = true; // call internal read method
455
-
456
- this._read(state.highWaterMark);
457
-
458
- state.sync = false; // If _read pushed data synchronously, then `reading` will be false,
459
- // and we need to re-evaluate how much data we can return to the user.
460
-
461
- if (!state.reading) n = howMuchToRead(nOrig, state);
462
- }
463
-
464
- var ret;
465
- if (n > 0) ret = fromList(n, state);else ret = null;
466
-
467
- if (ret === null) {
468
- state.needReadable = state.length <= state.highWaterMark;
469
- n = 0;
470
- } else {
471
- state.length -= n;
472
- state.awaitDrain = 0;
473
- }
474
-
475
- if (state.length === 0) {
476
- // If we have nothing in the buffer, then we want to know
477
- // as soon as we *do* get something into the buffer.
478
- if (!state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick.
479
-
480
- if (nOrig !== n && state.ended) endReadable(this);
481
- }
482
-
483
- if (ret !== null) this.emit('data', ret);
484
- return ret;
485
- };
486
-
487
- function onEofChunk(stream, state) {
488
- debug('onEofChunk');
489
- if (state.ended) return;
490
-
491
- if (state.decoder) {
492
- var chunk = state.decoder.end();
493
-
494
- if (chunk && chunk.length) {
495
- state.buffer.push(chunk);
496
- state.length += state.objectMode ? 1 : chunk.length;
497
- }
498
- }
499
-
500
- state.ended = true;
501
-
502
- if (state.sync) {
503
- // if we are sync, wait until next tick to emit the data.
504
- // Otherwise we risk emitting data in the flow()
505
- // the readable code triggers during a read() call
506
- emitReadable(stream);
507
- } else {
508
- // emit 'readable' now to make sure it gets picked up.
509
- state.needReadable = false;
510
-
511
- if (!state.emittedReadable) {
512
- state.emittedReadable = true;
513
- emitReadable_(stream);
514
- }
515
- }
516
- } // Don't emit readable right away in sync mode, because this can trigger
517
- // another read() call => stack overflow. This way, it might trigger
518
- // a nextTick recursion warning, but that's not so bad.
519
-
520
-
521
- function emitReadable(stream) {
522
- var state = stream._readableState;
523
- debug('emitReadable', state.needReadable, state.emittedReadable);
524
- state.needReadable = false;
525
-
526
- if (!state.emittedReadable) {
527
- debug('emitReadable', state.flowing);
528
- state.emittedReadable = true;
529
- process.nextTick(emitReadable_, stream);
530
- }
531
- }
532
-
533
- function emitReadable_(stream) {
534
- var state = stream._readableState;
535
- debug('emitReadable_', state.destroyed, state.length, state.ended);
536
-
537
- if (!state.destroyed && (state.length || state.ended)) {
538
- stream.emit('readable');
539
- state.emittedReadable = false;
540
- } // The stream needs another readable event if
541
- // 1. It is not flowing, as the flow mechanism will take
542
- // care of it.
543
- // 2. It is not ended.
544
- // 3. It is below the highWaterMark, so we can schedule
545
- // another readable later.
546
-
547
-
548
- state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;
549
- flow(stream);
550
- } // at this point, the user has presumably seen the 'readable' event,
551
- // and called read() to consume some data. that may have triggered
552
- // in turn another _read(n) call, in which case reading = true if
553
- // it's in progress.
554
- // However, if we're not ended, or reading, and the length < hwm,
555
- // then go ahead and try to read some more preemptively.
556
-
557
-
558
- function maybeReadMore(stream, state) {
559
- if (!state.readingMore) {
560
- state.readingMore = true;
561
- process.nextTick(maybeReadMore_, stream, state);
562
- }
563
- }
564
-
565
- function maybeReadMore_(stream, state) {
566
- // Attempt to read more data if we should.
567
- //
568
- // The conditions for reading more data are (one of):
569
- // - Not enough data buffered (state.length < state.highWaterMark). The loop
570
- // is responsible for filling the buffer with enough data if such data
571
- // is available. If highWaterMark is 0 and we are not in the flowing mode
572
- // we should _not_ attempt to buffer any extra data. We'll get more data
573
- // when the stream consumer calls read() instead.
574
- // - No data in the buffer, and the stream is in flowing mode. In this mode
575
- // the loop below is responsible for ensuring read() is called. Failing to
576
- // call read here would abort the flow and there's no other mechanism for
577
- // continuing the flow if the stream consumer has just subscribed to the
578
- // 'data' event.
579
- //
580
- // In addition to the above conditions to keep reading data, the following
581
- // conditions prevent the data from being read:
582
- // - The stream has ended (state.ended).
583
- // - There is already a pending 'read' operation (state.reading). This is a
584
- // case where the the stream has called the implementation defined _read()
585
- // method, but they are processing the call asynchronously and have _not_
586
- // called push() with new data. In this case we skip performing more
587
- // read()s. The execution ends in this method again after the _read() ends
588
- // up calling push() with more data.
589
- while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {
590
- var len = state.length;
591
- debug('maybeReadMore read 0');
592
- stream.read(0);
593
- if (len === state.length) // didn't get any data, stop spinning.
594
- break;
595
- }
596
-
597
- state.readingMore = false;
598
- } // abstract method. to be overridden in specific implementation classes.
599
- // call cb(er, data) where data is <= n in length.
600
- // for virtual (non-string, non-buffer) streams, "length" is somewhat
601
- // arbitrary, and perhaps not very meaningful.
602
-
603
-
604
- Readable.prototype._read = function (n) {
605
- errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));
606
- };
607
-
608
- Readable.prototype.pipe = function (dest, pipeOpts) {
609
- var src = this;
610
- var state = this._readableState;
611
-
612
- switch (state.pipesCount) {
613
- case 0:
614
- state.pipes = dest;
615
- break;
616
-
617
- case 1:
618
- state.pipes = [state.pipes, dest];
619
- break;
620
-
621
- default:
622
- state.pipes.push(dest);
623
- break;
624
- }
625
-
626
- state.pipesCount += 1;
627
- debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);
628
- var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;
629
- var endFn = doEnd ? onend : unpipe;
630
- if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);
631
- dest.on('unpipe', onunpipe);
632
-
633
- function onunpipe(readable, unpipeInfo) {
634
- debug('onunpipe');
635
-
636
- if (readable === src) {
637
- if (unpipeInfo && unpipeInfo.hasUnpiped === false) {
638
- unpipeInfo.hasUnpiped = true;
639
- cleanup();
640
- }
641
- }
642
- }
643
-
644
- function onend() {
645
- debug('onend');
646
- dest.end();
647
- } // when the dest drains, it reduces the awaitDrain counter
648
- // on the source. This would be more elegant with a .once()
649
- // handler in flow(), but adding and removing repeatedly is
650
- // too slow.
651
-
652
-
653
- var ondrain = pipeOnDrain(src);
654
- dest.on('drain', ondrain);
655
- var cleanedUp = false;
656
-
657
- function cleanup() {
658
- debug('cleanup'); // cleanup event handlers once the pipe is broken
659
-
660
- dest.removeListener('close', onclose);
661
- dest.removeListener('finish', onfinish);
662
- dest.removeListener('drain', ondrain);
663
- dest.removeListener('error', onerror);
664
- dest.removeListener('unpipe', onunpipe);
665
- src.removeListener('end', onend);
666
- src.removeListener('end', unpipe);
667
- src.removeListener('data', ondata);
668
- cleanedUp = true; // if the reader is waiting for a drain event from this
669
- // specific writer, then it would cause it to never start
670
- // flowing again.
671
- // So, if this is awaiting a drain, then we just call it now.
672
- // If we don't know, then assume that we are waiting for one.
673
-
674
- if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();
675
- }
676
-
677
- src.on('data', ondata);
678
-
679
- function ondata(chunk) {
680
- debug('ondata');
681
- var ret = dest.write(chunk);
682
- debug('dest.write', ret);
683
-
684
- if (ret === false) {
685
- // If the user unpiped during `dest.write()`, it is possible
686
- // to get stuck in a permanently paused state if that write
687
- // also returned false.
688
- // => Check whether `dest` is still a piping destination.
689
- if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {
690
- debug('false write response, pause', state.awaitDrain);
691
- state.awaitDrain++;
692
- }
693
-
694
- src.pause();
695
- }
696
- } // if the dest has an error, then stop piping into it.
697
- // however, don't suppress the throwing behavior for this.
698
-
699
-
700
- function onerror(er) {
701
- debug('onerror', er);
702
- unpipe();
703
- dest.removeListener('error', onerror);
704
- if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);
705
- } // Make sure our error handler is attached before userland ones.
706
-
707
-
708
- prependListener(dest, 'error', onerror); // Both close and finish should trigger unpipe, but only once.
709
-
710
- function onclose() {
711
- dest.removeListener('finish', onfinish);
712
- unpipe();
713
- }
714
-
715
- dest.once('close', onclose);
716
-
717
- function onfinish() {
718
- debug('onfinish');
719
- dest.removeListener('close', onclose);
720
- unpipe();
721
- }
722
-
723
- dest.once('finish', onfinish);
724
-
725
- function unpipe() {
726
- debug('unpipe');
727
- src.unpipe(dest);
728
- } // tell the dest that it's being piped to
729
-
730
-
731
- dest.emit('pipe', src); // start the flow if it hasn't been started already.
732
-
733
- if (!state.flowing) {
734
- debug('pipe resume');
735
- src.resume();
736
- }
737
-
738
- return dest;
739
- };
740
-
741
- function pipeOnDrain(src) {
742
- return function pipeOnDrainFunctionResult() {
743
- var state = src._readableState;
744
- debug('pipeOnDrain', state.awaitDrain);
745
- if (state.awaitDrain) state.awaitDrain--;
746
-
747
- if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {
748
- state.flowing = true;
749
- flow(src);
750
- }
751
- };
752
- }
753
-
754
- Readable.prototype.unpipe = function (dest) {
755
- var state = this._readableState;
756
- var unpipeInfo = {
757
- hasUnpiped: false
758
- }; // if we're not piping anywhere, then do nothing.
759
-
760
- if (state.pipesCount === 0) return this; // just one destination. most common case.
761
-
762
- if (state.pipesCount === 1) {
763
- // passed in one, but it's not the right one.
764
- if (dest && dest !== state.pipes) return this;
765
- if (!dest) dest = state.pipes; // got a match.
766
-
767
- state.pipes = null;
768
- state.pipesCount = 0;
769
- state.flowing = false;
770
- if (dest) dest.emit('unpipe', this, unpipeInfo);
771
- return this;
772
- } // slow case. multiple pipe destinations.
773
-
774
-
775
- if (!dest) {
776
- // remove all.
777
- var dests = state.pipes;
778
- var len = state.pipesCount;
779
- state.pipes = null;
780
- state.pipesCount = 0;
781
- state.flowing = false;
782
-
783
- for (var i = 0; i < len; i++) {
784
- dests[i].emit('unpipe', this, {
785
- hasUnpiped: false
786
- });
787
- }
788
-
789
- return this;
790
- } // try to find the right one.
791
-
792
-
793
- var index = indexOf(state.pipes, dest);
794
- if (index === -1) return this;
795
- state.pipes.splice(index, 1);
796
- state.pipesCount -= 1;
797
- if (state.pipesCount === 1) state.pipes = state.pipes[0];
798
- dest.emit('unpipe', this, unpipeInfo);
799
- return this;
800
- }; // set up data events if they are asked for
801
- // Ensure readable listeners eventually get something
802
-
803
-
804
- Readable.prototype.on = function (ev, fn) {
805
- var res = Stream.prototype.on.call(this, ev, fn);
806
- var state = this._readableState;
807
-
808
- if (ev === 'data') {
809
- // update readableListening so that resume() may be a no-op
810
- // a few lines down. This is needed to support once('readable').
811
- state.readableListening = this.listenerCount('readable') > 0; // Try start flowing on next tick if stream isn't explicitly paused
812
-
813
- if (state.flowing !== false) this.resume();
814
- } else if (ev === 'readable') {
815
- if (!state.endEmitted && !state.readableListening) {
816
- state.readableListening = state.needReadable = true;
817
- state.flowing = false;
818
- state.emittedReadable = false;
819
- debug('on readable', state.length, state.reading);
820
-
821
- if (state.length) {
822
- emitReadable(this);
823
- } else if (!state.reading) {
824
- process.nextTick(nReadingNextTick, this);
825
- }
826
- }
827
- }
828
-
829
- return res;
830
- };
831
-
832
- Readable.prototype.addListener = Readable.prototype.on;
833
-
834
- Readable.prototype.removeListener = function (ev, fn) {
835
- var res = Stream.prototype.removeListener.call(this, ev, fn);
836
-
837
- if (ev === 'readable') {
838
- // We need to check if there is someone still listening to
839
- // readable and reset the state. However this needs to happen
840
- // after readable has been emitted but before I/O (nextTick) to
841
- // support once('readable', fn) cycles. This means that calling
842
- // resume within the same tick will have no
843
- // effect.
844
- process.nextTick(updateReadableListening, this);
845
- }
846
-
847
- return res;
848
- };
849
-
850
- Readable.prototype.removeAllListeners = function (ev) {
851
- var res = Stream.prototype.removeAllListeners.apply(this, arguments);
852
-
853
- if (ev === 'readable' || ev === undefined) {
854
- // We need to check if there is someone still listening to
855
- // readable and reset the state. However this needs to happen
856
- // after readable has been emitted but before I/O (nextTick) to
857
- // support once('readable', fn) cycles. This means that calling
858
- // resume within the same tick will have no
859
- // effect.
860
- process.nextTick(updateReadableListening, this);
861
- }
862
-
863
- return res;
864
- };
865
-
866
- function updateReadableListening(self) {
867
- var state = self._readableState;
868
- state.readableListening = self.listenerCount('readable') > 0;
869
-
870
- if (state.resumeScheduled && !state.paused) {
871
- // flowing needs to be set to true now, otherwise
872
- // the upcoming resume will not flow.
873
- state.flowing = true; // crude way to check if we should resume
874
- } else if (self.listenerCount('data') > 0) {
875
- self.resume();
876
- }
877
- }
878
-
879
- function nReadingNextTick(self) {
880
- debug('readable nexttick read 0');
881
- self.read(0);
882
- } // pause() and resume() are remnants of the legacy readable stream API
883
- // If the user uses them, then switch into old mode.
884
-
885
-
886
- Readable.prototype.resume = function () {
887
- var state = this._readableState;
888
-
889
- if (!state.flowing) {
890
- debug('resume'); // we flow only if there is no one listening
891
- // for readable, but we still have to call
892
- // resume()
893
-
894
- state.flowing = !state.readableListening;
895
- resume(this, state);
896
- }
897
-
898
- state.paused = false;
899
- return this;
900
- };
901
-
902
- function resume(stream, state) {
903
- if (!state.resumeScheduled) {
904
- state.resumeScheduled = true;
905
- process.nextTick(resume_, stream, state);
906
- }
907
- }
908
-
909
- function resume_(stream, state) {
910
- debug('resume', state.reading);
911
-
912
- if (!state.reading) {
913
- stream.read(0);
914
- }
915
-
916
- state.resumeScheduled = false;
917
- stream.emit('resume');
918
- flow(stream);
919
- if (state.flowing && !state.reading) stream.read(0);
920
- }
921
-
922
- Readable.prototype.pause = function () {
923
- debug('call pause flowing=%j', this._readableState.flowing);
924
-
925
- if (this._readableState.flowing !== false) {
926
- debug('pause');
927
- this._readableState.flowing = false;
928
- this.emit('pause');
929
- }
930
-
931
- this._readableState.paused = true;
932
- return this;
933
- };
934
-
935
- function flow(stream) {
936
- var state = stream._readableState;
937
- debug('flow', state.flowing);
938
-
939
- while (state.flowing && stream.read() !== null) {
940
- ;
941
- }
942
- } // wrap an old-style stream as the async data source.
943
- // This is *not* part of the readable stream interface.
944
- // It is an ugly unfortunate mess of history.
945
-
946
-
947
- Readable.prototype.wrap = function (stream) {
948
- var _this = this;
949
-
950
- var state = this._readableState;
951
- var paused = false;
952
- stream.on('end', function () {
953
- debug('wrapped end');
954
-
955
- if (state.decoder && !state.ended) {
956
- var chunk = state.decoder.end();
957
- if (chunk && chunk.length) _this.push(chunk);
958
- }
959
-
960
- _this.push(null);
961
- });
962
- stream.on('data', function (chunk) {
963
- debug('wrapped data');
964
- if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode
965
-
966
- if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;
967
-
968
- var ret = _this.push(chunk);
969
-
970
- if (!ret) {
971
- paused = true;
972
- stream.pause();
973
- }
974
- }); // proxy all the other methods.
975
- // important when wrapping filters and duplexes.
976
-
977
- for (var i in stream) {
978
- if (this[i] === undefined && typeof stream[i] === 'function') {
979
- this[i] = function methodWrap(method) {
980
- return function methodWrapReturnFunction() {
981
- return stream[method].apply(stream, arguments);
982
- };
983
- }(i);
984
- }
985
- } // proxy certain important events.
986
-
987
-
988
- for (var n = 0; n < kProxyEvents.length; n++) {
989
- stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));
990
- } // when we try to consume some more bytes, simply unpause the
991
- // underlying stream.
992
-
993
-
994
- this._read = function (n) {
995
- debug('wrapped _read', n);
996
-
997
- if (paused) {
998
- paused = false;
999
- stream.resume();
1000
- }
1001
- };
1002
-
1003
- return this;
1004
- };
1005
-
1006
- if (typeof Symbol === 'function') {
1007
- Readable.prototype[Symbol.asyncIterator] = function () {
1008
- if (createReadableStreamAsyncIterator === undefined) {
1009
- createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');
1010
- }
1011
-
1012
- return createReadableStreamAsyncIterator(this);
1013
- };
1014
- }
1015
-
1016
- Object.defineProperty(Readable.prototype, 'readableHighWaterMark', {
1017
- // making it explicit this property is not enumerable
1018
- // because otherwise some prototype manipulation in
1019
- // userland will fail
1020
- enumerable: false,
1021
- get: function get() {
1022
- return this._readableState.highWaterMark;
1023
- }
1024
- });
1025
- Object.defineProperty(Readable.prototype, 'readableBuffer', {
1026
- // making it explicit this property is not enumerable
1027
- // because otherwise some prototype manipulation in
1028
- // userland will fail
1029
- enumerable: false,
1030
- get: function get() {
1031
- return this._readableState && this._readableState.buffer;
1032
- }
1033
- });
1034
- Object.defineProperty(Readable.prototype, 'readableFlowing', {
1035
- // making it explicit this property is not enumerable
1036
- // because otherwise some prototype manipulation in
1037
- // userland will fail
1038
- enumerable: false,
1039
- get: function get() {
1040
- return this._readableState.flowing;
1041
- },
1042
- set: function set(state) {
1043
- if (this._readableState) {
1044
- this._readableState.flowing = state;
1045
- }
1046
- }
1047
- }); // exposed for testing purposes only.
1048
-
1049
- Readable._fromList = fromList;
1050
- Object.defineProperty(Readable.prototype, 'readableLength', {
1051
- // making it explicit this property is not enumerable
1052
- // because otherwise some prototype manipulation in
1053
- // userland will fail
1054
- enumerable: false,
1055
- get: function get() {
1056
- return this._readableState.length;
1057
- }
1058
- }); // Pluck off n bytes from an array of buffers.
1059
- // Length is the combined lengths of all the buffers in the list.
1060
- // This function is designed to be inlinable, so please take care when making
1061
- // changes to the function body.
1062
-
1063
- function fromList(n, state) {
1064
- // nothing buffered
1065
- if (state.length === 0) return null;
1066
- var ret;
1067
- if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {
1068
- // read it all, truncate the list
1069
- if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);
1070
- state.buffer.clear();
1071
- } else {
1072
- // read part of list
1073
- ret = state.buffer.consume(n, state.decoder);
1074
- }
1075
- return ret;
1076
- }
1077
-
1078
- function endReadable(stream) {
1079
- var state = stream._readableState;
1080
- debug('endReadable', state.endEmitted);
1081
-
1082
- if (!state.endEmitted) {
1083
- state.ended = true;
1084
- process.nextTick(endReadableNT, state, stream);
1085
- }
1086
- }
1087
-
1088
- function endReadableNT(state, stream) {
1089
- debug('endReadableNT', state.endEmitted, state.length); // Check that we didn't get one last unshift.
1090
-
1091
- if (!state.endEmitted && state.length === 0) {
1092
- state.endEmitted = true;
1093
- stream.readable = false;
1094
- stream.emit('end');
1095
-
1096
- if (state.autoDestroy) {
1097
- // In case of duplex streams we need a way to detect
1098
- // if the writable side is ready for autoDestroy as well
1099
- var wState = stream._writableState;
1100
-
1101
- if (!wState || wState.autoDestroy && wState.finished) {
1102
- stream.destroy();
1103
- }
1104
- }
1105
- }
1106
- }
1107
-
1108
- if (typeof Symbol === 'function') {
1109
- Readable.from = function (iterable, opts) {
1110
- if (from === undefined) {
1111
- from = require('./internal/streams/from');
1112
- }
1113
-
1114
- return from(Readable, iterable, opts);
1115
- };
1116
- }
1117
-
1118
- function indexOf(xs, x) {
1119
- for (var i = 0, l = xs.length; i < l; i++) {
1120
- if (xs[i] === x) return i;
1121
- }
1122
-
1123
- return -1;
1124
- }