@metaplex-foundation/umi-serializers
Version:
A comprehensive set of serializers for the Umi framework
59 lines (55 loc) • 1.92 kB
JavaScript
import { fixSerializer, mergeBytes, DeserializingEmptyBufferError, NotEnoughBytesError } from '@metaplex-foundation/umi-serializers-core';
import { utf8 } from '@metaplex-foundation/umi-serializers-encodings';
import { u32 } from '@metaplex-foundation/umi-serializers-numbers';
import { getSizeDescription } from './utils.mjs';
/**
* Defines the options for string serializers.
* @category Serializers
*/
/**
* Creates a string serializer.
*
* @param options - A set of options for the serializer.
* @category Serializers
*/
function string(options = {}) {
const size = options.size ?? u32();
const encoding = options.encoding ?? utf8;
const description = options.description ?? `string(${encoding.description}; ${getSizeDescription(size)})`;
if (size === 'variable') {
return {
...encoding,
description
};
}
if (typeof size === 'number') {
return fixSerializer(encoding, size, description);
}
return {
description,
fixedSize: null,
maxSize: null,
serialize: value => {
const contentBytes = encoding.serialize(value);
const lengthBytes = size.serialize(contentBytes.length);
return mergeBytes([lengthBytes, contentBytes]);
},
deserialize: (buffer, offset = 0) => {
if (buffer.slice(offset).length === 0) {
throw new DeserializingEmptyBufferError('string');
}
const [lengthBigInt, lengthOffset] = size.deserialize(buffer, offset);
const length = Number(lengthBigInt);
offset = lengthOffset;
const contentBuffer = buffer.slice(offset, offset + length);
if (contentBuffer.length < length) {
throw new NotEnoughBytesError('string', length, contentBuffer.length);
}
const [value, contentOffset] = encoding.deserialize(contentBuffer);
offset += contentOffset;
return [value, offset];
}
};
}
export { string };
//# sourceMappingURL=string.mjs.map