import { Token, Type } from './token.js' import * as uint from './0uint.js' import { decodeErrPrefix } from './common.js' /** * @typedef {import('./bl.js').Bl} Bl * @typedef {import('../interface').DecodeOptions} DecodeOptions */ /** * @param {Uint8Array} _data * @param {number} _pos * @param {number} prefix * @param {number} length * @returns {Token} */ function toToken (_data, _pos, prefix, length) { return new Token(Type.map, length, prefix) } /** * @param {Uint8Array} data * @param {number} pos * @param {number} minor * @param {DecodeOptions} _options * @returns {Token} */ export function decodeMapCompact (data, pos, minor, _options) { return toToken(data, pos, 1, minor) } /** * @param {Uint8Array} data * @param {number} pos * @param {number} _minor * @param {DecodeOptions} options * @returns {Token} */ export function decodeMap8 (data, pos, _minor, options) { return toToken(data, pos, 2, uint.readUint8(data, pos + 1, options)) } /** * @param {Uint8Array} data * @param {number} pos * @param {number} _minor * @param {DecodeOptions} options * @returns {Token} */ export function decodeMap16 (data, pos, _minor, options) { return toToken(data, pos, 3, uint.readUint16(data, pos + 1, options)) } /** * @param {Uint8Array} data * @param {number} pos * @param {number} _minor * @param {DecodeOptions} options * @returns {Token} */ export function decodeMap32 (data, pos, _minor, options) { return toToken(data, pos, 5, uint.readUint32(data, pos + 1, options)) } // TODO: maybe we shouldn't support this .. /** * @param {Uint8Array} data * @param {number} pos * @param {number} _minor * @param {DecodeOptions} options * @returns {Token} */ export function decodeMap64 (data, pos, _minor, options) { const l = uint.readUint64(data, pos + 1, options) if (typeof l === 'bigint') { throw new Error(`${decodeErrPrefix} 64-bit integer map lengths not supported`) } return toToken(data, pos, 9, l) } /** * @param {Uint8Array} data * @param {number} pos * @param {number} _minor * @param {DecodeOptions} options * @returns {Token} */ export function decodeMapIndefinite (data, pos, _minor, options) { if (options.allowIndefinite === false) { throw new Error(`${decodeErrPrefix} indefinite length items not allowed`) } return toToken(data, pos, 1, Infinity) } /** * @param {Bl} buf * @param {Token} token */ export function encodeMap (buf, token) { uint.encodeUintValue(buf, Type.map.majorEncoded, token.value) } // using a map as a map key, are you sure about this? we can only sort // by map length here, it's up to the encoder to decide to look deeper encodeMap.compareTokens = uint.encodeUint.compareTokens /** * @param {Token} token * @returns {number} */ encodeMap.encodedSize = function encodedSize (token) { return uint.encodeUintValue.encodedSize(token.value) }