@adguard/agtree 2.2.0 → 3.0.0-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/ast-utils/clone.js +61 -0
- package/dist/ast-utils/modifiers.js +53 -0
- package/dist/ast-utils/network-rules.js +41 -0
- package/dist/ast-utils/scriptlets.js +87 -0
- package/dist/common/abp-snippet-injection-body-common.js +23 -0
- package/dist/common/agent-common.js +56 -0
- package/dist/common/ubo-selector-common.js +17 -0
- package/dist/compatibility-tables/base.js +262 -0
- package/dist/compatibility-tables/compatibility-table-data.js +11 -0
- package/dist/compatibility-tables/modifiers.js +55 -0
- package/dist/compatibility-tables/platforms.js +76 -0
- package/dist/compatibility-tables/redirects.js +100 -0
- package/dist/compatibility-tables/schemas/base.js +111 -0
- package/dist/compatibility-tables/schemas/modifier.js +129 -0
- package/dist/compatibility-tables/schemas/platform.js +69 -0
- package/dist/compatibility-tables/schemas/redirect.js +29 -0
- package/dist/compatibility-tables/schemas/resource-type.js +36 -0
- package/dist/compatibility-tables/schemas/scriptlet.js +79 -0
- package/dist/compatibility-tables/scriptlets.js +28 -0
- package/dist/compatibility-tables/utils/platform-helpers.js +105 -0
- package/dist/compatibility-tables/utils/resource-type-helpers.js +61 -0
- package/dist/compatibility-tables/utils/zod-camelcase.js +25 -0
- package/dist/converter/base-interfaces/base-converter.js +59 -0
- package/dist/converter/base-interfaces/conversion-result.js +38 -0
- package/dist/converter/base-interfaces/rule-converter-base.js +60 -0
- package/dist/converter/comment/index.js +54 -0
- package/dist/converter/cosmetic/css.js +69 -0
- package/dist/converter/cosmetic/element-hiding.js +62 -0
- package/dist/converter/cosmetic/header-removal.js +123 -0
- package/dist/converter/cosmetic/html.js +379 -0
- package/dist/converter/cosmetic/index.js +118 -0
- package/dist/converter/cosmetic/rule-modifiers/adg.js +79 -0
- package/dist/converter/cosmetic/scriptlet.js +354 -0
- package/dist/converter/css/index.js +188 -0
- package/dist/converter/data/css.js +126 -0
- package/dist/converter/filter-list.js +88 -0
- package/dist/converter/index.js +8 -0
- package/dist/converter/misc/network-rule-modifier.js +311 -0
- package/dist/converter/network/index.js +99 -0
- package/dist/converter/raw-filter-list.js +56 -0
- package/dist/converter/rule.js +81 -0
- package/dist/deserializer/base-deserializer.js +29 -0
- package/dist/deserializer/comment/agent-comment-deserializer.js +79 -0
- package/dist/deserializer/comment/agent-deserializer.js +65 -0
- package/dist/deserializer/comment/comment-rule-deserializer.js +54 -0
- package/dist/deserializer/comment/config-comment-deserializer.js +111 -0
- package/dist/deserializer/comment/hint-comment-deserializer.js +72 -0
- package/dist/deserializer/comment/hint-deserializer.js +85 -0
- package/dist/deserializer/comment/metadata-comment-deserializer.js +69 -0
- package/dist/deserializer/comment/pre-processor-comment-deserializer.js +112 -0
- package/dist/deserializer/comment/simple-comment-deserializer.js +65 -0
- package/dist/deserializer/cosmetic/cosmetic-rule-deserializer.js +131 -0
- package/dist/deserializer/cosmetic/css-injection-body-deserializer.js +56 -0
- package/dist/deserializer/cosmetic/element-hiding-body-deserializer.js +48 -0
- package/dist/deserializer/cosmetic/scriptlet-body/abp-snippet-injection-body-deserializer.js +39 -0
- package/dist/deserializer/cosmetic/scriptlet-body/adg-scriptlet-injection-body-deserializer.js +40 -0
- package/dist/deserializer/cosmetic/scriptlet-body/scriptlet-body-deserializer.js +54 -0
- package/dist/deserializer/cosmetic/scriptlet-body/ubo-scriptlet-injection-body-deserializer.js +38 -0
- package/dist/deserializer/empty-rule-deserializer.js +48 -0
- package/dist/deserializer/filterlist-deserializer.js +85 -0
- package/dist/deserializer/index.js +8 -0
- package/dist/deserializer/invalid-rule-deserializer.js +50 -0
- package/dist/deserializer/invalid-rule-error-node-deserializer.js +50 -0
- package/dist/deserializer/misc/domain-list-deserializer.js +64 -0
- package/dist/deserializer/misc/list-item-deserializer.js +69 -0
- package/dist/deserializer/misc/list-items-deserializer.js +30 -0
- package/dist/deserializer/misc/logical-expression-deserializer.js +196 -0
- package/dist/deserializer/misc/modifier-deserializer.js +87 -0
- package/dist/deserializer/misc/modifier-list-deserializer.js +61 -0
- package/dist/deserializer/misc/parameter-list-deserializer.js +64 -0
- package/dist/deserializer/misc/value-deserializer.js +50 -0
- package/dist/deserializer/network/host-rule-deserializer.js +67 -0
- package/dist/deserializer/network/hostname-list-deserializer.js +56 -0
- package/dist/deserializer/network/network-rule-deserializer.js +65 -0
- package/dist/deserializer/rule-deserializer.js +65 -0
- package/dist/deserializer/syntax-deserialization-map.js +21 -0
- package/dist/errors/adblock-syntax-error.js +39 -0
- package/dist/errors/binary-schema-mismatch-error.js +37 -0
- package/dist/errors/not-implemented-error.js +31 -0
- package/dist/errors/rule-conversion-error.js +26 -0
- package/dist/generator/base-generator.js +27 -0
- package/dist/generator/comment/agent-comment-generator.js +31 -0
- package/dist/generator/comment/agent-generator.js +36 -0
- package/dist/generator/comment/comment-rule-generator.js +47 -0
- package/dist/generator/comment/config-comment-generator.js +45 -0
- package/dist/generator/comment/hint-comment-generator.js +28 -0
- package/dist/generator/comment/hint-generator.js +33 -0
- package/dist/generator/comment/metadata-comment-generator.js +33 -0
- package/dist/generator/comment/pre-processor-comment-generator.js +48 -0
- package/dist/generator/comment/simple-comment-generator.js +29 -0
- package/dist/generator/cosmetic/body/abp-snippet-injection-body-generator.js +38 -0
- package/dist/generator/cosmetic/body/adg-scriptlet-injection-body-generator.js +43 -0
- package/dist/generator/cosmetic/body/ubo-scriptlet-injection-body-generator.js +45 -0
- package/dist/generator/cosmetic/cosmetic-rule-body-generator.js +94 -0
- package/dist/generator/cosmetic/cosmetic-rule-generator.js +54 -0
- package/dist/generator/cosmetic/cosmetic-rule-pattern-generator.js +42 -0
- package/dist/generator/css/adg-css-injection-generator.js +42 -0
- package/dist/generator/filterlist-generator.js +67 -0
- package/dist/generator/index.js +9 -0
- package/dist/generator/misc/domain-list-generator.js +26 -0
- package/dist/generator/misc/list-items-generator.js +39 -0
- package/dist/generator/misc/logical-expression-generator.js +48 -0
- package/dist/generator/misc/modifier-generator.js +34 -0
- package/dist/generator/misc/modifier-list-generator.js +29 -0
- package/dist/generator/misc/parameter-list-generator.js +41 -0
- package/dist/generator/misc/value-generator.js +24 -0
- package/dist/generator/network/host-rule-generator.js +39 -0
- package/dist/generator/network/network-rule-generator.js +38 -0
- package/dist/generator/rule-generator.js +65 -0
- package/dist/index.js +70 -0
- package/dist/marshalling-utils/comment/agent-comment-common.js +21 -0
- package/dist/marshalling-utils/comment/agent-common.js +40 -0
- package/dist/marshalling-utils/comment/config-comment-common.js +54 -0
- package/dist/marshalling-utils/comment/hint-comment-common.js +22 -0
- package/dist/marshalling-utils/comment/hint-common.js +56 -0
- package/dist/marshalling-utils/comment/metadata-comment-common.js +41 -0
- package/dist/marshalling-utils/comment/pre-processor-comment-common.js +59 -0
- package/dist/marshalling-utils/comment/simple-comment-common.js +22 -0
- package/dist/marshalling-utils/cosmetic/body/abp-snippet-injection-body-common.js +61 -0
- package/dist/marshalling-utils/cosmetic/body/adg-scriptlet-injection-body-common.js +66 -0
- package/dist/marshalling-utils/cosmetic/body/css-injection-body-common.js +24 -0
- package/dist/marshalling-utils/cosmetic/body/element-hiding-body-common.js +21 -0
- package/dist/marshalling-utils/cosmetic/body/ubo-scriptlet-injection-body-common.js +114 -0
- package/dist/marshalling-utils/cosmetic/cosmetic-rule-common.js +48 -0
- package/dist/marshalling-utils/empty-rule-common.js +20 -0
- package/dist/marshalling-utils/filter-list-common.js +21 -0
- package/dist/marshalling-utils/invalid-rule-common.js +21 -0
- package/dist/marshalling-utils/invalid-rule-error-node-common.js +22 -0
- package/dist/marshalling-utils/misc/binary-type-common.js +66 -0
- package/dist/marshalling-utils/misc/domain-list-common.js +36 -0
- package/dist/marshalling-utils/misc/host-rule-common.js +25 -0
- package/dist/marshalling-utils/misc/hostname-list-common.js +21 -0
- package/dist/marshalling-utils/misc/list-item-common.js +22 -0
- package/dist/marshalling-utils/misc/logical-expression-common.js +83 -0
- package/dist/marshalling-utils/misc/modifier-common.js +231 -0
- package/dist/marshalling-utils/misc/modifier-list-common.js +21 -0
- package/dist/marshalling-utils/misc/parameter-list-common.js +21 -0
- package/dist/marshalling-utils/misc/value-common.js +22 -0
- package/dist/marshalling-utils/network/network-rule-common.js +25 -0
- package/dist/marshalling-utils/syntax-serialization-map.js +30 -0
- package/dist/nodes/index.js +168 -0
- package/dist/package.json.js +9 -0
- package/dist/parser/base-parser.js +30 -0
- package/dist/parser/comment/agent-comment-parser.js +119 -0
- package/dist/parser/comment/agent-parser.js +110 -0
- package/dist/parser/comment/comment-parser.js +108 -0
- package/dist/parser/comment/config-comment-parser.js +137 -0
- package/dist/parser/comment/hint-comment-parser.js +117 -0
- package/dist/parser/comment/hint-parser.js +129 -0
- package/dist/parser/comment/metadata-comment-parser.js +129 -0
- package/dist/parser/comment/preprocessor-parser.js +199 -0
- package/dist/parser/comment/simple-comment-parser.js +106 -0
- package/dist/parser/cosmetic/body/abp-snippet-injection-body-parser.js +79 -0
- package/dist/parser/cosmetic/body/adg-scriptlet-injection-body-parser.js +149 -0
- package/dist/parser/cosmetic/body/ubo-scriptlet-injection-body-parser.js +110 -0
- package/dist/parser/cosmetic/cosmetic-rule-parser.js +453 -0
- package/dist/parser/css/adg-css-injection-parser.js +208 -0
- package/dist/parser/css/balancing.js +94 -0
- package/dist/parser/css/constants.js +18 -0
- package/dist/parser/css/css-token-stream.js +343 -0
- package/dist/parser/css/ubo-selector-parser.js +369 -0
- package/dist/parser/filterlist-parser.js +102 -0
- package/dist/parser/index.js +12 -0
- package/dist/parser/misc/app-list-parser.js +45 -0
- package/dist/parser/misc/domain-list-parser.js +52 -0
- package/dist/parser/misc/list-items-parser.js +116 -0
- package/dist/parser/misc/logical-expression-parser.js +279 -0
- package/dist/parser/misc/method-list-parser.js +46 -0
- package/dist/parser/misc/modifier-list.js +70 -0
- package/dist/parser/misc/modifier-parser.js +89 -0
- package/dist/parser/misc/parameter-list-parser.js +75 -0
- package/dist/parser/misc/stealth-option-list-parser.js +46 -0
- package/dist/parser/misc/ubo-parameter-list-parser.js +149 -0
- package/dist/parser/misc/value-parser.js +37 -0
- package/dist/parser/network/host-rule-parser.js +130 -0
- package/dist/parser/network/network-rule-parser.js +117 -0
- package/dist/parser/options.js +23 -0
- package/dist/parser/rule-parser.js +192 -0
- package/dist/serializer/base-serializer.js +29 -0
- package/dist/serializer/comment/agent-comment-serializer.js +74 -0
- package/dist/serializer/comment/agent-serializer.js +59 -0
- package/dist/serializer/comment/comment-rule-serializer.js +105 -0
- package/dist/serializer/comment/config-comment-serializer.js +82 -0
- package/dist/serializer/comment/hint-comment-serializer.js +65 -0
- package/dist/serializer/comment/hint-serializer.js +54 -0
- package/dist/serializer/comment/metadata-comment-serializer.js +73 -0
- package/dist/serializer/comment/pre-processor-comment-serializer.js +71 -0
- package/dist/serializer/comment/simple-comment-serializer.js +52 -0
- package/dist/serializer/cosmetic/body/abp-snippet-injection-body-serializer.js +36 -0
- package/dist/serializer/cosmetic/body/adg-scriptlet-injection-body-serializer.js +36 -0
- package/dist/serializer/cosmetic/body/scriptlet-body-serializer.js +50 -0
- package/dist/serializer/cosmetic/body/ubo-scriptlet-injection-body-serializer.js +36 -0
- package/dist/serializer/cosmetic/cosmetic-rule-serializer.js +120 -0
- package/dist/serializer/cosmetic/css-injection-body-serializer.js +51 -0
- package/dist/serializer/cosmetic/element-hiding-body-serializer.js +40 -0
- package/dist/serializer/empty-rule-serializer.js +37 -0
- package/dist/serializer/filterlist-serializer.js +45 -0
- package/dist/serializer/index.js +7 -0
- package/dist/serializer/invalid-rule-error-node-serializer.js +41 -0
- package/dist/serializer/invalid-rule-serializer.js +40 -0
- package/dist/serializer/misc/domain-list-serializer.js +64 -0
- package/dist/serializer/misc/list-item-serializer.js +58 -0
- package/dist/serializer/misc/list-items-serializer.js +29 -0
- package/dist/serializer/misc/logical-expression-serializer.js +136 -0
- package/dist/serializer/misc/modifier-list-serializer.js +58 -0
- package/dist/serializer/misc/modifier-serializer.js +49 -0
- package/dist/serializer/misc/parameter-list-serializer.js +52 -0
- package/dist/serializer/misc/value-serializer.js +50 -0
- package/dist/serializer/network/host-rule-serializer.js +70 -0
- package/dist/serializer/network/hostname-list-serializer.js +53 -0
- package/dist/serializer/network/network-rule-serializer.js +54 -0
- package/dist/serializer/rule-serializer.js +61 -0
- package/dist/types/ast-utils/clone.d.ts +26 -0
- package/dist/types/ast-utils/filter-list.d.ts +11 -0
- package/dist/types/ast-utils/modifiers.d.ts +20 -0
- package/dist/types/ast-utils/network-rules.d.ts +15 -0
- package/dist/types/ast-utils/scriptlets.d.ts +52 -0
- package/dist/types/common/abp-snippet-injection-body-common.d.ts +15 -0
- package/dist/types/common/agent-common.d.ts +10 -0
- package/dist/types/common/ubo-selector-common.d.ts +10 -0
- package/dist/types/compatibility-tables/base.d.ts +157 -0
- package/dist/types/compatibility-tables/compatibility-table-data.d.ts +68 -0
- package/dist/types/compatibility-tables/index.d.ts +13 -0
- package/dist/types/compatibility-tables/modifiers.d.ts +22 -0
- package/dist/types/compatibility-tables/platforms.d.ts +49 -0
- package/dist/types/compatibility-tables/redirects.d.ts +33 -0
- package/dist/types/compatibility-tables/schemas/base.d.ts +124 -0
- package/dist/types/compatibility-tables/schemas/index.d.ts +8 -0
- package/dist/types/compatibility-tables/schemas/modifier.d.ts +36 -0
- package/dist/types/compatibility-tables/schemas/platform.d.ts +16 -0
- package/dist/types/compatibility-tables/schemas/redirect.d.ts +25 -0
- package/dist/types/compatibility-tables/schemas/resource-type.d.ts +41 -0
- package/dist/types/compatibility-tables/schemas/scriptlet.d.ts +31 -0
- package/dist/types/compatibility-tables/scriptlets.d.ts +15 -0
- package/dist/types/compatibility-tables/types.d.ts +34 -0
- package/dist/types/compatibility-tables/utils/platform-helpers.d.ts +44 -0
- package/dist/types/compatibility-tables/utils/resource-type-helpers.d.ts +20 -0
- package/dist/types/compatibility-tables/utils/zod-camelcase.d.ts +15 -0
- package/dist/types/converter/base-interfaces/base-converter.d.ts +42 -0
- package/dist/types/converter/base-interfaces/conversion-result.d.ts +43 -0
- package/dist/types/converter/base-interfaces/rule-converter-base.d.ts +44 -0
- package/dist/types/converter/comment/index.d.ts +23 -0
- package/dist/types/converter/cosmetic/css.d.ts +23 -0
- package/dist/types/converter/cosmetic/element-hiding.d.ts +23 -0
- package/dist/types/converter/cosmetic/header-removal.d.ts +37 -0
- package/dist/types/converter/cosmetic/html.d.ts +54 -0
- package/dist/types/converter/cosmetic/index.d.ts +33 -0
- package/dist/types/converter/cosmetic/rule-modifiers/adg.d.ts +21 -0
- package/dist/types/converter/cosmetic/scriptlet.d.ts +33 -0
- package/dist/types/converter/css/index.d.ts +40 -0
- package/dist/types/converter/data/css.d.ts +48 -0
- package/dist/types/converter/filter-list.d.ts +31 -0
- package/dist/types/converter/index.d.ts +5 -0
- package/dist/types/converter/misc/network-rule-modifier.d.ts +35 -0
- package/dist/types/converter/network/index.d.ts +33 -0
- package/dist/types/converter/raw-filter-list.d.ts +31 -0
- package/dist/types/converter/raw-rule.d.ts +28 -0
- package/dist/types/converter/rule.d.ts +37 -0
- package/dist/types/deserializer/base-deserializer.d.ts +15 -0
- package/dist/types/deserializer/comment/agent-comment-deserializer.d.ts +34 -0
- package/dist/types/deserializer/comment/agent-deserializer.d.ts +25 -0
- package/dist/types/deserializer/comment/comment-rule-deserializer.d.ts +16 -0
- package/dist/types/deserializer/comment/config-comment-deserializer.d.ts +27 -0
- package/dist/types/deserializer/comment/hint-comment-deserializer.d.ts +24 -0
- package/dist/types/deserializer/comment/hint-deserializer.d.ts +26 -0
- package/dist/types/deserializer/comment/metadata-comment-deserializer.d.ts +26 -0
- package/dist/types/deserializer/comment/pre-processor-comment-deserializer.d.ts +29 -0
- package/dist/types/deserializer/comment/simple-comment-deserializer.d.ts +26 -0
- package/dist/types/deserializer/cosmetic/cosmetic-rule-deserializer.d.ts +18 -0
- package/dist/types/deserializer/cosmetic/css-injection-body-deserializer.d.ts +15 -0
- package/dist/types/deserializer/cosmetic/element-hiding-body-deserializer.d.ts +16 -0
- package/dist/types/deserializer/cosmetic/scriptlet-body/abp-snippet-injection-body-deserializer.d.ts +17 -0
- package/dist/types/deserializer/cosmetic/scriptlet-body/adg-scriptlet-injection-body-deserializer.d.ts +18 -0
- package/dist/types/deserializer/cosmetic/scriptlet-body/scriptlet-body-deserializer.d.ts +19 -0
- package/dist/types/deserializer/cosmetic/scriptlet-body/ubo-scriptlet-injection-body-deserializer.d.ts +17 -0
- package/dist/types/deserializer/empty-rule-deserializer.d.ts +16 -0
- package/dist/types/deserializer/filterlist-deserializer.d.ts +34 -0
- package/dist/types/deserializer/index.d.ts +2 -0
- package/dist/types/deserializer/invalid-rule-deserializer.d.ts +16 -0
- package/dist/types/deserializer/invalid-rule-error-node-deserializer.d.ts +16 -0
- package/dist/types/deserializer/misc/domain-list-deserializer.d.ts +15 -0
- package/dist/types/deserializer/misc/list-item-deserializer.d.ts +19 -0
- package/dist/types/deserializer/misc/list-items-deserializer.d.ts +16 -0
- package/dist/types/deserializer/misc/logical-expression-deserializer.d.ts +55 -0
- package/dist/types/deserializer/misc/modifier-deserializer.d.ts +18 -0
- package/dist/types/deserializer/misc/modifier-list-deserializer.d.ts +20 -0
- package/dist/types/deserializer/misc/parameter-list-deserializer.d.ts +18 -0
- package/dist/types/deserializer/misc/value-deserializer.d.ts +17 -0
- package/dist/types/deserializer/network/host-rule-deserializer.d.ts +18 -0
- package/dist/types/deserializer/network/hostname-list-deserializer.d.ts +15 -0
- package/dist/types/deserializer/network/network-rule-deserializer.d.ts +18 -0
- package/dist/types/deserializer/rule-deserializer.d.ts +17 -0
- package/dist/types/deserializer/syntax-deserialization-map.d.ts +2 -0
- package/dist/types/errors/adblock-syntax-error.d.ts +25 -0
- package/dist/types/errors/binary-schema-mismatch-error.d.ts +23 -0
- package/dist/types/errors/not-implemented-error.d.ts +14 -0
- package/dist/types/errors/rule-conversion-error.d.ts +14 -0
- package/dist/types/generator/base-generator.d.ts +12 -0
- package/dist/types/generator/comment/agent-comment-generator.d.ts +14 -0
- package/dist/types/generator/comment/agent-generator.d.ts +15 -0
- package/dist/types/generator/comment/comment-rule-generator.d.ts +14 -0
- package/dist/types/generator/comment/config-comment-generator.d.ts +14 -0
- package/dist/types/generator/comment/hint-comment-generator.d.ts +14 -0
- package/dist/types/generator/comment/hint-generator.d.ts +14 -0
- package/dist/types/generator/comment/index.d.ts +1 -0
- package/dist/types/generator/comment/metadata-comment-generator.d.ts +14 -0
- package/dist/types/generator/comment/pre-processor-comment-generator.d.ts +14 -0
- package/dist/types/generator/comment/simple-comment-generator.d.ts +14 -0
- package/dist/types/generator/cosmetic/body/abp-snippet-injection-body-generator.d.ts +15 -0
- package/dist/types/generator/cosmetic/body/adg-scriptlet-injection-body-generator.d.ts +21 -0
- package/dist/types/generator/cosmetic/body/ubo-scriptlet-injection-body-generator.d.ts +21 -0
- package/dist/types/generator/cosmetic/cosmetic-rule-body-generator.d.ts +20 -0
- package/dist/types/generator/cosmetic/cosmetic-rule-generator.d.ts +28 -0
- package/dist/types/generator/cosmetic/cosmetic-rule-pattern-generator.d.ts +18 -0
- package/dist/types/generator/cosmetic/index.d.ts +1 -0
- package/dist/types/generator/css/adg-css-injection-generator.d.ts +15 -0
- package/dist/types/generator/css/ubo-selector-generator.d.ts +14 -0
- package/dist/types/generator/filterlist-generator.d.ts +18 -0
- package/dist/types/generator/index.d.ts +3 -0
- package/dist/types/generator/misc/domain-list-generator.d.ts +15 -0
- package/dist/types/generator/misc/list-items-generator.d.ts +25 -0
- package/dist/types/generator/misc/logical-expression-generator.d.ts +14 -0
- package/dist/types/generator/misc/modifier-generator.d.ts +14 -0
- package/dist/types/generator/misc/modifier-list-generator.d.ts +14 -0
- package/dist/types/generator/misc/parameter-list-generator.d.ts +15 -0
- package/dist/types/generator/misc/value-generator.d.ts +14 -0
- package/dist/types/generator/network/host-rule-generator.d.ts +14 -0
- package/dist/types/generator/network/index.d.ts +2 -0
- package/dist/types/generator/network/network-rule-generator.d.ts +14 -0
- package/dist/types/generator/rule-generator.d.ts +24 -0
- package/dist/types/index.d.ts +55 -0
- package/dist/types/marshalling-utils/comment/agent-comment-common.d.ts +14 -0
- package/dist/types/marshalling-utils/comment/agent-common.d.ts +20 -0
- package/dist/types/marshalling-utils/comment/config-comment-common.d.ts +42 -0
- package/dist/types/marshalling-utils/comment/hint-comment-common.d.ts +15 -0
- package/dist/types/marshalling-utils/comment/hint-common.d.ts +33 -0
- package/dist/types/marshalling-utils/comment/metadata-comment-common.d.ts +21 -0
- package/dist/types/marshalling-utils/comment/pre-processor-comment-common.d.ts +37 -0
- package/dist/types/marshalling-utils/comment/simple-comment-common.d.ts +15 -0
- package/dist/types/marshalling-utils/cosmetic/body/abp-snippet-injection-body-common.d.ts +23 -0
- package/dist/types/marshalling-utils/cosmetic/body/adg-scriptlet-injection-body-common.d.ts +9 -0
- package/dist/types/marshalling-utils/cosmetic/body/css-injection-body-common.d.ts +17 -0
- package/dist/types/marshalling-utils/cosmetic/body/element-hiding-body-common.d.ts +14 -0
- package/dist/types/marshalling-utils/cosmetic/body/ubo-scriptlet-injection-body-common.d.ts +9 -0
- package/dist/types/marshalling-utils/cosmetic/cosmetic-rule-common.d.ts +28 -0
- package/dist/types/marshalling-utils/empty-rule-common.d.ts +13 -0
- package/dist/types/marshalling-utils/filter-list-common.d.ts +14 -0
- package/dist/types/marshalling-utils/invalid-rule-common.d.ts +14 -0
- package/dist/types/marshalling-utils/invalid-rule-error-node-common.d.ts +15 -0
- package/dist/types/marshalling-utils/misc/binary-type-common.d.ts +57 -0
- package/dist/types/marshalling-utils/misc/domain-list-common.d.ts +24 -0
- package/dist/types/marshalling-utils/misc/host-rule-common.d.ts +18 -0
- package/dist/types/marshalling-utils/misc/hostname-list-common.d.ts +14 -0
- package/dist/types/marshalling-utils/misc/list-item-common.d.ts +15 -0
- package/dist/types/marshalling-utils/misc/logical-expression-common.d.ts +47 -0
- package/dist/types/marshalling-utils/misc/modifier-common.d.ts +41 -0
- package/dist/types/marshalling-utils/misc/modifier-list-common.d.ts +14 -0
- package/dist/types/marshalling-utils/misc/parameter-list-common.d.ts +14 -0
- package/dist/types/marshalling-utils/misc/value-common.d.ts +15 -0
- package/dist/types/marshalling-utils/network/network-rule-common.d.ts +18 -0
- package/dist/types/marshalling-utils/syntax-serialization-map.d.ts +2 -0
- package/dist/types/nodes/index.d.ts +1183 -0
- package/dist/types/parser/base-parser.d.ts +16 -0
- package/dist/types/parser/comment/agent-comment-parser.d.ts +42 -0
- package/dist/types/parser/comment/agent-parser.d.ts +33 -0
- package/dist/types/parser/comment/comment-parser.d.ts +76 -0
- package/dist/types/parser/comment/config-comment-parser.d.ts +31 -0
- package/dist/types/parser/comment/hint-comment-parser.d.ts +33 -0
- package/dist/types/parser/comment/hint-parser.d.ts +30 -0
- package/dist/types/parser/comment/metadata-comment-parser.d.ts +29 -0
- package/dist/types/parser/comment/preprocessor-parser.d.ts +43 -0
- package/dist/types/parser/comment/simple-comment-parser.d.ts +33 -0
- package/dist/types/parser/cosmetic/body/abp-snippet-injection-body-parser.d.ts +34 -0
- package/dist/types/parser/cosmetic/body/adg-scriptlet-injection-body-parser.d.ts +47 -0
- package/dist/types/parser/cosmetic/body/ubo-scriptlet-injection-body-parser.d.ts +44 -0
- package/dist/types/parser/cosmetic/cosmetic-rule-parser.d.ts +51 -0
- package/dist/types/parser/css/adg-css-injection-parser.d.ts +28 -0
- package/dist/types/parser/css/balancing.d.ts +36 -0
- package/dist/types/parser/css/constants.d.ts +10 -0
- package/dist/types/parser/css/css-token-stream.d.ts +210 -0
- package/dist/types/parser/css/ubo-selector-parser.d.ts +46 -0
- package/dist/types/parser/filterlist-parser.d.ts +29 -0
- package/dist/types/parser/index.d.ts +6 -0
- package/dist/types/parser/misc/app-list-parser.d.ts +22 -0
- package/dist/types/parser/misc/domain-list-parser.d.ts +26 -0
- package/dist/types/parser/misc/list-items-parser.d.ts +37 -0
- package/dist/types/parser/misc/logical-expression-parser.d.ts +42 -0
- package/dist/types/parser/misc/method-list-parser.d.ts +22 -0
- package/dist/types/parser/misc/modifier-list.d.ts +24 -0
- package/dist/types/parser/misc/modifier-parser.d.ts +21 -0
- package/dist/types/parser/misc/parameter-list-parser.d.ts +17 -0
- package/dist/types/parser/misc/stealth-option-list-parser.d.ts +22 -0
- package/dist/types/parser/misc/ubo-parameter-list-parser.d.ts +21 -0
- package/dist/types/parser/misc/value-parser.d.ts +18 -0
- package/dist/types/parser/network/host-rule-parser.d.ts +35 -0
- package/dist/types/parser/network/network-rule-parser.d.ts +31 -0
- package/dist/types/parser/options.d.ts +41 -0
- package/dist/types/parser/rule-parser.d.ts +78 -0
- package/dist/types/serializer/base-serializer.d.ts +15 -0
- package/dist/types/serializer/comment/agent-comment-serializer.d.ts +34 -0
- package/dist/types/serializer/comment/agent-serializer.d.ts +15 -0
- package/dist/types/serializer/comment/comment-rule-serializer.d.ts +68 -0
- package/dist/types/serializer/comment/config-comment-serializer.d.ts +25 -0
- package/dist/types/serializer/comment/hint-comment-serializer.d.ts +23 -0
- package/dist/types/serializer/comment/hint-serializer.d.ts +24 -0
- package/dist/types/serializer/comment/metadata-comment-serializer.d.ts +25 -0
- package/dist/types/serializer/comment/pre-processor-comment-serializer.d.ts +28 -0
- package/dist/types/serializer/comment/simple-comment-serializer.d.ts +24 -0
- package/dist/types/serializer/cosmetic/body/abp-snippet-injection-body-serializer.d.ts +25 -0
- package/dist/types/serializer/cosmetic/body/adg-scriptlet-injection-body-serializer.d.ts +25 -0
- package/dist/types/serializer/cosmetic/body/scriptlet-body-serializer.d.ts +17 -0
- package/dist/types/serializer/cosmetic/body/ubo-scriptlet-injection-body-serializer.d.ts +25 -0
- package/dist/types/serializer/cosmetic/cosmetic-rule-serializer.d.ts +19 -0
- package/dist/types/serializer/cosmetic/css-injection-body-serializer.d.ts +15 -0
- package/dist/types/serializer/cosmetic/element-hiding-body-serializer.d.ts +15 -0
- package/dist/types/serializer/empty-rule-serializer.d.ts +15 -0
- package/dist/types/serializer/filterlist-serializer.d.ts +15 -0
- package/dist/types/serializer/index.d.ts +1 -0
- package/dist/types/serializer/invalid-rule-error-node-serializer.d.ts +15 -0
- package/dist/types/serializer/invalid-rule-serializer.d.ts +15 -0
- package/dist/types/serializer/misc/domain-list-serializer.d.ts +21 -0
- package/dist/types/serializer/misc/list-item-serializer.d.ts +16 -0
- package/dist/types/serializer/misc/list-items-serializer.d.ts +15 -0
- package/dist/types/serializer/misc/logical-expression-serializer.d.ts +52 -0
- package/dist/types/serializer/misc/modifier-list-serializer.d.ts +20 -0
- package/dist/types/serializer/misc/modifier-serializer.d.ts +18 -0
- package/dist/types/serializer/misc/parameter-list-serializer.d.ts +17 -0
- package/dist/types/serializer/misc/value-serializer.d.ts +17 -0
- package/dist/types/serializer/network/host-rule-serializer.d.ts +30 -0
- package/dist/types/serializer/network/hostname-list-serializer.d.ts +15 -0
- package/dist/types/serializer/network/network-rule-serializer.d.ts +18 -0
- package/dist/types/serializer/rule-serializer.d.ts +17 -0
- package/dist/types/utils/adblockers.d.ts +49 -0
- package/dist/types/utils/binary-schema-version.d.ts +9 -0
- package/dist/types/utils/byte-buffer.d.ts +54 -0
- package/dist/types/utils/categorizer.d.ts +14 -0
- package/dist/types/utils/clone.d.ts +15 -0
- package/dist/types/utils/constants.d.ts +188 -0
- package/dist/types/utils/cosmetic-rule-separator.d.ts +45 -0
- package/dist/types/utils/deep-freeze.d.ts +13 -0
- package/dist/types/utils/domain.d.ts +29 -0
- package/dist/types/utils/error.d.ts +8 -0
- package/dist/types/utils/index.d.ts +15 -0
- package/dist/types/utils/input-byte-buffer.d.ts +146 -0
- package/dist/types/utils/is-chromium.d.ts +7 -0
- package/dist/types/utils/logical-expression.d.ts +45 -0
- package/dist/types/utils/multi-value-map.d.ts +16 -0
- package/dist/types/utils/output-byte-buffer.d.ts +132 -0
- package/dist/types/utils/position-provider.d.ts +46 -0
- package/dist/types/utils/quotes.d.ts +94 -0
- package/dist/types/utils/regexp.d.ts +54 -0
- package/dist/types/utils/storage-interface.d.ts +23 -0
- package/dist/types/utils/string.d.ts +280 -0
- package/dist/types/utils/text-decoder-polyfill.d.ts +14 -0
- package/dist/types/utils/text-encoder-polyfill.d.ts +18 -0
- package/dist/types/utils/type-guards.d.ts +47 -0
- package/dist/types/validator/constants.d.ts +89 -0
- package/dist/types/validator/helpers.d.ts +37 -0
- package/dist/types/validator/index.d.ts +38 -0
- package/dist/types/validator/value.d.ts +12 -0
- package/dist/types/version.d.ts +5 -0
- package/dist/utils/adblockers.js +56 -0
- package/dist/utils/binary-schema-version.js +17 -0
- package/dist/utils/byte-buffer.js +91 -0
- package/dist/utils/categorizer.js +44 -0
- package/dist/utils/clone.js +28 -0
- package/dist/utils/constants.js +249 -0
- package/dist/utils/cosmetic-rule-separator.js +127 -0
- package/dist/utils/deep-freeze.js +32 -0
- package/dist/utils/domain.js +59 -0
- package/dist/utils/error.js +49 -0
- package/dist/utils/index.js +21 -0
- package/dist/utils/input-byte-buffer.js +265 -0
- package/dist/utils/is-chromium.js +20 -0
- package/dist/utils/logical-expression.js +92 -0
- package/dist/utils/multi-value-map.js +33 -0
- package/dist/utils/output-byte-buffer.js +231 -0
- package/dist/utils/position-provider.js +73 -0
- package/dist/utils/quotes.js +214 -0
- package/dist/utils/regexp.js +176 -0
- package/dist/utils/string.js +559 -0
- package/dist/utils/text-decoder-polyfill.js +107 -0
- package/dist/utils/text-encoder-polyfill.js +78 -0
- package/dist/utils/type-guards.js +47 -0
- package/dist/validator/constants.js +210 -0
- package/dist/validator/helpers.js +45 -0
- package/dist/validator/index.js +174 -0
- package/dist/validator/value.js +568 -0
- package/dist/version.js +18 -0
- package/package.json +61 -39
- package/dist/agtree.d.ts +0 -4155
- package/dist/agtree.js +0 -15819
- package/dist/agtree.mjs +0 -15720
- package/dist/compatibility-table-data.js +0 -12782
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* AGTree v3.0.0-alpha.2 (build date: Tue, 17 Dec 2024 16:50:04 GMT)
|
|
3
|
+
* (c) 2024 Adguard Software Ltd.
|
|
4
|
+
* Released under the MIT license
|
|
5
|
+
* https://github.com/AdguardTeam/tsurlfilter/tree/master/packages/agtree#readme
|
|
6
|
+
*/
|
|
7
|
+
import { AdblockSyntax } from '../utils/adblockers.js';
|
|
8
|
+
import { CommentParser } from './comment/comment-parser.js';
|
|
9
|
+
import { CosmeticRuleParser } from './cosmetic/cosmetic-rule-parser.js';
|
|
10
|
+
import { NetworkRuleParser } from './network/network-rule-parser.js';
|
|
11
|
+
import { RuleCategory } from '../nodes/index.js';
|
|
12
|
+
import { AdblockSyntaxError } from '../errors/adblock-syntax-error.js';
|
|
13
|
+
import { defaultParserOptions } from './options.js';
|
|
14
|
+
import { BaseParser } from './base-parser.js';
|
|
15
|
+
import { HostRuleParser } from './network/host-rule-parser.js';
|
|
16
|
+
|
|
17
|
+
/* eslint-disable no-param-reassign */
|
|
18
|
+
/**
|
|
19
|
+
* `RuleParser` is responsible for parsing the rules.
|
|
20
|
+
*
|
|
21
|
+
* It automatically determines the category and syntax of the rule, so you can pass any kind of rule to it.
|
|
22
|
+
*/
|
|
23
|
+
class RuleParser extends BaseParser {
|
|
24
|
+
/**
|
|
25
|
+
* Helper method to parse host rules if the `parseHostRules` option is enabled, otherwise it will
|
|
26
|
+
* parse network rules.
|
|
27
|
+
*
|
|
28
|
+
* @param raw Raw input to parse.
|
|
29
|
+
* @param options Global parser options.
|
|
30
|
+
* @param baseOffset Starting offset of the input. Node locations are calculated relative to this offset.
|
|
31
|
+
* @returns Host rule or network rule node.
|
|
32
|
+
*/
|
|
33
|
+
static parseHostOrNetworkRule(raw, options, baseOffset) {
|
|
34
|
+
if (options.parseHostRules) {
|
|
35
|
+
try {
|
|
36
|
+
return HostRuleParser.parse(raw, options, baseOffset);
|
|
37
|
+
}
|
|
38
|
+
catch (error) {
|
|
39
|
+
// Ignore the error, and fall back to network rule parser
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return NetworkRuleParser.parse(raw, options, baseOffset);
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Parse an adblock rule. You can pass any kind of rule to this method, since it will automatically determine
|
|
46
|
+
* the category and syntax. If the rule is syntactically invalid, then an error will be thrown. If the
|
|
47
|
+
* syntax / compatibility cannot be determined clearly, then the value of the `syntax` property will be
|
|
48
|
+
* `Common`.
|
|
49
|
+
*
|
|
50
|
+
* For example, let's have this network rule:
|
|
51
|
+
* ```adblock
|
|
52
|
+
* ||example.org^$important
|
|
53
|
+
* ```
|
|
54
|
+
* The `syntax` property will be `Common`, since the rule is syntactically correct in every adblockers, but we
|
|
55
|
+
* cannot determine at parsing level whether `important` is an existing option or not, nor if it exists, then
|
|
56
|
+
* which adblocker supports it. This is why the `syntax` property is simply `Common` at this point.
|
|
57
|
+
* The concrete COMPATIBILITY of the rule will be determined later, in a different, higher-level layer, called
|
|
58
|
+
* "Compatibility table".
|
|
59
|
+
*
|
|
60
|
+
* But we can determinate the concrete syntax of this rule:
|
|
61
|
+
* ```adblock
|
|
62
|
+
* example.org#%#//scriptlet("scriptlet0", "arg0")
|
|
63
|
+
* ```
|
|
64
|
+
* since it is clearly an AdGuard-specific rule and no other adblockers uses this syntax natively. However, we also
|
|
65
|
+
* cannot determine the COMPATIBILITY of this rule, as it is not clear at this point whether the `scriptlet0`
|
|
66
|
+
* scriptlet is supported by AdGuard or not. This is also the task of the "Compatibility table". Here, we simply
|
|
67
|
+
* mark the rule with the `AdGuard` syntax in this case.
|
|
68
|
+
*
|
|
69
|
+
* @param raw Raw input to parse.
|
|
70
|
+
* @param options Global parser options.
|
|
71
|
+
* @param baseOffset Starting offset of the input. Node locations are calculated relative to this offset.
|
|
72
|
+
* @returns Adblock rule node
|
|
73
|
+
* @throws If the input matches a pattern but syntactically invalid
|
|
74
|
+
* @example
|
|
75
|
+
* Take a look at the following example:
|
|
76
|
+
* ```js
|
|
77
|
+
* // Parse a network rule
|
|
78
|
+
* const ast1 = RuleParser.parse("||example.org^$important");
|
|
79
|
+
*
|
|
80
|
+
* // Parse another network rule
|
|
81
|
+
* const ast2 = RuleParser.parse("/ads.js^$important,third-party,domain=example.org|~example.com");
|
|
82
|
+
*
|
|
83
|
+
* // Parse a cosmetic rule
|
|
84
|
+
* const ast2 = RuleParser.parse("example.org##.banner");
|
|
85
|
+
*
|
|
86
|
+
* // Parse another cosmetic rule
|
|
87
|
+
* const ast3 = RuleParser.parse("example.org#?#.banner:-abp-has(.ad)");
|
|
88
|
+
*
|
|
89
|
+
* // Parse a comment rule
|
|
90
|
+
* const ast4 = RuleParser.parse("! Comment");
|
|
91
|
+
*
|
|
92
|
+
* // Parse an empty rule
|
|
93
|
+
* const ast5 = RuleParser.parse("");
|
|
94
|
+
*
|
|
95
|
+
* // Parse a comment rule (with metadata)
|
|
96
|
+
* const ast6 = RuleParser.parse("! Title: Example");
|
|
97
|
+
*
|
|
98
|
+
* // Parse a pre-processor rule
|
|
99
|
+
* const ast7 = RuleParser.parse("!#if (adguard)");
|
|
100
|
+
* ```
|
|
101
|
+
*/
|
|
102
|
+
static parse(raw, options = defaultParserOptions, baseOffset = 0) {
|
|
103
|
+
try {
|
|
104
|
+
// Empty lines / rules (handle it just for convenience)
|
|
105
|
+
if (raw.trim().length === 0) {
|
|
106
|
+
const result = {
|
|
107
|
+
type: 'EmptyRule',
|
|
108
|
+
category: RuleCategory.Empty,
|
|
109
|
+
syntax: AdblockSyntax.Common,
|
|
110
|
+
};
|
|
111
|
+
if (options.includeRaws) {
|
|
112
|
+
result.raws = {
|
|
113
|
+
text: raw,
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
if (options.isLocIncluded) {
|
|
117
|
+
result.start = baseOffset;
|
|
118
|
+
result.end = baseOffset + raw.length;
|
|
119
|
+
}
|
|
120
|
+
return result;
|
|
121
|
+
}
|
|
122
|
+
// Try to parse the rule with all sub-parsers. If a rule doesn't match
|
|
123
|
+
// the pattern of a parser, then it will return `null`. For example, a
|
|
124
|
+
// network rule will not match the pattern of a comment rule, since it
|
|
125
|
+
// doesn't start with comment marker. But if the rule matches the
|
|
126
|
+
// pattern of a parser, then it will return the AST of the rule, or
|
|
127
|
+
// throw an error if the rule is syntactically invalid.
|
|
128
|
+
if (options.ignoreComments) {
|
|
129
|
+
if (CommentParser.isCommentRule(raw)) {
|
|
130
|
+
const result = {
|
|
131
|
+
type: 'EmptyRule',
|
|
132
|
+
category: RuleCategory.Empty,
|
|
133
|
+
syntax: AdblockSyntax.Common,
|
|
134
|
+
};
|
|
135
|
+
if (options.includeRaws) {
|
|
136
|
+
result.raws = {
|
|
137
|
+
text: raw,
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
if (options.isLocIncluded) {
|
|
141
|
+
result.start = baseOffset;
|
|
142
|
+
result.end = baseOffset + raw.length;
|
|
143
|
+
}
|
|
144
|
+
return result;
|
|
145
|
+
}
|
|
146
|
+
return CosmeticRuleParser.parse(raw, options, baseOffset)
|
|
147
|
+
|| RuleParser.parseHostOrNetworkRule(raw, options, baseOffset);
|
|
148
|
+
}
|
|
149
|
+
return CommentParser.parse(raw, options, baseOffset)
|
|
150
|
+
|| CosmeticRuleParser.parse(raw, options, baseOffset)
|
|
151
|
+
|| RuleParser.parseHostOrNetworkRule(raw, options, baseOffset);
|
|
152
|
+
}
|
|
153
|
+
catch (error) {
|
|
154
|
+
// If tolerant mode is disabled or the error is not known, then simply
|
|
155
|
+
// re-throw the error
|
|
156
|
+
if (!options.tolerant || !(error instanceof Error)) {
|
|
157
|
+
throw error;
|
|
158
|
+
}
|
|
159
|
+
const errorNode = {
|
|
160
|
+
type: 'InvalidRuleError',
|
|
161
|
+
name: error.name,
|
|
162
|
+
message: error.message,
|
|
163
|
+
};
|
|
164
|
+
// If the error is an AdblockSyntaxError, then we can add the
|
|
165
|
+
// location of the error to the result
|
|
166
|
+
if (error instanceof AdblockSyntaxError) {
|
|
167
|
+
errorNode.start = error.start;
|
|
168
|
+
errorNode.end = error.end;
|
|
169
|
+
}
|
|
170
|
+
// Otherwise, return an invalid rule (tolerant mode)
|
|
171
|
+
const result = {
|
|
172
|
+
type: 'InvalidRule',
|
|
173
|
+
category: RuleCategory.Invalid,
|
|
174
|
+
syntax: AdblockSyntax.Common,
|
|
175
|
+
raw,
|
|
176
|
+
error: errorNode,
|
|
177
|
+
};
|
|
178
|
+
if (options.includeRaws) {
|
|
179
|
+
result.raws = {
|
|
180
|
+
text: raw,
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
if (options.isLocIncluded) {
|
|
184
|
+
result.start = baseOffset;
|
|
185
|
+
result.end = baseOffset + raw.length;
|
|
186
|
+
}
|
|
187
|
+
return result;
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
export { RuleParser };
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* AGTree v3.0.0-alpha.2 (build date: Tue, 17 Dec 2024 16:50:04 GMT)
|
|
3
|
+
* (c) 2024 Adguard Software Ltd.
|
|
4
|
+
* Released under the MIT license
|
|
5
|
+
* https://github.com/AdguardTeam/tsurlfilter/tree/master/packages/agtree#readme
|
|
6
|
+
*/
|
|
7
|
+
import { NotImplementedError } from '../errors/not-implemented-error.js';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* @file Base serializer class.
|
|
11
|
+
*/
|
|
12
|
+
/**
|
|
13
|
+
* Base class for serializers. Each serializer should extend this class.
|
|
14
|
+
*/
|
|
15
|
+
class BaseSerializer {
|
|
16
|
+
/**
|
|
17
|
+
* Serializes the AST node to a byte buffer.
|
|
18
|
+
*
|
|
19
|
+
* @param node AST node to serialize.
|
|
20
|
+
* @param buffer Output byte buffer to write to.
|
|
21
|
+
* @param args Additional, parser-specific arguments, if needed.
|
|
22
|
+
*/
|
|
23
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
24
|
+
static serialize(node, buffer, ...args) {
|
|
25
|
+
throw new NotImplementedError();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export { BaseSerializer };
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* AGTree v3.0.0-alpha.2 (build date: Tue, 17 Dec 2024 16:50:04 GMT)
|
|
3
|
+
* (c) 2024 Adguard Software Ltd.
|
|
4
|
+
* Released under the MIT license
|
|
5
|
+
* https://github.com/AdguardTeam/tsurlfilter/tree/master/packages/agtree#readme
|
|
6
|
+
*/
|
|
7
|
+
import { UINT8_MAX, NULL } from '../../utils/constants.js';
|
|
8
|
+
import { AgentSerializer } from './agent-serializer.js';
|
|
9
|
+
import { isUndefined } from '../../utils/type-guards.js';
|
|
10
|
+
import { BaseSerializer } from '../base-serializer.js';
|
|
11
|
+
import { AgentCommentMarshallingMap } from '../../marshalling-utils/comment/agent-comment-common.js';
|
|
12
|
+
import { BinaryTypeMarshallingMap } from '../../marshalling-utils/misc/binary-type-common.js';
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* `AgentCommentSerializer` is responsible for serializing an Adblock agent comments.
|
|
16
|
+
* Adblock agent comment marks that the filter list is supposed to
|
|
17
|
+
* be used by the specified ad blockers.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* - ```adblock
|
|
21
|
+
* [AdGuard]
|
|
22
|
+
* ```
|
|
23
|
+
* - ```adblock
|
|
24
|
+
* [Adblock Plus 2.0]
|
|
25
|
+
* ```
|
|
26
|
+
* - ```adblock
|
|
27
|
+
* [uBlock Origin]
|
|
28
|
+
* ```
|
|
29
|
+
* - ```adblock
|
|
30
|
+
* [uBlock Origin 1.45.3]
|
|
31
|
+
* ```
|
|
32
|
+
* - ```adblock
|
|
33
|
+
* [Adblock Plus 2.0; AdGuard]
|
|
34
|
+
* ```
|
|
35
|
+
*/
|
|
36
|
+
class AgentCommentSerializer extends BaseSerializer {
|
|
37
|
+
/**
|
|
38
|
+
* Serializes an adblock agent list node to binary format.
|
|
39
|
+
*
|
|
40
|
+
* @param node Node to serialize.
|
|
41
|
+
* @param buffer ByteBuffer for writing binary data.
|
|
42
|
+
*/
|
|
43
|
+
// TODO: add support for raws, if ever needed
|
|
44
|
+
static serialize(node, buffer) {
|
|
45
|
+
buffer.writeUint8(BinaryTypeMarshallingMap.AgentRuleNode);
|
|
46
|
+
const count = node.children.length;
|
|
47
|
+
// If there are no children, we do not write any data related to them, to avoid using unnecessary storage,
|
|
48
|
+
// but children is a required field, so during deserialization we should initialize it as an empty array,
|
|
49
|
+
// if there are no children in the binary data.
|
|
50
|
+
if (count) {
|
|
51
|
+
buffer.writeUint8(AgentCommentMarshallingMap.Children);
|
|
52
|
+
// note: we store the count, because re-construction of the array is faster if we know the length
|
|
53
|
+
// 8 bits is more than enough here
|
|
54
|
+
if (count > UINT8_MAX) {
|
|
55
|
+
throw new Error(`Too many children: ${count}, the limit is ${UINT8_MAX}`);
|
|
56
|
+
}
|
|
57
|
+
buffer.writeUint8(count);
|
|
58
|
+
for (let i = 0; i < count; i += 1) {
|
|
59
|
+
AgentSerializer.serialize(node.children[i], buffer);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
if (!isUndefined(node.start)) {
|
|
63
|
+
buffer.writeUint8(AgentCommentMarshallingMap.Start);
|
|
64
|
+
buffer.writeUint32(node.start);
|
|
65
|
+
}
|
|
66
|
+
if (!isUndefined(node.end)) {
|
|
67
|
+
buffer.writeUint8(AgentCommentMarshallingMap.End);
|
|
68
|
+
buffer.writeUint32(node.end);
|
|
69
|
+
}
|
|
70
|
+
buffer.writeUint8(NULL);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
export { AgentCommentSerializer };
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* AGTree v3.0.0-alpha.2 (build date: Tue, 17 Dec 2024 16:50:04 GMT)
|
|
3
|
+
* (c) 2024 Adguard Software Ltd.
|
|
4
|
+
* Released under the MIT license
|
|
5
|
+
* https://github.com/AdguardTeam/tsurlfilter/tree/master/packages/agtree#readme
|
|
6
|
+
*/
|
|
7
|
+
import { NULL } from '../../utils/constants.js';
|
|
8
|
+
import { ValueSerializer } from '../misc/value-serializer.js';
|
|
9
|
+
import { isUndefined } from '../../utils/type-guards.js';
|
|
10
|
+
import { BaseSerializer } from '../base-serializer.js';
|
|
11
|
+
import { AgentNodeMarshallingMap, FREQUENT_AGENTS_DESERIALIZATION_MAP } from '../../marshalling-utils/comment/agent-common.js';
|
|
12
|
+
import { BinaryTypeMarshallingMap } from '../../marshalling-utils/misc/binary-type-common.js';
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Value map for binary serialization. This helps to reduce the size of the serialized data,
|
|
16
|
+
* as it allows us to use a single byte to represent frequently used values.
|
|
17
|
+
*
|
|
18
|
+
* ! IMPORTANT: If you change values here, please update the {@link BINARY_SCHEMA_VERSION}!
|
|
19
|
+
*
|
|
20
|
+
* @note Only 256 values can be represented this way.
|
|
21
|
+
*/
|
|
22
|
+
let frequentAgentsSerializationMap;
|
|
23
|
+
const getFrequentAgentsSerializationMap = () => {
|
|
24
|
+
if (!frequentAgentsSerializationMap) {
|
|
25
|
+
frequentAgentsSerializationMap = new Map(Array.from(FREQUENT_AGENTS_DESERIALIZATION_MAP).map(([key, value]) => [value.toLowerCase(), key]));
|
|
26
|
+
}
|
|
27
|
+
return frequentAgentsSerializationMap;
|
|
28
|
+
};
|
|
29
|
+
/**
|
|
30
|
+
* `AgentSerializer` is responsible for serializing single adblock agent elements into a binary format.
|
|
31
|
+
*/
|
|
32
|
+
class AgentSerializer extends BaseSerializer {
|
|
33
|
+
/**
|
|
34
|
+
* Serializes an agent node to binary format.
|
|
35
|
+
*
|
|
36
|
+
* @param node Node to serialize.
|
|
37
|
+
* @param buffer ByteBuffer for writing binary data.
|
|
38
|
+
*/
|
|
39
|
+
static serialize(node, buffer) {
|
|
40
|
+
buffer.writeUint8(BinaryTypeMarshallingMap.AgentNode);
|
|
41
|
+
buffer.writeUint8(AgentNodeMarshallingMap.Adblock);
|
|
42
|
+
ValueSerializer.serialize(node.adblock, buffer, getFrequentAgentsSerializationMap(), true);
|
|
43
|
+
if (!isUndefined(node.version)) {
|
|
44
|
+
buffer.writeUint8(AgentNodeMarshallingMap.Version);
|
|
45
|
+
ValueSerializer.serialize(node.version, buffer);
|
|
46
|
+
}
|
|
47
|
+
if (!isUndefined(node.start)) {
|
|
48
|
+
buffer.writeUint8(AgentNodeMarshallingMap.Start);
|
|
49
|
+
buffer.writeUint32(node.start);
|
|
50
|
+
}
|
|
51
|
+
if (!isUndefined(node.end)) {
|
|
52
|
+
buffer.writeUint8(AgentNodeMarshallingMap.End);
|
|
53
|
+
buffer.writeUint32(node.end);
|
|
54
|
+
}
|
|
55
|
+
buffer.writeUint8(NULL);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
export { AgentSerializer };
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* AGTree v3.0.0-alpha.2 (build date: Tue, 17 Dec 2024 16:50:04 GMT)
|
|
3
|
+
* (c) 2024 Adguard Software Ltd.
|
|
4
|
+
* Released under the MIT license
|
|
5
|
+
* https://github.com/AdguardTeam/tsurlfilter/tree/master/packages/agtree#readme
|
|
6
|
+
*/
|
|
7
|
+
import { AgentCommentSerializer } from './agent-comment-serializer.js';
|
|
8
|
+
import { CommentRuleType } from '../../nodes/index.js';
|
|
9
|
+
import { ConfigCommentSerializer } from './config-comment-serializer.js';
|
|
10
|
+
import { HintCommentSerializer } from './hint-comment-serializer.js';
|
|
11
|
+
import { MetadataCommentSerializer } from './metadata-comment-serializer.js';
|
|
12
|
+
import { PreProcessorCommentSerializer } from './pre-processor-comment-serializer.js';
|
|
13
|
+
import { SimpleCommentSerializer } from './simple-comment-serializer.js';
|
|
14
|
+
import { BaseSerializer } from '../base-serializer.js';
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* `CommentRuleSerializer` is responsible for serializing any comment-like adblock rules.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* Example rules:
|
|
21
|
+
* - Adblock agent rules:
|
|
22
|
+
* - ```adblock
|
|
23
|
+
* [AdGuard]
|
|
24
|
+
* ```
|
|
25
|
+
* - ```adblock
|
|
26
|
+
* [Adblock Plus 2.0]
|
|
27
|
+
* ```
|
|
28
|
+
* - etc.
|
|
29
|
+
* - AdGuard hint rules:
|
|
30
|
+
* - ```adblock
|
|
31
|
+
* !+ NOT_OPTIMIZED
|
|
32
|
+
* ```
|
|
33
|
+
* - ```adblock
|
|
34
|
+
* !+ NOT_OPTIMIZED PLATFORM(windows)
|
|
35
|
+
* ```
|
|
36
|
+
* - etc.
|
|
37
|
+
* - Pre-processor rules:
|
|
38
|
+
* - ```adblock
|
|
39
|
+
* !#if (adguard)
|
|
40
|
+
* ```
|
|
41
|
+
* - ```adblock
|
|
42
|
+
* !#endif
|
|
43
|
+
* ```
|
|
44
|
+
* - etc.
|
|
45
|
+
* - Metadata rules:
|
|
46
|
+
* - ```adblock
|
|
47
|
+
* ! Title: My List
|
|
48
|
+
* ```
|
|
49
|
+
* - ```adblock
|
|
50
|
+
* ! Version: 2.0.150
|
|
51
|
+
* ```
|
|
52
|
+
* - etc.
|
|
53
|
+
* - AGLint inline config rules:
|
|
54
|
+
* - ```adblock
|
|
55
|
+
* ! aglint-enable some-rule
|
|
56
|
+
* ```
|
|
57
|
+
* - ```adblock
|
|
58
|
+
* ! aglint-disable some-rule
|
|
59
|
+
* ```
|
|
60
|
+
* - etc.
|
|
61
|
+
* - Simple comments:
|
|
62
|
+
* - Regular version:
|
|
63
|
+
* ```adblock
|
|
64
|
+
* ! This is just a comment
|
|
65
|
+
* ```
|
|
66
|
+
* - uBlock Origin / "hostlist" version:
|
|
67
|
+
* ```adblock
|
|
68
|
+
* # This is just a comment
|
|
69
|
+
* ```
|
|
70
|
+
* - etc.
|
|
71
|
+
*/
|
|
72
|
+
class CommentRuleSerializer extends BaseSerializer {
|
|
73
|
+
/**
|
|
74
|
+
* Serializes a comment rule node to binary format.
|
|
75
|
+
*
|
|
76
|
+
* @param node Node to serialize.
|
|
77
|
+
* @param buffer ByteBuffer for writing binary data.
|
|
78
|
+
*/
|
|
79
|
+
static serialize(node, buffer) {
|
|
80
|
+
switch (node.type) {
|
|
81
|
+
case CommentRuleType.AgentCommentRule:
|
|
82
|
+
AgentCommentSerializer.serialize(node, buffer);
|
|
83
|
+
return;
|
|
84
|
+
case CommentRuleType.HintCommentRule:
|
|
85
|
+
HintCommentSerializer.serialize(node, buffer);
|
|
86
|
+
return;
|
|
87
|
+
case CommentRuleType.PreProcessorCommentRule:
|
|
88
|
+
PreProcessorCommentSerializer.serialize(node, buffer);
|
|
89
|
+
return;
|
|
90
|
+
case CommentRuleType.MetadataCommentRule:
|
|
91
|
+
MetadataCommentSerializer.serialize(node, buffer);
|
|
92
|
+
return;
|
|
93
|
+
case CommentRuleType.ConfigCommentRule:
|
|
94
|
+
ConfigCommentSerializer.serialize(node, buffer);
|
|
95
|
+
return;
|
|
96
|
+
case CommentRuleType.CommentRule:
|
|
97
|
+
SimpleCommentSerializer.serialize(node, buffer);
|
|
98
|
+
break;
|
|
99
|
+
default:
|
|
100
|
+
throw new Error('Unknown comment rule type');
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
export { CommentRuleSerializer };
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* AGTree v3.0.0-alpha.2 (build date: Tue, 17 Dec 2024 16:50:04 GMT)
|
|
3
|
+
* (c) 2024 Adguard Software Ltd.
|
|
4
|
+
* Released under the MIT license
|
|
5
|
+
* https://github.com/AdguardTeam/tsurlfilter/tree/master/packages/agtree#readme
|
|
6
|
+
*/
|
|
7
|
+
import { NULL } from '../../utils/constants.js';
|
|
8
|
+
import { ParameterListSerializer } from '../misc/parameter-list-serializer.js';
|
|
9
|
+
import { ValueSerializer } from '../misc/value-serializer.js';
|
|
10
|
+
import { isUndefined } from '../../utils/type-guards.js';
|
|
11
|
+
import { BaseSerializer } from '../base-serializer.js';
|
|
12
|
+
import { ConfigNodeMarshallingMap, ConfigCommentRuleMarshallingMap, FREQUENT_COMMANDS_SERIALIZATION_MAP } from '../../marshalling-utils/comment/config-comment-common.js';
|
|
13
|
+
import { BinaryTypeMarshallingMap } from '../../marshalling-utils/misc/binary-type-common.js';
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* `ConfigCommentSerializer` is responsible for serializing inline AGLint configuration rules into a binary format.
|
|
17
|
+
* Generally, the idea is inspired by ESLint inline configuration comments.
|
|
18
|
+
*
|
|
19
|
+
* @see {@link https://eslint.org/docs/latest/user-guide/configuring/rules#using-configuration-comments}
|
|
20
|
+
*/
|
|
21
|
+
class ConfigCommentSerializer extends BaseSerializer {
|
|
22
|
+
/**
|
|
23
|
+
* Serializes a config node to binary format.
|
|
24
|
+
*
|
|
25
|
+
* @param node Node to serialize.
|
|
26
|
+
* @param buffer ByteBuffer for writing binary data.
|
|
27
|
+
*/
|
|
28
|
+
static serializeConfigNode(node, buffer) {
|
|
29
|
+
buffer.writeUint8(BinaryTypeMarshallingMap.ConfigNode);
|
|
30
|
+
buffer.writeUint8(ConfigNodeMarshallingMap.Value);
|
|
31
|
+
// note: we don't support serializing generic objects, only AGTree nodes
|
|
32
|
+
// this is a very special case, so we just stringify the configuration object
|
|
33
|
+
buffer.writeString(JSON.stringify(node.value));
|
|
34
|
+
if (!isUndefined(node.start)) {
|
|
35
|
+
buffer.writeUint8(ConfigNodeMarshallingMap.Start);
|
|
36
|
+
buffer.writeUint32(node.start);
|
|
37
|
+
}
|
|
38
|
+
if (!isUndefined(node.end)) {
|
|
39
|
+
buffer.writeUint8(ConfigNodeMarshallingMap.End);
|
|
40
|
+
buffer.writeUint32(node.end);
|
|
41
|
+
}
|
|
42
|
+
buffer.writeUint8(NULL);
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Serializes a metadata comment node to binary format.
|
|
46
|
+
*
|
|
47
|
+
* @param node Node to serialize.
|
|
48
|
+
* @param buffer ByteBuffer for writing binary data.
|
|
49
|
+
*/
|
|
50
|
+
// TODO: add support for raws, if ever needed
|
|
51
|
+
static serialize(node, buffer) {
|
|
52
|
+
buffer.writeUint8(BinaryTypeMarshallingMap.ConfigCommentRuleNode);
|
|
53
|
+
buffer.writeUint8(ConfigCommentRuleMarshallingMap.Marker);
|
|
54
|
+
ValueSerializer.serialize(node.marker, buffer);
|
|
55
|
+
buffer.writeUint8(ConfigCommentRuleMarshallingMap.Command);
|
|
56
|
+
ValueSerializer.serialize(node.command, buffer, FREQUENT_COMMANDS_SERIALIZATION_MAP, true);
|
|
57
|
+
if (!isUndefined(node.params)) {
|
|
58
|
+
buffer.writeUint8(ConfigCommentRuleMarshallingMap.Params);
|
|
59
|
+
if (node.params.type === 'ParameterList') {
|
|
60
|
+
ParameterListSerializer.serialize(node.params, buffer);
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
ConfigCommentSerializer.serializeConfigNode(node.params, buffer);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
if (!isUndefined(node.comment)) {
|
|
67
|
+
buffer.writeUint8(ConfigCommentRuleMarshallingMap.Comment);
|
|
68
|
+
ValueSerializer.serialize(node.comment, buffer);
|
|
69
|
+
}
|
|
70
|
+
if (!isUndefined(node.start)) {
|
|
71
|
+
buffer.writeUint8(ConfigCommentRuleMarshallingMap.Start);
|
|
72
|
+
buffer.writeUint32(node.start);
|
|
73
|
+
}
|
|
74
|
+
if (!isUndefined(node.end)) {
|
|
75
|
+
buffer.writeUint8(ConfigCommentRuleMarshallingMap.End);
|
|
76
|
+
buffer.writeUint32(node.end);
|
|
77
|
+
}
|
|
78
|
+
buffer.writeUint8(NULL);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
export { ConfigCommentSerializer };
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* AGTree v3.0.0-alpha.2 (build date: Tue, 17 Dec 2024 16:50:04 GMT)
|
|
3
|
+
* (c) 2024 Adguard Software Ltd.
|
|
4
|
+
* Released under the MIT license
|
|
5
|
+
* https://github.com/AdguardTeam/tsurlfilter/tree/master/packages/agtree#readme
|
|
6
|
+
*/
|
|
7
|
+
import { NULL } from '../../utils/constants.js';
|
|
8
|
+
import { HintSerializer } from './hint-serializer.js';
|
|
9
|
+
import { AdblockSyntax } from '../../utils/adblockers.js';
|
|
10
|
+
import { isUndefined } from '../../utils/type-guards.js';
|
|
11
|
+
import { BaseSerializer } from '../base-serializer.js';
|
|
12
|
+
import { HintCommentMarshallingMap } from '../../marshalling-utils/comment/hint-comment-common.js';
|
|
13
|
+
import { BinaryTypeMarshallingMap } from '../../marshalling-utils/misc/binary-type-common.js';
|
|
14
|
+
import { getSyntaxSerializationMap } from '../../marshalling-utils/syntax-serialization-map.js';
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* `HintCommentSerializer` is responsible for serializing AdGuard hint rules.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* The following hint rule
|
|
21
|
+
* ```adblock
|
|
22
|
+
* !+ NOT_OPTIMIZED PLATFORM(windows)
|
|
23
|
+
* ```
|
|
24
|
+
* contains two hints: `NOT_OPTIMIZED` and `PLATFORM`.
|
|
25
|
+
* @see {@link https://kb.adguard.com/en/general/how-to-create-your-own-ad-filters#hints}
|
|
26
|
+
*/
|
|
27
|
+
class HintCommentSerializer extends BaseSerializer {
|
|
28
|
+
/**
|
|
29
|
+
* Serializes a hint rule node to binary format.
|
|
30
|
+
*
|
|
31
|
+
* @param node Node to serialize.
|
|
32
|
+
* @param buffer ByteBuffer for writing binary data.
|
|
33
|
+
*/
|
|
34
|
+
// TODO: add support for raws, if ever needed
|
|
35
|
+
static serialize(node, buffer) {
|
|
36
|
+
buffer.writeUint8(BinaryTypeMarshallingMap.HintRuleNode);
|
|
37
|
+
if (node.syntax === AdblockSyntax.Adg) {
|
|
38
|
+
buffer.writeUint8(HintCommentMarshallingMap.Syntax);
|
|
39
|
+
buffer.writeUint8(getSyntaxSerializationMap().get(AdblockSyntax.Adg) ?? 0);
|
|
40
|
+
}
|
|
41
|
+
const count = node.children.length;
|
|
42
|
+
// If there are no children, we do not write any data related to them, to avoid using unnecessary storage,
|
|
43
|
+
// but children is a required field, so during deserialization we should initialize it as an empty array,
|
|
44
|
+
// if there are no children in the binary data.
|
|
45
|
+
if (count) {
|
|
46
|
+
buffer.writeUint8(HintCommentMarshallingMap.Children);
|
|
47
|
+
// note: we store the count, because re-construction of the array is faster if we know the length
|
|
48
|
+
buffer.writeUint8(count);
|
|
49
|
+
for (let i = 0; i < count; i += 1) {
|
|
50
|
+
HintSerializer.serialize(node.children[i], buffer);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
if (!isUndefined(node.start)) {
|
|
54
|
+
buffer.writeUint8(HintCommentMarshallingMap.Start);
|
|
55
|
+
buffer.writeUint32(node.start);
|
|
56
|
+
}
|
|
57
|
+
if (!isUndefined(node.end)) {
|
|
58
|
+
buffer.writeUint8(HintCommentMarshallingMap.End);
|
|
59
|
+
buffer.writeUint32(node.end);
|
|
60
|
+
}
|
|
61
|
+
buffer.writeUint8(NULL);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
export { HintCommentSerializer };
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* AGTree v3.0.0-alpha.2 (build date: Tue, 17 Dec 2024 16:50:04 GMT)
|
|
3
|
+
* (c) 2024 Adguard Software Ltd.
|
|
4
|
+
* Released under the MIT license
|
|
5
|
+
* https://github.com/AdguardTeam/tsurlfilter/tree/master/packages/agtree#readme
|
|
6
|
+
*/
|
|
7
|
+
import { NULL } from '../../utils/constants.js';
|
|
8
|
+
import { ParameterListSerializer } from '../misc/parameter-list-serializer.js';
|
|
9
|
+
import { ValueSerializer } from '../misc/value-serializer.js';
|
|
10
|
+
import { isUndefined } from '../../utils/type-guards.js';
|
|
11
|
+
import { BaseSerializer } from '../base-serializer.js';
|
|
12
|
+
import { HintNodeMarshallingMap, FREQUENT_HINTS_SERIALIZATION_MAP, FREQUENT_PLATFORMS_SERIALIZATION_MAP } from '../../marshalling-utils/comment/hint-common.js';
|
|
13
|
+
import { BinaryTypeMarshallingMap } from '../../marshalling-utils/misc/binary-type-common.js';
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* `HintSerializer` is responsible for serializing AdGuard hints.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* If the hint rule is
|
|
20
|
+
* ```adblock
|
|
21
|
+
* !+ NOT_OPTIMIZED PLATFORM(windows)
|
|
22
|
+
* ```
|
|
23
|
+
* then the hints are `NOT_OPTIMIZED` and `PLATFORM(windows)`, and this
|
|
24
|
+
* class is responsible for parsing them. The rule itself is parsed by
|
|
25
|
+
* the `HintRuleParser`, which uses this class to parse single hints.
|
|
26
|
+
*/
|
|
27
|
+
class HintSerializer extends BaseSerializer {
|
|
28
|
+
/**
|
|
29
|
+
* Serializes a hint node to binary format.
|
|
30
|
+
*
|
|
31
|
+
* @param node Node to serialize.
|
|
32
|
+
* @param buffer ByteBuffer for writing binary data.
|
|
33
|
+
*/
|
|
34
|
+
static serialize(node, buffer) {
|
|
35
|
+
buffer.writeUint8(BinaryTypeMarshallingMap.HintNode);
|
|
36
|
+
buffer.writeUint8(HintNodeMarshallingMap.Name);
|
|
37
|
+
ValueSerializer.serialize(node.name, buffer, FREQUENT_HINTS_SERIALIZATION_MAP);
|
|
38
|
+
if (!isUndefined(node.params)) {
|
|
39
|
+
buffer.writeUint8(HintNodeMarshallingMap.Params);
|
|
40
|
+
ParameterListSerializer.serialize(node.params, buffer, FREQUENT_PLATFORMS_SERIALIZATION_MAP);
|
|
41
|
+
}
|
|
42
|
+
if (!isUndefined(node.start)) {
|
|
43
|
+
buffer.writeUint8(HintNodeMarshallingMap.Start);
|
|
44
|
+
buffer.writeUint32(node.start);
|
|
45
|
+
}
|
|
46
|
+
if (!isUndefined(node.end)) {
|
|
47
|
+
buffer.writeUint8(HintNodeMarshallingMap.End);
|
|
48
|
+
buffer.writeUint32(node.end);
|
|
49
|
+
}
|
|
50
|
+
buffer.writeUint8(NULL);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export { HintSerializer };
|