mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* Convert runMany and runManySync to use injectManyWithMeta Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup type errors due to new Runnable requirements Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add documentation for verifyRunnablesAreDAG Signed-off-by: Sebastian Malton <sebastian@malton.name> * Simplify convertToWithIdWith Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move all utility functions to separate package Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move testing utilities to separate package Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move run-many and run-many-sync to separate package Signed-off-by: Sebastian Malton <sebastian@malton.name> * Replace all internal uses of utilities with new packages Signed-off-by: Sebastian Malton <sebastian@malton.name> * Use new @k8slens/run-many package in core Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add dep to open-lens Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup type errors Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup uses of @k8slens/test-utils Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup getGlobalOverride Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move tests to new package too Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix type errors Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup uses of AsyncResult and autoBind Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup remaining import issues Signed-off-by: Sebastian Malton <sebastian@malton.name> * Finial fixups to fix build Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix lint Signed-off-by: Sebastian Malton <sebastian@malton.name> * Revert moving "testUsingFakeTime" to separate package - This fixes tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix integration tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix unit test failing due to spelling fix Signed-off-by: Sebastian Malton <sebastian@malton.name> --------- Signed-off-by: Sebastian Malton <sebastian@malton.name>
61 lines
1.9 KiB
TypeScript
61 lines
1.9 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
import { array } from "./array";
|
|
|
|
/**
|
|
* A strict N-tuple of type T
|
|
*/
|
|
export type Tuple<T, N extends number> = N extends N
|
|
? number extends N
|
|
? T[]
|
|
: TupleOfImpl<T, N, []>
|
|
: never;
|
|
type TupleOfImpl<T, N extends number, R extends unknown[]> = R["length"] extends N
|
|
? R
|
|
: TupleOfImpl<T, N, [T, ...R]>;
|
|
|
|
/**
|
|
* Iterates over `sources` yielding full tuples until one of the tuple arrays
|
|
* is empty. Then it returns a tuple with the rest of each of tuples
|
|
* @param sources The source arrays
|
|
* @yields A tuple of the next element from each of the sources
|
|
* @returns The tuple of all the sources as soon as at least one of the sources is exausted
|
|
*/
|
|
function zip<T>(...sources: Tuple<T[], 0>): Iterator<Tuple<T, 0>, Tuple<T[], 0>>;
|
|
function zip<T>(...sources: Tuple<T[], 1>): Iterator<Tuple<T, 1>, Tuple<T[], 1>>;
|
|
function zip<T>(...sources: Tuple<T[], 2>): Iterator<Tuple<T, 2>, Tuple<T[], 2>>;
|
|
function* zip<T, N extends number>(...sources: Tuple<T[], N>): Iterator<Tuple<T, N>, Tuple<T[], N>> {
|
|
const maxSafeLength = Math.min(...sources.map(source => source.length));
|
|
|
|
for (let i = 0; i < maxSafeLength; i += 1) {
|
|
yield sources.map(source => source[i]) as Tuple<T, N>;
|
|
}
|
|
|
|
return sources.map(source => source.slice(maxSafeLength)) as Tuple<T[], N>;
|
|
}
|
|
|
|
/**
|
|
* Returns a `length` tuple filled with copies of `value`
|
|
* @param length The size of the tuple
|
|
* @param value The value for each of the tuple entries
|
|
*/
|
|
function filled<T, L extends number>(length: L, value: T): Tuple<T, L> {
|
|
return array.filled(length, value) as Tuple<T, L>;
|
|
}
|
|
|
|
/**
|
|
* A function for converting an explicit array to a tuple but without the `readonly` typing
|
|
*/
|
|
function from<T extends any[]>(...args: T): [...T] {
|
|
return args;
|
|
}
|
|
|
|
export const tuple = {
|
|
zip,
|
|
filled,
|
|
from,
|
|
};
|