2024-07-25 02:33:22 +03:00
|
|
|
/*! *****************************************************************************
|
|
|
|
Copyright (c) Microsoft Corporation. All rights reserved.
|
|
|
|
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
|
|
|
|
|
|
|
|
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
|
|
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
|
|
|
|
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
|
|
|
|
MERCHANTABLITY OR NON-INFRINGEMENT.
|
|
|
|
|
|
|
|
See the Apache Version 2.0 License for specific language governing permissions
|
|
|
|
and limitations under the License.
|
|
|
|
***************************************************************************** */
|
|
|
|
|
|
|
|
|
|
|
|
/// <reference no-default-lib="true"/>
|
|
|
|
|
|
|
|
/// <reference lib="es2015.iterable" />
|
|
|
|
|
|
|
|
// NOTE: This is specified as what is essentially an unreachable module. All actual global declarations can be found
|
|
|
|
// in the `declare global` section, below. This is necessary as there is currently no way to declare an `abstract`
|
|
|
|
// member without declaring a `class`, but declaring `class Iterator<T>` globally would conflict with TypeScript's
|
|
|
|
// general purpose `Iterator<T>` interface.
|
|
|
|
export {};
|
|
|
|
|
|
|
|
// Abstract type that allows us to mark `next` as `abstract`
|
2024-08-19 21:22:52 +03:00
|
|
|
declare abstract class Iterator<T, TResult = undefined, TNext = unknown> { // eslint-disable-line @typescript-eslint/no-unsafe-declaration-merging
|
|
|
|
abstract next(value?: TNext): IteratorResult<T, TResult>;
|
2024-07-25 02:33:22 +03:00
|
|
|
}
|
|
|
|
|
2024-08-19 21:22:52 +03:00
|
|
|
// Merge all members of `IteratorObject<T>` into `Iterator<T>`
|
|
|
|
interface Iterator<T, TResult, TNext> extends globalThis.IteratorObject<T, TResult, TNext> {}
|
2024-07-25 02:33:22 +03:00
|
|
|
|
|
|
|
// Capture the `Iterator` constructor in a type we can use in the `extends` clause of `IteratorConstructor`.
|
2024-08-19 21:22:52 +03:00
|
|
|
type IteratorObjectConstructor = typeof Iterator;
|
2024-07-25 02:33:22 +03:00
|
|
|
|
|
|
|
declare global {
|
2024-08-19 21:22:52 +03:00
|
|
|
// Global `IteratorObject<T, TReturn, TNext>` interface that can be augmented by polyfills
|
|
|
|
interface IteratorObject<T, TReturn, TNext> {
|
2024-07-25 02:33:22 +03:00
|
|
|
/**
|
|
|
|
* Returns this iterator.
|
|
|
|
*/
|
2024-08-19 21:22:52 +03:00
|
|
|
[Symbol.iterator](): IteratorObject<T, TReturn, TNext>;
|
2024-07-25 02:33:22 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an iterator whose values are the result of applying the callback to the values from this iterator.
|
|
|
|
* @param callbackfn A function that accepts up to two arguments to be used to transform values from the underlying iterator.
|
|
|
|
*/
|
2024-08-19 21:22:52 +03:00
|
|
|
map<U>(callbackfn: (value: T, index: number) => U): IteratorObject<U, undefined, unknown>;
|
2024-07-25 02:33:22 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an iterator whose values are those from this iterator for which the provided predicate returns true.
|
|
|
|
* @param predicate A function that accepts up to two arguments to be used to test values from the underlying iterator.
|
|
|
|
*/
|
2024-08-19 21:22:52 +03:00
|
|
|
filter<S extends T>(predicate: (value: T, index: number) => value is S): IteratorObject<S, undefined, unknown>;
|
2024-07-25 02:33:22 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an iterator whose values are those from this iterator for which the provided predicate returns true.
|
|
|
|
* @param predicate A function that accepts up to two arguments to be used to test values from the underlying iterator.
|
|
|
|
*/
|
2024-08-19 21:22:52 +03:00
|
|
|
filter(predicate: (value: T, index: number) => unknown): IteratorObject<T, undefined, unknown>;
|
2024-07-25 02:33:22 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an iterator whose values are the values from this iterator, stopping once the provided limit is reached.
|
|
|
|
* @param limit The maximum number of values to yield.
|
|
|
|
*/
|
2024-08-19 21:22:52 +03:00
|
|
|
take(limit: number): IteratorObject<T, undefined, unknown>;
|
2024-07-25 02:33:22 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an iterator whose values are the values from this iterator after skipping the provided count.
|
|
|
|
* @param count The number of values to drop.
|
|
|
|
*/
|
2024-08-19 21:22:52 +03:00
|
|
|
drop(count: number): IteratorObject<T, undefined, unknown>;
|
2024-07-25 02:33:22 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an iterator whose values are the result of applying the callback to the values from this iterator and then flattening the resulting iterators or iterables.
|
|
|
|
* @param callback A function that accepts up to two arguments to be used to transform values from the underlying iterator into new iterators or iterables to be flattened into the result.
|
|
|
|
*/
|
2024-08-19 21:22:52 +03:00
|
|
|
flatMap<U>(callback: (value: T, index: number) => Iterator<U, unknown, undefined> | Iterable<U, unknown, undefined>): IteratorObject<U, undefined, unknown>;
|
2024-07-25 02:33:22 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Calls the specified callback function for all the elements in this iterator. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
|
|
|
|
* @param callbackfn A function that accepts up to three arguments. The reduce method calls the callbackfn function one time for each element in the iterator.
|
|
|
|
* @param initialValue If initialValue is specified, it is used as the initial value to start the accumulation. The first call to the callbackfn function provides this value as an argument instead of a value from the iterator.
|
|
|
|
*/
|
|
|
|
reduce(callbackfn: (previousValue: T, currentValue: T, currentIndex: number) => T): T;
|
|
|
|
reduce(callbackfn: (previousValue: T, currentValue: T, currentIndex: number) => T, initialValue: T): T;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calls the specified callback function for all the elements in this iterator. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
|
|
|
|
* @param callbackfn A function that accepts up to three arguments. The reduce method calls the callbackfn function one time for each element in the iterator.
|
|
|
|
* @param initialValue If initialValue is specified, it is used as the initial value to start the accumulation. The first call to the callbackfn function provides this value as an argument instead of a value from the iterator.
|
|
|
|
*/
|
|
|
|
reduce<U>(callbackfn: (previousValue: U, currentValue: T, currentIndex: number) => U, initialValue: U): U;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a new array from the values yielded by this iterator.
|
|
|
|
*/
|
|
|
|
toArray(): T[];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Performs the specified action for each element in the iterator.
|
|
|
|
* @param callbackfn A function that accepts up to two arguments. forEach calls the callbackfn function one time for each element in the iterator.
|
|
|
|
*/
|
|
|
|
forEach(callbackfn: (value: T, index: number) => void): void;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determines whether the specified callback function returns true for any element of this iterator.
|
|
|
|
* @param predicate A function that accepts up to two arguments. The some method calls
|
|
|
|
* the predicate function for each element in this iterator until the predicate returns a value
|
|
|
|
* true, or until the end of the iterator.
|
|
|
|
*/
|
|
|
|
some(predicate: (value: T, index: number) => unknown): boolean;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determines whether all the members of this iterator satisfy the specified test.
|
|
|
|
* @param predicate A function that accepts up to two arguments. The every method calls
|
|
|
|
* the predicate function for each element in this iterator until the predicate returns
|
|
|
|
* false, or until the end of this iterator.
|
|
|
|
*/
|
|
|
|
every(predicate: (value: T, index: number) => unknown): boolean;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the value of the first element in this iterator where predicate is true, and undefined
|
|
|
|
* otherwise.
|
|
|
|
* @param predicate find calls predicate once for each element of this iterator, in
|
|
|
|
* order, until it finds one where predicate returns true. If such an element is found, find
|
|
|
|
* immediately returns that element value. Otherwise, find returns undefined.
|
|
|
|
*/
|
|
|
|
find<S extends T>(predicate: (value: T, index: number) => value is S): S | undefined;
|
|
|
|
find(predicate: (value: T, index: number) => unknown): T | undefined;
|
|
|
|
|
|
|
|
readonly [Symbol.toStringTag]: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Global `IteratorConstructor` interface that can be augmented by polyfills
|
2024-08-19 21:22:52 +03:00
|
|
|
interface IteratorConstructor extends IteratorObjectConstructor {
|
2024-07-25 02:33:22 +03:00
|
|
|
/**
|
|
|
|
* Creates a native iterator from an iterator or iterable object.
|
|
|
|
* Returns its input if the input already inherits from the built-in Iterator class.
|
|
|
|
* @param value An iterator or iterable object to convert a native iterator.
|
|
|
|
*/
|
2024-08-19 21:22:52 +03:00
|
|
|
from<T>(value: Iterator<T, unknown, undefined> | Iterable<T, unknown, undefined>): IteratorObject<T, undefined, unknown>;
|
2024-07-25 02:33:22 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
var Iterator: IteratorConstructor;
|
|
|
|
}
|