You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

33 lines
755 B

/**
* Mnemonist HashedArrayTree Typings
* ==================================
*/
import {IArrayLikeConstructor} from './utils/types';
type HashedArrayTreeOptions = {
initialCapacity?: number;
initialLength?: number;
blockSize?: number;
}
export default class HashedArrayTree<T> {
// Members
blockSize: number;
capacity: number;
length: number;
// Constructor
constructor(ArrayClass: IArrayLikeConstructor, capacity: number);
constructor(ArrayClass: IArrayLikeConstructor, options: HashedArrayTreeOptions);
// Methods
set(index: number, value: T): this;
get(index: number): T | undefined;
grow(capacity: number): this;
resize(length: number): this;
push(value: T): number;
pop(): T | undefined;
inspect(): any;
}