Remove deprecated scripts for adding head-matter to wt_config.xml, including Python and Bash implementations, to streamline configuration management.
This commit is contained in:
201
node_modules/bare-stream/LICENSE
generated
vendored
Normal file
201
node_modules/bare-stream/LICENSE
generated
vendored
Normal file
@@ -0,0 +1,201 @@
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright [yyyy] [name of copyright owner]
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
15
node_modules/bare-stream/README.md
generated
vendored
Normal file
15
node_modules/bare-stream/README.md
generated
vendored
Normal file
@@ -0,0 +1,15 @@
|
||||
# bare-stream
|
||||
|
||||
Streaming data for JavaScript.
|
||||
|
||||
```
|
||||
npm i bare-stream
|
||||
```
|
||||
|
||||
## API
|
||||
|
||||
See <https://github.com/mafintosh/streamx>.
|
||||
|
||||
## License
|
||||
|
||||
Apache-2.0
|
||||
8
node_modules/bare-stream/global.js
generated
vendored
Normal file
8
node_modules/bare-stream/global.js
generated
vendored
Normal file
@@ -0,0 +1,8 @@
|
||||
const stream = require('./web')
|
||||
|
||||
global.ReadableStream = stream.ReadableStream
|
||||
global.ReadableStreamDefaultController = stream.ReadableStreamDefaultController
|
||||
global.ReadableStreamDefaultReader = stream.ReadableStreamDefaultReader
|
||||
|
||||
global.CountQueuingStrategy = stream.CountQueuingStrategy
|
||||
global.ByteLengthQueuingStrategy = stream.ByteLengthQueuingStrategy
|
||||
237
node_modules/bare-stream/index.d.ts
generated
vendored
Normal file
237
node_modules/bare-stream/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,237 @@
|
||||
import EventEmitter, { EventMap } from 'bare-events'
|
||||
import Buffer, { BufferEncoding } from 'bare-buffer'
|
||||
|
||||
type StreamEncoding = BufferEncoding | 'buffer'
|
||||
|
||||
interface StreamCallback {
|
||||
(err: Error | null): void
|
||||
}
|
||||
|
||||
interface StreamEvents extends EventMap {
|
||||
close: []
|
||||
error: [err: Error]
|
||||
}
|
||||
|
||||
interface StreamOptions<S extends Stream = Stream> {
|
||||
eagerOpen?: boolean
|
||||
signal?: AbortSignal
|
||||
open?(this: S, cb: StreamCallback): void
|
||||
predestroy?(this: S): void
|
||||
destroy?(this: S, err: Error | null, cb: StreamCallback): void
|
||||
}
|
||||
|
||||
interface Stream<M extends StreamEvents = StreamEvents>
|
||||
extends EventEmitter<M> {
|
||||
_open(cb: StreamCallback): void
|
||||
_predestroy(): void
|
||||
_destroy(err: Error | null, cb: StreamCallback): void
|
||||
|
||||
readonly readable: boolean
|
||||
readonly writable: boolean
|
||||
readonly destroyed: boolean
|
||||
readonly destroying: boolean
|
||||
|
||||
destroy(err?: Error | null): void
|
||||
}
|
||||
|
||||
declare class Stream {}
|
||||
|
||||
interface ReadableEvents extends StreamEvents {
|
||||
data: [data: unknown]
|
||||
end: []
|
||||
readable: []
|
||||
piping: [dest: Writable]
|
||||
}
|
||||
|
||||
interface ReadableOptions<S extends Readable = Readable>
|
||||
extends StreamOptions<S> {
|
||||
encoding?: BufferEncoding
|
||||
highWaterMark?: number
|
||||
read?(this: S, size: number): void
|
||||
}
|
||||
|
||||
interface Readable<M extends ReadableEvents = ReadableEvents>
|
||||
extends Stream<M>,
|
||||
AsyncIterable<unknown> {
|
||||
_read(size: number): void
|
||||
|
||||
push(data: unknown | null, encoding?: BufferEncoding): boolean
|
||||
unshift(data: unknown | null, encoding?: BufferEncoding): boolean
|
||||
read(): unknown | null
|
||||
|
||||
resume(): this
|
||||
pause(): this
|
||||
|
||||
pipe<S extends Writable>(dest: S, cb?: StreamCallback): S
|
||||
|
||||
setEncoding(encoding: BufferEncoding): void
|
||||
}
|
||||
|
||||
declare class Readable<
|
||||
M extends ReadableEvents = ReadableEvents
|
||||
> extends Stream<M> {
|
||||
constructor(opts?: ReadableOptions)
|
||||
|
||||
static from(
|
||||
data: unknown | unknown[] | AsyncIterable<unknown>,
|
||||
opts?: ReadableOptions
|
||||
): Readable
|
||||
|
||||
static isBackpressured(rs: Readable): boolean
|
||||
|
||||
static isPaused(rs: Readable): boolean
|
||||
}
|
||||
|
||||
interface WritableEvents extends StreamEvents {
|
||||
drain: []
|
||||
finish: []
|
||||
pipe: [src: Readable]
|
||||
}
|
||||
|
||||
interface WritableOptions<S extends Writable = Writable>
|
||||
extends StreamOptions<S> {
|
||||
write?(
|
||||
this: S,
|
||||
data: unknown,
|
||||
encoding: StreamEncoding,
|
||||
cb: StreamCallback
|
||||
): void
|
||||
writev?(
|
||||
this: S,
|
||||
batch: { chunk: unknown; encoding: StreamEncoding }[],
|
||||
cb: StreamCallback
|
||||
): void
|
||||
final?(this: S, cb: StreamCallback): void
|
||||
}
|
||||
|
||||
interface Writable<M extends WritableEvents = WritableEvents>
|
||||
extends Stream<M> {
|
||||
_write(data: unknown, encoding: StreamEncoding, cb: StreamCallback): void
|
||||
_writev(
|
||||
batch: { chunk: unknown; encoding: StreamEncoding }[],
|
||||
cb: StreamCallback
|
||||
): void
|
||||
_final(cb: StreamCallback): void
|
||||
|
||||
readonly destroyed: boolean
|
||||
|
||||
write(data: unknown, encoding?: BufferEncoding, cb?: StreamCallback): boolean
|
||||
write(data: unknown, cb?: StreamCallback): boolean
|
||||
|
||||
end(cb?: StreamCallback): this
|
||||
end(data: unknown, encoding?: BufferEncoding, cb?: StreamCallback): this
|
||||
end(data: unknown, cb?: StreamCallback): this
|
||||
|
||||
cork(): void
|
||||
uncork(): void
|
||||
}
|
||||
|
||||
declare class Writable<
|
||||
M extends WritableEvents = WritableEvents
|
||||
> extends Stream<M> {
|
||||
constructor(opts?: WritableOptions)
|
||||
|
||||
static isBackpressured(ws: Writable): boolean
|
||||
|
||||
static drained(ws: Writable): Promise<boolean>
|
||||
}
|
||||
|
||||
interface DuplexEvents extends ReadableEvents, WritableEvents {}
|
||||
|
||||
interface DuplexOptions<S extends Duplex = Duplex>
|
||||
extends ReadableOptions<S>,
|
||||
WritableOptions<S> {}
|
||||
|
||||
interface Duplex<M extends DuplexEvents = DuplexEvents>
|
||||
extends Readable<M>,
|
||||
Writable<M> {}
|
||||
|
||||
declare class Duplex<M extends DuplexEvents = DuplexEvents> extends Stream<M> {
|
||||
constructor(opts?: DuplexOptions)
|
||||
}
|
||||
|
||||
interface TransformEvents extends DuplexEvents {}
|
||||
|
||||
interface TransformOptions<S extends Transform = Transform>
|
||||
extends DuplexOptions<S> {
|
||||
transform?(
|
||||
this: S,
|
||||
data: unknown,
|
||||
encoding: StreamEncoding,
|
||||
cb: StreamCallback
|
||||
): void
|
||||
flush?(this: S, cb: StreamCallback): void
|
||||
}
|
||||
|
||||
interface Transform<M extends TransformEvents = TransformEvents>
|
||||
extends Duplex<M> {
|
||||
_transform(data: unknown, encoding: StreamEncoding, cb: StreamCallback): void
|
||||
_flush(cb: StreamCallback): void
|
||||
}
|
||||
|
||||
declare class Transform<
|
||||
M extends TransformEvents = TransformEvents
|
||||
> extends Duplex<M> {
|
||||
constructor(opts?: TransformOptions)
|
||||
}
|
||||
|
||||
type Pipeline<S extends Writable> = [
|
||||
src: Readable,
|
||||
...transforms: Duplex[],
|
||||
dest: S
|
||||
]
|
||||
|
||||
declare namespace Stream {
|
||||
export {
|
||||
Stream,
|
||||
StreamEvents,
|
||||
StreamOptions,
|
||||
Readable,
|
||||
ReadableEvents,
|
||||
ReadableOptions,
|
||||
Writable,
|
||||
WritableEvents,
|
||||
WritableOptions,
|
||||
Duplex,
|
||||
DuplexEvents,
|
||||
DuplexOptions,
|
||||
Transform,
|
||||
TransformEvents,
|
||||
TransformOptions,
|
||||
Transform as PassThrough
|
||||
}
|
||||
|
||||
export function pipeline<S extends Writable>(
|
||||
streams: Pipeline<S>,
|
||||
cb?: StreamCallback
|
||||
): S
|
||||
|
||||
export function pipeline<S extends Writable>(...args: Pipeline<S>): S
|
||||
|
||||
export function pipeline<S extends Writable>(
|
||||
...args: [...Pipeline<S>, cb: StreamCallback]
|
||||
): S
|
||||
|
||||
export function finished(
|
||||
stream: Stream,
|
||||
opts: { cleanup?: boolean },
|
||||
cb: StreamCallback
|
||||
): () => void
|
||||
|
||||
export function finished(stream: Stream, cb: StreamCallback): () => void
|
||||
|
||||
export function isStream(stream: unknown): stream is Stream
|
||||
|
||||
export function isEnded(stream: Stream): boolean
|
||||
|
||||
export function isFinished(stream: Stream): boolean
|
||||
|
||||
export function isDisturbed(stream: Stream): boolean
|
||||
|
||||
export function getStreamError(
|
||||
stream: Stream,
|
||||
opts?: { all?: boolean }
|
||||
): Error | null
|
||||
}
|
||||
|
||||
export = Stream
|
||||
355
node_modules/bare-stream/index.js
generated
vendored
Normal file
355
node_modules/bare-stream/index.js
generated
vendored
Normal file
@@ -0,0 +1,355 @@
|
||||
const stream = require('streamx')
|
||||
|
||||
const defaultEncoding = 'utf8'
|
||||
|
||||
module.exports = exports = stream.Stream
|
||||
|
||||
exports.pipeline = stream.pipeline
|
||||
|
||||
exports.isStream = stream.isStream
|
||||
exports.isEnded = stream.isEnded
|
||||
exports.isFinished = stream.isFinished
|
||||
exports.isDisturbed = stream.isDisturbed
|
||||
|
||||
exports.getStreamError = stream.getStreamError
|
||||
|
||||
exports.Stream = exports
|
||||
|
||||
exports.Readable = class Readable extends stream.Readable {
|
||||
constructor(opts = {}) {
|
||||
super({
|
||||
...opts,
|
||||
byteLength: null,
|
||||
byteLengthReadable: null,
|
||||
map: null,
|
||||
mapReadable: null
|
||||
})
|
||||
|
||||
if (this._construct) this._open = this._construct
|
||||
|
||||
if (this._read !== stream.Readable.prototype._read) {
|
||||
this._read = read.bind(this, this._read)
|
||||
}
|
||||
|
||||
if (this._destroy !== stream.Stream.prototype._destroy) {
|
||||
this._destroy = destroy.bind(this, this._destroy)
|
||||
}
|
||||
}
|
||||
|
||||
push(chunk, encoding) {
|
||||
if (typeof chunk === 'string') {
|
||||
chunk = Buffer.from(chunk, encoding || defaultEncoding)
|
||||
}
|
||||
|
||||
return super.push(chunk)
|
||||
}
|
||||
|
||||
unshift(chunk, encoding) {
|
||||
if (typeof chunk === 'string') {
|
||||
chunk = Buffer.from(chunk, encoding || defaultEncoding)
|
||||
}
|
||||
|
||||
super.unshift(chunk)
|
||||
}
|
||||
}
|
||||
|
||||
exports.Writable = class Writable extends stream.Writable {
|
||||
constructor(opts = {}) {
|
||||
super({
|
||||
...opts,
|
||||
byteLength: null,
|
||||
byteLengthWritable,
|
||||
map: null,
|
||||
mapWritable: null
|
||||
})
|
||||
|
||||
if (this._construct) this._open = this._construct
|
||||
|
||||
if (this._write !== stream.Writable.prototype._write) {
|
||||
this._write = write.bind(this, this._write)
|
||||
}
|
||||
|
||||
if (this._destroy !== stream.Stream.prototype._destroy) {
|
||||
this._destroy = destroy.bind(this, this._destroy)
|
||||
}
|
||||
}
|
||||
|
||||
write(chunk, encoding, cb) {
|
||||
if (typeof encoding === 'function') {
|
||||
cb = encoding
|
||||
encoding = null
|
||||
}
|
||||
|
||||
if (typeof chunk === 'string') {
|
||||
encoding = encoding || defaultEncoding
|
||||
chunk = Buffer.from(chunk, encoding)
|
||||
} else {
|
||||
encoding = 'buffer'
|
||||
}
|
||||
|
||||
const result = super.write({ chunk, encoding })
|
||||
|
||||
if (cb) stream.Writable.drained(this).then(() => cb(null), cb)
|
||||
|
||||
return result
|
||||
}
|
||||
|
||||
end(chunk, encoding, cb) {
|
||||
if (typeof chunk === 'function') {
|
||||
cb = chunk
|
||||
chunk = null
|
||||
} else if (typeof encoding === 'function') {
|
||||
cb = encoding
|
||||
encoding = null
|
||||
}
|
||||
|
||||
if (typeof chunk === 'string') {
|
||||
encoding = encoding || defaultEncoding
|
||||
chunk = Buffer.from(chunk, encoding || defaultEncoding)
|
||||
} else {
|
||||
encoding = 'buffer'
|
||||
}
|
||||
|
||||
const result =
|
||||
chunk !== undefined && chunk !== null
|
||||
? super.end({ chunk, encoding })
|
||||
: super.end()
|
||||
|
||||
if (cb) this.once('finish', () => cb(null))
|
||||
|
||||
return result
|
||||
}
|
||||
}
|
||||
|
||||
exports.Duplex = class Duplex extends stream.Duplex {
|
||||
constructor(opts = {}) {
|
||||
super({
|
||||
...opts,
|
||||
byteLength: null,
|
||||
byteLengthReadable: null,
|
||||
byteLengthWritable,
|
||||
map: null,
|
||||
mapReadable: null,
|
||||
mapWritable: null
|
||||
})
|
||||
|
||||
if (this._construct) this._open = this._construct
|
||||
|
||||
if (this._read !== stream.Readable.prototype._read) {
|
||||
this._read = read.bind(this, this._read)
|
||||
}
|
||||
|
||||
if (this._write !== stream.Duplex.prototype._write) {
|
||||
this._write = write.bind(this, this._write)
|
||||
}
|
||||
|
||||
if (this._destroy !== stream.Stream.prototype._destroy) {
|
||||
this._destroy = destroy.bind(this, this._destroy)
|
||||
}
|
||||
}
|
||||
|
||||
push(chunk, encoding) {
|
||||
if (typeof chunk === 'string') {
|
||||
chunk = Buffer.from(chunk, encoding || defaultEncoding)
|
||||
}
|
||||
|
||||
return super.push(chunk)
|
||||
}
|
||||
|
||||
unshift(chunk, encoding) {
|
||||
if (typeof chunk === 'string') {
|
||||
chunk = Buffer.from(chunk, encoding || defaultEncoding)
|
||||
}
|
||||
|
||||
super.unshift(chunk)
|
||||
}
|
||||
|
||||
write(chunk, encoding, cb) {
|
||||
if (typeof encoding === 'function') {
|
||||
cb = encoding
|
||||
encoding = null
|
||||
}
|
||||
|
||||
if (typeof chunk === 'string') {
|
||||
encoding = encoding || defaultEncoding
|
||||
chunk = Buffer.from(chunk, encoding)
|
||||
} else {
|
||||
encoding = 'buffer'
|
||||
}
|
||||
|
||||
const result = super.write({ chunk, encoding })
|
||||
|
||||
if (cb) stream.Writable.drained(this).then(() => cb(null), cb)
|
||||
|
||||
return result
|
||||
}
|
||||
|
||||
end(chunk, encoding, cb) {
|
||||
if (typeof chunk === 'function') {
|
||||
cb = chunk
|
||||
chunk = null
|
||||
} else if (typeof encoding === 'function') {
|
||||
cb = encoding
|
||||
encoding = null
|
||||
}
|
||||
|
||||
if (typeof chunk === 'string') {
|
||||
encoding = encoding || defaultEncoding
|
||||
chunk = Buffer.from(chunk, encoding)
|
||||
} else {
|
||||
encoding = 'buffer'
|
||||
}
|
||||
|
||||
const result =
|
||||
chunk !== undefined && chunk !== null
|
||||
? super.end({ chunk, encoding })
|
||||
: super.end()
|
||||
|
||||
if (cb) this.once('finish', () => cb(null))
|
||||
|
||||
return result
|
||||
}
|
||||
}
|
||||
|
||||
exports.Transform = class Transform extends stream.Transform {
|
||||
constructor(opts = {}) {
|
||||
super({
|
||||
...opts,
|
||||
byteLength: null,
|
||||
byteLengthReadable: null,
|
||||
byteLengthWritable,
|
||||
map: null,
|
||||
mapReadable: null,
|
||||
mapWritable: null
|
||||
})
|
||||
|
||||
if (this._transform !== stream.Transform.prototype._transform) {
|
||||
this._transform = transform.bind(this, this._transform)
|
||||
} else {
|
||||
this._transform = passthrough
|
||||
}
|
||||
}
|
||||
|
||||
push(chunk, encoding) {
|
||||
if (typeof chunk === 'string') {
|
||||
chunk = Buffer.from(chunk, encoding || defaultEncoding)
|
||||
}
|
||||
|
||||
return super.push(chunk)
|
||||
}
|
||||
|
||||
unshift(chunk, encoding) {
|
||||
if (typeof chunk === 'string') {
|
||||
chunk = Buffer.from(chunk, encoding || defaultEncoding)
|
||||
}
|
||||
|
||||
super.unshift(chunk)
|
||||
}
|
||||
|
||||
write(chunk, encoding, cb) {
|
||||
if (typeof encoding === 'function') {
|
||||
cb = encoding
|
||||
encoding = null
|
||||
}
|
||||
|
||||
if (typeof chunk === 'string') {
|
||||
encoding = encoding || defaultEncoding
|
||||
chunk = Buffer.from(chunk, encoding)
|
||||
} else {
|
||||
encoding = 'buffer'
|
||||
}
|
||||
|
||||
const result = super.write({ chunk, encoding })
|
||||
|
||||
if (cb) stream.Writable.drained(this).then(() => cb(null), cb)
|
||||
|
||||
return result
|
||||
}
|
||||
|
||||
end(chunk, encoding, cb) {
|
||||
if (typeof chunk === 'function') {
|
||||
cb = chunk
|
||||
chunk = null
|
||||
} else if (typeof encoding === 'function') {
|
||||
cb = encoding
|
||||
encoding = null
|
||||
}
|
||||
|
||||
if (typeof chunk === 'string') {
|
||||
encoding = encoding || defaultEncoding
|
||||
chunk = Buffer.from(chunk, encoding)
|
||||
} else {
|
||||
encoding = 'buffer'
|
||||
}
|
||||
|
||||
const result =
|
||||
chunk !== undefined && chunk !== null
|
||||
? super.end({ chunk, encoding })
|
||||
: super.end()
|
||||
|
||||
if (cb) this.once('finish', () => cb(null))
|
||||
|
||||
return result
|
||||
}
|
||||
}
|
||||
|
||||
exports.PassThrough = class PassThrough extends exports.Transform {}
|
||||
|
||||
exports.finished = function finished(stream, opts, cb) {
|
||||
if (typeof opts === 'function') {
|
||||
cb = opts
|
||||
opts = {}
|
||||
}
|
||||
|
||||
if (!opts) opts = {}
|
||||
|
||||
const { cleanup = false } = opts
|
||||
|
||||
const done = () => {
|
||||
cb(exports.getStreamError(stream, { all: true }))
|
||||
|
||||
if (cleanup) detach()
|
||||
}
|
||||
|
||||
const detach = () => {
|
||||
stream.off('close', done)
|
||||
stream.off('error', noop)
|
||||
}
|
||||
|
||||
if (stream.destroyed) {
|
||||
done()
|
||||
} else {
|
||||
stream.on('close', done)
|
||||
stream.on('error', noop)
|
||||
}
|
||||
|
||||
return detach
|
||||
}
|
||||
|
||||
function read(read, cb) {
|
||||
read.call(this, 65536)
|
||||
|
||||
cb(null)
|
||||
}
|
||||
|
||||
function write(write, data, cb) {
|
||||
write.call(this, data.chunk, data.encoding, cb)
|
||||
}
|
||||
|
||||
function transform(transform, data, cb) {
|
||||
transform.call(this, data.chunk, data.encoding, cb)
|
||||
}
|
||||
|
||||
function destroy(destroy, cb) {
|
||||
destroy.call(this, exports.getStreamError(this), cb)
|
||||
}
|
||||
|
||||
function passthrough(data, cb) {
|
||||
cb(null, data.chunk)
|
||||
}
|
||||
|
||||
function byteLengthWritable(data) {
|
||||
return data.chunk.byteLength
|
||||
}
|
||||
|
||||
function noop() {}
|
||||
61
node_modules/bare-stream/package.json
generated
vendored
Normal file
61
node_modules/bare-stream/package.json
generated
vendored
Normal file
@@ -0,0 +1,61 @@
|
||||
{
|
||||
"name": "bare-stream",
|
||||
"version": "2.7.0",
|
||||
"description": "Streaming data for JavaScript",
|
||||
"exports": {
|
||||
".": {
|
||||
"types": "./index.d.ts",
|
||||
"default": "./index.js"
|
||||
},
|
||||
"./package": "./package.json",
|
||||
"./promises": "./promises.js",
|
||||
"./web": {
|
||||
"types": "./web.d.ts",
|
||||
"default": "./web.js"
|
||||
},
|
||||
"./global": "./global.js"
|
||||
},
|
||||
"files": [
|
||||
"index.js",
|
||||
"index.d.ts",
|
||||
"promises.js",
|
||||
"web.js",
|
||||
"web.d.ts",
|
||||
"global.js"
|
||||
],
|
||||
"scripts": {
|
||||
"test": "prettier . --check && bare test.js"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "git+https://github.com/holepunchto/bare-stream.git"
|
||||
},
|
||||
"author": "Holepunch",
|
||||
"license": "Apache-2.0",
|
||||
"bugs": {
|
||||
"url": "https://github.com/holepunchto/bare-stream/issues"
|
||||
},
|
||||
"homepage": "https://github.com/holepunchto/bare-stream#readme",
|
||||
"dependencies": {
|
||||
"streamx": "^2.21.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"bare-buffer": "^3.0.0",
|
||||
"bare-events": "^2.5.4",
|
||||
"brittle": "^3.5.2",
|
||||
"prettier": "^3.3.3",
|
||||
"prettier-config-standard": "^7.0.0"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"bare-buffer": "*",
|
||||
"bare-events": "*"
|
||||
},
|
||||
"peerDependenciesMeta": {
|
||||
"bare-buffer": {
|
||||
"optional": true
|
||||
},
|
||||
"bare-events": {
|
||||
"optional": true
|
||||
}
|
||||
}
|
||||
}
|
||||
3
node_modules/bare-stream/promises.js
generated
vendored
Normal file
3
node_modules/bare-stream/promises.js
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
const stream = require('streamx')
|
||||
|
||||
exports.pipeline = stream.pipelinePromise
|
||||
73
node_modules/bare-stream/web.d.ts
generated
vendored
Normal file
73
node_modules/bare-stream/web.d.ts
generated
vendored
Normal file
@@ -0,0 +1,73 @@
|
||||
import { Writable } from '.'
|
||||
|
||||
export interface ReadableStreamDefaultReader {
|
||||
read(): Promise<{ value: unknown; done: boolean }>
|
||||
cancel(reason?: unknown): Promise<void>
|
||||
}
|
||||
|
||||
export class ReadableStreamDefaultReader {
|
||||
constructor(stream: ReadableStream)
|
||||
}
|
||||
|
||||
export interface ReadableStreamDefaultController {
|
||||
readonly desiredSize: number
|
||||
|
||||
enqueue(data: unknown): void
|
||||
close(): void
|
||||
error(error?: unknown): void
|
||||
}
|
||||
|
||||
export class ReadableStreamDefaultController {
|
||||
constructor(stream: ReadableStream)
|
||||
}
|
||||
|
||||
export interface UnderlyingSource<S extends ReadableStream = ReadableStream> {
|
||||
start?(this: S, controller: ReadableStreamDefaultController): void
|
||||
pull?(this: S, controller: ReadableStreamDefaultController): void
|
||||
}
|
||||
|
||||
export interface CustomQueuingStrategy {
|
||||
highWaterMark?: number
|
||||
size?: (chunk: unknown) => number
|
||||
}
|
||||
|
||||
export interface ReadableStream extends AsyncIterable<unknown> {
|
||||
getReader(): ReadableStreamDefaultReader
|
||||
cancel(reason?: unknown): Promise<void>
|
||||
pipeTo(destination: Writable): Promise<void>
|
||||
}
|
||||
|
||||
export class ReadableStream {
|
||||
constructor(
|
||||
underlyingSource?: UnderlyingSource,
|
||||
queuingStrategy?: CustomQueuingStrategy
|
||||
)
|
||||
|
||||
static from(
|
||||
iterable: unknown | unknown[] | AsyncIterable<unknown>
|
||||
): ReadableStream
|
||||
}
|
||||
|
||||
export interface QueuingStrategyOptions {
|
||||
highWaterMark?: number
|
||||
}
|
||||
|
||||
interface QueuingStrategy {
|
||||
readonly highWaterMark: number
|
||||
|
||||
size(chunk: unknown): number
|
||||
}
|
||||
|
||||
declare class QueuingStrategy {
|
||||
constructor(opts?: QueuingStrategyOptions)
|
||||
}
|
||||
|
||||
export { type QueuingStrategy }
|
||||
|
||||
export class CountQueuingStrategy extends QueuingStrategy {}
|
||||
|
||||
export class ByteLengthQueuingStrategy extends QueuingStrategy {}
|
||||
|
||||
export function isReadableStream(value: unknown): value is ReadableStream
|
||||
|
||||
export function isReadableStreamDisturbed(stream: ReadableStream): boolean
|
||||
229
node_modules/bare-stream/web.js
generated
vendored
Normal file
229
node_modules/bare-stream/web.js
generated
vendored
Normal file
@@ -0,0 +1,229 @@
|
||||
const { Readable, getStreamError, isStreamx, isDisturbed } = require('streamx')
|
||||
|
||||
const readableKind = Symbol.for('bare.stream.readable.kind')
|
||||
|
||||
// https://streams.spec.whatwg.org/#readablestreamdefaultreader
|
||||
exports.ReadableStreamDefaultReader = class ReadableStreamDefaultReader {
|
||||
constructor(stream) {
|
||||
this._stream = stream._stream
|
||||
}
|
||||
|
||||
read() {
|
||||
const stream = this._stream
|
||||
|
||||
return new Promise((resolve, reject) => {
|
||||
const err = getStreamError(stream)
|
||||
|
||||
if (err) return reject(err)
|
||||
|
||||
if (stream.destroyed) {
|
||||
return resolve({ value: undefined, done: true })
|
||||
}
|
||||
|
||||
const value = stream.read()
|
||||
|
||||
if (value !== null) {
|
||||
return resolve({ value, done: false })
|
||||
}
|
||||
|
||||
stream
|
||||
.once('readable', onreadable)
|
||||
.once('close', onclose)
|
||||
.once('error', onerror)
|
||||
|
||||
function onreadable() {
|
||||
const value = stream.read()
|
||||
|
||||
ondone(
|
||||
null,
|
||||
value === null
|
||||
? { value: undefined, done: true }
|
||||
: { value, done: false }
|
||||
)
|
||||
}
|
||||
|
||||
function onclose() {
|
||||
ondone(null, { value: undefined, done: true })
|
||||
}
|
||||
|
||||
function onerror(err) {
|
||||
ondone(err, null)
|
||||
}
|
||||
|
||||
function ondone(err, value) {
|
||||
stream
|
||||
.off('readable', onreadable)
|
||||
.off('close', onclose)
|
||||
.off('error', onerror)
|
||||
|
||||
if (err) reject(err)
|
||||
else resolve(value)
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
cancel(reason) {
|
||||
if (this._stream.destroyed) return Promise.resolve()
|
||||
|
||||
return new Promise((resolve) =>
|
||||
this._stream.once('close', resolve).destroy(reason)
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
// https://streams.spec.whatwg.org/#readablestreamdefaultcontroller
|
||||
exports.ReadableStreamDefaultController = class ReadableStreamDefaultController {
|
||||
constructor(stream) {
|
||||
this._stream = stream._stream
|
||||
}
|
||||
|
||||
get desiredSize() {
|
||||
return (
|
||||
this._stream._readableState.highWaterMark -
|
||||
this._stream._readableState.buffered
|
||||
)
|
||||
}
|
||||
|
||||
enqueue(data) {
|
||||
this._stream.push(data)
|
||||
}
|
||||
|
||||
close() {
|
||||
this._stream.push(null)
|
||||
}
|
||||
|
||||
error(err) {
|
||||
this._stream.destroy(err)
|
||||
}
|
||||
}
|
||||
|
||||
// https://streams.spec.whatwg.org/#readablestream
|
||||
class ReadableStream {
|
||||
static get [readableKind]() {
|
||||
return 0 // Compatibility version
|
||||
}
|
||||
|
||||
constructor(underlyingSource = {}, queuingStrategy) {
|
||||
if (isStreamx(underlyingSource)) {
|
||||
this._stream = underlyingSource
|
||||
} else {
|
||||
if (queuingStrategy === undefined) {
|
||||
queuingStrategy = new exports.CountQueuingStrategy()
|
||||
}
|
||||
|
||||
const { start, pull } = underlyingSource
|
||||
const { highWaterMark = 1, size = defaultSize } = queuingStrategy
|
||||
|
||||
this._stream = new Readable({ highWaterMark, byteLength: size })
|
||||
|
||||
const controller = new exports.ReadableStreamDefaultController(this)
|
||||
|
||||
if (start) {
|
||||
this._stream._open = open.bind(this, start.call(this, controller))
|
||||
}
|
||||
|
||||
if (pull) {
|
||||
this._stream._read = read.bind(this, pull.bind(this, controller))
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
get [readableKind]() {
|
||||
return ReadableStream[readableKind]
|
||||
}
|
||||
|
||||
getReader() {
|
||||
return new exports.ReadableStreamDefaultReader(this)
|
||||
}
|
||||
|
||||
cancel(reason) {
|
||||
if (this._stream.destroyed) return Promise.resolve()
|
||||
|
||||
return new Promise((resolve) =>
|
||||
this._stream.once('close', resolve).destroy(reason)
|
||||
)
|
||||
}
|
||||
|
||||
pipeTo(destination) {
|
||||
return new Promise((resolve, reject) =>
|
||||
this._stream.pipe(destination, (err) => {
|
||||
err ? reject(err) : resolve()
|
||||
})
|
||||
)
|
||||
}
|
||||
|
||||
[Symbol.asyncIterator]() {
|
||||
return this._stream[Symbol.asyncIterator]()
|
||||
}
|
||||
|
||||
static from(iterable) {
|
||||
return new ReadableStream(Readable.from(iterable))
|
||||
}
|
||||
}
|
||||
|
||||
async function open(starting, cb) {
|
||||
try {
|
||||
await starting
|
||||
|
||||
cb(null)
|
||||
} catch (err) {
|
||||
cb(err)
|
||||
}
|
||||
}
|
||||
|
||||
async function read(pull, cb) {
|
||||
try {
|
||||
await pull()
|
||||
|
||||
cb(null)
|
||||
} catch (err) {
|
||||
cb(err)
|
||||
}
|
||||
}
|
||||
|
||||
function defaultSize() {
|
||||
return 1
|
||||
}
|
||||
|
||||
exports.ReadableStream = ReadableStream
|
||||
|
||||
// https://streams.spec.whatwg.org/#countqueuingstrategy
|
||||
exports.CountQueuingStrategy = class CountQueuingStrategy {
|
||||
constructor(opts = {}) {
|
||||
const { highWaterMark = 1 } = opts
|
||||
|
||||
this.highWaterMark = highWaterMark
|
||||
}
|
||||
|
||||
size(chunk) {
|
||||
return 1
|
||||
}
|
||||
}
|
||||
|
||||
// https://streams.spec.whatwg.org/#bytelengthqueuingstrategy
|
||||
exports.ByteLengthQueuingStrategy = class ByteLengthQueuingStrategy {
|
||||
constructor(opts = {}) {
|
||||
const { highWaterMark = 16384 } = opts
|
||||
|
||||
this.highWaterMark = highWaterMark
|
||||
}
|
||||
|
||||
size(chunk) {
|
||||
return chunk.byteLength
|
||||
}
|
||||
}
|
||||
|
||||
exports.isReadableStream = function isReadableStream(value) {
|
||||
if (value instanceof ReadableStream) return true
|
||||
|
||||
return (
|
||||
typeof value === 'object' &&
|
||||
value !== null &&
|
||||
value[readableKind] === ReadableStream[readableKind]
|
||||
)
|
||||
}
|
||||
|
||||
// https://streams.spec.whatwg.org/#is-readable-stream-disturbed
|
||||
exports.isReadableStreamDisturbed = function isReadableStreamDisturbed(stream) {
|
||||
return isDisturbed(stream._stream)
|
||||
}
|
||||
Reference in New Issue
Block a user