deepv-code 1.0.182 → 1.0.185

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 (193) hide show
  1. package/bundle/dvcode.js +757 -753
  2. package/package.json +1 -1
  3. package/bundle/assets/help/README.md +0 -113
  4. package/bundle/assets/sounds/README.md +0 -74
  5. package/bundle/node_modules/undici/LICENSE +0 -21
  6. package/bundle/node_modules/undici/README.md +0 -472
  7. package/bundle/node_modules/undici/docs/docs/api/Agent.md +0 -83
  8. package/bundle/node_modules/undici/docs/docs/api/BalancedPool.md +0 -99
  9. package/bundle/node_modules/undici/docs/docs/api/CacheStorage.md +0 -30
  10. package/bundle/node_modules/undici/docs/docs/api/CacheStore.md +0 -151
  11. package/bundle/node_modules/undici/docs/docs/api/Client.md +0 -281
  12. package/bundle/node_modules/undici/docs/docs/api/ClientStats.md +0 -27
  13. package/bundle/node_modules/undici/docs/docs/api/Connector.md +0 -115
  14. package/bundle/node_modules/undici/docs/docs/api/ContentType.md +0 -57
  15. package/bundle/node_modules/undici/docs/docs/api/Cookies.md +0 -101
  16. package/bundle/node_modules/undici/docs/docs/api/Debug.md +0 -62
  17. package/bundle/node_modules/undici/docs/docs/api/DiagnosticsChannel.md +0 -204
  18. package/bundle/node_modules/undici/docs/docs/api/Dispatcher.md +0 -1200
  19. package/bundle/node_modules/undici/docs/docs/api/EnvHttpProxyAgent.md +0 -159
  20. package/bundle/node_modules/undici/docs/docs/api/Errors.md +0 -49
  21. package/bundle/node_modules/undici/docs/docs/api/EventSource.md +0 -45
  22. package/bundle/node_modules/undici/docs/docs/api/Fetch.md +0 -52
  23. package/bundle/node_modules/undici/docs/docs/api/H2CClient.md +0 -262
  24. package/bundle/node_modules/undici/docs/docs/api/MockAgent.md +0 -603
  25. package/bundle/node_modules/undici/docs/docs/api/MockCallHistory.md +0 -197
  26. package/bundle/node_modules/undici/docs/docs/api/MockCallHistoryLog.md +0 -43
  27. package/bundle/node_modules/undici/docs/docs/api/MockClient.md +0 -77
  28. package/bundle/node_modules/undici/docs/docs/api/MockErrors.md +0 -12
  29. package/bundle/node_modules/undici/docs/docs/api/MockPool.md +0 -548
  30. package/bundle/node_modules/undici/docs/docs/api/Pool.md +0 -84
  31. package/bundle/node_modules/undici/docs/docs/api/PoolStats.md +0 -35
  32. package/bundle/node_modules/undici/docs/docs/api/ProxyAgent.md +0 -227
  33. package/bundle/node_modules/undici/docs/docs/api/RedirectHandler.md +0 -96
  34. package/bundle/node_modules/undici/docs/docs/api/RetryAgent.md +0 -45
  35. package/bundle/node_modules/undici/docs/docs/api/RetryHandler.md +0 -117
  36. package/bundle/node_modules/undici/docs/docs/api/Util.md +0 -25
  37. package/bundle/node_modules/undici/docs/docs/api/WebSocket.md +0 -85
  38. package/bundle/node_modules/undici/docs/docs/api/api-lifecycle.md +0 -91
  39. package/bundle/node_modules/undici/docs/docs/best-practices/client-certificate.md +0 -64
  40. package/bundle/node_modules/undici/docs/docs/best-practices/mocking-request.md +0 -190
  41. package/bundle/node_modules/undici/docs/docs/best-practices/proxy.md +0 -127
  42. package/bundle/node_modules/undici/docs/docs/best-practices/writing-tests.md +0 -20
  43. package/bundle/node_modules/undici/index-fetch.js +0 -35
  44. package/bundle/node_modules/undici/index.d.ts +0 -3
  45. package/bundle/node_modules/undici/index.js +0 -183
  46. package/bundle/node_modules/undici/lib/api/abort-signal.js +0 -59
  47. package/bundle/node_modules/undici/lib/api/api-connect.js +0 -110
  48. package/bundle/node_modules/undici/lib/api/api-pipeline.js +0 -252
  49. package/bundle/node_modules/undici/lib/api/api-request.js +0 -199
  50. package/bundle/node_modules/undici/lib/api/api-stream.js +0 -209
  51. package/bundle/node_modules/undici/lib/api/api-upgrade.js +0 -110
  52. package/bundle/node_modules/undici/lib/api/index.js +0 -7
  53. package/bundle/node_modules/undici/lib/api/readable.js +0 -558
  54. package/bundle/node_modules/undici/lib/api/util.js +0 -95
  55. package/bundle/node_modules/undici/lib/cache/memory-cache-store.js +0 -234
  56. package/bundle/node_modules/undici/lib/cache/sqlite-cache-store.js +0 -461
  57. package/bundle/node_modules/undici/lib/core/connect.js +0 -164
  58. package/bundle/node_modules/undici/lib/core/constants.js +0 -143
  59. package/bundle/node_modules/undici/lib/core/diagnostics.js +0 -196
  60. package/bundle/node_modules/undici/lib/core/errors.js +0 -244
  61. package/bundle/node_modules/undici/lib/core/request.js +0 -397
  62. package/bundle/node_modules/undici/lib/core/symbols.js +0 -68
  63. package/bundle/node_modules/undici/lib/core/tree.js +0 -160
  64. package/bundle/node_modules/undici/lib/core/util.js +0 -988
  65. package/bundle/node_modules/undici/lib/dispatcher/agent.js +0 -135
  66. package/bundle/node_modules/undici/lib/dispatcher/balanced-pool.js +0 -206
  67. package/bundle/node_modules/undici/lib/dispatcher/client-h1.js +0 -1615
  68. package/bundle/node_modules/undici/lib/dispatcher/client-h2.js +0 -798
  69. package/bundle/node_modules/undici/lib/dispatcher/client.js +0 -614
  70. package/bundle/node_modules/undici/lib/dispatcher/dispatcher-base.js +0 -161
  71. package/bundle/node_modules/undici/lib/dispatcher/dispatcher.js +0 -48
  72. package/bundle/node_modules/undici/lib/dispatcher/env-http-proxy-agent.js +0 -151
  73. package/bundle/node_modules/undici/lib/dispatcher/fixed-queue.js +0 -159
  74. package/bundle/node_modules/undici/lib/dispatcher/h2c-client.js +0 -122
  75. package/bundle/node_modules/undici/lib/dispatcher/pool-base.js +0 -191
  76. package/bundle/node_modules/undici/lib/dispatcher/pool.js +0 -118
  77. package/bundle/node_modules/undici/lib/dispatcher/proxy-agent.js +0 -275
  78. package/bundle/node_modules/undici/lib/dispatcher/retry-agent.js +0 -35
  79. package/bundle/node_modules/undici/lib/global.js +0 -32
  80. package/bundle/node_modules/undici/lib/handler/cache-handler.js +0 -448
  81. package/bundle/node_modules/undici/lib/handler/cache-revalidation-handler.js +0 -124
  82. package/bundle/node_modules/undici/lib/handler/decorator-handler.js +0 -67
  83. package/bundle/node_modules/undici/lib/handler/redirect-handler.js +0 -227
  84. package/bundle/node_modules/undici/lib/handler/retry-handler.js +0 -342
  85. package/bundle/node_modules/undici/lib/handler/unwrap-handler.js +0 -96
  86. package/bundle/node_modules/undici/lib/handler/wrap-handler.js +0 -95
  87. package/bundle/node_modules/undici/lib/interceptor/cache.js +0 -372
  88. package/bundle/node_modules/undici/lib/interceptor/dns.js +0 -432
  89. package/bundle/node_modules/undici/lib/interceptor/dump.js +0 -111
  90. package/bundle/node_modules/undici/lib/interceptor/redirect.js +0 -21
  91. package/bundle/node_modules/undici/lib/interceptor/response-error.js +0 -95
  92. package/bundle/node_modules/undici/lib/interceptor/retry.js +0 -19
  93. package/bundle/node_modules/undici/lib/llhttp/.gitkeep +0 -0
  94. package/bundle/node_modules/undici/lib/llhttp/constants.d.ts +0 -97
  95. package/bundle/node_modules/undici/lib/llhttp/constants.js +0 -498
  96. package/bundle/node_modules/undici/lib/llhttp/constants.js.map +0 -1
  97. package/bundle/node_modules/undici/lib/llhttp/llhttp-wasm.js +0 -15
  98. package/bundle/node_modules/undici/lib/llhttp/llhttp_simd-wasm.js +0 -15
  99. package/bundle/node_modules/undici/lib/llhttp/utils.d.ts +0 -2
  100. package/bundle/node_modules/undici/lib/llhttp/utils.js +0 -15
  101. package/bundle/node_modules/undici/lib/llhttp/utils.js.map +0 -1
  102. package/bundle/node_modules/undici/lib/mock/mock-agent.js +0 -224
  103. package/bundle/node_modules/undici/lib/mock/mock-call-history.js +0 -248
  104. package/bundle/node_modules/undici/lib/mock/mock-client.js +0 -64
  105. package/bundle/node_modules/undici/lib/mock/mock-errors.js +0 -19
  106. package/bundle/node_modules/undici/lib/mock/mock-interceptor.js +0 -209
  107. package/bundle/node_modules/undici/lib/mock/mock-pool.js +0 -64
  108. package/bundle/node_modules/undici/lib/mock/mock-symbols.js +0 -31
  109. package/bundle/node_modules/undici/lib/mock/mock-utils.js +0 -433
  110. package/bundle/node_modules/undici/lib/mock/pending-interceptors-formatter.js +0 -43
  111. package/bundle/node_modules/undici/lib/util/cache.js +0 -368
  112. package/bundle/node_modules/undici/lib/util/date.js +0 -259
  113. package/bundle/node_modules/undici/lib/util/stats.js +0 -32
  114. package/bundle/node_modules/undici/lib/util/timers.js +0 -423
  115. package/bundle/node_modules/undici/lib/web/cache/cache.js +0 -862
  116. package/bundle/node_modules/undici/lib/web/cache/cachestorage.js +0 -152
  117. package/bundle/node_modules/undici/lib/web/cache/util.js +0 -45
  118. package/bundle/node_modules/undici/lib/web/cookies/constants.js +0 -12
  119. package/bundle/node_modules/undici/lib/web/cookies/index.js +0 -199
  120. package/bundle/node_modules/undici/lib/web/cookies/parse.js +0 -322
  121. package/bundle/node_modules/undici/lib/web/cookies/util.js +0 -282
  122. package/bundle/node_modules/undici/lib/web/eventsource/eventsource-stream.js +0 -399
  123. package/bundle/node_modules/undici/lib/web/eventsource/eventsource.js +0 -484
  124. package/bundle/node_modules/undici/lib/web/eventsource/util.js +0 -37
  125. package/bundle/node_modules/undici/lib/web/fetch/LICENSE +0 -21
  126. package/bundle/node_modules/undici/lib/web/fetch/body.js +0 -532
  127. package/bundle/node_modules/undici/lib/web/fetch/constants.js +0 -131
  128. package/bundle/node_modules/undici/lib/web/fetch/data-url.js +0 -744
  129. package/bundle/node_modules/undici/lib/web/fetch/dispatcher-weakref.js +0 -46
  130. package/bundle/node_modules/undici/lib/web/fetch/formdata-parser.js +0 -501
  131. package/bundle/node_modules/undici/lib/web/fetch/formdata.js +0 -263
  132. package/bundle/node_modules/undici/lib/web/fetch/global.js +0 -40
  133. package/bundle/node_modules/undici/lib/web/fetch/headers.js +0 -719
  134. package/bundle/node_modules/undici/lib/web/fetch/index.js +0 -2258
  135. package/bundle/node_modules/undici/lib/web/fetch/request.js +0 -1099
  136. package/bundle/node_modules/undici/lib/web/fetch/response.js +0 -636
  137. package/bundle/node_modules/undici/lib/web/fetch/util.js +0 -1782
  138. package/bundle/node_modules/undici/lib/web/fetch/webidl.js +0 -740
  139. package/bundle/node_modules/undici/lib/web/websocket/connection.js +0 -325
  140. package/bundle/node_modules/undici/lib/web/websocket/constants.js +0 -126
  141. package/bundle/node_modules/undici/lib/web/websocket/events.js +0 -331
  142. package/bundle/node_modules/undici/lib/web/websocket/frame.js +0 -138
  143. package/bundle/node_modules/undici/lib/web/websocket/permessage-deflate.js +0 -70
  144. package/bundle/node_modules/undici/lib/web/websocket/receiver.js +0 -454
  145. package/bundle/node_modules/undici/lib/web/websocket/sender.js +0 -109
  146. package/bundle/node_modules/undici/lib/web/websocket/stream/websocketerror.js +0 -83
  147. package/bundle/node_modules/undici/lib/web/websocket/stream/websocketstream.js +0 -485
  148. package/bundle/node_modules/undici/lib/web/websocket/util.js +0 -338
  149. package/bundle/node_modules/undici/lib/web/websocket/websocket.js +0 -686
  150. package/bundle/node_modules/undici/package.json +0 -149
  151. package/bundle/node_modules/undici/scripts/strip-comments.js +0 -10
  152. package/bundle/node_modules/undici/types/README.md +0 -6
  153. package/bundle/node_modules/undici/types/agent.d.ts +0 -35
  154. package/bundle/node_modules/undici/types/api.d.ts +0 -43
  155. package/bundle/node_modules/undici/types/balanced-pool.d.ts +0 -29
  156. package/bundle/node_modules/undici/types/cache-interceptor.d.ts +0 -172
  157. package/bundle/node_modules/undici/types/cache.d.ts +0 -36
  158. package/bundle/node_modules/undici/types/client-stats.d.ts +0 -15
  159. package/bundle/node_modules/undici/types/client.d.ts +0 -110
  160. package/bundle/node_modules/undici/types/connector.d.ts +0 -34
  161. package/bundle/node_modules/undici/types/content-type.d.ts +0 -21
  162. package/bundle/node_modules/undici/types/cookies.d.ts +0 -30
  163. package/bundle/node_modules/undici/types/diagnostics-channel.d.ts +0 -66
  164. package/bundle/node_modules/undici/types/dispatcher.d.ts +0 -281
  165. package/bundle/node_modules/undici/types/env-http-proxy-agent.d.ts +0 -21
  166. package/bundle/node_modules/undici/types/errors.d.ts +0 -171
  167. package/bundle/node_modules/undici/types/eventsource.d.ts +0 -61
  168. package/bundle/node_modules/undici/types/fetch.d.ts +0 -210
  169. package/bundle/node_modules/undici/types/formdata.d.ts +0 -108
  170. package/bundle/node_modules/undici/types/global-dispatcher.d.ts +0 -9
  171. package/bundle/node_modules/undici/types/global-origin.d.ts +0 -7
  172. package/bundle/node_modules/undici/types/h2c-client.d.ts +0 -75
  173. package/bundle/node_modules/undici/types/handlers.d.ts +0 -15
  174. package/bundle/node_modules/undici/types/header.d.ts +0 -160
  175. package/bundle/node_modules/undici/types/index.d.ts +0 -75
  176. package/bundle/node_modules/undici/types/interceptors.d.ts +0 -34
  177. package/bundle/node_modules/undici/types/mock-agent.d.ts +0 -68
  178. package/bundle/node_modules/undici/types/mock-call-history.d.ts +0 -111
  179. package/bundle/node_modules/undici/types/mock-client.d.ts +0 -25
  180. package/bundle/node_modules/undici/types/mock-errors.d.ts +0 -12
  181. package/bundle/node_modules/undici/types/mock-interceptor.d.ts +0 -93
  182. package/bundle/node_modules/undici/types/mock-pool.d.ts +0 -25
  183. package/bundle/node_modules/undici/types/patch.d.ts +0 -29
  184. package/bundle/node_modules/undici/types/pool-stats.d.ts +0 -19
  185. package/bundle/node_modules/undici/types/pool.d.ts +0 -41
  186. package/bundle/node_modules/undici/types/proxy-agent.d.ts +0 -29
  187. package/bundle/node_modules/undici/types/readable.d.ts +0 -68
  188. package/bundle/node_modules/undici/types/retry-agent.d.ts +0 -8
  189. package/bundle/node_modules/undici/types/retry-handler.d.ts +0 -116
  190. package/bundle/node_modules/undici/types/util.d.ts +0 -18
  191. package/bundle/node_modules/undici/types/utility.d.ts +0 -7
  192. package/bundle/node_modules/undici/types/webidl.d.ts +0 -266
  193. package/bundle/node_modules/undici/types/websocket.d.ts +0 -184
@@ -1,744 +0,0 @@
1
- 'use strict'
2
-
3
- const assert = require('node:assert')
4
-
5
- const encoder = new TextEncoder()
6
-
7
- /**
8
- * @see https://mimesniff.spec.whatwg.org/#http-token-code-point
9
- */
10
- const HTTP_TOKEN_CODEPOINTS = /^[!#$%&'*+\-.^_|~A-Za-z0-9]+$/
11
- const HTTP_WHITESPACE_REGEX = /[\u000A\u000D\u0009\u0020]/ // eslint-disable-line
12
- const ASCII_WHITESPACE_REPLACE_REGEX = /[\u0009\u000A\u000C\u000D\u0020]/g // eslint-disable-line
13
- /**
14
- * @see https://mimesniff.spec.whatwg.org/#http-quoted-string-token-code-point
15
- */
16
- const HTTP_QUOTED_STRING_TOKENS = /^[\u0009\u0020-\u007E\u0080-\u00FF]+$/ // eslint-disable-line
17
-
18
- // https://fetch.spec.whatwg.org/#data-url-processor
19
- /** @param {URL} dataURL */
20
- function dataURLProcessor (dataURL) {
21
- // 1. Assert: dataURL’s scheme is "data".
22
- assert(dataURL.protocol === 'data:')
23
-
24
- // 2. Let input be the result of running the URL
25
- // serializer on dataURL with exclude fragment
26
- // set to true.
27
- let input = URLSerializer(dataURL, true)
28
-
29
- // 3. Remove the leading "data:" string from input.
30
- input = input.slice(5)
31
-
32
- // 4. Let position point at the start of input.
33
- const position = { position: 0 }
34
-
35
- // 5. Let mimeType be the result of collecting a
36
- // sequence of code points that are not equal
37
- // to U+002C (,), given position.
38
- let mimeType = collectASequenceOfCodePointsFast(
39
- ',',
40
- input,
41
- position
42
- )
43
-
44
- // 6. Strip leading and trailing ASCII whitespace
45
- // from mimeType.
46
- // Undici implementation note: we need to store the
47
- // length because if the mimetype has spaces removed,
48
- // the wrong amount will be sliced from the input in
49
- // step #9
50
- const mimeTypeLength = mimeType.length
51
- mimeType = removeASCIIWhitespace(mimeType, true, true)
52
-
53
- // 7. If position is past the end of input, then
54
- // return failure
55
- if (position.position >= input.length) {
56
- return 'failure'
57
- }
58
-
59
- // 8. Advance position by 1.
60
- position.position++
61
-
62
- // 9. Let encodedBody be the remainder of input.
63
- const encodedBody = input.slice(mimeTypeLength + 1)
64
-
65
- // 10. Let body be the percent-decoding of encodedBody.
66
- let body = stringPercentDecode(encodedBody)
67
-
68
- // 11. If mimeType ends with U+003B (;), followed by
69
- // zero or more U+0020 SPACE, followed by an ASCII
70
- // case-insensitive match for "base64", then:
71
- if (/;(\u0020){0,}base64$/i.test(mimeType)) {
72
- // 1. Let stringBody be the isomorphic decode of body.
73
- const stringBody = isomorphicDecode(body)
74
-
75
- // 2. Set body to the forgiving-base64 decode of
76
- // stringBody.
77
- body = forgivingBase64(stringBody)
78
-
79
- // 3. If body is failure, then return failure.
80
- if (body === 'failure') {
81
- return 'failure'
82
- }
83
-
84
- // 4. Remove the last 6 code points from mimeType.
85
- mimeType = mimeType.slice(0, -6)
86
-
87
- // 5. Remove trailing U+0020 SPACE code points from mimeType,
88
- // if any.
89
- mimeType = mimeType.replace(/(\u0020)+$/, '')
90
-
91
- // 6. Remove the last U+003B (;) code point from mimeType.
92
- mimeType = mimeType.slice(0, -1)
93
- }
94
-
95
- // 12. If mimeType starts with U+003B (;), then prepend
96
- // "text/plain" to mimeType.
97
- if (mimeType.startsWith(';')) {
98
- mimeType = 'text/plain' + mimeType
99
- }
100
-
101
- // 13. Let mimeTypeRecord be the result of parsing
102
- // mimeType.
103
- let mimeTypeRecord = parseMIMEType(mimeType)
104
-
105
- // 14. If mimeTypeRecord is failure, then set
106
- // mimeTypeRecord to text/plain;charset=US-ASCII.
107
- if (mimeTypeRecord === 'failure') {
108
- mimeTypeRecord = parseMIMEType('text/plain;charset=US-ASCII')
109
- }
110
-
111
- // 15. Return a new data: URL struct whose MIME
112
- // type is mimeTypeRecord and body is body.
113
- // https://fetch.spec.whatwg.org/#data-url-struct
114
- return { mimeType: mimeTypeRecord, body }
115
- }
116
-
117
- // https://url.spec.whatwg.org/#concept-url-serializer
118
- /**
119
- * @param {URL} url
120
- * @param {boolean} excludeFragment
121
- */
122
- function URLSerializer (url, excludeFragment = false) {
123
- if (!excludeFragment) {
124
- return url.href
125
- }
126
-
127
- const href = url.href
128
- const hashLength = url.hash.length
129
-
130
- const serialized = hashLength === 0 ? href : href.substring(0, href.length - hashLength)
131
-
132
- if (!hashLength && href.endsWith('#')) {
133
- return serialized.slice(0, -1)
134
- }
135
-
136
- return serialized
137
- }
138
-
139
- // https://infra.spec.whatwg.org/#collect-a-sequence-of-code-points
140
- /**
141
- * @param {(char: string) => boolean} condition
142
- * @param {string} input
143
- * @param {{ position: number }} position
144
- */
145
- function collectASequenceOfCodePoints (condition, input, position) {
146
- // 1. Let result be the empty string.
147
- let result = ''
148
-
149
- // 2. While position doesn’t point past the end of input and the
150
- // code point at position within input meets the condition condition:
151
- while (position.position < input.length && condition(input[position.position])) {
152
- // 1. Append that code point to the end of result.
153
- result += input[position.position]
154
-
155
- // 2. Advance position by 1.
156
- position.position++
157
- }
158
-
159
- // 3. Return result.
160
- return result
161
- }
162
-
163
- /**
164
- * A faster collectASequenceOfCodePoints that only works when comparing a single character.
165
- * @param {string} char
166
- * @param {string} input
167
- * @param {{ position: number }} position
168
- */
169
- function collectASequenceOfCodePointsFast (char, input, position) {
170
- const idx = input.indexOf(char, position.position)
171
- const start = position.position
172
-
173
- if (idx === -1) {
174
- position.position = input.length
175
- return input.slice(start)
176
- }
177
-
178
- position.position = idx
179
- return input.slice(start, position.position)
180
- }
181
-
182
- // https://url.spec.whatwg.org/#string-percent-decode
183
- /** @param {string} input */
184
- function stringPercentDecode (input) {
185
- // 1. Let bytes be the UTF-8 encoding of input.
186
- const bytes = encoder.encode(input)
187
-
188
- // 2. Return the percent-decoding of bytes.
189
- return percentDecode(bytes)
190
- }
191
-
192
- /**
193
- * @param {number} byte
194
- */
195
- function isHexCharByte (byte) {
196
- // 0-9 A-F a-f
197
- return (byte >= 0x30 && byte <= 0x39) || (byte >= 0x41 && byte <= 0x46) || (byte >= 0x61 && byte <= 0x66)
198
- }
199
-
200
- /**
201
- * @param {number} byte
202
- */
203
- function hexByteToNumber (byte) {
204
- return (
205
- // 0-9
206
- byte >= 0x30 && byte <= 0x39
207
- ? (byte - 48)
208
- // Convert to uppercase
209
- // ((byte & 0xDF) - 65) + 10
210
- : ((byte & 0xDF) - 55)
211
- )
212
- }
213
-
214
- // https://url.spec.whatwg.org/#percent-decode
215
- /** @param {Uint8Array} input */
216
- function percentDecode (input) {
217
- const length = input.length
218
- // 1. Let output be an empty byte sequence.
219
- /** @type {Uint8Array} */
220
- const output = new Uint8Array(length)
221
- let j = 0
222
- // 2. For each byte byte in input:
223
- for (let i = 0; i < length; ++i) {
224
- const byte = input[i]
225
-
226
- // 1. If byte is not 0x25 (%), then append byte to output.
227
- if (byte !== 0x25) {
228
- output[j++] = byte
229
-
230
- // 2. Otherwise, if byte is 0x25 (%) and the next two bytes
231
- // after byte in input are not in the ranges
232
- // 0x30 (0) to 0x39 (9), 0x41 (A) to 0x46 (F),
233
- // and 0x61 (a) to 0x66 (f), all inclusive, append byte
234
- // to output.
235
- } else if (
236
- byte === 0x25 &&
237
- !(isHexCharByte(input[i + 1]) && isHexCharByte(input[i + 2]))
238
- ) {
239
- output[j++] = 0x25
240
-
241
- // 3. Otherwise:
242
- } else {
243
- // 1. Let bytePoint be the two bytes after byte in input,
244
- // decoded, and then interpreted as hexadecimal number.
245
- // 2. Append a byte whose value is bytePoint to output.
246
- output[j++] = (hexByteToNumber(input[i + 1]) << 4) | hexByteToNumber(input[i + 2])
247
-
248
- // 3. Skip the next two bytes in input.
249
- i += 2
250
- }
251
- }
252
-
253
- // 3. Return output.
254
- return length === j ? output : output.subarray(0, j)
255
- }
256
-
257
- // https://mimesniff.spec.whatwg.org/#parse-a-mime-type
258
- /** @param {string} input */
259
- function parseMIMEType (input) {
260
- // 1. Remove any leading and trailing HTTP whitespace
261
- // from input.
262
- input = removeHTTPWhitespace(input, true, true)
263
-
264
- // 2. Let position be a position variable for input,
265
- // initially pointing at the start of input.
266
- const position = { position: 0 }
267
-
268
- // 3. Let type be the result of collecting a sequence
269
- // of code points that are not U+002F (/) from
270
- // input, given position.
271
- const type = collectASequenceOfCodePointsFast(
272
- '/',
273
- input,
274
- position
275
- )
276
-
277
- // 4. If type is the empty string or does not solely
278
- // contain HTTP token code points, then return failure.
279
- // https://mimesniff.spec.whatwg.org/#http-token-code-point
280
- if (type.length === 0 || !HTTP_TOKEN_CODEPOINTS.test(type)) {
281
- return 'failure'
282
- }
283
-
284
- // 5. If position is past the end of input, then return
285
- // failure
286
- if (position.position >= input.length) {
287
- return 'failure'
288
- }
289
-
290
- // 6. Advance position by 1. (This skips past U+002F (/).)
291
- position.position++
292
-
293
- // 7. Let subtype be the result of collecting a sequence of
294
- // code points that are not U+003B (;) from input, given
295
- // position.
296
- let subtype = collectASequenceOfCodePointsFast(
297
- ';',
298
- input,
299
- position
300
- )
301
-
302
- // 8. Remove any trailing HTTP whitespace from subtype.
303
- subtype = removeHTTPWhitespace(subtype, false, true)
304
-
305
- // 9. If subtype is the empty string or does not solely
306
- // contain HTTP token code points, then return failure.
307
- if (subtype.length === 0 || !HTTP_TOKEN_CODEPOINTS.test(subtype)) {
308
- return 'failure'
309
- }
310
-
311
- const typeLowercase = type.toLowerCase()
312
- const subtypeLowercase = subtype.toLowerCase()
313
-
314
- // 10. Let mimeType be a new MIME type record whose type
315
- // is type, in ASCII lowercase, and subtype is subtype,
316
- // in ASCII lowercase.
317
- // https://mimesniff.spec.whatwg.org/#mime-type
318
- const mimeType = {
319
- type: typeLowercase,
320
- subtype: subtypeLowercase,
321
- /** @type {Map<string, string>} */
322
- parameters: new Map(),
323
- // https://mimesniff.spec.whatwg.org/#mime-type-essence
324
- essence: `${typeLowercase}/${subtypeLowercase}`
325
- }
326
-
327
- // 11. While position is not past the end of input:
328
- while (position.position < input.length) {
329
- // 1. Advance position by 1. (This skips past U+003B (;).)
330
- position.position++
331
-
332
- // 2. Collect a sequence of code points that are HTTP
333
- // whitespace from input given position.
334
- collectASequenceOfCodePoints(
335
- // https://fetch.spec.whatwg.org/#http-whitespace
336
- char => HTTP_WHITESPACE_REGEX.test(char),
337
- input,
338
- position
339
- )
340
-
341
- // 3. Let parameterName be the result of collecting a
342
- // sequence of code points that are not U+003B (;)
343
- // or U+003D (=) from input, given position.
344
- let parameterName = collectASequenceOfCodePoints(
345
- (char) => char !== ';' && char !== '=',
346
- input,
347
- position
348
- )
349
-
350
- // 4. Set parameterName to parameterName, in ASCII
351
- // lowercase.
352
- parameterName = parameterName.toLowerCase()
353
-
354
- // 5. If position is not past the end of input, then:
355
- if (position.position < input.length) {
356
- // 1. If the code point at position within input is
357
- // U+003B (;), then continue.
358
- if (input[position.position] === ';') {
359
- continue
360
- }
361
-
362
- // 2. Advance position by 1. (This skips past U+003D (=).)
363
- position.position++
364
- }
365
-
366
- // 6. If position is past the end of input, then break.
367
- if (position.position >= input.length) {
368
- break
369
- }
370
-
371
- // 7. Let parameterValue be null.
372
- let parameterValue = null
373
-
374
- // 8. If the code point at position within input is
375
- // U+0022 ("), then:
376
- if (input[position.position] === '"') {
377
- // 1. Set parameterValue to the result of collecting
378
- // an HTTP quoted string from input, given position
379
- // and the extract-value flag.
380
- parameterValue = collectAnHTTPQuotedString(input, position, true)
381
-
382
- // 2. Collect a sequence of code points that are not
383
- // U+003B (;) from input, given position.
384
- collectASequenceOfCodePointsFast(
385
- ';',
386
- input,
387
- position
388
- )
389
-
390
- // 9. Otherwise:
391
- } else {
392
- // 1. Set parameterValue to the result of collecting
393
- // a sequence of code points that are not U+003B (;)
394
- // from input, given position.
395
- parameterValue = collectASequenceOfCodePointsFast(
396
- ';',
397
- input,
398
- position
399
- )
400
-
401
- // 2. Remove any trailing HTTP whitespace from parameterValue.
402
- parameterValue = removeHTTPWhitespace(parameterValue, false, true)
403
-
404
- // 3. If parameterValue is the empty string, then continue.
405
- if (parameterValue.length === 0) {
406
- continue
407
- }
408
- }
409
-
410
- // 10. If all of the following are true
411
- // - parameterName is not the empty string
412
- // - parameterName solely contains HTTP token code points
413
- // - parameterValue solely contains HTTP quoted-string token code points
414
- // - mimeType’s parameters[parameterName] does not exist
415
- // then set mimeType’s parameters[parameterName] to parameterValue.
416
- if (
417
- parameterName.length !== 0 &&
418
- HTTP_TOKEN_CODEPOINTS.test(parameterName) &&
419
- (parameterValue.length === 0 || HTTP_QUOTED_STRING_TOKENS.test(parameterValue)) &&
420
- !mimeType.parameters.has(parameterName)
421
- ) {
422
- mimeType.parameters.set(parameterName, parameterValue)
423
- }
424
- }
425
-
426
- // 12. Return mimeType.
427
- return mimeType
428
- }
429
-
430
- // https://infra.spec.whatwg.org/#forgiving-base64-decode
431
- /** @param {string} data */
432
- function forgivingBase64 (data) {
433
- // 1. Remove all ASCII whitespace from data.
434
- data = data.replace(ASCII_WHITESPACE_REPLACE_REGEX, '')
435
-
436
- let dataLength = data.length
437
- // 2. If data’s code point length divides by 4 leaving
438
- // no remainder, then:
439
- if (dataLength % 4 === 0) {
440
- // 1. If data ends with one or two U+003D (=) code points,
441
- // then remove them from data.
442
- if (data.charCodeAt(dataLength - 1) === 0x003D) {
443
- --dataLength
444
- if (data.charCodeAt(dataLength - 1) === 0x003D) {
445
- --dataLength
446
- }
447
- }
448
- }
449
-
450
- // 3. If data’s code point length divides by 4 leaving
451
- // a remainder of 1, then return failure.
452
- if (dataLength % 4 === 1) {
453
- return 'failure'
454
- }
455
-
456
- // 4. If data contains a code point that is not one of
457
- // U+002B (+)
458
- // U+002F (/)
459
- // ASCII alphanumeric
460
- // then return failure.
461
- if (/[^+/0-9A-Za-z]/.test(data.length === dataLength ? data : data.substring(0, dataLength))) {
462
- return 'failure'
463
- }
464
-
465
- const buffer = Buffer.from(data, 'base64')
466
- return new Uint8Array(buffer.buffer, buffer.byteOffset, buffer.byteLength)
467
- }
468
-
469
- // https://fetch.spec.whatwg.org/#collect-an-http-quoted-string
470
- // tests: https://fetch.spec.whatwg.org/#example-http-quoted-string
471
- /**
472
- * @param {string} input
473
- * @param {{ position: number }} position
474
- * @param {boolean} [extractValue=false]
475
- */
476
- function collectAnHTTPQuotedString (input, position, extractValue = false) {
477
- // 1. Let positionStart be position.
478
- const positionStart = position.position
479
-
480
- // 2. Let value be the empty string.
481
- let value = ''
482
-
483
- // 3. Assert: the code point at position within input
484
- // is U+0022 (").
485
- assert(input[position.position] === '"')
486
-
487
- // 4. Advance position by 1.
488
- position.position++
489
-
490
- // 5. While true:
491
- while (true) {
492
- // 1. Append the result of collecting a sequence of code points
493
- // that are not U+0022 (") or U+005C (\) from input, given
494
- // position, to value.
495
- value += collectASequenceOfCodePoints(
496
- (char) => char !== '"' && char !== '\\',
497
- input,
498
- position
499
- )
500
-
501
- // 2. If position is past the end of input, then break.
502
- if (position.position >= input.length) {
503
- break
504
- }
505
-
506
- // 3. Let quoteOrBackslash be the code point at position within
507
- // input.
508
- const quoteOrBackslash = input[position.position]
509
-
510
- // 4. Advance position by 1.
511
- position.position++
512
-
513
- // 5. If quoteOrBackslash is U+005C (\), then:
514
- if (quoteOrBackslash === '\\') {
515
- // 1. If position is past the end of input, then append
516
- // U+005C (\) to value and break.
517
- if (position.position >= input.length) {
518
- value += '\\'
519
- break
520
- }
521
-
522
- // 2. Append the code point at position within input to value.
523
- value += input[position.position]
524
-
525
- // 3. Advance position by 1.
526
- position.position++
527
-
528
- // 6. Otherwise:
529
- } else {
530
- // 1. Assert: quoteOrBackslash is U+0022 (").
531
- assert(quoteOrBackslash === '"')
532
-
533
- // 2. Break.
534
- break
535
- }
536
- }
537
-
538
- // 6. If the extract-value flag is set, then return value.
539
- if (extractValue) {
540
- return value
541
- }
542
-
543
- // 7. Return the code points from positionStart to position,
544
- // inclusive, within input.
545
- return input.slice(positionStart, position.position)
546
- }
547
-
548
- /**
549
- * @see https://mimesniff.spec.whatwg.org/#serialize-a-mime-type
550
- */
551
- function serializeAMimeType (mimeType) {
552
- assert(mimeType !== 'failure')
553
- const { parameters, essence } = mimeType
554
-
555
- // 1. Let serialization be the concatenation of mimeType’s
556
- // type, U+002F (/), and mimeType’s subtype.
557
- let serialization = essence
558
-
559
- // 2. For each name → value of mimeType’s parameters:
560
- for (let [name, value] of parameters.entries()) {
561
- // 1. Append U+003B (;) to serialization.
562
- serialization += ';'
563
-
564
- // 2. Append name to serialization.
565
- serialization += name
566
-
567
- // 3. Append U+003D (=) to serialization.
568
- serialization += '='
569
-
570
- // 4. If value does not solely contain HTTP token code
571
- // points or value is the empty string, then:
572
- if (!HTTP_TOKEN_CODEPOINTS.test(value)) {
573
- // 1. Precede each occurrence of U+0022 (") or
574
- // U+005C (\) in value with U+005C (\).
575
- value = value.replace(/(\\|")/g, '\\$1')
576
-
577
- // 2. Prepend U+0022 (") to value.
578
- value = '"' + value
579
-
580
- // 3. Append U+0022 (") to value.
581
- value += '"'
582
- }
583
-
584
- // 5. Append value to serialization.
585
- serialization += value
586
- }
587
-
588
- // 3. Return serialization.
589
- return serialization
590
- }
591
-
592
- /**
593
- * @see https://fetch.spec.whatwg.org/#http-whitespace
594
- * @param {number} char
595
- */
596
- function isHTTPWhiteSpace (char) {
597
- // "\r\n\t "
598
- return char === 0x00d || char === 0x00a || char === 0x009 || char === 0x020
599
- }
600
-
601
- /**
602
- * @see https://fetch.spec.whatwg.org/#http-whitespace
603
- * @param {string} str
604
- * @param {boolean} [leading=true]
605
- * @param {boolean} [trailing=true]
606
- */
607
- function removeHTTPWhitespace (str, leading = true, trailing = true) {
608
- return removeChars(str, leading, trailing, isHTTPWhiteSpace)
609
- }
610
-
611
- /**
612
- * @see https://infra.spec.whatwg.org/#ascii-whitespace
613
- * @param {number} char
614
- */
615
- function isASCIIWhitespace (char) {
616
- // "\r\n\t\f "
617
- return char === 0x00d || char === 0x00a || char === 0x009 || char === 0x00c || char === 0x020
618
- }
619
-
620
- /**
621
- * @see https://infra.spec.whatwg.org/#strip-leading-and-trailing-ascii-whitespace
622
- * @param {string} str
623
- * @param {boolean} [leading=true]
624
- * @param {boolean} [trailing=true]
625
- */
626
- function removeASCIIWhitespace (str, leading = true, trailing = true) {
627
- return removeChars(str, leading, trailing, isASCIIWhitespace)
628
- }
629
-
630
- /**
631
- * @param {string} str
632
- * @param {boolean} leading
633
- * @param {boolean} trailing
634
- * @param {(charCode: number) => boolean} predicate
635
- * @returns
636
- */
637
- function removeChars (str, leading, trailing, predicate) {
638
- let lead = 0
639
- let trail = str.length - 1
640
-
641
- if (leading) {
642
- while (lead < str.length && predicate(str.charCodeAt(lead))) lead++
643
- }
644
-
645
- if (trailing) {
646
- while (trail > 0 && predicate(str.charCodeAt(trail))) trail--
647
- }
648
-
649
- return lead === 0 && trail === str.length - 1 ? str : str.slice(lead, trail + 1)
650
- }
651
-
652
- /**
653
- * @see https://infra.spec.whatwg.org/#isomorphic-decode
654
- * @param {Uint8Array} input
655
- * @returns {string}
656
- */
657
- function isomorphicDecode (input) {
658
- // 1. To isomorphic decode a byte sequence input, return a string whose code point
659
- // length is equal to input’s length and whose code points have the same values
660
- // as the values of input’s bytes, in the same order.
661
- const length = input.length
662
- if ((2 << 15) - 1 > length) {
663
- return String.fromCharCode.apply(null, input)
664
- }
665
- let result = ''; let i = 0
666
- let addition = (2 << 15) - 1
667
- while (i < length) {
668
- if (i + addition > length) {
669
- addition = length - i
670
- }
671
- result += String.fromCharCode.apply(null, input.subarray(i, i += addition))
672
- }
673
- return result
674
- }
675
-
676
- /**
677
- * @see https://mimesniff.spec.whatwg.org/#minimize-a-supported-mime-type
678
- * @param {Exclude<ReturnType<typeof parseMIMEType>, 'failure'>} mimeType
679
- */
680
- function minimizeSupportedMimeType (mimeType) {
681
- switch (mimeType.essence) {
682
- case 'application/ecmascript':
683
- case 'application/javascript':
684
- case 'application/x-ecmascript':
685
- case 'application/x-javascript':
686
- case 'text/ecmascript':
687
- case 'text/javascript':
688
- case 'text/javascript1.0':
689
- case 'text/javascript1.1':
690
- case 'text/javascript1.2':
691
- case 'text/javascript1.3':
692
- case 'text/javascript1.4':
693
- case 'text/javascript1.5':
694
- case 'text/jscript':
695
- case 'text/livescript':
696
- case 'text/x-ecmascript':
697
- case 'text/x-javascript':
698
- // 1. If mimeType is a JavaScript MIME type, then return "text/javascript".
699
- return 'text/javascript'
700
- case 'application/json':
701
- case 'text/json':
702
- // 2. If mimeType is a JSON MIME type, then return "application/json".
703
- return 'application/json'
704
- case 'image/svg+xml':
705
- // 3. If mimeType’s essence is "image/svg+xml", then return "image/svg+xml".
706
- return 'image/svg+xml'
707
- case 'text/xml':
708
- case 'application/xml':
709
- // 4. If mimeType is an XML MIME type, then return "application/xml".
710
- return 'application/xml'
711
- }
712
-
713
- // 2. If mimeType is a JSON MIME type, then return "application/json".
714
- if (mimeType.subtype.endsWith('+json')) {
715
- return 'application/json'
716
- }
717
-
718
- // 4. If mimeType is an XML MIME type, then return "application/xml".
719
- if (mimeType.subtype.endsWith('+xml')) {
720
- return 'application/xml'
721
- }
722
-
723
- // 5. If mimeType is supported by the user agent, then return mimeType’s essence.
724
- // Technically, node doesn't support any mimetypes.
725
-
726
- // 6. Return the empty string.
727
- return ''
728
- }
729
-
730
- module.exports = {
731
- dataURLProcessor,
732
- URLSerializer,
733
- collectASequenceOfCodePoints,
734
- collectASequenceOfCodePointsFast,
735
- stringPercentDecode,
736
- parseMIMEType,
737
- collectAnHTTPQuotedString,
738
- serializeAMimeType,
739
- removeChars,
740
- removeHTTPWhitespace,
741
- minimizeSupportedMimeType,
742
- HTTP_TOKEN_CODEPOINTS,
743
- isomorphicDecode
744
- }