UNPKG

@adguard/agtree

Version:
62 lines (59 loc) 2.64 kB
/* * AGTree v3.4.3 (build date: Thu, 11 Dec 2025 13:43:19 GMT) * (c) 2025 Adguard Software Ltd. * Released under the MIT license * https://github.com/AdguardTeam/tsurlfilter/tree/master/packages/agtree#readme */ import { NULL } from '../../utils/constants.js'; import { BaseDeserializer } from '../base-deserializer.js'; import { ModifierDeserializer } from './modifier-deserializer.js'; import { ModifierListNodeMarshallingMap } from '../../marshalling-utils/misc/modifier-list-common.js'; import { BinaryTypeMarshallingMap } from '../../marshalling-utils/misc/binary-type-common.js'; /* eslint-disable no-param-reassign */ /** * `ModifierListDeserializer` is responsible for deserializing modifier lists. Please note that the name is not * uniform, "modifiers" are also known as "options". * * @see {@link https://kb.adguard.com/en/general/how-to-create-your-own-ad-filters#basic-rules-modifiers} * @see {@link https://kb.adguard.com/en/general/how-to-create-your-own-ad-filters#non-basic-rules-modifiers} * @see {@link https://help.eyeo.com/adblockplus/how-to-write-filters#options} */ class ModifierListDeserializer extends BaseDeserializer { /** * Deserializes a modifier list node from binary format. * * @param buffer ByteBuffer for reading binary data. * @param node Destination node. */ static deserialize(buffer, node) { buffer.assertUint8(BinaryTypeMarshallingMap.ModifierListNode); node.type = 'ModifierList'; let prop = buffer.readUint8(); while (prop !== NULL) { switch (prop) { case ModifierListNodeMarshallingMap.Children: node.children = new Array(buffer.readUint16()); // read children for (let i = 0; i < node.children.length; i += 1) { ModifierDeserializer.deserialize(buffer, node.children[i] = {}); } break; case ModifierListNodeMarshallingMap.Start: node.start = buffer.readUint32(); break; case ModifierListNodeMarshallingMap.End: node.end = buffer.readUint32(); break; default: throw new Error(`Invalid property: ${prop}.`); } prop = buffer.readUint8(); } // Maybe children are not present in the binary data, // in this case, we should initialize it as an empty array. if (!node.children) { node.children = []; } } } export { ModifierListDeserializer };