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>
56 lines
1.6 KiB
TypeScript
56 lines
1.6 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
/**
|
|
* A inference typed version of `Array(length).fill(value)`
|
|
* @param length The number of entries
|
|
* @param value The value of each of the indices
|
|
*/
|
|
function filled<T>(length: number, value: T): T[] {
|
|
return Array(length).fill(value);
|
|
}
|
|
|
|
/**
|
|
* This function splits an array into two sub arrays on the first instance of
|
|
* element (from the left). If the array does not contain the element. The
|
|
* return value is defined to be `[array, [], false]`. If the element is in
|
|
* the array then the return value is `[left, right, true]` where `left` is
|
|
* the elements of `array` from `[0, index)` and `right` is `(index, length)`
|
|
* @param array the full array to split into two sub-arrays
|
|
* @param element the element in the middle of the array
|
|
* @returns the left and right sub-arrays which when conjoined with `element`
|
|
* is the same as `array`, and `true`
|
|
*/
|
|
function split<T>(src: T[], element: T): [T[], T[], boolean] {
|
|
const index = src.indexOf(element);
|
|
|
|
if (index < 0) {
|
|
return [src, [], false];
|
|
}
|
|
|
|
return [src.slice(0, index), src.slice(index + 1, src.length), true];
|
|
}
|
|
|
|
function bifurcate<T>(src: T[], condition: (item: T) => any): [falses: T[], trues: T[]] {
|
|
const trues: T[] = [];
|
|
const falses: T[] = [];
|
|
|
|
for (const item of src) {
|
|
if (condition(item)) {
|
|
trues.push(item);
|
|
} else {
|
|
falses.push(item);
|
|
}
|
|
}
|
|
|
|
return [falses, trues];
|
|
}
|
|
|
|
export const array = {
|
|
bifurcate,
|
|
filled,
|
|
split,
|
|
};
|