import { HashComputationLevel, Node, Tree } from "@chainsafe/persistent-merkle-tree"; import type { ArrayLike } from "../interface.ts"; import { Require } from "../util/types.ts"; import { ArrayBasicTreeView, ArrayBasicType } from "../view/arrayBasic.ts"; import { ArrayBasicTreeViewDU } from "../viewDU/arrayBasic.ts"; import { ByteViews, ValueOf } from "./abstract.ts"; import { ArrayType } from "./array.ts"; import { BasicType } from "./basic.ts"; export type VectorBasicOpts = { typeName?: string; }; /** * Vector: Ordered fixed-length homogeneous collection, with N values * * Array of Basic type: * - Basic types are max 32 bytes long so multiple values may be packed in the same node. * - Basic types are never returned in a view wrapper, but their value representation */ export declare class VectorBasicType> extends ArrayType, ArrayBasicTreeViewDU> implements ArrayBasicType { readonly elementType: ElementType; readonly length: number; readonly typeName: string; readonly itemsPerChunk: number; readonly depth: number; readonly chunkDepth: number; readonly maxChunkCount: number; readonly fixedSize: number; readonly minSize: number; readonly maxSize: number; readonly isList = false; readonly isViewMutable = true; protected readonly defaultLen: number; constructor(elementType: ElementType, length: number, opts?: VectorBasicOpts); static named>(elementType: ElementType, limit: number, opts: Require): VectorBasicType; getView(tree: Tree): ArrayBasicTreeView; toView(value: ArrayLike>): ArrayBasicTreeView; getViewDU(node: Node, cache?: unknown): ArrayBasicTreeViewDU; commitView(view: ArrayBasicTreeView): Node; commitViewDU(view: ArrayBasicTreeViewDU, hcOffset?: number, hcByLevel?: HashComputationLevel[] | null): Node; cacheOfViewDU(view: ArrayBasicTreeViewDU): unknown; toViewDU(value: ArrayLike>): ArrayBasicTreeViewDU; value_serializedSize(): number; value_serializeToBytes(output: ByteViews, offset: number, value: ValueOf[]): number; value_deserializeFromBytes(data: ByteViews, start: number, end: number): ValueOf[]; tree_serializedSize(): number; tree_serializeToBytes(output: ByteViews, offset: number, node: Node): number; tree_deserializeFromBytes(data: ByteViews, start: number, end: number): Node; tree_getLength(): number; tree_setLength(): void; tree_getChunksNode(node: Node): Node; tree_chunksNodeOffset(): number; tree_setChunksNode(_rootNode: Node, chunksNode: Node): Node; protected getBlocksBytes(value: ValueOf[]): Uint8Array; }