UNPKG

2.57 kBJavaScriptView Raw
1"use strict";
2var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3 if (k2 === undefined) k2 = k;
4 Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5}) : (function(o, m, k, k2) {
6 if (k2 === undefined) k2 = k;
7 o[k2] = m[k];
8}));
9var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10 Object.defineProperty(o, "default", { enumerable: true, value: v });
11}) : function(o, v) {
12 o["default"] = v;
13});
14var __importStar = (this && this.__importStar) || function (mod) {
15 if (mod && mod.__esModule) return mod;
16 var result = {};
17 if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18 __setModuleDefault(result, mod);
19 return result;
20};
21Object.defineProperty(exports, "__esModule", { value: true });
22exports.parseTrie = void 0;
23const characters = __importStar(require("./characters"));
24const nodes_1 = require("./nodes");
25const parseTrie = (serializedTrie) => {
26 const rootNode = (0, nodes_1.createRootNode)();
27 let domain = "";
28 let parentNode = rootNode;
29 // Type assertion necessary here due to a TypeScript unsoundness
30 // https://github.com/microsoft/TypeScript/issues/9998#issuecomment-235963457
31 let node = rootNode;
32 const addDomain = () => {
33 node = (0, nodes_1.createOrGetChild)(parentNode, domain);
34 domain = "";
35 };
36 for (let i = 0; i < serializedTrie.length; i++) {
37 const char = serializedTrie.charAt(i);
38 switch (char) {
39 case characters.SAME: {
40 addDomain();
41 continue;
42 }
43 case characters.DOWN: {
44 addDomain();
45 parentNode = node;
46 continue;
47 }
48 case characters.RESET: {
49 addDomain();
50 parentNode = rootNode;
51 continue;
52 }
53 case characters.UP: {
54 if (parentNode.type === nodes_1.NODE_TYPE_ROOT) {
55 throw new Error(`Error in serialized trie at position ${i}: Cannot go up, current parent node is already root`);
56 }
57 addDomain();
58 parentNode = parentNode.parent;
59 continue;
60 }
61 }
62 domain += char;
63 }
64 if (domain !== "") {
65 addDomain();
66 }
67 return rootNode;
68};
69exports.parseTrie = parseTrie;
70//# sourceMappingURL=parse-trie.js.map
\No newline at end of file