import { HashComputationLevel, Node, Tree } from "@chainsafe/persistent-merkle-tree"; import { Require } from "../util/types.ts"; import { ArrayBasicType } from "../view/arrayBasic.ts"; import { ListBasicTreeView } from "../view/listBasic.ts"; import { ListBasicTreeViewDU } from "../viewDU/listBasic.ts"; import { ValueOf } from "./abstract.ts"; import { ArrayType } from "./array.ts"; import { BasicType } from "./basic.ts"; import { ByteViews } from "./composite.ts"; export interface ListBasicOpts { typeName?: string; cachePermanentRootStruct?: boolean; } /** * List: ordered variable-length homogeneous collection, limited to 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 ListBasicType> extends ArrayType, ListBasicTreeViewDU> implements ArrayBasicType { readonly elementType: ElementType; readonly limit: number; readonly typeName: string; readonly itemsPerChunk: number; readonly depth: number; readonly chunkDepth: number; readonly maxChunkCount: number; readonly fixedSize: null; readonly minSize: number; readonly maxSize: number; readonly isList = true; readonly isViewMutable = true; readonly mixInLengthBlockBytes: Uint8Array; readonly mixInLengthBuffer: Buffer; protected readonly defaultLen = 0; constructor(elementType: ElementType, limit: number, opts?: ListBasicOpts); static named>(elementType: ElementType, limit: number, opts: Require): ListBasicType; getView(tree: Tree): ListBasicTreeView; getViewDU(node: Node, cache?: unknown): ListBasicTreeViewDU; commitView(view: ListBasicTreeView): Node; commitViewDU(view: ListBasicTreeViewDU, hcOffset?: number, hcByLevel?: HashComputationLevel[] | null): Node; cacheOfViewDU(view: ListBasicTreeViewDU): unknown; value_serializedSize(value: ValueOf[]): number; value_serializeToBytes(output: ByteViews, offset: number, value: ValueOf[]): number; value_deserializeFromBytes(data: ByteViews, start: number, end: number): ValueOf[]; tree_serializedSize(node: Node): number; tree_serializeToBytes(output: ByteViews, offset: number, node: Node): number; tree_deserializeFromBytes(data: ByteViews, start: number, end: number): Node; tree_getLength(node: Node): number; tree_setLength(tree: Tree, length: number): void; tree_getChunksNode(node: Node): Node; tree_chunksNodeOffset(): number; tree_setChunksNode(rootNode: Node, chunksNode: Node, newLength: number | null, hcOffset?: number, hcByLevel?: HashComputationLevel[] | null): Node; hashTreeRoot(value: ValueOf[]): Uint8Array; hashTreeRootInto(value: ValueOf[], output: Uint8Array, offset: number, safeCache?: boolean): void; protected getBlocksBytes(value: ValueOf[]): Uint8Array; }