1 | "use strict";
|
2 | var __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 | }));
|
9 | var __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 | });
|
14 | var __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 | };
|
21 | Object.defineProperty(exports, "__esModule", { value: true });
|
22 | exports.parseTrie = void 0;
|
23 | const characters = __importStar(require("./characters"));
|
24 | const nodes_1 = require("./nodes");
|
25 | const parseTrie = (serializedTrie) => {
|
26 | const rootNode = (0, nodes_1.createRootNode)();
|
27 | let domain = "";
|
28 | let parentNode = rootNode;
|
29 |
|
30 |
|
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 | };
|
69 | exports.parseTrie = parseTrie;
|
70 |
|
\ | No newline at end of file |