UNPKG

8.32 kBJavaScriptView Raw
1"use strict";
2var __extends = (this && this.__extends) || (function () {
3 var extendStatics = function (d, b) {
4 extendStatics = Object.setPrototypeOf ||
5 ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6 function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7 return extendStatics(d, b);
8 };
9 return function (d, b) {
10 if (typeof b !== "function" && b !== null)
11 throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12 extendStatics(d, b);
13 function __() { this.constructor = d; }
14 d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15 };
16})();
17var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
18 function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
19 return new (P || (P = Promise))(function (resolve, reject) {
20 function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
21 function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
22 function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
23 step((generator = generator.apply(thisArg, _arguments || [])).next());
24 });
25};
26var __generator = (this && this.__generator) || function (thisArg, body) {
27 var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
28 return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
29 function verb(n) { return function (v) { return step([n, v]); }; }
30 function step(op) {
31 if (f) throw new TypeError("Generator is already executing.");
32 while (_) try {
33 if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
34 if (y = 0, t) op = [op[0] & 2, t.value];
35 switch (op[0]) {
36 case 0: case 1: t = op; break;
37 case 4: _.label++; return { value: op[1], done: false };
38 case 5: _.label++; y = op[1]; op = [0]; continue;
39 case 7: op = _.ops.pop(); _.trys.pop(); continue;
40 default:
41 if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
42 if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
43 if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
44 if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
45 if (t[2]) _.ops.pop();
46 _.trys.pop(); continue;
47 }
48 op = body.call(thisArg, _);
49 } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
50 if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
51 }
52};
53var __read = (this && this.__read) || function (o, n) {
54 var m = typeof Symbol === "function" && o[Symbol.iterator];
55 if (!m) return o;
56 var i = m.call(o), r, ar = [], e;
57 try {
58 while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
59 }
60 catch (error) { e = { error: error }; }
61 finally {
62 try {
63 if (r && !r.done && (m = i["return"])) m.call(i);
64 }
65 finally { if (e) throw e.error; }
66 }
67 return ar;
68};
69var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
70 if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
71 if (ar || !(i in from)) {
72 if (!ar) ar = Array.prototype.slice.call(from, 0, i);
73 ar[i] = from[i];
74 }
75 }
76 return to.concat(ar || Array.prototype.slice.call(from));
77};
78Object.defineProperty(exports, "__esModule", { value: true });
79exports.CheckpointTrie = void 0;
80var baseTrie_1 = require("./baseTrie");
81var checkpointDb_1 = require("./checkpointDb");
82/**
83 * Adds checkpointing to the {@link BaseTrie}
84 */
85var CheckpointTrie = /** @class */ (function (_super) {
86 __extends(CheckpointTrie, _super);
87 function CheckpointTrie() {
88 var args = [];
89 for (var _i = 0; _i < arguments.length; _i++) {
90 args[_i] = arguments[_i];
91 }
92 var _this = _super.apply(this, __spreadArray([], __read(args), false)) || this;
93 _this.db = new (checkpointDb_1.CheckpointDB.bind.apply(checkpointDb_1.CheckpointDB, __spreadArray([void 0], __read(args), false)))();
94 return _this;
95 }
96 Object.defineProperty(CheckpointTrie.prototype, "isCheckpoint", {
97 /**
98 * Is the trie during a checkpoint phase?
99 */
100 get: function () {
101 return this.db.isCheckpoint;
102 },
103 enumerable: false,
104 configurable: true
105 });
106 /**
107 * Creates a checkpoint that can later be reverted to or committed.
108 * After this is called, all changes can be reverted until `commit` is called.
109 */
110 CheckpointTrie.prototype.checkpoint = function () {
111 this.db.checkpoint(this.root);
112 };
113 /**
114 * Commits a checkpoint to disk, if current checkpoint is not nested.
115 * If nested, only sets the parent checkpoint as current checkpoint.
116 * @throws If not during a checkpoint phase
117 */
118 CheckpointTrie.prototype.commit = function () {
119 return __awaiter(this, void 0, void 0, function () {
120 return __generator(this, function (_a) {
121 switch (_a.label) {
122 case 0:
123 if (!this.isCheckpoint) {
124 throw new Error('trying to commit when not checkpointed');
125 }
126 return [4 /*yield*/, this.lock.wait()];
127 case 1:
128 _a.sent();
129 return [4 /*yield*/, this.db.commit()];
130 case 2:
131 _a.sent();
132 this.lock.signal();
133 return [2 /*return*/];
134 }
135 });
136 });
137 };
138 /**
139 * Reverts the trie to the state it was at when `checkpoint` was first called.
140 * If during a nested checkpoint, sets root to most recent checkpoint, and sets
141 * parent checkpoint as current.
142 */
143 CheckpointTrie.prototype.revert = function () {
144 return __awaiter(this, void 0, void 0, function () {
145 var _a;
146 return __generator(this, function (_b) {
147 switch (_b.label) {
148 case 0:
149 if (!this.isCheckpoint) {
150 throw new Error('trying to revert when not checkpointed');
151 }
152 return [4 /*yield*/, this.lock.wait()];
153 case 1:
154 _b.sent();
155 _a = this;
156 return [4 /*yield*/, this.db.revert()];
157 case 2:
158 _a.root = _b.sent();
159 this.lock.signal();
160 return [2 /*return*/];
161 }
162 });
163 });
164 };
165 /**
166 * Returns a copy of the underlying trie with the interface of CheckpointTrie.
167 * @param includeCheckpoints - If true and during a checkpoint, the copy will contain the checkpointing metadata and will use the same scratch as underlying db.
168 */
169 CheckpointTrie.prototype.copy = function (includeCheckpoints) {
170 if (includeCheckpoints === void 0) { includeCheckpoints = true; }
171 var db = this.db.copy();
172 var trie = new CheckpointTrie(db._leveldb, this.root);
173 if (includeCheckpoints && this.isCheckpoint) {
174 trie.db.checkpoints = __spreadArray([], __read(this.db.checkpoints), false);
175 }
176 return trie;
177 };
178 return CheckpointTrie;
179}(baseTrie_1.Trie));
180exports.CheckpointTrie = CheckpointTrie;
181//# sourceMappingURL=checkpointTrie.js.map
\No newline at end of file