@kubb/agent 4.28.1 → 4.29.0
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.
- package/.output/nitro.json +1 -1
- package/.output/server/chunks/nitro/nitro.mjs +378 -642
- package/.output/server/chunks/nitro/nitro.mjs.map +1 -1
- package/.output/server/chunks/routes/api/health.get.mjs +4 -6
- package/.output/server/chunks/routes/api/health.get.mjs.map +1 -1
- package/.output/server/index.mjs +4 -6
- package/.output/server/index.mjs.map +1 -1
- package/.output/server/node_modules/@kubb/fabric-core/dist/{defaultParser-BD_N68Bo.js → defaultParser-C1atU7yU.js} +2 -3
- package/.output/server/node_modules/@kubb/fabric-core/dist/{getRelativePath-C4Au07ON.js → getRelativePath-BcieQL5M.js} +1 -2
- package/.output/server/node_modules/@kubb/fabric-core/dist/index.js +8 -9
- package/.output/server/node_modules/@kubb/fabric-core/dist/{Root-BQX3eHqb.js → onProcessExit-CF200hsz.js} +109 -190
- package/.output/server/node_modules/@kubb/fabric-core/dist/parsers/typescript.js +3 -4
- package/.output/server/node_modules/@kubb/fabric-core/dist/parsers.js +2 -3
- package/.output/server/node_modules/@kubb/fabric-core/dist/plugins.js +58 -298
- package/.output/server/node_modules/@kubb/fabric-core/package.json +8 -18
- package/.output/server/node_modules/@kubb/react-fabric/dist/{chunk-DbZtQ4qb.js → chunk-Cnw5r_-A.js} +1 -5
- package/.output/server/node_modules/@kubb/react-fabric/dist/index.js +39 -41
- package/.output/server/node_modules/@kubb/react-fabric/dist/{jsx-runtime-CQFBnRKx.js → jsx-runtime-Dm7PKVbc.js} +6 -24
- package/.output/server/node_modules/@kubb/react-fabric/dist/jsx-runtime.js +5 -4
- package/.output/server/node_modules/@kubb/react-fabric/dist/plugins.js +3 -3
- package/.output/server/node_modules/@kubb/react-fabric/dist/{react--draJ5Pm.js → react-D652OKii.js} +31 -91
- package/.output/server/node_modules/@kubb/react-fabric/dist/{reactPlugin-DqJsInTf.js → reactPlugin-BkDkx1cs.js} +410 -1650
- package/.output/server/node_modules/@kubb/react-fabric/package.json +8 -11
- package/.output/server/node_modules/empathic/access.js +39 -0
- package/.output/server/node_modules/empathic/access.mjs +34 -0
- package/.output/server/node_modules/empathic/find.js +81 -0
- package/.output/server/node_modules/empathic/find.mjs +76 -0
- package/.output/server/node_modules/empathic/package.json +49 -0
- package/.output/server/node_modules/empathic/package.mjs +52 -0
- package/.output/server/node_modules/empathic/resolve.js +31 -0
- package/.output/server/node_modules/empathic/resolve.mjs +27 -0
- package/.output/server/node_modules/empathic/walk.js +22 -0
- package/.output/server/node_modules/empathic/walk.mjs +20 -0
- package/.output/server/node_modules/tinyexec/dist/main.js +633 -0
- package/.output/server/node_modules/tinyexec/package.json +61 -0
- package/.output/server/package.json +6 -44
- package/package.json +19 -21
- package/.output/server/node_modules/.nitro/path-key@3.1.1/index.js +0 -16
- package/.output/server/node_modules/.nitro/path-key@3.1.1/package.json +0 -39
- package/.output/server/node_modules/.nitro/path-key@4.0.0/index.js +0 -12
- package/.output/server/node_modules/.nitro/path-key@4.0.0/package.json +0 -41
- package/.output/server/node_modules/.nitro/path-to-regexp@3.3.0/index.js +0 -421
- package/.output/server/node_modules/.nitro/path-to-regexp@3.3.0/package.json +0 -46
- package/.output/server/node_modules/@kubb/fabric-core/dist/chunk-BVHe6Par.js +0 -22
- package/.output/server/node_modules/@sec-ant/readable-stream/dist/ponyfill/asyncIterator.js +0 -89
- package/.output/server/node_modules/@sec-ant/readable-stream/dist/ponyfill/fromAnyIterable.js +0 -34
- package/.output/server/node_modules/@sec-ant/readable-stream/dist/ponyfill/index.js +0 -6
- package/.output/server/node_modules/@sec-ant/readable-stream/package.json +0 -98
- package/.output/server/node_modules/@sindresorhus/merge-streams/index.js +0 -265
- package/.output/server/node_modules/@sindresorhus/merge-streams/package.json +0 -49
- package/.output/server/node_modules/balanced-match/index.js +0 -62
- package/.output/server/node_modules/balanced-match/package.json +0 -48
- package/.output/server/node_modules/brace-expansion/index.js +0 -201
- package/.output/server/node_modules/brace-expansion/package.json +0 -50
- package/.output/server/node_modules/bytes/index.js +0 -159
- package/.output/server/node_modules/bytes/package.json +0 -39
- package/.output/server/node_modules/concat-map/index.js +0 -13
- package/.output/server/node_modules/concat-map/package.json +0 -59
- package/.output/server/node_modules/content-disposition/index.js +0 -445
- package/.output/server/node_modules/content-disposition/package.json +0 -39
- package/.output/server/node_modules/cross-spawn/index.js +0 -39
- package/.output/server/node_modules/cross-spawn/lib/enoent.js +0 -59
- package/.output/server/node_modules/cross-spawn/lib/parse.js +0 -91
- package/.output/server/node_modules/cross-spawn/lib/util/escape.js +0 -47
- package/.output/server/node_modules/cross-spawn/lib/util/readShebang.js +0 -23
- package/.output/server/node_modules/cross-spawn/lib/util/resolveCommand.js +0 -52
- package/.output/server/node_modules/cross-spawn/package.json +0 -73
- package/.output/server/node_modules/execa/index.js +0 -28
- package/.output/server/node_modules/execa/lib/arguments/command.js +0 -20
- package/.output/server/node_modules/execa/lib/arguments/cwd.js +0 -39
- package/.output/server/node_modules/execa/lib/arguments/encoding-option.js +0 -50
- package/.output/server/node_modules/execa/lib/arguments/escape.js +0 -88
- package/.output/server/node_modules/execa/lib/arguments/fd-options.js +0 -108
- package/.output/server/node_modules/execa/lib/arguments/file-url.js +0 -25
- package/.output/server/node_modules/execa/lib/arguments/options.js +0 -96
- package/.output/server/node_modules/execa/lib/arguments/shell.js +0 -11
- package/.output/server/node_modules/execa/lib/arguments/specific.js +0 -111
- package/.output/server/node_modules/execa/lib/convert/add.js +0 -15
- package/.output/server/node_modules/execa/lib/convert/concurrent.js +0 -33
- package/.output/server/node_modules/execa/lib/convert/duplex.js +0 -69
- package/.output/server/node_modules/execa/lib/convert/iterable.js +0 -34
- package/.output/server/node_modules/execa/lib/convert/readable.js +0 -113
- package/.output/server/node_modules/execa/lib/convert/shared.js +0 -46
- package/.output/server/node_modules/execa/lib/convert/writable.js +0 -90
- package/.output/server/node_modules/execa/lib/io/contents.js +0 -116
- package/.output/server/node_modules/execa/lib/io/input-sync.js +0 -44
- package/.output/server/node_modules/execa/lib/io/iterate.js +0 -110
- package/.output/server/node_modules/execa/lib/io/max-buffer.js +0 -89
- package/.output/server/node_modules/execa/lib/io/output-async.js +0 -80
- package/.output/server/node_modules/execa/lib/io/output-sync.js +0 -135
- package/.output/server/node_modules/execa/lib/io/pipeline.js +0 -48
- package/.output/server/node_modules/execa/lib/io/strip-newline.js +0 -12
- package/.output/server/node_modules/execa/lib/ipc/array.js +0 -4
- package/.output/server/node_modules/execa/lib/ipc/buffer-messages.js +0 -47
- package/.output/server/node_modules/execa/lib/ipc/forward.js +0 -56
- package/.output/server/node_modules/execa/lib/ipc/get-each.js +0 -89
- package/.output/server/node_modules/execa/lib/ipc/get-one.js +0 -69
- package/.output/server/node_modules/execa/lib/ipc/graceful.js +0 -72
- package/.output/server/node_modules/execa/lib/ipc/incoming.js +0 -79
- package/.output/server/node_modules/execa/lib/ipc/ipc-input.js +0 -44
- package/.output/server/node_modules/execa/lib/ipc/methods.js +0 -49
- package/.output/server/node_modules/execa/lib/ipc/outgoing.js +0 -47
- package/.output/server/node_modules/execa/lib/ipc/reference.js +0 -44
- package/.output/server/node_modules/execa/lib/ipc/send.js +0 -91
- package/.output/server/node_modules/execa/lib/ipc/strict.js +0 -113
- package/.output/server/node_modules/execa/lib/ipc/validation.js +0 -111
- package/.output/server/node_modules/execa/lib/methods/bind.js +0 -23
- package/.output/server/node_modules/execa/lib/methods/command.js +0 -43
- package/.output/server/node_modules/execa/lib/methods/create.js +0 -65
- package/.output/server/node_modules/execa/lib/methods/main-async.js +0 -194
- package/.output/server/node_modules/execa/lib/methods/main-sync.js +0 -163
- package/.output/server/node_modules/execa/lib/methods/node.js +0 -51
- package/.output/server/node_modules/execa/lib/methods/parameters.js +0 -31
- package/.output/server/node_modules/execa/lib/methods/promise.js +0 -15
- package/.output/server/node_modules/execa/lib/methods/script.js +0 -22
- package/.output/server/node_modules/execa/lib/methods/template.js +0 -153
- package/.output/server/node_modules/execa/lib/pipe/abort.js +0 -20
- package/.output/server/node_modules/execa/lib/pipe/pipe-arguments.js +0 -91
- package/.output/server/node_modules/execa/lib/pipe/sequence.js +0 -24
- package/.output/server/node_modules/execa/lib/pipe/setup.js +0 -72
- package/.output/server/node_modules/execa/lib/pipe/streaming.js +0 -51
- package/.output/server/node_modules/execa/lib/pipe/throw.js +0 -58
- package/.output/server/node_modules/execa/lib/resolve/all-async.js +0 -46
- package/.output/server/node_modules/execa/lib/resolve/all-sync.js +0 -33
- package/.output/server/node_modules/execa/lib/resolve/exit-async.js +0 -54
- package/.output/server/node_modules/execa/lib/resolve/exit-sync.js +0 -25
- package/.output/server/node_modules/execa/lib/resolve/stdio.js +0 -47
- package/.output/server/node_modules/execa/lib/resolve/wait-stream.js +0 -96
- package/.output/server/node_modules/execa/lib/resolve/wait-subprocess.js +0 -146
- package/.output/server/node_modules/execa/lib/return/duration.js +0 -8
- package/.output/server/node_modules/execa/lib/return/early-error.js +0 -60
- package/.output/server/node_modules/execa/lib/return/final-error.js +0 -40
- package/.output/server/node_modules/execa/lib/return/message.js +0 -157
- package/.output/server/node_modules/execa/lib/return/reject.js +0 -13
- package/.output/server/node_modules/execa/lib/return/result.js +0 -186
- package/.output/server/node_modules/execa/lib/stdio/direction.js +0 -76
- package/.output/server/node_modules/execa/lib/stdio/duplicate.js +0 -116
- package/.output/server/node_modules/execa/lib/stdio/handle-async.js +0 -52
- package/.output/server/node_modules/execa/lib/stdio/handle-sync.js +0 -57
- package/.output/server/node_modules/execa/lib/stdio/handle.js +0 -214
- package/.output/server/node_modules/execa/lib/stdio/input-option.js +0 -50
- package/.output/server/node_modules/execa/lib/stdio/native.js +0 -106
- package/.output/server/node_modules/execa/lib/stdio/stdio-option.js +0 -60
- package/.output/server/node_modules/execa/lib/stdio/type.js +0 -173
- package/.output/server/node_modules/execa/lib/terminate/cancel.js +0 -20
- package/.output/server/node_modules/execa/lib/terminate/cleanup.js +0 -16
- package/.output/server/node_modules/execa/lib/terminate/graceful.js +0 -71
- package/.output/server/node_modules/execa/lib/terminate/kill.js +0 -93
- package/.output/server/node_modules/execa/lib/terminate/signal.js +0 -70
- package/.output/server/node_modules/execa/lib/terminate/timeout.js +0 -21
- package/.output/server/node_modules/execa/lib/transform/encoding-transform.js +0 -51
- package/.output/server/node_modules/execa/lib/transform/generator.js +0 -107
- package/.output/server/node_modules/execa/lib/transform/normalize.js +0 -111
- package/.output/server/node_modules/execa/lib/transform/object-mode.js +0 -41
- package/.output/server/node_modules/execa/lib/transform/run-async.js +0 -60
- package/.output/server/node_modules/execa/lib/transform/run-sync.js +0 -50
- package/.output/server/node_modules/execa/lib/transform/split.js +0 -110
- package/.output/server/node_modules/execa/lib/transform/validate.js +0 -43
- package/.output/server/node_modules/execa/lib/utils/abort-signal.js +0 -8
- package/.output/server/node_modules/execa/lib/utils/deferred.js +0 -7
- package/.output/server/node_modules/execa/lib/utils/max-listeners.js +0 -14
- package/.output/server/node_modules/execa/lib/utils/standard-stream.js +0 -6
- package/.output/server/node_modules/execa/lib/utils/uint-array.js +0 -69
- package/.output/server/node_modules/execa/lib/verbose/complete.js +0 -24
- package/.output/server/node_modules/execa/lib/verbose/custom.js +0 -26
- package/.output/server/node_modules/execa/lib/verbose/default.js +0 -54
- package/.output/server/node_modules/execa/lib/verbose/error.js +0 -13
- package/.output/server/node_modules/execa/lib/verbose/info.js +0 -39
- package/.output/server/node_modules/execa/lib/verbose/ipc.js +0 -15
- package/.output/server/node_modules/execa/lib/verbose/log.js +0 -54
- package/.output/server/node_modules/execa/lib/verbose/output.js +0 -60
- package/.output/server/node_modules/execa/lib/verbose/start.js +0 -15
- package/.output/server/node_modules/execa/lib/verbose/values.js +0 -33
- package/.output/server/node_modules/execa/package.json +0 -105
- package/.output/server/node_modules/figures/index.js +0 -292
- package/.output/server/node_modules/figures/package.json +0 -49
- package/.output/server/node_modules/fs-extra/lib/copy/copy-sync.js +0 -176
- package/.output/server/node_modules/fs-extra/lib/copy/copy.js +0 -180
- package/.output/server/node_modules/fs-extra/lib/copy/index.js +0 -7
- package/.output/server/node_modules/fs-extra/lib/empty/index.js +0 -39
- package/.output/server/node_modules/fs-extra/lib/ensure/file.js +0 -66
- package/.output/server/node_modules/fs-extra/lib/ensure/index.js +0 -23
- package/.output/server/node_modules/fs-extra/lib/ensure/link.js +0 -64
- package/.output/server/node_modules/fs-extra/lib/ensure/symlink-paths.js +0 -101
- package/.output/server/node_modules/fs-extra/lib/ensure/symlink-type.js +0 -34
- package/.output/server/node_modules/fs-extra/lib/ensure/symlink.js +0 -67
- package/.output/server/node_modules/fs-extra/lib/fs/index.js +0 -146
- package/.output/server/node_modules/fs-extra/lib/index.js +0 -16
- package/.output/server/node_modules/fs-extra/lib/json/index.js +0 -16
- package/.output/server/node_modules/fs-extra/lib/json/jsonfile.js +0 -11
- package/.output/server/node_modules/fs-extra/lib/json/output-json-sync.js +0 -12
- package/.output/server/node_modules/fs-extra/lib/json/output-json.js +0 -12
- package/.output/server/node_modules/fs-extra/lib/mkdirs/index.js +0 -14
- package/.output/server/node_modules/fs-extra/lib/mkdirs/make-dir.js +0 -27
- package/.output/server/node_modules/fs-extra/lib/mkdirs/utils.js +0 -21
- package/.output/server/node_modules/fs-extra/lib/move/index.js +0 -7
- package/.output/server/node_modules/fs-extra/lib/move/move-sync.js +0 -55
- package/.output/server/node_modules/fs-extra/lib/move/move.js +0 -59
- package/.output/server/node_modules/fs-extra/lib/output-file/index.js +0 -31
- package/.output/server/node_modules/fs-extra/lib/path-exists/index.js +0 -12
- package/.output/server/node_modules/fs-extra/lib/remove/index.js +0 -17
- package/.output/server/node_modules/fs-extra/lib/util/async.js +0 -29
- package/.output/server/node_modules/fs-extra/lib/util/stat.js +0 -159
- package/.output/server/node_modules/fs-extra/lib/util/utimes.js +0 -36
- package/.output/server/node_modules/fs-extra/package.json +0 -71
- package/.output/server/node_modules/get-stream/package.json +0 -60
- package/.output/server/node_modules/get-stream/source/array-buffer.js +0 -84
- package/.output/server/node_modules/get-stream/source/array.js +0 -32
- package/.output/server/node_modules/get-stream/source/buffer.js +0 -19
- package/.output/server/node_modules/get-stream/source/contents.js +0 -121
- package/.output/server/node_modules/get-stream/source/exports.js +0 -5
- package/.output/server/node_modules/get-stream/source/index.js +0 -13
- package/.output/server/node_modules/get-stream/source/stream.js +0 -65
- package/.output/server/node_modules/get-stream/source/string.js +0 -41
- package/.output/server/node_modules/get-stream/source/utils.js +0 -11
- package/.output/server/node_modules/graceful-fs/clone.js +0 -23
- package/.output/server/node_modules/graceful-fs/graceful-fs.js +0 -448
- package/.output/server/node_modules/graceful-fs/legacy-streams.js +0 -118
- package/.output/server/node_modules/graceful-fs/package.json +0 -53
- package/.output/server/node_modules/graceful-fs/polyfills.js +0 -355
- package/.output/server/node_modules/human-signals/build/src/core.js +0 -273
- package/.output/server/node_modules/human-signals/build/src/main.js +0 -70
- package/.output/server/node_modules/human-signals/build/src/realtime.js +0 -16
- package/.output/server/node_modules/human-signals/build/src/signals.js +0 -34
- package/.output/server/node_modules/human-signals/package.json +0 -66
- package/.output/server/node_modules/is-plain-obj/index.js +0 -8
- package/.output/server/node_modules/is-plain-obj/package.json +0 -41
- package/.output/server/node_modules/is-stream/index.js +0 -37
- package/.output/server/node_modules/is-stream/package.json +0 -48
- package/.output/server/node_modules/is-unicode-supported/index.js +0 -21
- package/.output/server/node_modules/is-unicode-supported/package.json +0 -47
- package/.output/server/node_modules/isexe/index.js +0 -57
- package/.output/server/node_modules/isexe/mode.js +0 -41
- package/.output/server/node_modules/isexe/package.json +0 -31
- package/.output/server/node_modules/isexe/windows.js +0 -42
- package/.output/server/node_modules/js-runtime/dist/index.js +0 -5
- package/.output/server/node_modules/js-runtime/package.json +0 -72
- package/.output/server/node_modules/jsonfile/index.js +0 -88
- package/.output/server/node_modules/jsonfile/package.json +0 -40
- package/.output/server/node_modules/jsonfile/utils.js +0 -14
- package/.output/server/node_modules/mime-db/db.json +0 -7088
- package/.output/server/node_modules/mime-db/index.js +0 -11
- package/.output/server/node_modules/mime-db/package.json +0 -57
- package/.output/server/node_modules/mime-types/index.js +0 -188
- package/.output/server/node_modules/mime-types/package.json +0 -43
- package/.output/server/node_modules/minimatch/minimatch.js +0 -947
- package/.output/server/node_modules/minimatch/package.json +0 -33
- package/.output/server/node_modules/natural-orderby/dist/main.js +0 -19
- package/.output/server/node_modules/natural-orderby/dist/umd/natural-orderby.development.js +0 -420
- package/.output/server/node_modules/natural-orderby/dist/umd/natural-orderby.production.min.js +0 -11
- package/.output/server/node_modules/natural-orderby/package.json +0 -119
- package/.output/server/node_modules/npm-run-path/index.js +0 -55
- package/.output/server/node_modules/npm-run-path/package.json +0 -52
- package/.output/server/node_modules/parse-ms/index.js +0 -45
- package/.output/server/node_modules/parse-ms/package.json +0 -47
- package/.output/server/node_modules/path-is-inside/lib/path-is-inside.js +0 -28
- package/.output/server/node_modules/path-is-inside/package.json +0 -27
- package/.output/server/node_modules/pretty-ms/index.js +0 -149
- package/.output/server/node_modules/pretty-ms/package.json +0 -55
- package/.output/server/node_modules/range-parser/index.js +0 -158
- package/.output/server/node_modules/range-parser/package.json +0 -40
- package/.output/server/node_modules/serve-handler/package.json +0 -68
- package/.output/server/node_modules/serve-handler/src/directory.js +0 -16
- package/.output/server/node_modules/serve-handler/src/error.js +0 -10
- package/.output/server/node_modules/serve-handler/src/glob-slash.js +0 -9
- package/.output/server/node_modules/serve-handler/src/index.js +0 -769
- package/.output/server/node_modules/shebang-command/index.js +0 -19
- package/.output/server/node_modules/shebang-command/package.json +0 -34
- package/.output/server/node_modules/shebang-regex/index.js +0 -2
- package/.output/server/node_modules/shebang-regex/package.json +0 -35
- package/.output/server/node_modules/signal-exit/dist/mjs/index.js +0 -275
- package/.output/server/node_modules/signal-exit/dist/mjs/package.json +0 -3
- package/.output/server/node_modules/signal-exit/dist/mjs/signals.js +0 -39
- package/.output/server/node_modules/signal-exit/package.json +0 -106
- package/.output/server/node_modules/string-argv/index.js +0 -41
- package/.output/server/node_modules/string-argv/package.json +0 -51
- package/.output/server/node_modules/strip-final-newline/index.js +0 -26
- package/.output/server/node_modules/strip-final-newline/package.json +0 -49
- package/.output/server/node_modules/unicorn-magic/default.js +0 -14
- package/.output/server/node_modules/unicorn-magic/node.js +0 -49
- package/.output/server/node_modules/unicorn-magic/package.json +0 -62
- package/.output/server/node_modules/universalify/index.js +0 -24
- package/.output/server/node_modules/universalify/package.json +0 -34
- package/.output/server/node_modules/which/package.json +0 -43
- package/.output/server/node_modules/which/which.js +0 -125
- package/.output/server/node_modules/yoctocolors/base.js +0 -94
- package/.output/server/node_modules/yoctocolors/index.js +0 -2
- package/.output/server/node_modules/yoctocolors/package.json +0 -69
- /package/.output/server/node_modules/{.nitro/path-to-regexp@8.3.0 → path-to-regexp}/dist/index.js +0 -0
- /package/.output/server/node_modules/{.nitro/path-to-regexp@8.3.0 → path-to-regexp}/package.json +0 -0
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@sec-ant/readable-stream",
|
|
3
|
-
"description": "A tiny, zero-dependency yet spec-compliant asynchronous iterator polyfill/ponyfill for ReadableStreams.",
|
|
4
|
-
"private": false,
|
|
5
|
-
"version": "0.4.1",
|
|
6
|
-
"type": "module",
|
|
7
|
-
"files": [
|
|
8
|
-
"./dist"
|
|
9
|
-
],
|
|
10
|
-
"main": "./dist/index/index.js",
|
|
11
|
-
"module": "./dist/index/index.js",
|
|
12
|
-
"exports": {
|
|
13
|
-
".": "./dist/index/index.js",
|
|
14
|
-
"./asyncIterator": "./dist/index/asyncIterator.js",
|
|
15
|
-
"./fromAnyIterable": "./dist/index/fromAnyIterable.js",
|
|
16
|
-
"./ponyfill": "./dist/ponyfill/index.js",
|
|
17
|
-
"./ponyfill/asyncIterator": "./dist/ponyfill/asyncIterator.js",
|
|
18
|
-
"./ponyfill/fromAnyIterable": "./dist/ponyfill/fromAnyIterable.js",
|
|
19
|
-
"./polyfill": "./dist/polyfill/index.js",
|
|
20
|
-
"./polyfill/asyncIterator": "./dist/polyfill/asyncIterator.js",
|
|
21
|
-
"./polyfill/fromAnyIterable": "./dist/polyfill/fromAnyIterable.js",
|
|
22
|
-
"./async-iterator": {
|
|
23
|
-
"types": "./dist/types/async-iterator.d.ts"
|
|
24
|
-
}
|
|
25
|
-
},
|
|
26
|
-
"repository": {
|
|
27
|
-
"type": "git",
|
|
28
|
-
"url": "git+https://github.com/Sec-ant/readable-stream.git"
|
|
29
|
-
},
|
|
30
|
-
"homepage": "https://github.com/Sec-ant/readable-stream",
|
|
31
|
-
"bugs": {
|
|
32
|
-
"url": "https://github.com/Sec-ant/readable-stream/issues",
|
|
33
|
-
"email": "zezhengwu@proton.me"
|
|
34
|
-
},
|
|
35
|
-
"keywords": [
|
|
36
|
-
"stream",
|
|
37
|
-
"web-streams",
|
|
38
|
-
"readablestream",
|
|
39
|
-
"async",
|
|
40
|
-
"asynchronous",
|
|
41
|
-
"iterator",
|
|
42
|
-
"iteration",
|
|
43
|
-
"async-iterator",
|
|
44
|
-
"polyfill",
|
|
45
|
-
"esm",
|
|
46
|
-
"from-iterable"
|
|
47
|
-
],
|
|
48
|
-
"author": {
|
|
49
|
-
"name": "Ze-Zheng Wu"
|
|
50
|
-
},
|
|
51
|
-
"license": "MIT",
|
|
52
|
-
"publishConfig": {
|
|
53
|
-
"access": "public"
|
|
54
|
-
},
|
|
55
|
-
"scripts": {
|
|
56
|
-
"install:ci": "npm ci && npx playwright install --with-deps",
|
|
57
|
-
"install:codesandbox": "npm ci && ./scripts/prepare.sh",
|
|
58
|
-
"update-hooks": "simple-git-hooks",
|
|
59
|
-
"changeset": "changeset",
|
|
60
|
-
"bump": "changeset version 2>/dev/null | grep . && npm i; exit 0",
|
|
61
|
-
"type-check": "tsc --noEmit --emitDeclarationOnly false",
|
|
62
|
-
"format:prettier": "prettier . --write",
|
|
63
|
-
"format:biome": "biome format . --write",
|
|
64
|
-
"format": "conc \"npm:format:prettier\" \"npm:format:biome\"",
|
|
65
|
-
"check:biome": "biome check --apply .",
|
|
66
|
-
"check": "conc \"npm:format:prettier\" \"npm:check:biome\"",
|
|
67
|
-
"prebuild": "npm run check && npm run type-check",
|
|
68
|
-
"build": "vite build",
|
|
69
|
-
"copy": "copy-files-from-to",
|
|
70
|
-
"postbuild": "tsc && npm run copy",
|
|
71
|
-
"test:chromium": "vitest run --browser.name=chromium",
|
|
72
|
-
"test:firefox": "vitest run --browser.name=firefox",
|
|
73
|
-
"test": "npm run test:chromium && npm run test:firefox",
|
|
74
|
-
"test:coverage": "vitest run --coverage",
|
|
75
|
-
"test:ui": "vitest --ui --coverage",
|
|
76
|
-
"prepublishOnly": "npm run build",
|
|
77
|
-
"bump-biome:latest": "npm i -DE @biomejs/biome@latest",
|
|
78
|
-
"bump-biome:nightly": "npm i -DE @biomejs/biome@nightly"
|
|
79
|
-
},
|
|
80
|
-
"devDependencies": {
|
|
81
|
-
"@biomejs/biome": "1.6.1",
|
|
82
|
-
"@changesets/cli": "^2.27.1",
|
|
83
|
-
"@commitlint/cli": "^19.1.0",
|
|
84
|
-
"@commitlint/config-conventional": "^19.1.0",
|
|
85
|
-
"@vitest/browser": "^1.3.1",
|
|
86
|
-
"@vitest/coverage-istanbul": "^1.3.1",
|
|
87
|
-
"@vitest/ui": "^1.3.1",
|
|
88
|
-
"concurrently": "^8.2.2",
|
|
89
|
-
"copy-files-from-to": "^3.9.1",
|
|
90
|
-
"lint-staged": "^15.2.2",
|
|
91
|
-
"playwright": "^1.42.1",
|
|
92
|
-
"prettier": "^3.2.5",
|
|
93
|
-
"simple-git-hooks": "^2.10.0",
|
|
94
|
-
"typescript": "^5.4.2",
|
|
95
|
-
"vite": "^5.1.6",
|
|
96
|
-
"vitest": "^1.3.1"
|
|
97
|
-
}
|
|
98
|
-
}
|
|
@@ -1,265 +0,0 @@
|
|
|
1
|
-
import {on, once} from 'node:events';
|
|
2
|
-
import {PassThrough as PassThroughStream, getDefaultHighWaterMark} from 'node:stream';
|
|
3
|
-
import {finished} from 'node:stream/promises';
|
|
4
|
-
|
|
5
|
-
export default function mergeStreams(streams) {
|
|
6
|
-
if (!Array.isArray(streams)) {
|
|
7
|
-
throw new TypeError(`Expected an array, got \`${typeof streams}\`.`);
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
for (const stream of streams) {
|
|
11
|
-
validateStream(stream);
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
const objectMode = streams.some(({readableObjectMode}) => readableObjectMode);
|
|
15
|
-
const highWaterMark = getHighWaterMark(streams, objectMode);
|
|
16
|
-
const passThroughStream = new MergedStream({
|
|
17
|
-
objectMode,
|
|
18
|
-
writableHighWaterMark: highWaterMark,
|
|
19
|
-
readableHighWaterMark: highWaterMark,
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
for (const stream of streams) {
|
|
23
|
-
passThroughStream.add(stream);
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
return passThroughStream;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
const getHighWaterMark = (streams, objectMode) => {
|
|
30
|
-
if (streams.length === 0) {
|
|
31
|
-
return getDefaultHighWaterMark(objectMode);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
const highWaterMarks = streams
|
|
35
|
-
.filter(({readableObjectMode}) => readableObjectMode === objectMode)
|
|
36
|
-
.map(({readableHighWaterMark}) => readableHighWaterMark);
|
|
37
|
-
return Math.max(...highWaterMarks);
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
class MergedStream extends PassThroughStream {
|
|
41
|
-
#streams = new Set([]);
|
|
42
|
-
#ended = new Set([]);
|
|
43
|
-
#aborted = new Set([]);
|
|
44
|
-
#onFinished;
|
|
45
|
-
#unpipeEvent = Symbol('unpipe');
|
|
46
|
-
#streamPromises = new WeakMap();
|
|
47
|
-
|
|
48
|
-
add(stream) {
|
|
49
|
-
validateStream(stream);
|
|
50
|
-
|
|
51
|
-
if (this.#streams.has(stream)) {
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
this.#streams.add(stream);
|
|
56
|
-
|
|
57
|
-
this.#onFinished ??= onMergedStreamFinished(this, this.#streams, this.#unpipeEvent);
|
|
58
|
-
const streamPromise = endWhenStreamsDone({
|
|
59
|
-
passThroughStream: this,
|
|
60
|
-
stream,
|
|
61
|
-
streams: this.#streams,
|
|
62
|
-
ended: this.#ended,
|
|
63
|
-
aborted: this.#aborted,
|
|
64
|
-
onFinished: this.#onFinished,
|
|
65
|
-
unpipeEvent: this.#unpipeEvent,
|
|
66
|
-
});
|
|
67
|
-
this.#streamPromises.set(stream, streamPromise);
|
|
68
|
-
|
|
69
|
-
stream.pipe(this, {end: false});
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
async remove(stream) {
|
|
73
|
-
validateStream(stream);
|
|
74
|
-
|
|
75
|
-
if (!this.#streams.has(stream)) {
|
|
76
|
-
return false;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
const streamPromise = this.#streamPromises.get(stream);
|
|
80
|
-
if (streamPromise === undefined) {
|
|
81
|
-
return false;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
this.#streamPromises.delete(stream);
|
|
85
|
-
|
|
86
|
-
stream.unpipe(this);
|
|
87
|
-
await streamPromise;
|
|
88
|
-
return true;
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
const onMergedStreamFinished = async (passThroughStream, streams, unpipeEvent) => {
|
|
93
|
-
updateMaxListeners(passThroughStream, PASSTHROUGH_LISTENERS_COUNT);
|
|
94
|
-
const controller = new AbortController();
|
|
95
|
-
|
|
96
|
-
try {
|
|
97
|
-
await Promise.race([
|
|
98
|
-
onMergedStreamEnd(passThroughStream, controller),
|
|
99
|
-
onInputStreamsUnpipe(passThroughStream, streams, unpipeEvent, controller),
|
|
100
|
-
]);
|
|
101
|
-
} finally {
|
|
102
|
-
controller.abort();
|
|
103
|
-
updateMaxListeners(passThroughStream, -PASSTHROUGH_LISTENERS_COUNT);
|
|
104
|
-
}
|
|
105
|
-
};
|
|
106
|
-
|
|
107
|
-
const onMergedStreamEnd = async (passThroughStream, {signal}) => {
|
|
108
|
-
try {
|
|
109
|
-
await finished(passThroughStream, {signal, cleanup: true});
|
|
110
|
-
} catch (error) {
|
|
111
|
-
errorOrAbortStream(passThroughStream, error);
|
|
112
|
-
throw error;
|
|
113
|
-
}
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
const onInputStreamsUnpipe = async (passThroughStream, streams, unpipeEvent, {signal}) => {
|
|
117
|
-
for await (const [unpipedStream] of on(passThroughStream, 'unpipe', {signal})) {
|
|
118
|
-
if (streams.has(unpipedStream)) {
|
|
119
|
-
unpipedStream.emit(unpipeEvent);
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
};
|
|
123
|
-
|
|
124
|
-
const validateStream = stream => {
|
|
125
|
-
if (typeof stream?.pipe !== 'function') {
|
|
126
|
-
throw new TypeError(`Expected a readable stream, got: \`${typeof stream}\`.`);
|
|
127
|
-
}
|
|
128
|
-
};
|
|
129
|
-
|
|
130
|
-
const endWhenStreamsDone = async ({passThroughStream, stream, streams, ended, aborted, onFinished, unpipeEvent}) => {
|
|
131
|
-
updateMaxListeners(passThroughStream, PASSTHROUGH_LISTENERS_PER_STREAM);
|
|
132
|
-
const controller = new AbortController();
|
|
133
|
-
|
|
134
|
-
try {
|
|
135
|
-
await Promise.race([
|
|
136
|
-
afterMergedStreamFinished(onFinished, stream, controller),
|
|
137
|
-
onInputStreamEnd({
|
|
138
|
-
passThroughStream,
|
|
139
|
-
stream,
|
|
140
|
-
streams,
|
|
141
|
-
ended,
|
|
142
|
-
aborted,
|
|
143
|
-
controller,
|
|
144
|
-
}),
|
|
145
|
-
onInputStreamUnpipe({
|
|
146
|
-
stream,
|
|
147
|
-
streams,
|
|
148
|
-
ended,
|
|
149
|
-
aborted,
|
|
150
|
-
unpipeEvent,
|
|
151
|
-
controller,
|
|
152
|
-
}),
|
|
153
|
-
]);
|
|
154
|
-
} finally {
|
|
155
|
-
controller.abort();
|
|
156
|
-
updateMaxListeners(passThroughStream, -PASSTHROUGH_LISTENERS_PER_STREAM);
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
if (streams.size > 0 && streams.size === ended.size + aborted.size) {
|
|
160
|
-
if (ended.size === 0 && aborted.size > 0) {
|
|
161
|
-
abortStream(passThroughStream);
|
|
162
|
-
} else {
|
|
163
|
-
endStream(passThroughStream);
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
};
|
|
167
|
-
|
|
168
|
-
const afterMergedStreamFinished = async (onFinished, stream, {signal}) => {
|
|
169
|
-
try {
|
|
170
|
-
await onFinished;
|
|
171
|
-
if (!signal.aborted) {
|
|
172
|
-
abortStream(stream);
|
|
173
|
-
}
|
|
174
|
-
} catch (error) {
|
|
175
|
-
if (!signal.aborted) {
|
|
176
|
-
errorOrAbortStream(stream, error);
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
};
|
|
180
|
-
|
|
181
|
-
const onInputStreamEnd = async ({passThroughStream, stream, streams, ended, aborted, controller: {signal}}) => {
|
|
182
|
-
try {
|
|
183
|
-
await finished(stream, {
|
|
184
|
-
signal,
|
|
185
|
-
cleanup: true,
|
|
186
|
-
readable: true,
|
|
187
|
-
writable: false,
|
|
188
|
-
});
|
|
189
|
-
if (streams.has(stream)) {
|
|
190
|
-
ended.add(stream);
|
|
191
|
-
}
|
|
192
|
-
} catch (error) {
|
|
193
|
-
if (signal.aborted || !streams.has(stream)) {
|
|
194
|
-
return;
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
if (isAbortError(error)) {
|
|
198
|
-
aborted.add(stream);
|
|
199
|
-
} else {
|
|
200
|
-
errorStream(passThroughStream, error);
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
};
|
|
204
|
-
|
|
205
|
-
const onInputStreamUnpipe = async ({stream, streams, ended, aborted, unpipeEvent, controller: {signal}}) => {
|
|
206
|
-
await once(stream, unpipeEvent, {signal});
|
|
207
|
-
|
|
208
|
-
if (!stream.readable) {
|
|
209
|
-
return once(signal, 'abort', {signal});
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
streams.delete(stream);
|
|
213
|
-
ended.delete(stream);
|
|
214
|
-
aborted.delete(stream);
|
|
215
|
-
};
|
|
216
|
-
|
|
217
|
-
const endStream = stream => {
|
|
218
|
-
if (stream.writable) {
|
|
219
|
-
stream.end();
|
|
220
|
-
}
|
|
221
|
-
};
|
|
222
|
-
|
|
223
|
-
const errorOrAbortStream = (stream, error) => {
|
|
224
|
-
if (isAbortError(error)) {
|
|
225
|
-
abortStream(stream);
|
|
226
|
-
} else {
|
|
227
|
-
errorStream(stream, error);
|
|
228
|
-
}
|
|
229
|
-
};
|
|
230
|
-
|
|
231
|
-
// This is the error thrown by `finished()` on `stream.destroy()`
|
|
232
|
-
const isAbortError = error => error?.code === 'ERR_STREAM_PREMATURE_CLOSE';
|
|
233
|
-
|
|
234
|
-
const abortStream = stream => {
|
|
235
|
-
if (stream.readable || stream.writable) {
|
|
236
|
-
stream.destroy();
|
|
237
|
-
}
|
|
238
|
-
};
|
|
239
|
-
|
|
240
|
-
// `stream.destroy(error)` crashes the process with `uncaughtException` if no `error` event listener exists on `stream`.
|
|
241
|
-
// We take care of error handling on user behalf, so we do not want this to happen.
|
|
242
|
-
const errorStream = (stream, error) => {
|
|
243
|
-
if (!stream.destroyed) {
|
|
244
|
-
stream.once('error', noop);
|
|
245
|
-
stream.destroy(error);
|
|
246
|
-
}
|
|
247
|
-
};
|
|
248
|
-
|
|
249
|
-
const noop = () => {};
|
|
250
|
-
|
|
251
|
-
const updateMaxListeners = (passThroughStream, increment) => {
|
|
252
|
-
const maxListeners = passThroughStream.getMaxListeners();
|
|
253
|
-
if (maxListeners !== 0 && maxListeners !== Number.POSITIVE_INFINITY) {
|
|
254
|
-
passThroughStream.setMaxListeners(maxListeners + increment);
|
|
255
|
-
}
|
|
256
|
-
};
|
|
257
|
-
|
|
258
|
-
// Number of times `passThroughStream.on()` is called regardless of streams:
|
|
259
|
-
// - once due to `finished(passThroughStream)`
|
|
260
|
-
// - once due to `on(passThroughStream)`
|
|
261
|
-
const PASSTHROUGH_LISTENERS_COUNT = 2;
|
|
262
|
-
|
|
263
|
-
// Number of times `passThroughStream.on()` is called per stream:
|
|
264
|
-
// - once due to `stream.pipe(passThroughStream)`
|
|
265
|
-
const PASSTHROUGH_LISTENERS_PER_STREAM = 1;
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@sindresorhus/merge-streams",
|
|
3
|
-
"version": "4.0.0",
|
|
4
|
-
"description": "Merge multiple streams into a unified stream",
|
|
5
|
-
"license": "MIT",
|
|
6
|
-
"repository": "sindresorhus/merge-streams",
|
|
7
|
-
"funding": "https://github.com/sponsors/sindresorhus",
|
|
8
|
-
"author": {
|
|
9
|
-
"name": "Sindre Sorhus",
|
|
10
|
-
"email": "sindresorhus@gmail.com",
|
|
11
|
-
"url": "https://sindresorhus.com"
|
|
12
|
-
},
|
|
13
|
-
"type": "module",
|
|
14
|
-
"exports": {
|
|
15
|
-
"types": "./index.d.ts",
|
|
16
|
-
"default": "./index.js"
|
|
17
|
-
},
|
|
18
|
-
"sideEffects": false,
|
|
19
|
-
"engines": {
|
|
20
|
-
"node": ">=18"
|
|
21
|
-
},
|
|
22
|
-
"scripts": {
|
|
23
|
-
"test": "xo && c8 ava && tsd"
|
|
24
|
-
},
|
|
25
|
-
"files": [
|
|
26
|
-
"index.js",
|
|
27
|
-
"index.d.ts"
|
|
28
|
-
],
|
|
29
|
-
"keywords": [
|
|
30
|
-
"merge",
|
|
31
|
-
"stream",
|
|
32
|
-
"streams",
|
|
33
|
-
"readable",
|
|
34
|
-
"passthrough",
|
|
35
|
-
"interleave",
|
|
36
|
-
"interleaved",
|
|
37
|
-
"unify",
|
|
38
|
-
"unified"
|
|
39
|
-
],
|
|
40
|
-
"devDependencies": {
|
|
41
|
-
"@types/node": "^20.8.9",
|
|
42
|
-
"ava": "^6.1.0",
|
|
43
|
-
"c8": "^9.1.0",
|
|
44
|
-
"tempfile": "^5.0.0",
|
|
45
|
-
"tsd": "^0.31.0",
|
|
46
|
-
"typescript": "^5.2.2",
|
|
47
|
-
"xo": "^0.58.0"
|
|
48
|
-
}
|
|
49
|
-
}
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
module.exports = balanced;
|
|
3
|
-
function balanced(a, b, str) {
|
|
4
|
-
if (a instanceof RegExp) a = maybeMatch(a, str);
|
|
5
|
-
if (b instanceof RegExp) b = maybeMatch(b, str);
|
|
6
|
-
|
|
7
|
-
var r = range(a, b, str);
|
|
8
|
-
|
|
9
|
-
return r && {
|
|
10
|
-
start: r[0],
|
|
11
|
-
end: r[1],
|
|
12
|
-
pre: str.slice(0, r[0]),
|
|
13
|
-
body: str.slice(r[0] + a.length, r[1]),
|
|
14
|
-
post: str.slice(r[1] + b.length)
|
|
15
|
-
};
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
function maybeMatch(reg, str) {
|
|
19
|
-
var m = str.match(reg);
|
|
20
|
-
return m ? m[0] : null;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
balanced.range = range;
|
|
24
|
-
function range(a, b, str) {
|
|
25
|
-
var begs, beg, left, right, result;
|
|
26
|
-
var ai = str.indexOf(a);
|
|
27
|
-
var bi = str.indexOf(b, ai + 1);
|
|
28
|
-
var i = ai;
|
|
29
|
-
|
|
30
|
-
if (ai >= 0 && bi > 0) {
|
|
31
|
-
if(a===b) {
|
|
32
|
-
return [ai, bi];
|
|
33
|
-
}
|
|
34
|
-
begs = [];
|
|
35
|
-
left = str.length;
|
|
36
|
-
|
|
37
|
-
while (i >= 0 && !result) {
|
|
38
|
-
if (i == ai) {
|
|
39
|
-
begs.push(i);
|
|
40
|
-
ai = str.indexOf(a, i + 1);
|
|
41
|
-
} else if (begs.length == 1) {
|
|
42
|
-
result = [ begs.pop(), bi ];
|
|
43
|
-
} else {
|
|
44
|
-
beg = begs.pop();
|
|
45
|
-
if (beg < left) {
|
|
46
|
-
left = beg;
|
|
47
|
-
right = bi;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
bi = str.indexOf(b, i + 1);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
i = ai < bi && ai >= 0 ? ai : bi;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
if (begs.length) {
|
|
57
|
-
result = [ left, right ];
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
return result;
|
|
62
|
-
}
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "balanced-match",
|
|
3
|
-
"description": "Match balanced character pairs, like \"{\" and \"}\"",
|
|
4
|
-
"version": "1.0.2",
|
|
5
|
-
"repository": {
|
|
6
|
-
"type": "git",
|
|
7
|
-
"url": "git://github.com/juliangruber/balanced-match.git"
|
|
8
|
-
},
|
|
9
|
-
"homepage": "https://github.com/juliangruber/balanced-match",
|
|
10
|
-
"main": "index.js",
|
|
11
|
-
"scripts": {
|
|
12
|
-
"test": "tape test/test.js",
|
|
13
|
-
"bench": "matcha test/bench.js"
|
|
14
|
-
},
|
|
15
|
-
"devDependencies": {
|
|
16
|
-
"matcha": "^0.7.0",
|
|
17
|
-
"tape": "^4.6.0"
|
|
18
|
-
},
|
|
19
|
-
"keywords": [
|
|
20
|
-
"match",
|
|
21
|
-
"regexp",
|
|
22
|
-
"test",
|
|
23
|
-
"balanced",
|
|
24
|
-
"parse"
|
|
25
|
-
],
|
|
26
|
-
"author": {
|
|
27
|
-
"name": "Julian Gruber",
|
|
28
|
-
"email": "mail@juliangruber.com",
|
|
29
|
-
"url": "http://juliangruber.com"
|
|
30
|
-
},
|
|
31
|
-
"license": "MIT",
|
|
32
|
-
"testling": {
|
|
33
|
-
"files": "test/*.js",
|
|
34
|
-
"browsers": [
|
|
35
|
-
"ie/8..latest",
|
|
36
|
-
"firefox/20..latest",
|
|
37
|
-
"firefox/nightly",
|
|
38
|
-
"chrome/25..latest",
|
|
39
|
-
"chrome/canary",
|
|
40
|
-
"opera/12..latest",
|
|
41
|
-
"opera/next",
|
|
42
|
-
"safari/5.1..latest",
|
|
43
|
-
"ipad/6.0..latest",
|
|
44
|
-
"iphone/6.0..latest",
|
|
45
|
-
"android-browser/4.2..latest"
|
|
46
|
-
]
|
|
47
|
-
}
|
|
48
|
-
}
|