Sha256: fcc438e50c00c9e865d9c1777627d3fdc1e13a4078c996fb4b04e67e462648c8

Contents?: true

Size: 1.28 KB

Versions: 33

Compression:

Stored size: 1.28 KB

Contents

import type {IsEqual, Subtract} from './internal';

type Recursive<T> = Array<Recursive<T>>;

/**
Creates a type that represents a multidimensional array of the given type and dimension.

Use-cases:
- Return a n-dimensional array from functions.
- Declare a n-dimensional array by defining its dimensions rather than declaring `[]` repetitively.
- Infer the dimensions of a n-dimensional array automatically from function arguments.
- Avoid the need to know in advance the dimensions of a n-dimensional array allowing them to be dynamic.

@example
```
import type {MultidimensionalArray} from 'type-fest';

function emptyMatrix<T extends number>(dimensions: T): MultidimensionalArray<unknown, T> {
	const matrix: unknown[] = [];

	let subMatrix = matrix;
	for (let dimension = 1; dimension < dimensions; ++dimension) {
		console.log(`Initializing dimension #${dimension}`);

		subMatrix[0] = [];
		subMatrix = subMatrix[0] as unknown[];
	}

	return matrix as MultidimensionalArray<unknown, T>;
}

const matrix = emptyMatrix(3);

matrix[0][0][0] = 42;
```

@category Array
*/
export type MultidimensionalArray<Element, Dimensions extends number> = number extends Dimensions
	? Recursive<Element>
	: IsEqual<Dimensions, 0> extends true
		? Element
		: Array<MultidimensionalArray<Element, Subtract<Dimensions, 1>>>;

Version data entries

33 entries across 33 versions & 1 rubygems

Version Path
immosquare-cleaner-0.1.60 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.59 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.58 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.57 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.56 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.55 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.54 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.53 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.52 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.51 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.50 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.49 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.48 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.47 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.46 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.45 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.44 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.43 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.42 node_modules/type-fest/source/multidimensional-array.d.ts
immosquare-cleaner-0.1.41 node_modules/type-fest/source/multidimensional-array.d.ts