mirror of
https://github.com/zhigang1992/DefinitelyTyped.git
synced 2026-04-22 11:57:33 +08:00
1020 lines
31 KiB
TypeScript
1020 lines
31 KiB
TypeScript
// Type definitions for Highland 1.14.0
|
|
// Project: http://highlandjs.org/
|
|
// Definitions by: Bart van der Schoor <https://github.com/Bartvds/>
|
|
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
|
|
|
/// <reference types="node" />
|
|
|
|
// TODO export the top-level functions
|
|
|
|
// TODO figure out curry arguments
|
|
// TODO create more overloads for nested data, like streams-of-streams or streams-of-array-of-streams etc
|
|
// TODO use externalised Thenable
|
|
// TODO use externalised Readable/Writable (not node's)
|
|
|
|
/**
|
|
* Highland: the high-level streams library
|
|
*
|
|
* Highland may be freely distributed under the Apache 2.0 license.
|
|
* http://github.com/caolan/highland
|
|
* Copyright (c) Caolan McMahon
|
|
*
|
|
*/
|
|
interface HighlandStatic {
|
|
/**
|
|
* The Stream constructor, accepts an array of values or a generator function
|
|
* as an optional argument. This is typically the entry point to the Highland
|
|
* APIs, providing a convenient way of chaining calls together.
|
|
*
|
|
* **Arrays -** Streams created from Arrays will emit each value of the Array
|
|
* and then emit a [nil](#nil) value to signal the end of the Stream.
|
|
*
|
|
* **Generators -** These are functions which provide values for the Stream.
|
|
* They are lazy and can be infinite, they can also be asynchronous (for
|
|
* example, making a HTTP request). You emit values on the Stream by calling
|
|
* `push(err, val)`, much like a standard Node.js callback. You call `next()`
|
|
* to signal you've finished processing the current data. If the Stream is
|
|
* still being consumed the generator function will then be called again.
|
|
*
|
|
* You can also redirect a generator Stream by passing a new source Stream
|
|
* to read from to next. For example: `next(other_stream)` - then any subsequent
|
|
* calls will be made to the new source.
|
|
*
|
|
* **Node Readable Stream -** Pass in a Node Readable Stream object to wrap
|
|
* it with the Highland API. Reading from the resulting Highland Stream will
|
|
* begin piping the data from the Node Stream to the Highland Stream.
|
|
*
|
|
* **EventEmitter / jQuery Elements -** Pass in both an event name and an
|
|
* event emitter as the two arguments to the constructor and the first
|
|
* argument emitted to the event handler will be written to the new Stream.
|
|
*
|
|
* **Promise -** Accepts an ES6 / jQuery style promise and returns a
|
|
* Highland Stream which will emit a single value (or an error).
|
|
*
|
|
* @id _(source)
|
|
* @section Streams
|
|
* @name _(source)
|
|
* @param {Array | Function | Readable Stream | Promise} source - (optional) source to take values from from
|
|
* @api public
|
|
*/
|
|
<R>(): Highland.Stream<R>;
|
|
<R>(xs: R[]): Highland.Stream<R>;
|
|
<R>(xs: (push: (err: Error, x?: R) => void, next: () => void) => void): Highland.Stream<R>;
|
|
|
|
<R>(xs: Highland.Stream<R>): Highland.Stream<R>;
|
|
<R>(xs: NodeJS.ReadableStream): Highland.Stream<R>;
|
|
<R>(xs: NodeJS.EventEmitter): Highland.Stream<R>;
|
|
|
|
// moar (promise for everything?)
|
|
<R>(xs: Highland.Thenable<Highland.Stream<R>>): Highland.Stream<R>;
|
|
<R>(xs: Highland.Thenable<R>): Highland.Stream<R>;
|
|
|
|
/**
|
|
* The end of stream marker. This is sent along the data channel of a Stream
|
|
* to tell consumers that the Stream has ended. See the following map code for
|
|
* an example of detecting the end of a Stream:
|
|
*
|
|
* @id nil
|
|
* @section Streams
|
|
* @name _.nil
|
|
* @api public
|
|
*/
|
|
nil: Highland.Nil;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Transforms a function with specific arity (all arguments must be
|
|
* defined) in a way that it can be called as a chain of functions until
|
|
* the arguments list is saturated.
|
|
*
|
|
* This function is not itself curryable.
|
|
*
|
|
* @id curry
|
|
* @name curry(fn, [*arguments])
|
|
* @section Functions
|
|
* @param {Function} fn - the function to curry
|
|
* @param args.. - any number of arguments to pre-apply to the function
|
|
* @returns Function
|
|
* @api public
|
|
*/
|
|
curry(fn: Function, ...args: any[]): Function;
|
|
|
|
/**
|
|
* Same as `curry` but with a specific number of arguments. This can be
|
|
* useful when functions do not explicitly define all its parameters.
|
|
*
|
|
* This function is not itself curryable.
|
|
*
|
|
* @id ncurry
|
|
* @name ncurry(n, fn, [args...])
|
|
* @section Functions
|
|
* @param {Number} n - the number of arguments to wait for before apply fn
|
|
* @param {Function} fn - the function to curry
|
|
* @param args... - any number of arguments to pre-apply to the function
|
|
* @returns Function
|
|
* @api public
|
|
*/
|
|
ncurry(n: number, fn: Function, ...args: any[]): Function;
|
|
|
|
/**
|
|
* Partially applies the function (regardless of whether it has had curry
|
|
* called on it). This will always postpone execution until at least the next
|
|
* call of the partially applied function.
|
|
*
|
|
* @id partial
|
|
* @name partial(fn, args...)
|
|
* @section Functions
|
|
* @param {Function} fn - function to partial apply
|
|
* @param args... - the arguments to apply to the function
|
|
* @api public
|
|
*/
|
|
partial(f: Function, ...args: any[]): Function;
|
|
|
|
/**
|
|
* Evaluates the function `fn` with the argument positions swapped. Only
|
|
* works with functions that accept two arguments.
|
|
*
|
|
* @id flip
|
|
* @name flip(fn, [x, y])
|
|
* @section Functions
|
|
* @param {Function} f - function to flip argument application for
|
|
* @param x - parameter to apply to the right hand side of f
|
|
* @param y - parameter to apply to the left hand side of f
|
|
* @api public
|
|
*/
|
|
flip(fn: Function, ...args: any[]): Function;
|
|
|
|
/**
|
|
* Creates a composite function, which is the application of function1 to
|
|
* the results of function2. You can pass an arbitrary number of arguments
|
|
* and have them composed. This means you can't partially apply the compose
|
|
* function itself.
|
|
*
|
|
* @id compose
|
|
* @name compose(fn1, fn2, ...)
|
|
* @section Functions
|
|
* @api public
|
|
*/
|
|
compose(...functions: Function[]): Function;
|
|
|
|
/**
|
|
* The reversed version of compose. Where arguments are in the order of
|
|
* application.
|
|
*
|
|
* @id seq
|
|
* @name seq(fn1, fn2, ...)
|
|
* @section Functions
|
|
* @api public
|
|
*/
|
|
seq(...functions: Function[]): Function;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Returns true if `x` is a Highland Stream.
|
|
*
|
|
* @id isStream
|
|
* @section Streams
|
|
* @name _.isStream(x)
|
|
* @param x - the object to test
|
|
* @api public
|
|
*/
|
|
isStream(x: any): boolean;
|
|
|
|
isStreamError(x: any): boolean;
|
|
|
|
isStreamRedirect(x: any): boolean;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Returns values from an Object as a Stream. Reads properties
|
|
* lazily, so if you don't read from all keys on an object, not
|
|
* all properties will be read from (may have an effect where getters
|
|
* are used).
|
|
*
|
|
* @id values
|
|
* @section Objects
|
|
* @name _.values(obj)
|
|
* @param {Object} obj - the object to return values from
|
|
* @api public
|
|
*/
|
|
values(obj: Object): Highland.Stream<any>;
|
|
|
|
/**
|
|
* Returns keys from an Object as a Stream.
|
|
*
|
|
* @id keys
|
|
* @section Objects
|
|
* @name _.keys(obj)
|
|
* @param {Object} obj - the object to return keys from
|
|
* @api public
|
|
*/
|
|
keys(obj: Object): Highland.Stream<string>;
|
|
|
|
/**
|
|
* Returns key/value pairs for an Object as a Stream. Reads properties
|
|
* lazily, so if you don't read from all keys on an object, not
|
|
* all properties will be read from (may have an effect where getters
|
|
* are used).
|
|
*
|
|
* @id pairs
|
|
* @section Objects
|
|
* @name _.pairs(obj)
|
|
* @param {Object} obj - the object to return key/value pairs from
|
|
* @api public
|
|
*/
|
|
pairs(obj: Object): Highland.Stream<any[]>;
|
|
|
|
pairs(obj: any[]): Highland.Stream<any[]>;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Extends one object with the properties of another. **Note:** The
|
|
* arguments are in the reverse order of other libraries such as
|
|
* underscore. This is so it follows the convention of other functions in
|
|
* this library and so you can more meaningfully partially apply it.
|
|
*
|
|
* @id extend
|
|
* @section Objects
|
|
* @name _.extend(a, b)
|
|
* @param {Object} a - the properties to extend b with
|
|
* @param {Object} b - the original object to extend
|
|
* @api public
|
|
*/
|
|
extend(extensions: Object, target: Object): Object;
|
|
|
|
extend(target: Object): (extensions: Object) => Object;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Returns a property from an object.
|
|
*
|
|
* @id get
|
|
* @section Objects
|
|
* @name _.get(prop, obj)
|
|
* @param {String} prop - the property to return
|
|
* @param {Object} obj - the object to read properties from
|
|
* @api public
|
|
*/
|
|
get(prop: string, obj: Object): string;
|
|
|
|
get(prop: string): (obj: Object) => Object;
|
|
|
|
/**
|
|
* Updates a property on an object, returning the updated object.
|
|
*
|
|
* @id set
|
|
* @section Objects
|
|
* @name _.set(prop, value, obj)
|
|
* @param {String} prop - the property to return
|
|
* @param value - the value to set the property to
|
|
* @param {Object} obj - the object to set properties on
|
|
* @api public
|
|
*/
|
|
set(prop: string, val: any, obj: Object): Object;
|
|
|
|
set(prop: string, val: any): (obj: Object) => Object;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Logs values to the console, a simple wrapper around `console.log` that
|
|
* it suitable for passing to other functions by reference without having to
|
|
* call `bind`.
|
|
*
|
|
* @id log
|
|
* @section Utils
|
|
* @name _.log(args..)
|
|
* @api public
|
|
*/
|
|
log(x: any, ...args: any[]): void;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Wraps a node-style async function which accepts a callback, transforming
|
|
* it to a function which accepts the same arguments minus the callback and
|
|
* returns a Highland Stream instead. Only the first argument to the
|
|
* callback (or an error) will be pushed onto the Stream.
|
|
*
|
|
* @id wrapCallback
|
|
* @section Utils
|
|
* @name _.wrapCallback(f)
|
|
* @param {Function} f - the node-style function to wrap
|
|
* @api public
|
|
*/
|
|
wrapCallback(f: Function): Function;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Add two values. Can be partially applied.
|
|
*
|
|
* @id add
|
|
* @section Operators
|
|
* @name _.add(a, b)
|
|
* @api public
|
|
*/
|
|
add(a: number, b: number): number;
|
|
add(a: number): (b: number) => number;
|
|
|
|
not<R>(a: any): boolean;
|
|
}
|
|
|
|
declare namespace Highland {
|
|
|
|
interface Thenable<R> {
|
|
then<U>(onFulfilled: (value: R) => Thenable<U>, onRejected: (error: any) => Thenable<U>): Thenable<U>;
|
|
then<U>(onFulfilled: (value: R) => Thenable<U>, onRejected?: (error: any) => U): Thenable<U>;
|
|
then<U>(onFulfilled: (value: R) => U, onRejected: (error: any) => Thenable<U>): Thenable<U>;
|
|
then<U>(onFulfilled?: (value: R) => U, onRejected?: (error: any) => U): Thenable<U>;
|
|
}
|
|
// hacky unique
|
|
// TODO do we need this?
|
|
interface Nil {
|
|
Highland_NIL: Nil;
|
|
}
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Used as an Error marker when writing to a Stream's incoming buffer
|
|
*/
|
|
// TODO is this public?
|
|
class StreamError {
|
|
constructor(err: Error);
|
|
|
|
error: Error;
|
|
}
|
|
|
|
/**
|
|
* Used as a Redirect marker when writing to a Stream's incoming buffer
|
|
*/
|
|
// TODO is this public?
|
|
class StreamRedirect<R> {
|
|
constructor(to: Stream<R>)
|
|
|
|
to: Stream<R>;
|
|
}
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Actual Stream constructor wrapped the the main exported function
|
|
*/
|
|
interface Stream<R> extends NodeJS.EventEmitter {
|
|
|
|
/**
|
|
* Pauses the stream. All Highland Streams start in the paused state.
|
|
*
|
|
* @id pause
|
|
* @section Streams
|
|
* @name Stream.pause()
|
|
* @api public
|
|
*/
|
|
pause(): void;
|
|
|
|
/**
|
|
* Resumes a paused Stream. This will either read from the Stream's incoming
|
|
* buffer or request more data from an upstream source.
|
|
*
|
|
* @id resume
|
|
* @section Streams
|
|
* @name Stream.resume()
|
|
* @api public
|
|
*/
|
|
resume(): void;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Ends a Stream. This is the same as sending a [nil](#nil) value as data.
|
|
* You shouldn't need to call this directly, rather it will be called by
|
|
* any [Node Readable Streams](http://nodejs.org/api/stream.html#stream_class_stream_readable)
|
|
* you pipe in.
|
|
*
|
|
* @id end
|
|
* @section Streams
|
|
* @name Stream.end()
|
|
* @api public
|
|
*/
|
|
end(): void;
|
|
|
|
/**
|
|
* Pipes a Highland Stream to a [Node Writable Stream](http://nodejs.org/api/stream.html#stream_class_stream_writable)
|
|
* (Highland Streams are also Node Writable Streams). This will pull all the
|
|
* data from the source Highland Stream and write it to the destination,
|
|
* automatically managing flow so that the destination is not overwhelmed
|
|
* by a fast source.
|
|
*
|
|
* This function returns the destination so you can chain together pipe calls.
|
|
*
|
|
* @id pipe
|
|
* @section Streams
|
|
* @name Stream.pipe(dest)
|
|
* @param {Writable Stream} dest - the destination to write all data to
|
|
* @api public
|
|
*/
|
|
pipe<U>(dest: Stream<U>): Stream<U>;
|
|
pipe<U>(dest: NodeJS.ReadWriteStream): Stream<U>;
|
|
pipe(dest: NodeJS.WritableStream): void;
|
|
|
|
/**
|
|
* Destroys a stream by unlinking it from any consumers and sources. This will
|
|
* stop all consumers from receiving events from this stream and removes this
|
|
* stream as a consumer of any source stream.
|
|
*
|
|
* This function calls end() on the stream and unlinks it from any piped-to streams.
|
|
*
|
|
* @id pipe
|
|
* @section Streams
|
|
* @name Stream.destroy()
|
|
* @api public
|
|
*/
|
|
destroy(): void;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Consumes values from a Stream (once resumed) and returns a new Stream for
|
|
* you to optionally push values onto using the provided push / next functions.
|
|
*
|
|
* This function forms the basis of many higher-level Stream operations.
|
|
* It will not cause a paused stream to immediately resume, but behaves more
|
|
* like a 'through' stream, handling values as they are read.
|
|
*
|
|
* @id consume
|
|
* @section Streams
|
|
* @name Stream.consume(f)
|
|
* @param {Function} f - the function to handle errors and values
|
|
* @api public
|
|
*/
|
|
consume<U>(f: (err: Error, x: R, push: (err: Error, value?: U) => void, next: () => void) => void): Stream<U>;
|
|
|
|
/**
|
|
* Consumes a single item from the Stream. Unlike consume, this function will
|
|
* not provide a new stream for you to push values onto, and it will unsubscribe
|
|
* as soon as it has a single error, value or nil from the source.
|
|
*
|
|
* You probably won't need to use this directly, but it is used internally by
|
|
* some functions in the Highland library.
|
|
*
|
|
* @id pull
|
|
* @section Streams
|
|
* @name Stream.pull(f)
|
|
* @param {Function} f - the function to handle data
|
|
* @api public
|
|
*/
|
|
pull(f: (err: Error, x: R) => void): void;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Writes a value to the Stream. If the Stream is paused it will go into the
|
|
* Stream's incoming buffer, otherwise it will be immediately processed and
|
|
* sent to the Stream's consumers (if any). Returns false if the Stream is
|
|
* paused, true otherwise. This lets Node's pipe method handle back-pressure.
|
|
*
|
|
* You shouldn't need to call this yourself, but it may be called by Node
|
|
* functions which treat Highland Streams as a [Node Writable Stream](http://nodejs.org/api/stream.html#stream_class_stream_writable).
|
|
*
|
|
* @id write
|
|
* @section Streams
|
|
* @name Stream.write(x)
|
|
* @param x - the value to write to the Stream
|
|
* @api public
|
|
*/
|
|
write(x: R): boolean;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Forks a stream, allowing you to add additional consumers with shared
|
|
* back-pressure. A stream forked to multiple consumers will only pull values
|
|
* from it's source as fast as the slowest consumer can handle them.
|
|
*
|
|
* @id fork
|
|
* @section Streams
|
|
* @name Stream.fork()
|
|
* @api public
|
|
*/
|
|
fork(): Stream<R>;
|
|
|
|
/**
|
|
* Observes a stream, allowing you to handle values as they are emitted, without
|
|
* adding back-pressure or causing data to be pulled from the source. This can
|
|
* be useful when you are performing two related queries on a stream where one
|
|
* would block the other. Just be aware that a slow observer could fill up it's
|
|
* buffer and cause memory issues. Where possible, you should use [fork](#fork).
|
|
*
|
|
* @id observe
|
|
* @section Streams
|
|
* @name Stream.observe()
|
|
* @api public
|
|
*/
|
|
observe(): Stream<R>;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Extracts errors from a Stream and applies them to an error handler
|
|
* function. Returns a new Stream with the errors removed (unless the error
|
|
* handler chooses to rethrow them using `push`). Errors can also be
|
|
* transformed and put back onto the Stream as values.
|
|
*
|
|
* @id errors
|
|
* @section Streams
|
|
* @name Stream.errors(f)
|
|
* @param {Function} f - the function to pass all errors to
|
|
* @api public
|
|
*/
|
|
errors(f: (err: Error, push: (err: Error, x?: R) => void) => void): Stream<R>;
|
|
|
|
/**
|
|
* Like the [errors](#errors) method, but emits a Stream end marker after
|
|
* an Error is encountered.
|
|
*
|
|
* @id stopOnError
|
|
* @section Streams
|
|
* @name Stream.stopOnError(f)
|
|
* @param {Function} f - the function to handle an error
|
|
* @api public
|
|
*/
|
|
stopOnError(f: (err: Error) => void): Stream<R>;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Iterates over every value from the Stream, calling the iterator function
|
|
* on each of them. This function causes a **thunk**.
|
|
*
|
|
* If an error from the Stream reaches the `each` call, it will emit an
|
|
* error event (which will cause it to throw if unhandled).
|
|
*
|
|
* @id each
|
|
* @section Streams
|
|
* @name Stream.each(f)
|
|
* @param {Function} f - the iterator function
|
|
* @api public
|
|
*/
|
|
each(f: (x: R) => void): void;
|
|
|
|
/**
|
|
* Applies results from a Stream as arguments to a function
|
|
*
|
|
* @id apply
|
|
* @section Streams
|
|
* @name Stream.apply(f)
|
|
* @param {Function} f - the function to apply arguments to
|
|
* @api public
|
|
*/
|
|
// TODO what to do here?
|
|
apply(f: Function): void;
|
|
|
|
/**
|
|
* Collects all values from a Stream into an Array and calls a function with
|
|
* once with the result. This function causes a **thunk**.
|
|
*
|
|
* If an error from the Stream reaches the `toArray` call, it will emit an
|
|
* error event (which will cause it to throw if unhandled).
|
|
*
|
|
* @id toArray
|
|
* @section Streams
|
|
* @name Stream.toArray(f)
|
|
* @param {Function} f - the callback to provide the completed Array to
|
|
* @api public
|
|
*/
|
|
toArray(f: (arr: R[]) => void): void;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Creates a new Stream of transformed values by applying a function to each
|
|
* value from the source. The transformation function can be replaced with
|
|
* a non-function value for convenience, and it will emit that value
|
|
* for every data event on the source Stream.
|
|
*
|
|
* @id map
|
|
* @section Streams
|
|
* @name Stream.map(f)
|
|
* @param f - the transformation function or value to map to
|
|
* @api public
|
|
*/
|
|
map<U>(f: (x: R) => U): Stream<U>;
|
|
|
|
/**
|
|
* Creates a new Stream of values by applying each item in a Stream to an
|
|
* iterator function which may return a Stream. Each item on these result
|
|
* Streams are then emitted on a single output Stream.
|
|
*
|
|
* The same as calling `stream.map(f).flatten()`.
|
|
*
|
|
* @id flatMap
|
|
* @section Streams
|
|
* @name Stream.flatMap(f)
|
|
* @param {Function} f - the iterator function
|
|
* @api public
|
|
*/
|
|
flatMap<U>(f: (x: R) => Stream<U>): Stream<U>;
|
|
flatMap<U>(f: (x: R) => U): Stream<U>;
|
|
|
|
/**
|
|
* Retrieves values associated with a given property from all elements in
|
|
* the collection.
|
|
*
|
|
* @id pluck
|
|
* @section Streams
|
|
* @name Stream.pluck(property)
|
|
* @param {String} prop - the property to which values should be associated
|
|
* @api public
|
|
*/
|
|
pluck<U>(prop: string): Stream<U>;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Creates a new Stream including only the values which pass a truth test.
|
|
*
|
|
* @id filter
|
|
* @section Streams
|
|
* @name Stream.filter(f)
|
|
* @param f - the truth test function
|
|
* @api public
|
|
*/
|
|
filter(f: (x: R) => boolean): Stream<R>;
|
|
|
|
/**
|
|
* Filters using a predicate which returns a Stream. If you need to check
|
|
* against an asynchronous data source when filtering a Stream, this can
|
|
* be convenient. The Stream returned from the filter function should have
|
|
* a Boolean as it's first value (all other values on the Stream will be
|
|
* disregarded).
|
|
*
|
|
* @id flatFilter
|
|
* @section Streams
|
|
* @name Stream.flatFilter(f)
|
|
* @param {Function} f - the truth test function which returns a Stream
|
|
* @api public
|
|
*/
|
|
flatFilter(f: (x: R) => Stream<boolean>): Stream<R>;
|
|
|
|
/**
|
|
* The inverse of [filter](#filter).
|
|
*
|
|
* @id reject
|
|
* @section Streams
|
|
* @name Stream.reject(f)
|
|
* @param {Function} f - the truth test function
|
|
* @api public
|
|
*
|
|
* var odds = _([1, 2, 3, 4]).reject(function (x) {
|
|
* return x % 2 === 0;
|
|
* });
|
|
*/
|
|
reject(f: (x: R) => boolean): Stream<R>;
|
|
|
|
/**
|
|
* A convenient form of filter, which returns the first object from a
|
|
* Stream that passes the provided truth test
|
|
*
|
|
* @id find
|
|
* @section Streams
|
|
* @name Stream.find(f)
|
|
* @param {Function} f - the truth test function which returns a Stream
|
|
* @api public
|
|
*/
|
|
find(f: (x: R) => boolean): Stream<R>;
|
|
|
|
/**
|
|
* A convenient form of reduce, which groups items based on a function or property name
|
|
*
|
|
* @id group
|
|
* @section Streams
|
|
* @name Stream.group(f)
|
|
* @param {Function|String} f - the function or property name on which to group,
|
|
* toString() is called on the result of a function.
|
|
* @api public
|
|
*/
|
|
// TODO verify this
|
|
group(f: (x: R) => string): Stream<{[prop:string]:R[]}>;
|
|
group(prop: string): Stream<{[prop:string]:R[]}>;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Filters a Stream to drop all non-truthy values.
|
|
*
|
|
* @id compact
|
|
* @section Streams
|
|
* @name Stream.compact()
|
|
* @api public
|
|
*/
|
|
compact(): Stream<R>;
|
|
|
|
/**
|
|
* A convenient form of filter, which returns all objects from a Stream
|
|
* match a set of property values.
|
|
*
|
|
* @id where
|
|
* @section Streams
|
|
* @name Stream.where(props)
|
|
* @param {Object} props - the properties to match against
|
|
* @api public
|
|
*/
|
|
where(props: Object): Stream<R>;
|
|
|
|
/**
|
|
* Takes two Streams and returns a Stream of corresponding pairs.
|
|
*
|
|
* @id zip
|
|
* @section Streams
|
|
* @name Stream.zip(ys)
|
|
* @param {Array | Stream} ys - the other stream to combine values with
|
|
* @api public
|
|
*/
|
|
zip(ys: R[]): Stream<R>;
|
|
zip(ys: Stream<R>): Stream<R>;
|
|
|
|
/**
|
|
* Creates a new Stream with the first `n` values from the source.
|
|
*
|
|
* @id take
|
|
* @section Streams
|
|
* @name Stream.take(n)
|
|
* @param {Number} n - integer representing number of values to read from source
|
|
* @api public
|
|
*/
|
|
take(n: number): Stream<R>;
|
|
|
|
/**
|
|
* Creates a new Stream with only the first value from the source.
|
|
*
|
|
* @id head
|
|
* @section Streams
|
|
* @name Stream.head()
|
|
* @api public
|
|
*
|
|
* _([1, 2, 3, 4]).head() // => 1
|
|
*/
|
|
head(): Stream<R>;
|
|
|
|
/**
|
|
* Drops all values from the Stream apart from the last one (if any).
|
|
*
|
|
* @id last
|
|
* @section Streams
|
|
* @name Stream.last()
|
|
* @api public
|
|
*/
|
|
last(): Stream<R>;
|
|
|
|
/**
|
|
* Reads values from a Stream of Streams, emitting them on a Single output
|
|
* Stream. This can be thought of as a flatten, just one level deep. Often
|
|
* used for resolving asynchronous actions such as a HTTP request or reading
|
|
* a file.
|
|
*
|
|
* @id sequence
|
|
* @section Streams
|
|
* @name Stream.sequence()
|
|
* @api public
|
|
*/
|
|
//TODO figure out typing
|
|
sequence<U>(): Stream<U>;
|
|
|
|
/**
|
|
* An alias for the [sequence](#sequence) method.
|
|
*
|
|
* @id series
|
|
* @section Streams
|
|
* @name Stream.series()
|
|
* @api public
|
|
*/
|
|
// TODO figure out typing
|
|
series<U>(): Stream<U>;
|
|
|
|
/**
|
|
* Recursively reads values from a Stream which may contain nested Streams
|
|
* or Arrays. As values or errors are encountered, they are emitted on a
|
|
* single output Stream.
|
|
*
|
|
* @id flatten
|
|
* @section Streams
|
|
* @name Stream.flatten()
|
|
* @api public
|
|
*/
|
|
flatten<U>(): Stream<U>;
|
|
flatten(): Stream<R>;
|
|
|
|
/**
|
|
* Takes a Stream of Streams and reads from them in parallel, buffering
|
|
* the results until they can be returned to the consumer in their original
|
|
* order.
|
|
*
|
|
* @id parallel
|
|
* @section Streams
|
|
* @name Stream.parallel(n)
|
|
* @param {Number} n - the maximum number of concurrent reads/buffers
|
|
* @api public
|
|
*/
|
|
parallel(n: number): Stream<R>;
|
|
|
|
/**
|
|
* Switches source to an alternate Stream if the current Stream is empty.
|
|
*
|
|
* @id otherwise
|
|
* @section Streams
|
|
* @name Stream.otherwise(ys)
|
|
* @param {Stream} ys - alternate stream to use if this stream is empty
|
|
* @api public
|
|
*/
|
|
otherwise(ys: Stream<R>): Stream<R>;
|
|
|
|
/**
|
|
* Adds a value to the end of a Stream.
|
|
*
|
|
* @id append
|
|
* @section Streams
|
|
* @name Stream.append(y)
|
|
* @param y - the value to append to the Stream
|
|
* @api public
|
|
*/
|
|
append(y: R): Stream<R>;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Boils down a Stream to a single value. The memo is the initial state
|
|
* of the reduction, and each successive step of it should be returned by
|
|
* the iterator function. The iterator is passed two arguments:
|
|
* the memo and the next value.
|
|
*
|
|
* @id reduce
|
|
* @section Streams
|
|
* @name Stream.reduce(memo, iterator)
|
|
* @param memo - the initial state of the reduction
|
|
* @param {Function} iterator - the function which reduces the values
|
|
* @api public
|
|
*/
|
|
// TODO: convert this to this.scan(z, f).last()
|
|
reduce<U>(memo: U, f: (memo: U, x: R) => U): Stream<U>;
|
|
|
|
/**
|
|
* Same as [reduce](#reduce), but uses the first element as the initial
|
|
* state instead of passing in a `memo` value.
|
|
*
|
|
* @id reduce1
|
|
* @section Streams
|
|
* @name Stream.reduce1(iterator)
|
|
* @param {Function} iterator - the function which reduces the values
|
|
* @api public
|
|
*/
|
|
reduce1<U>(memo: U, f: (memo: U, x: R) => U): Stream<U>;
|
|
|
|
/**
|
|
* Groups all values into an Array and passes down the stream as a single
|
|
* data event. This is a bit like doing [toArray](#toArray), but instead
|
|
* of accepting a callback and causing a *thunk*, it passes the value on.
|
|
*
|
|
* @id collect
|
|
* @section Streams
|
|
* @name Stream.collect()
|
|
* @api public
|
|
*/
|
|
collect(): Stream<R[]>;
|
|
|
|
/**
|
|
* Like [reduce](#reduce), but emits each intermediate value of the
|
|
* reduction as it is calculated.
|
|
*
|
|
* @id scan
|
|
* @section Streams
|
|
* @name Stream.scan(memo, iterator)
|
|
* @param memo - the initial state of the reduction
|
|
* @param {Function} iterator - the function which reduces the values
|
|
* @api public
|
|
*/
|
|
scan<U>(memo: U, x: (memo: U, x: R) => U): Stream<U>;
|
|
|
|
/**
|
|
* Same as [scan](#scan), but uses the first element as the initial
|
|
* state instead of passing in a `memo` value.
|
|
*
|
|
* @id scan1
|
|
* @section Streams
|
|
* @name Stream.scan1(iterator)
|
|
* @param {Function} iterator - the function which reduces the values
|
|
* @api public
|
|
*
|
|
* _([1, 2, 3, 4]).scan1(add) // => 1, 3, 6, 10
|
|
*/
|
|
scan1<U>(memo: U, x: (memo: U, x: R) => U): Stream<U>;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Concatenates a Stream to the end of this Stream.
|
|
*
|
|
* Be aware that in the top-level export, the args may be in the reverse
|
|
* order to what you'd expect `_([a], [b]) => [b, a]`, as this follows the
|
|
* convention of other top-level exported functions which do `x` to `y`.
|
|
*
|
|
* @id concat
|
|
* @section Streams
|
|
* @name Stream.concat(ys)
|
|
* @params {Stream | Array} ys - the values to concatenate onto this Stream
|
|
* @api public
|
|
*/
|
|
concat(ys: Stream<R>): Stream<R>;
|
|
concat(ys: R[]): Stream<R>;
|
|
|
|
/**
|
|
* Takes a Stream of Streams and merges their values and errors into a
|
|
* single new Stream. The merged stream ends when all source streams have
|
|
* ended.
|
|
*
|
|
* Note that no guarantee is made with respect to the order in which
|
|
* values for each stream end up in the merged stream. Values in the
|
|
* merged stream will, however, respect the order they were emitted from
|
|
* their respective streams.
|
|
*
|
|
* @id merge
|
|
* @section Streams
|
|
* @name Stream.merge()
|
|
* @api public
|
|
*
|
|
* var txt = _(['foo.txt', 'bar.txt']).map(readFile)
|
|
* var md = _(['baz.md']).map(readFile)
|
|
*
|
|
* _([txt, md]).merge();
|
|
* // => contents of foo.txt, bar.txt and baz.txt in the order they were read
|
|
*/
|
|
merge (ys: Stream<Stream<R>>): Stream<R>;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Calls a named method on each object from the Stream - returning
|
|
* a new stream with the result of those calls.
|
|
*
|
|
* @id invoke
|
|
* @section Streams
|
|
* @name Stream.invoke(method, args)
|
|
* @param {String} method - the method name to call
|
|
* @param {Array} args - the arguments to call the method with
|
|
* @api public
|
|
*/
|
|
invoke<U>(method: string, args: any[]): Stream<U>;
|
|
|
|
/**
|
|
* Ensures that only one data event is push downstream (or into the buffer)
|
|
* every `ms` milliseconds, any other values are dropped.
|
|
*
|
|
* @id throttle
|
|
* @section Streams
|
|
* @name Stream.throttle(ms)
|
|
* @param {Number} ms - the minimum milliseconds between each value
|
|
* @api public
|
|
*/
|
|
throttle(ms: number): Stream<R>;
|
|
|
|
/**
|
|
* Holds off pushing data events downstream until there has been no more
|
|
* data for `ms` milliseconds. Sends the last value that occurred before
|
|
* the delay, discarding all other values.
|
|
*
|
|
* @id debounce
|
|
* @section Streams
|
|
* @name Stream.debounce(ms)
|
|
* @param {Number} ms - the milliseconds to wait before sending data
|
|
* @api public
|
|
*/
|
|
debounce(ms: number): Stream<R>;
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/**
|
|
* Creates a new Stream, which when read from, only returns the last
|
|
* seen value from the source. The source stream does not experience
|
|
* back-pressure. Useful if you're using a Stream to model a changing
|
|
* property which you need to query periodically.
|
|
*
|
|
* @id latest
|
|
* @section Streams
|
|
* @name Stream.latest()
|
|
* @api public
|
|
*/
|
|
latest(): Stream<R>;
|
|
}
|
|
}
|
|
|
|
declare var highland:HighlandStatic;
|
|
|
|
declare module 'highland' {
|
|
export = highland;
|
|
}
|
|
|