From 3142b0f1610397759236a00785a1738cd79da959 Mon Sep 17 00:00:00 2001 From: Kevin Jahns <kevin.jahns@rwth-aachen.de> Date: Sun, 21 Jun 2015 14:55:39 +0200 Subject: [PATCH] added some Operations, a connector, more structure. In particular I put a lot of time into the event handling --- src/Connectors.js | 446 +++++++++++++++++++++++++++++++ src/OperationStore.js | 46 ++++ src/OperationStores/IndexedDB.js | 2 +- src/Operations.js | 116 +++++++- src/Types.js | 25 ++ src/y.js | 5 + y.js | 2 +- y.js.map | 2 +- 8 files changed, 634 insertions(+), 10 deletions(-) create mode 100644 src/Connectors.js create mode 100644 src/Types.js diff --git a/src/Connectors.js b/src/Connectors.js new file mode 100644 index 00000000..96b9905d --- /dev/null +++ b/src/Connectors.js @@ -0,0 +1,446 @@ + + +(function(){ + function WebRTC(webrtc_options){ + if(webrtc_options === undefined){ + throw new Error("webrtc_options must not be undefined!") + } + var room = webrtc_options.room; + + // connect per default to our server + if(webrtc_options.url === undefined){ + webrtc_options.url = "https://yatta.ninja:8888"; + } + + var swr = new SimpleWebRTC(webrtc_options); + this.swr = swr; + var self = this; + + var channel; + + swr.once('connectionReady',function(user_id){ + // SimpleWebRTC (swr) is initialized + swr.joinRoom(room); + + swr.once('joinedRoom', function(){ + // the client joined the specified room + + // initialize the connector with the required parameters. + // You always should specify `role`, `syncMethod`, and `user_id` + self.init({ + role : "slave", + syncMethod : "syncAll", + user_id : user_id + }); + var i; + // notify the connector class about all the users that already + // joined the session + for(i in self.swr.webrtc.peers){ + self.userJoined(self.swr.webrtc.peers[i].id, "slave"); + } + + + swr.on("channelMessage", function(peer, room, message){ + // The client received a message + // Check if the connector is already initialized, + // only then forward the message to the connector class + if(self.is_initialized && message.type === "yjs"){ + self.receiveMessage(peer.id, message.payload); + } + }); + }); + + swr.on("createdPeer", function(peer){ + // a new peer/client joined the session. + // Notify the connector class, if the connector + // is already initialized + if(self.is_initialized){ + // note: Since the WebRTC Connector only supports the SyncAll + // syncmethod, every client is a slave. + self.userJoined(peer.id, "slave"); + } + }); + + swr.on("peerStreamRemoved",function(peer){ + // a client left the session. + // Notify the connector class, if the connector + // is already initialized + if(self.is_initialized){ + self.userLeft(peer.id); + } + }); + }); + } + + // Specify how to send a message to a specific user (by uid) + WebRTC.prototype.send = function(uid, message){ + var self = this; + // we have to make sure that the message is sent under all circumstances + var send = function(){ + // check if the clients still exists + var peer = self.swr.webrtc.getPeers(uid)[0]; + var success; + if(peer){ + // success is true, if the message is successfully sent + success = peer.sendDirectly("simplewebrtc", "yjs", message); + } + if(!success){ + // resend the message if it didn't work + window.setTimeout(send,500); + } + }; + // try to send the message + send(); + }; + + // specify how to broadcast a message to all users + // (it may send the message back to itself). + // The webrtc connecor tries to send it to every single clients directly + WebRTC.prototype.broadcast = function(message){ + this.swr.sendDirectlyToAll("simplewebrtc","yjs",message); + }; + + Y.Connectors.WebRTC = WebRTC; +})() + + +var connectorAdapter = (){ + # + # @params new Connector(options) + # @param options.syncMethod {String} is either "syncAll" or "master-slave". + # @param options.role {String} The role of this client + # (slave or master (only used when syncMethod is master-slave)) + # @param options.perform_send_again {Boolean} Whetehr to whether to resend the HB after some time period. This reduces sync errors, but has some overhead (optional) + # + init: (options)-> + req = (name, choices)=> + if options[name]? + if (not choices?) or choices.some((c)->c is options[name]) + @[name] = options[name] + else + throw new Error "You can set the '"+name+"' option to one of the following choices: "+JSON.encode(choices) + else + throw new Error "You must specify "+name+", when initializing the Connector!" + + req "syncMethod", ["syncAll", "master-slave"] + req "role", ["master", "slave"] + req "user_id" + @on_user_id_set?(@user_id) + + # whether to resend the HB after some time period. This reduces sync errors. + # But this is not necessary in the test-connector + if options.perform_send_again? + @perform_send_again = options.perform_send_again + else + @perform_send_again = true + + # A Master should sync with everyone! TODO: really? - for now its safer this way! + if @role is "master" + @syncMethod = "syncAll" + + # is set to true when this is synced with all other connections + @is_synced = false + # Peerjs Connections: key: conn-id, value: object + @connections = {} + # List of functions that shall process incoming data + @receive_handlers ?= [] + + # whether this instance is bound to any y instance + @connections = {} + @current_sync_target = null + @sent_hb_to_all_users = false + @is_initialized = true + + onUserEvent: (f)-> + @connections_listeners ?= [] + @connections_listeners.push f + + isRoleMaster: -> + @role is "master" + + isRoleSlave: -> + @role is "slave" + + findNewSyncTarget: ()-> + @current_sync_target = null + if @syncMethod is "syncAll" + for user, c of @connections + if not c.is_synced + @performSync user + break + if not @current_sync_target? + @setStateSynced() + null + + userLeft: (user)-> + delete @connections[user] + @findNewSyncTarget() + if @connections_listeners? + for f in @connections_listeners + f { + action: "userLeft" + user: user + } + + + userJoined: (user, role)-> + if not role? + throw new Error "Internal: You must specify the role of the joined user! E.g. userJoined('uid:3939','slave')" + # a user joined the room + @connections[user] ?= {} + @connections[user].is_synced = false + + if (not @is_synced) or @syncMethod is "syncAll" + if @syncMethod is "syncAll" + @performSync user + else if role is "master" + # TODO: What if there are two masters? Prevent sending everything two times! + @performSyncWithMaster user + + if @connections_listeners? + for f in @connections_listeners + f { + action: "userJoined" + user: user + role: role + } + + # + # Execute a function _when_ we are connected. If not connected, wait until connected. + # @param f {Function} Will be executed on the Connector context. + # + whenSynced: (args)-> + if args.constructor is Function + args = [args] + if @is_synced + args[0].apply this, args[1..] + else + @compute_when_synced ?= [] + @compute_when_synced.push args + + # + # Execute an function when a message is received. + # @param f {Function} Will be executed on the PeerJs-Connector context. f will be called with (sender_id, broadcast {true|false}, message). + # + onReceive: (f)-> + @receive_handlers.push f + + # + # perform a sync with a specific user. + # + performSync: (user)-> + if not @current_sync_target? + @current_sync_target = user + @send user, + sync_step: "getHB" + send_again: "true" + data: @getStateVector() + if not @sent_hb_to_all_users + @sent_hb_to_all_users = true + + hb = @getHB([]).hb + _hb = [] + for o in hb + _hb.push o + if _hb.length > 10 + @broadcast + sync_step: "applyHB_" + data: _hb + _hb = [] + @broadcast + sync_step: "applyHB" + data: _hb + + # + # When a master node joined the room, perform this sync with him. It will ask the master for the HB, + # and will broadcast his own HB + # + performSyncWithMaster: (user)-> + @current_sync_target = user + @send user, + sync_step: "getHB" + send_again: "true" + data: @getStateVector() + hb = @getHB([]).hb + _hb = [] + for o in hb + _hb.push o + if _hb.length > 10 + @broadcast + sync_step: "applyHB_" + data: _hb + _hb = [] + @broadcast + sync_step: "applyHB" + data: _hb + + # + # You are sure that all clients are synced, call this function. + # + setStateSynced: ()-> + if not @is_synced + @is_synced = true + if @compute_when_synced? + for el in @compute_when_synced + f = el[0] + args = el[1..] + f.apply(args) + delete @compute_when_synced + null + + # executed when the a state_vector is received. listener will be called only once! + whenReceivedStateVector: (f)-> + @when_received_state_vector_listeners ?= [] + @when_received_state_vector_listeners.push f + + + # + # You received a raw message, and you know that it is intended for to Yjs. Then call this function. + # + receiveMessage: (sender, res)-> + if not res.sync_step? + for f in @receive_handlers + f sender, res + else + if sender is @user_id + return + if res.sync_step is "getHB" + # call listeners + if @when_received_state_vector_listeners? + for f in @when_received_state_vector_listeners + f.call this, res.data + delete @when_received_state_vector_listeners + + data = @getHB(res.data) + hb = data.hb + _hb = [] + # always broadcast, when not synced. + # This reduces errors, when the clients goes offline prematurely. + # When this client only syncs to one other clients, but looses connectors, + # before syncing to the other clients, the online clients have different states. + # Since we do not want to perform regular syncs, this is a good alternative + if @is_synced + sendApplyHB = (m)=> + @send sender, m + else + sendApplyHB = (m)=> + @broadcast m + + for o in hb + _hb.push o + if _hb.length > 10 + sendApplyHB + sync_step: "applyHB_" + data: _hb + _hb = [] + + sendApplyHB + sync_step : "applyHB" + data: _hb + + if res.send_again? and @perform_send_again + send_again = do (sv = data.state_vector)=> + ()=> + hb = @getHB(sv).hb + for o in hb + _hb.push o + if _hb.length > 10 + @send sender, + sync_step: "applyHB_" + data: _hb + _hb = [] + @send sender, + sync_step: "applyHB", + data: _hb + sent_again: "true" + setTimeout send_again, 3000 + else if res.sync_step is "applyHB" + @applyHB(res.data, sender is @current_sync_target) + + if (@syncMethod is "syncAll" or res.sent_again?) and (not @is_synced) and ((@current_sync_target is sender) or (not @current_sync_target?)) + @connections[sender].is_synced = true + @findNewSyncTarget() + + else if res.sync_step is "applyHB_" + @applyHB(res.data, sender is @current_sync_target) + + + # Currently, the HB encodes operations as JSON. For the moment I want to keep it + # that way. Maybe we support encoding in the HB as XML in the future, but for now I don't want + # too much overhead. Y is very likely to get changed a lot in the future + # + # Because we don't want to encode JSON as string (with character escaping, wich makes it pretty much unreadable) + # we encode the JSON as XML. + # + # When the HB support encoding as XML, the format should look pretty much like this. + + # does not support primitive values as array elements + # expects an ltx (less than xml) object + parseMessageFromXml: (m)-> + parse_array = (node)-> + for n in node.children + if n.getAttribute("isArray") is "true" + parse_array n + else + parse_object n + + parse_object = (node)-> + json = {} + for name, value of node.attrs + int = parseInt(value) + if isNaN(int) or (""+int) isnt value + json[name] = value + else + json[name] = int + for n in node.children + name = n.name + if n.getAttribute("isArray") is "true" + json[name] = parse_array n + else + json[name] = parse_object n + json + parse_object m + + # encode message in xml + # we use string because Strophe only accepts an "xml-string".. + # So {a:4,b:{c:5}} will look like + # <y a="4"> + # <b c="5"></b> + # </y> + # m - ltx element + # json - guess it ;) + # + encodeMessageToXml: (m, json)-> + # attributes is optional + encode_object = (m, json)-> + for name,value of json + if not value? + # nop + else if value.constructor is Object + encode_object m.c(name), value + else if value.constructor is Array + encode_array m.c(name), value + else + m.setAttribute(name,value) + m + encode_array = (m, array)-> + m.setAttribute("isArray","true") + for e in array + if e.constructor is Object + encode_object m.c("array-element"), e + else + encode_array m.c("array-element"), e + m + if json.constructor is Object + encode_object m.c("y",{xmlns:"http://y.ninja/connector-stanza"}), json + else if json.constructor is Array + encode_array m.c("y",{xmlns:"http://y.ninja/connector-stanza"}), json + else + throw new Error "I can't encode this json!" + + setIsBoundToY: ()-> + @on_bound_to_y?() + delete @when_bound_to_y + @is_bound_to_y = true + } +}; diff --git a/src/OperationStore.js b/src/OperationStore.js index 7d77f1a3..072947cb 100644 --- a/src/OperationStore.js +++ b/src/OperationStore.js @@ -26,6 +26,9 @@ type Id = [string, number]; class AbstractOperationStore { //eslint-disable-line no-unused-vars constructor () { + this.parentListeners = {}; + this.parentListenersRequestPending = false; + this.parentListenersActivated = {}; // E.g. this.listenersById[id] : Array<Listener> this.listenersById = {}; // Execute the next time a transaction is requested @@ -106,6 +109,7 @@ class AbstractOperationStore { //eslint-disable-line no-unused-vars } // called by a transaction when an operation is added operationAdded (op) { + // notify whenOperation listeners (by id) var l = this.listenersById[op.id]; if (l != null) { for (var listener of l){ @@ -114,5 +118,47 @@ class AbstractOperationStore { //eslint-disable-line no-unused-vars } } } + // notify parent listeners, if possible + var listeners = this.parentListeners[op.parent]; + if ( this.parentListenersRequestPending + || ( listeners == null ) + || ( listeners.length === 0 )) { + return; + } + var al = this.parentListenersActivated[JSON.stringify(op.parent)]; + if ( al == null ){ + al = []; + this.parentListenersActivated[JSON.stringify(op.parent)] = al; + } + al.push(op); + + this.parentListenersRequestPending = true; + var store = this; + this.requestTransaction(function*(myRequest){ // you can throw error on myRequest, then restart if you have to + store.parentListenersRequestPending = false; + var activatedOperations = store.parentListenersActivated; + store.parentListenersActivated = {}; + for (var parent_id in activatedOperations){ + var parent = yield* this.getOperation(parent_id); + Struct[parent.type].notifyObservers(activatedOperations[parent_id]); + } + }) + + } + removeParentListener (id, f) { + var ls = this.parentListeners[id]; + if (ls != null) { + this.parentListeners[id] = ls.filter(function(g){ + return (f !== g); + }); + } + } + addParentListener (id, f) { + var ls = this.parentListeners[JSON.stringify(id)]; + if (ls == null) { + ls = []; + this.parentListeners[JSON.stringify(id)] = ls; + } + ls.push(f); } } diff --git a/src/OperationStores/IndexedDB.js b/src/OperationStores/IndexedDB.js index 706dcced..fd3f4d87 100644 --- a/src/OperationStores/IndexedDB.js +++ b/src/OperationStores/IndexedDB.js @@ -128,7 +128,7 @@ var IndexedDB = (function(){ //eslint-disable-line no-unused-vars var request = yield transactionQueue; transaction = new Transaction(store); - yield* request.call(transaction);/* + yield* request.call(transaction, request);/* while (transactionQueue.queue.length > 0) { yield* transactionQueue.queue.shift().call(transaction); }*/ diff --git a/src/Operations.js b/src/Operations.js index 8934df5a..6205e46f 100644 --- a/src/Operations.js +++ b/src/Operations.js @@ -1,7 +1,7 @@ /* @flow */ // Op is anything that we could get from the OperationStore. -type Op = Object; +struct Op = Object; var Struct = { Operation: { //eslint-disable-line no-unused-vars @@ -14,13 +14,15 @@ var Struct = { Insert: { create: function*( op : Op, user : string, + content : any, left : Struct.Insert, - right : Struct.Insert) : Struct.Insert { + right : Struct.Insert, + parent : Struct.List) : Struct.Insert { op.left = left ? left.id : null; op.origin = op.left; op.right = right ? right.id : null; - op.type = "Insert"; - yield* Struct.Operation.create(op, user); + op.struct = "Insert"; + yield* Struct.Operation.create.call(this, op, user); if (left != null) { left.right = op.id; @@ -33,12 +35,112 @@ var Struct = { return op; }, requiredOps: function(op, ids){ - ids.push(op.left); - ids.push(op.right); + if(op.left != null){ + ids.push(op.left); + } + if(op.right != null){ + ids.push(op.right); + } return ids; }, + getDistanceToOrigin: function *(op){ + var d = 0; + var o = yield this.getOperation(op.left); + while (op.origin !== (o ? o.id : null)) { + d++; + o = yield this.getOperation(o.left); + } + return d; + }, + /* + # $this has to find a unique position between origin and the next known character + # case 1: $origin equals $o.origin: the $creator parameter decides if left or right + # let $OL= [o1,o2,o3,o4], whereby $this is to be inserted between o1 and o4 + # o2,o3 and o4 origin is 1 (the position of o2) + # there is the case that $this.creator < o2.creator, but o3.creator < $this.creator + # then o2 knows o3. Since on another client $OL could be [o1,o3,o4] the problem is complex + # therefore $this would be always to the right of o3 + # case 2: $origin < $o.origin + # if current $this insert_position > $o origin: $this ins + # else $insert_position will not change + # (maybe we encounter case 1 later, then this will be to the right of $o) + # case 3: $origin > $o.origin + # $this insert_position is to the left of $o (forever!) + */ execute: function*(op){ - return op; + var distance_to_origin = yield* Struct.Insert.getDistanceToOrigin(op); // most cases: 0 (starts from 0) + var i = distance_to_origin; // loop counter + var o = yield* this.getOperation(this.left); + o = yield* this.getOperation(o.right); + var tmp; + while (true) { + if (o.id !== this.right){ + if (Struct.Insert.getDistanceToOrigin(o) === i) { + // case 1 + if (o.id[0] < op.id[0]) { + op.left = o; + distance_to_origin = i + 1; + } + } else if ((tmp = Struct.Insert.getDistanceToOrigin(o)) < i) { + // case 2 + if (i - distance_to_origin <= tmp) { + op.left = o; + distance_to_origin = i+1; + } + } else { + break; + } + i++; + o = yield* this.getOperation(o.next_cl); + } else { + break + } + } + // reconnect.. + var left = this.getOperation(op.left); + var right = this.getOperation(op.right); + left.right = op.id; + right.left = op.id; + op.left = left; + op.right = right; + yield* this.setOperation(left); + yield* this.setOperation(right); + yield* this.setOperation(op); + } + }, + List: { + create: function*( op : Op, + user : string){ + op.start = null; + op.end = null; + op.struct = "List"; + return yield* Struct.Operation.create.call(this, op, user); + }, + requiredOps: function(op, ids){ + if (op.start != null) { + ids.push(op.start); + } + if (op.end != null){ + ids.push(op.end); + } + return ids; + }, + execute: function* (op) { + // nop + } + ref: function* (op, pos) : Struct.Insert | undefined{ + var o = op.start; + while ( pos !== 0 || o == null) { + o = (yield* this.getOperation(op.start)).right; + } + return (o == null) ? null : yield* this.getOperation(o); + } + insert: function* (op, pos : number, contents : Array<any>) { + var o = yield* Struct.List.ref.call(this, op, pos); + var o_end = yield* this.getOperation(o.right); + for (var content of contents) { + o = yield* Struct.Insert.create.call(this, {}, user, content, o, o_end, op); + } } } }; diff --git a/src/Types.js b/src/Types.js new file mode 100644 index 00000000..e42d10b3 --- /dev/null +++ b/src/Types.js @@ -0,0 +1,25 @@ + + +(function(){ + + class List { + constructor (_model) { + this._model = _model; + } + *val (pos) { + var o = yield* this.Struct.List.ref(pos); + return o ? o.content : null; + } + *insert (pos, contents) { + yield* this.Struct.List.insert(pos, contents); + } + } + + Y.List = function* YList(){ + var model = yield* this.Struct.List.create(); + return new Y.List.Create(model); + } + + Y.List.Create = List; + Y.List = List; +})(); diff --git a/src/y.js b/src/y.js index e667c471..723865ee 100644 --- a/src/y.js +++ b/src/y.js @@ -1 +1,6 @@ /* @flow */ + +function Y (opts) { + var connector = opts.connector; + Y.Connectors[connector.name] +} diff --git a/y.js b/y.js index a471e1ad..86c64885 100644 --- a/y.js +++ b/y.js @@ -1,2 +1,2 @@ -"use strict";function _inherits(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)}function _classCallCheck(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}!function(e){function t(e,t,r,a){var i=Object.create((t||n).prototype);return i._invoke=c(e,r||null,new p(a||[])),i}function r(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(n){return{type:"throw",arg:n}}}function n(){}function a(){}function i(){}function o(e){["next","throw","return"].forEach(function(t){e[t]=function(e){return this._invoke(t,e)}})}function s(e){this.arg=e}function u(e){function t(t,r){var n=e[t](r),o=n.value;return o instanceof s?Promise.resolve(o.arg).then(a,i):Promise.resolve(o).then(function(e){return n.value=e,n},i)}function r(e,r){var a=n?n.then(function(){return t(e,r)}):new Promise(function(n){n(t(e,r))});return n=a["catch"](o),a}"object"==typeof process&&process.domain&&(t=process.domain.bind(t));var n,a=t.bind(e,"next"),i=t.bind(e,"throw"),o=t.bind(e,"return");this._invoke=r}function c(e,t,n){var a=m;return function(i,o){if(a===w)throw new Error("Generator is already running");if(a===R)return d();for(;;){var s=n.delegate;if(s){if("return"===i||"throw"===i&&s.iterator[i]===y){n.delegate=null;var u=s.iterator["return"];if(u){var c=r(u,s.iterator,o);if("throw"===c.type){i="throw",o=c.arg;continue}}if("return"===i)continue}var c=r(s.iterator[i],s.iterator,o);if("throw"===c.type){n.delegate=null,i="throw",o=c.arg;continue}i="next",o=y;var l=c.arg;if(!l.done)return a=k,l;n[s.resultName]=l.value,n.next=s.nextLoc,n.delegate=null}if("next"===i)a===k?n.sent=o:delete n.sent;else if("throw"===i){if(a===m)throw a=R,o;n.dispatchException(o)&&(i="next",o=y)}else"return"===i&&n.abrupt("return",o);a=w;var c=r(e,t,n);if("normal"===c.type){a=n.done?R:k;var l={value:c.arg,done:n.done};if(c.arg!==S)return l;n.delegate&&"next"===i&&(o=y)}else"throw"===c.type&&(a=R,i="throw",o=c.arg)}}}function l(e){var t={tryLoc:e[0]};1 in e&&(t.catchLoc=e[1]),2 in e&&(t.finallyLoc=e[2],t.afterLoc=e[3]),this.tryEntries.push(t)}function f(e){var t=e.completion||{};t.type="normal",delete t.arg,e.completion=t}function p(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(l,this),this.reset()}function h(e){if(e){var t=e[b];if(t)return t.call(e);if("function"==typeof e.next)return e;if(!isNaN(e.length)){var r=-1,n=function a(){for(;++r<e.length;)if(g.call(e,r))return a.value=e[r],a.done=!1,a;return a.value=y,a.done=!0,a};return n.next=n}}return{next:d}}function d(){return{value:y,done:!0}}var y,g=Object.prototype.hasOwnProperty,b="function"==typeof Symbol&&Symbol.iterator||"@@iterator",v="object"==typeof module,x=e.regeneratorRuntime;if(x)return void(v&&(module.exports=x));x=e.regeneratorRuntime=v?module.exports:{},x.wrap=t;var m="suspendedStart",k="suspendedYield",w="executing",R="completed",S={},O=i.prototype=n.prototype;a.prototype=O.constructor=i,i.constructor=a,a.displayName="GeneratorFunction",x.isGeneratorFunction=function(e){var t="function"==typeof e&&e.constructor;return t?t===a||"GeneratorFunction"===(t.displayName||t.name):!1},x.mark=function(e){return e.__proto__=i,e.prototype=Object.create(O),e},x.awrap=function(e){return new s(e)},o(u.prototype),x.async=function(e,r,n,a){var i=new u(t(e,r,n,a));return x.isGeneratorFunction(r)?i:i.next().then(function(e){return e.done?e.value:i.next()})},o(O),O[b]=function(){return this},O.toString=function(){return"[object Generator]"},x.keys=function(e){var t=[];for(var r in e)t.push(r);return t.reverse(),function n(){for(;t.length;){var r=t.pop();if(r in e)return n.value=r,n.done=!1,n}return n.done=!0,n}},x.values=h,p.prototype={constructor:p,reset:function(){this.prev=0,this.next=0,this.sent=y,this.done=!1,this.delegate=null,this.tryEntries.forEach(f);for(var e,t=0;g.call(this,e="t"+t)||20>t;++t)this[e]=null},stop:function(){this.done=!0;var e=this.tryEntries[0],t=e.completion;if("throw"===t.type)throw t.arg;return this.rval},dispatchException:function(e){function t(t,n){return i.type="throw",i.arg=e,r.next=t,!!n}if(this.done)throw e;for(var r=this,n=this.tryEntries.length-1;n>=0;--n){var a=this.tryEntries[n],i=a.completion;if("root"===a.tryLoc)return t("end");if(a.tryLoc<=this.prev){var o=g.call(a,"catchLoc"),s=g.call(a,"finallyLoc");if(o&&s){if(this.prev<a.catchLoc)return t(a.catchLoc,!0);if(this.prev<a.finallyLoc)return t(a.finallyLoc)}else if(o){if(this.prev<a.catchLoc)return t(a.catchLoc,!0)}else{if(!s)throw new Error("try statement without catch or finally");if(this.prev<a.finallyLoc)return t(a.finallyLoc)}}}},abrupt:function(e,t){for(var r=this.tryEntries.length-1;r>=0;--r){var n=this.tryEntries[r];if(n.tryLoc<=this.prev&&g.call(n,"finallyLoc")&&this.prev<n.finallyLoc){var a=n;break}}a&&("break"===e||"continue"===e)&&a.tryLoc<=t&&t<=a.finallyLoc&&(a=null);var i=a?a.completion:{};return i.type=e,i.arg=t,a?this.next=a.finallyLoc:this.complete(i),S},complete:function(e,t){if("throw"===e.type)throw e.arg;"break"===e.type||"continue"===e.type?this.next=e.arg:"return"===e.type?(this.rval=e.arg,this.next="end"):"normal"===e.type&&t&&(this.next=t)},finish:function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.finallyLoc===e)return this.complete(r.completion,r.afterLoc),f(r),S}},"catch":function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.tryLoc===e){var n=r.completion;if("throw"===n.type){var a=n.arg;f(r)}return a}}throw new Error("illegal catch attempt")},delegateYield:function(e,t,r){return this.delegate={iterator:h(e),resultName:t,nextLoc:r},S}}}("object"==typeof global?global:"object"==typeof window?window:"object"==typeof self?self:void 0);var AbstractTransaction=function(){function e(t){_classCallCheck(this,e),this.store=t}return e.prototype.addOperation=regeneratorRuntime.mark(function t(e){var r;return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:if(r=this.getState(e.id[0]),e.id[1]!==r.clock){t.next=8;break}return r.clock++,t.delegateYield(this.setState(r),"t0",4);case 4:return this.store.operationAdded(e),t.abrupt("return",!0);case 8:return t.abrupt("return",!1);case 9:case"end":return t.stop()}},t,this)}),e}(),AbstractOperationStore=function(){function e(){_classCallCheck(this,e),this.listenersById={},this.listenersByIdExecuteNow=[],this.listenersByIdRequestPending=!1}return e.prototype.whenOperationsExist=function(e,t,r){if(e.length>0)for(var n={f:t,args:r||[],missing:e.length},a=e,i=Array.isArray(a),o=0,a=i?a:a[Symbol.iterator]();;){var s;if(i){if(o>=a.length)break;s=a[o++]}else{if(o=a.next(),o.done)break;s=o.value}var u=s,c=JSON.stringify(u),l=this.listenersById[c];null==l&&(l=[],this.listenersById[c]=l),l.push(n)}else this.listenersByIdExecuteNow.push({f:t,args:r||[]});if(!this.listenersByIdRequestPending){this.listenersByIdRequestPending=!0;var f=this;this.requestTransaction(regeneratorRuntime.mark(function p(){var e,t,r,n,a,i,o,s,u,c,l,h,d,y;return regeneratorRuntime.wrap(function(p){for(;;)switch(p.prev=p.next){case 0:e=f.listenersByIdExecuteNow,f.listenersByIdExecuteNow=[],t=f.listenersById,f.listenersById={},f.listenersByIdRequestPending=!1,r=e,n=Array.isArray(r),a=0,r=n?r:r[Symbol.iterator]();case 6:if(!n){p.next=12;break}if(!(a>=r.length)){p.next=9;break}return p.abrupt("break",20);case 9:i=r[a++],p.next=16;break;case 12:if(a=r.next(),!a.done){p.next=15;break}return p.abrupt("break",20);case 15:i=a.value;case 16:return o=i,p.delegateYield(o.f.apply(this,o.args),"t0",18);case 18:p.next=6;break;case 20:p.t1=regeneratorRuntime.keys(t);case 21:if((p.t2=p.t1()).done){p.next=48;break}return s=p.t2.value,u=t[s],c=JSON.parse(s),p.delegateYield(this.getOperation(c),"t3",26);case 26:if(null!=p.t3){p.next=30;break}f.listenersById[s]=u,p.next=46;break;case 30:l=u,h=Array.isArray(l),d=0,l=h?l:l[Symbol.iterator]();case 31:if(!h){p.next=37;break}if(!(d>=l.length)){p.next=34;break}return p.abrupt("break",46);case 34:y=l[d++],p.next=41;break;case 37:if(d=l.next(),!d.done){p.next=40;break}return p.abrupt("break",46);case 40:y=d.value;case 41:if(o=y,0!==--o.missing){p.next=44;break}return p.delegateYield(o.f.apply(this,o.args),"t4",44);case 44:p.next=31;break;case 46:p.next=21;break;case 48:case"end":return p.stop()}},p,this)}))}},e.prototype.operationAdded=function(e){var t=this.listenersById[e.id];if(null!=t)for(var r=t,n=Array.isArray(r),a=0,r=n?r:r[Symbol.iterator]();;){var i;if(n){if(a>=r.length)break;i=r[a++]}else{if(a=r.next(),a.done)break;i=a.value}var o=i;0===--o.missing&&this.whenOperationsExist([],o.f,o.args)}},e}(),Struct={Operation:{create:regeneratorRuntime.mark(function e(t,r){var n;return regeneratorRuntime.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:return e.delegateYield(this.getState(r),"t0",1);case 1:return n=e.t0,t.id=[r,n.clock],e.delegateYield(this.addOperation(t),"t1",4);case 4:return e.abrupt("return",e.t1);case 5:case"end":return e.stop()}},e,this)})},Insert:{create:regeneratorRuntime.mark(function t(e,r,n,a){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return e.left=n?n.id:null,e.origin=e.left,e.right=a?a.id:null,e.type="Insert",t.delegateYield(Struct.Operation.create(e,r),"t0",5);case 5:if(null==n){t.next=8;break}return n.right=e.id,t.delegateYield(this.setOperation(n),"t1",8);case 8:if(null==a){t.next=11;break}return a.left=e.id,t.delegateYield(this.setOperation(a),"t2",11);case 11:return t.abrupt("return",e);case 12:case"end":return t.stop()}},t,this)}),requiredOps:function(e,t){return t.push(e.left),t.push(e.right),t},execute:regeneratorRuntime.mark(function r(e){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return t.abrupt("return",e);case 1:case"end":return t.stop()}},r,this)})}},GeneratorFunction=regeneratorRuntime.mark(function n(){return regeneratorRuntime.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:case"end":return e.stop()}},n,this)}).constructor,IndexedDB=function(){var e=function(e){function t(r){_classCallCheck(this,t),e.call(this,r),this.transaction=r.db.transaction(["OperationStore","StateVector"],"readwrite"),this.sv=this.transaction.objectStore("StateVector"),this.os=this.transaction.objectStore("OperationStore"),this.buffer={}}return _inherits(t,e),t.prototype.setOperation=regeneratorRuntime.mark(function r(e){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return t.next=2,this.os.put(e);case 2:return this.buffer[JSON.stringify(e.id)]=e,t.abrupt("return",e);case 4:case"end":return t.stop()}},r,this)}),t.prototype.getOperation=regeneratorRuntime.mark(function n(e){var t;return regeneratorRuntime.wrap(function(r){for(;;)switch(r.prev=r.next){case 0:if(t=this.buffer[JSON.stringify(e)],null!=t){r.next=6;break}return r.next=4,this.os.get(e);case 4:t=r.sent,this.buffer[JSON.stringify(e)]=t;case 6:return r.abrupt("return",t);case 7:case"end":return r.stop()}},n,this)}),t.prototype.removeOperation=regeneratorRuntime.mark(function a(e){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return this.buffer[JSON.stringify(e)]=null,t.next=3,this.os["delete"](e);case 3:return t.abrupt("return",t.sent);case 4:case"end":return t.stop()}},a,this)}),t.prototype.setState=regeneratorRuntime.mark(function i(e){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return t.next=2,this.sv.put(e);case 2:return t.abrupt("return",t.sent);case 3:case"end":return t.stop()}},i,this)}),t.prototype.getState=regeneratorRuntime.mark(function o(e){var t;return regeneratorRuntime.wrap(function(r){for(;;)switch(r.prev=r.next){case 0:return r.next=2,this.sv.get(e);case 2:if(r.t0=t=r.sent,null==r.t0){r.next=7;break}return r.abrupt("return",t);case 7:return r.abrupt("return",{user:e,clock:0});case 8:case"end":return r.stop()}},o,this)}),t.prototype.getStateVector=regeneratorRuntime.mark(function s(){var e,t,r;return regeneratorRuntime.wrap(function(n){for(;;)switch(n.prev=n.next){case 0:e=[],t=this.sv.openCursor();case 2:return n.next=4,t;case 4:if(n.t0=r=n.sent,null==n.t0){n.next=10;break}e.push(r.value),r["continue"](),n.next=2;break;case 10:return n.abrupt("return",e);case 11:case"end":return n.stop()}},s,this)}),t.prototype.getStateSet=regeneratorRuntime.mark(function u(){var e,t,r,n,a,i,o;return regeneratorRuntime.wrap(function(s){for(;;)switch(s.prev=s.next){case 0:return s.delegateYield(this.getStateVector(),"t0",1);case 1:e=s.t0,t={},r=e,n=Array.isArray(r),a=0,r=n?r:r[Symbol.iterator]();case 4:if(!n){s.next=10;break}if(!(a>=r.length)){s.next=7;break}return s.abrupt("break",18);case 7:i=r[a++],s.next=14;break;case 10:if(a=r.next(),!a.done){s.next=13;break}return s.abrupt("break",18);case 13:i=a.value;case 14:o=i,t[o.user]=o.clock;case 16:s.next=4;break;case 18:return s.abrupt("return",t);case 19:case"end":return s.stop()}},u,this)}),t.prototype.getOperations=regeneratorRuntime.mark(function c(e){var t,r,n,a,i,o,s,u,l,f,p,h,d;return regeneratorRuntime.wrap(function(c){for(;;)switch(c.prev=c.next){case 0:return null==e&&(e={}),t=[],c.delegateYield(this.getStateVector(),"t0",3);case 3:r=c.t0,n=r,a=Array.isArray(n),i=0,n=a?n:n[Symbol.iterator]();case 5:if(!a){c.next=11;break}if(!(i>=n.length)){c.next=8;break}return c.abrupt("break",31);case 8:o=n[i++],c.next=15;break;case 11:if(i=n.next(),!i.done){c.next=14;break}return c.abrupt("break",31);case 14:o=i.value;case 15:s=o,u=s.user,l=e[u]||0,f=s.clock,p=IDBKeyRange.bound([u,l],[u,f]),h=this.os.openCursor(p);case 21:return c.next=23,h;case 23:if(c.t1=d=c.sent,null==c.t1){c.next=29;break}t.push(d.value),d["continue"](),c.next=21;break;case 29:c.next=5;break;case 31:return c.abrupt("return",t);case 32:case"end":return c.stop()}},c,this)}),t}(AbstractTransaction),t=function(t){function r(n){function a(e){var t=e.value;e.done||(t.constructor===IDBRequest||t.constructor===IDBCursor?(t.onsuccess=function(){a(o.next(t.result))},t.onerror=function(e){o["throw"](e)}):t===i.transactionQueue?t.queue.length>0?a(o.next(t.queue.shift())):t.onRequest=function(){t.onRequest=null,a(o.next(t.queue.shift()))}:t.constructor===IDBOpenDBRequest?(t.onsuccess=function(e){var t=e.target.result;a(o.next(t))},t.onerror=function(){o["throw"]("Couldn't open IndexedDB database!")},t.onupgradeneeded=function(e){var t=e.target.result;t.createObjectStore("OperationStore",{keyPath:"id"}),t.createObjectStore("StateVector",{keyPath:"user"})}):o["throw"]("You can not yield this type!"))}_classCallCheck(this,r),t.call(this),this.namespace=n,this.transactionQueue={queue:[],onRequest:null};var i=this,o=regeneratorRuntime.mark(function s(){var t,r,a,o;return regeneratorRuntime.wrap(function(s){for(;;)switch(s.prev=s.next){case 0:return s.next=2,indexedDB.open(n,3);case 2:i.db=s.sent,t=i.transactionQueue,r=null,a=!0;case 6:if(!a){s.next=14;break}return s.next=9,t;case 9:return o=s.sent,r=new e(i),s.delegateYield(o.call(r),"t0",12);case 12:s.next=6;break;case 14:case"end":return s.stop()}},s,this)})();a(o.next())}return _inherits(r,t),r.prototype.requestTransaction=function(e){this.transactionQueue.queue.push(e),null!=this.transactionQueue.onRequest&&this.transactionQueue.onRequest()},r.prototype.removeDatabase=regeneratorRuntime.mark(function n(){return regeneratorRuntime.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:return this.db.close(),e.next=3,indexedDB.deleteDatabase(this.namespace);case 3:case"end":return e.stop()}},n,this)}),r}(AbstractOperationStore);return t}(); +"use strict";function _inherits(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(e.__proto__=t)}function _classCallCheck(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}!function(e){function t(e,t,r,a){var i=Object.create((t||n).prototype);return i._invoke=c(e,r||null,new p(a||[])),i}function r(e,t,r){try{return{type:"normal",arg:e.call(t,r)}}catch(n){return{type:"throw",arg:n}}}function n(){}function a(){}function i(){}function o(e){["next","throw","return"].forEach(function(t){e[t]=function(e){return this._invoke(t,e)}})}function s(e){this.arg=e}function u(e){function t(t,r){var n=e[t](r),o=n.value;return o instanceof s?Promise.resolve(o.arg).then(a,i):Promise.resolve(o).then(function(e){return n.value=e,n},i)}function r(e,r){var a=n?n.then(function(){return t(e,r)}):new Promise(function(n){n(t(e,r))});return n=a["catch"](o),a}"object"==typeof process&&process.domain&&(t=process.domain.bind(t));var n,a=t.bind(e,"next"),i=t.bind(e,"throw"),o=t.bind(e,"return");this._invoke=r}function c(e,t,n){var a=m;return function(i,o){if(a===w)throw new Error("Generator is already running");if(a===R)return d();for(;;){var s=n.delegate;if(s){if("return"===i||"throw"===i&&s.iterator[i]===y){n.delegate=null;var u=s.iterator["return"];if(u){var c=r(u,s.iterator,o);if("throw"===c.type){i="throw",o=c.arg;continue}}if("return"===i)continue}var c=r(s.iterator[i],s.iterator,o);if("throw"===c.type){n.delegate=null,i="throw",o=c.arg;continue}i="next",o=y;var l=c.arg;if(!l.done)return a=k,l;n[s.resultName]=l.value,n.next=s.nextLoc,n.delegate=null}if("next"===i)a===k?n.sent=o:delete n.sent;else if("throw"===i){if(a===m)throw a=R,o;n.dispatchException(o)&&(i="next",o=y)}else"return"===i&&n.abrupt("return",o);a=w;var c=r(e,t,n);if("normal"===c.type){a=n.done?R:k;var l={value:c.arg,done:n.done};if(c.arg!==S)return l;n.delegate&&"next"===i&&(o=y)}else"throw"===c.type&&(a=R,i="throw",o=c.arg)}}}function l(e){var t={tryLoc:e[0]};1 in e&&(t.catchLoc=e[1]),2 in e&&(t.finallyLoc=e[2],t.afterLoc=e[3]),this.tryEntries.push(t)}function f(e){var t=e.completion||{};t.type="normal",delete t.arg,e.completion=t}function p(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(l,this),this.reset()}function h(e){if(e){var t=e[b];if(t)return t.call(e);if("function"==typeof e.next)return e;if(!isNaN(e.length)){var r=-1,n=function a(){for(;++r<e.length;)if(g.call(e,r))return a.value=e[r],a.done=!1,a;return a.value=y,a.done=!0,a};return n.next=n}}return{next:d}}function d(){return{value:y,done:!0}}var y,g=Object.prototype.hasOwnProperty,b="function"==typeof Symbol&&Symbol.iterator||"@@iterator",v="object"==typeof module,x=e.regeneratorRuntime;if(x)return void(v&&(module.exports=x));x=e.regeneratorRuntime=v?module.exports:{},x.wrap=t;var m="suspendedStart",k="suspendedYield",w="executing",R="completed",S={},O=i.prototype=n.prototype;a.prototype=O.constructor=i,i.constructor=a,a.displayName="GeneratorFunction",x.isGeneratorFunction=function(e){var t="function"==typeof e&&e.constructor;return t?t===a||"GeneratorFunction"===(t.displayName||t.name):!1},x.mark=function(e){return e.__proto__=i,e.prototype=Object.create(O),e},x.awrap=function(e){return new s(e)},o(u.prototype),x.async=function(e,r,n,a){var i=new u(t(e,r,n,a));return x.isGeneratorFunction(r)?i:i.next().then(function(e){return e.done?e.value:i.next()})},o(O),O[b]=function(){return this},O.toString=function(){return"[object Generator]"},x.keys=function(e){var t=[];for(var r in e)t.push(r);return t.reverse(),function n(){for(;t.length;){var r=t.pop();if(r in e)return n.value=r,n.done=!1,n}return n.done=!0,n}},x.values=h,p.prototype={constructor:p,reset:function(){this.prev=0,this.next=0,this.sent=y,this.done=!1,this.delegate=null,this.tryEntries.forEach(f);for(var e,t=0;g.call(this,e="t"+t)||20>t;++t)this[e]=null},stop:function(){this.done=!0;var e=this.tryEntries[0],t=e.completion;if("throw"===t.type)throw t.arg;return this.rval},dispatchException:function(e){function t(t,n){return i.type="throw",i.arg=e,r.next=t,!!n}if(this.done)throw e;for(var r=this,n=this.tryEntries.length-1;n>=0;--n){var a=this.tryEntries[n],i=a.completion;if("root"===a.tryLoc)return t("end");if(a.tryLoc<=this.prev){var o=g.call(a,"catchLoc"),s=g.call(a,"finallyLoc");if(o&&s){if(this.prev<a.catchLoc)return t(a.catchLoc,!0);if(this.prev<a.finallyLoc)return t(a.finallyLoc)}else if(o){if(this.prev<a.catchLoc)return t(a.catchLoc,!0)}else{if(!s)throw new Error("try statement without catch or finally");if(this.prev<a.finallyLoc)return t(a.finallyLoc)}}}},abrupt:function(e,t){for(var r=this.tryEntries.length-1;r>=0;--r){var n=this.tryEntries[r];if(n.tryLoc<=this.prev&&g.call(n,"finallyLoc")&&this.prev<n.finallyLoc){var a=n;break}}a&&("break"===e||"continue"===e)&&a.tryLoc<=t&&t<=a.finallyLoc&&(a=null);var i=a?a.completion:{};return i.type=e,i.arg=t,a?this.next=a.finallyLoc:this.complete(i),S},complete:function(e,t){if("throw"===e.type)throw e.arg;"break"===e.type||"continue"===e.type?this.next=e.arg:"return"===e.type?(this.rval=e.arg,this.next="end"):"normal"===e.type&&t&&(this.next=t)},finish:function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.finallyLoc===e)return this.complete(r.completion,r.afterLoc),f(r),S}},"catch":function(e){for(var t=this.tryEntries.length-1;t>=0;--t){var r=this.tryEntries[t];if(r.tryLoc===e){var n=r.completion;if("throw"===n.type){var a=n.arg;f(r)}return a}}throw new Error("illegal catch attempt")},delegateYield:function(e,t,r){return this.delegate={iterator:h(e),resultName:t,nextLoc:r},S}}}("object"==typeof global?global:"object"==typeof window?window:"object"==typeof self?self:void 0);var AbstractTransaction=function(){function e(t){_classCallCheck(this,e),this.store=t}return e.prototype.addOperation=regeneratorRuntime.mark(function t(e){var r;return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:if(r=this.getState(e.id[0]),e.id[1]!==r.clock){t.next=8;break}return r.clock++,t.delegateYield(this.setState(r),"t0",4);case 4:return this.store.operationAdded(e),t.abrupt("return",!0);case 8:return t.abrupt("return",!1);case 9:case"end":return t.stop()}},t,this)}),e}(),AbstractOperationStore=function(){function e(){_classCallCheck(this,e),this.listenersById={},this.listenersByIdExecuteNow=[],this.listenersByIdRequestPending=!1}return e.prototype.whenOperationsExist=function(e,t,r){if(e.length>0)for(var n={f:t,args:r||[],missing:e.length},a=e,i=Array.isArray(a),o=0,a=i?a:a[Symbol.iterator]();;){var s;if(i){if(o>=a.length)break;s=a[o++]}else{if(o=a.next(),o.done)break;s=o.value}var u=s,c=JSON.stringify(u),l=this.listenersById[c];null==l&&(l=[],this.listenersById[c]=l),l.push(n)}else this.listenersByIdExecuteNow.push({f:t,args:r||[]});if(!this.listenersByIdRequestPending){this.listenersByIdRequestPending=!0;var f=this;this.requestTransaction(regeneratorRuntime.mark(function p(){var e,t,r,n,a,i,o,s,u,c,l,h,d,y;return regeneratorRuntime.wrap(function(p){for(;;)switch(p.prev=p.next){case 0:e=f.listenersByIdExecuteNow,f.listenersByIdExecuteNow=[],t=f.listenersById,f.listenersById={},f.listenersByIdRequestPending=!1,r=e,n=Array.isArray(r),a=0,r=n?r:r[Symbol.iterator]();case 6:if(!n){p.next=12;break}if(!(a>=r.length)){p.next=9;break}return p.abrupt("break",20);case 9:i=r[a++],p.next=16;break;case 12:if(a=r.next(),!a.done){p.next=15;break}return p.abrupt("break",20);case 15:i=a.value;case 16:return o=i,p.delegateYield(o.f.apply(this,o.args),"t0",18);case 18:p.next=6;break;case 20:p.t1=regeneratorRuntime.keys(t);case 21:if((p.t2=p.t1()).done){p.next=48;break}return s=p.t2.value,u=t[s],c=JSON.parse(s),p.delegateYield(this.getOperation(c),"t3",26);case 26:if(null!=p.t3){p.next=30;break}f.listenersById[s]=u,p.next=46;break;case 30:l=u,h=Array.isArray(l),d=0,l=h?l:l[Symbol.iterator]();case 31:if(!h){p.next=37;break}if(!(d>=l.length)){p.next=34;break}return p.abrupt("break",46);case 34:y=l[d++],p.next=41;break;case 37:if(d=l.next(),!d.done){p.next=40;break}return p.abrupt("break",46);case 40:y=d.value;case 41:if(o=y,0!==--o.missing){p.next=44;break}return p.delegateYield(o.f.apply(this,o.args),"t4",44);case 44:p.next=31;break;case 46:p.next=21;break;case 48:case"end":return p.stop()}},p,this)}))}},e.prototype.operationAdded=function(e){var t=this.listenersById[e.id];if(null!=t)for(var r=t,n=Array.isArray(r),a=0,r=n?r:r[Symbol.iterator]();;){var i;if(n){if(a>=r.length)break;i=r[a++]}else{if(a=r.next(),a.done)break;i=a.value}var o=i;0===--o.missing&&this.whenOperationsExist([],o.f,o.args)}},e}(),Struct={Operation:{create:regeneratorRuntime.mark(function e(t,r){var n;return regeneratorRuntime.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:return e.delegateYield(this.getState(r),"t0",1);case 1:return n=e.t0,t.id=[r,n.clock],e.delegateYield(this.addOperation(t),"t1",4);case 4:return e.abrupt("return",e.t1);case 5:case"end":return e.stop()}},e,this)})},Insert:{create:regeneratorRuntime.mark(function t(e,r,n,a){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return e.left=n?n.id:null,e.origin=e.left,e.right=a?a.id:null,e.type="Insert",t.delegateYield(Struct.Operation.create(e,r),"t0",5);case 5:if(null==n){t.next=8;break}return n.right=e.id,t.delegateYield(this.setOperation(n),"t1",8);case 8:if(null==a){t.next=11;break}return a.left=e.id,t.delegateYield(this.setOperation(a),"t2",11);case 11:return t.abrupt("return",e);case 12:case"end":return t.stop()}},t,this)}),requiredOps:function(e,t){return t.push(e.left),t.push(e.right),t},execute:regeneratorRuntime.mark(function r(e){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return t.abrupt("return",e);case 1:case"end":return t.stop()}},r,this)})}},IndexedDB=function(){var e=function(e){function t(r){_classCallCheck(this,t),e.call(this,r),this.transaction=r.db.transaction(["OperationStore","StateVector"],"readwrite"),this.sv=this.transaction.objectStore("StateVector"),this.os=this.transaction.objectStore("OperationStore"),this.buffer={}}return _inherits(t,e),t.prototype.setOperation=regeneratorRuntime.mark(function r(e){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return t.next=2,this.os.put(e);case 2:return this.buffer[JSON.stringify(e.id)]=e,t.abrupt("return",e);case 4:case"end":return t.stop()}},r,this)}),t.prototype.getOperation=regeneratorRuntime.mark(function n(e){var t;return regeneratorRuntime.wrap(function(r){for(;;)switch(r.prev=r.next){case 0:if(t=this.buffer[JSON.stringify(e)],null!=t){r.next=6;break}return r.next=4,this.os.get(e);case 4:t=r.sent,this.buffer[JSON.stringify(e)]=t;case 6:return r.abrupt("return",t);case 7:case"end":return r.stop()}},n,this)}),t.prototype.removeOperation=regeneratorRuntime.mark(function a(e){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return this.buffer[JSON.stringify(e)]=null,t.next=3,this.os["delete"](e);case 3:return t.abrupt("return",t.sent);case 4:case"end":return t.stop()}},a,this)}),t.prototype.setState=regeneratorRuntime.mark(function i(e){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return t.next=2,this.sv.put(e);case 2:return t.abrupt("return",t.sent);case 3:case"end":return t.stop()}},i,this)}),t.prototype.getState=regeneratorRuntime.mark(function o(e){var t;return regeneratorRuntime.wrap(function(r){for(;;)switch(r.prev=r.next){case 0:return r.next=2,this.sv.get(e);case 2:if(r.t0=t=r.sent,null==r.t0){r.next=7;break}return r.abrupt("return",t);case 7:return r.abrupt("return",{user:e,clock:0});case 8:case"end":return r.stop()}},o,this)}),t.prototype.getStateVector=regeneratorRuntime.mark(function s(){var e,t,r;return regeneratorRuntime.wrap(function(n){for(;;)switch(n.prev=n.next){case 0:e=[],t=this.sv.openCursor();case 2:return n.next=4,t;case 4:if(n.t0=r=n.sent,null==n.t0){n.next=10;break}e.push(r.value),r["continue"](),n.next=2;break;case 10:return n.abrupt("return",e);case 11:case"end":return n.stop()}},s,this)}),t.prototype.getStateSet=regeneratorRuntime.mark(function u(){var e,t,r,n,a,i,o;return regeneratorRuntime.wrap(function(s){for(;;)switch(s.prev=s.next){case 0:return s.delegateYield(this.getStateVector(),"t0",1);case 1:e=s.t0,t={},r=e,n=Array.isArray(r),a=0,r=n?r:r[Symbol.iterator]();case 4:if(!n){s.next=10;break}if(!(a>=r.length)){s.next=7;break}return s.abrupt("break",18);case 7:i=r[a++],s.next=14;break;case 10:if(a=r.next(),!a.done){s.next=13;break}return s.abrupt("break",18);case 13:i=a.value;case 14:o=i,t[o.user]=o.clock;case 16:s.next=4;break;case 18:return s.abrupt("return",t);case 19:case"end":return s.stop()}},u,this)}),t.prototype.getOperations=regeneratorRuntime.mark(function c(e){var t,r,n,a,i,o,s,u,l,f,p,h,d;return regeneratorRuntime.wrap(function(c){for(;;)switch(c.prev=c.next){case 0:return null==e&&(e={}),t=[],c.delegateYield(this.getStateVector(),"t0",3);case 3:r=c.t0,n=r,a=Array.isArray(n),i=0,n=a?n:n[Symbol.iterator]();case 5:if(!a){c.next=11;break}if(!(i>=n.length)){c.next=8;break}return c.abrupt("break",31);case 8:o=n[i++],c.next=15;break;case 11:if(i=n.next(),!i.done){c.next=14;break}return c.abrupt("break",31);case 14:o=i.value;case 15:s=o,u=s.user,l=e[u]||0,f=s.clock,p=IDBKeyRange.bound([u,l],[u,f]),h=this.os.openCursor(p);case 21:return c.next=23,h;case 23:if(c.t1=d=c.sent,null==c.t1){c.next=29;break}t.push(d.value),d["continue"](),c.next=21;break;case 29:c.next=5;break;case 31:return c.abrupt("return",t);case 32:case"end":return c.stop()}},c,this)}),t}(AbstractTransaction),t=function(t){function r(n){function a(e){var t=e.value;e.done||(t.constructor===IDBRequest||t.constructor===IDBCursor?(t.onsuccess=function(){a(o.next(t.result))},t.onerror=function(e){o["throw"](e)}):t===i.transactionQueue?t.queue.length>0?a(o.next(t.queue.shift())):t.onRequest=function(){t.onRequest=null,a(o.next(t.queue.shift()))}:t.constructor===IDBOpenDBRequest?(t.onsuccess=function(e){var t=e.target.result;a(o.next(t))},t.onerror=function(){o["throw"]("Couldn't open IndexedDB database!")},t.onupgradeneeded=function(e){var t=e.target.result;t.createObjectStore("OperationStore",{keyPath:"id"}),t.createObjectStore("StateVector",{keyPath:"user"})}):o["throw"]("You can not yield this type!"))}_classCallCheck(this,r),t.call(this),this.namespace=n,this.transactionQueue={queue:[],onRequest:null};var i=this,o=regeneratorRuntime.mark(function s(){var t,r,a,o;return regeneratorRuntime.wrap(function(s){for(;;)switch(s.prev=s.next){case 0:return s.next=2,indexedDB.open(n,3);case 2:i.db=s.sent,t=i.transactionQueue,r=null,a=!0;case 6:if(!a){s.next=14;break}return s.next=9,t;case 9:return o=s.sent,r=new e(i),s.delegateYield(o.call(r),"t0",12);case 12:s.next=6;break;case 14:case"end":return s.stop()}},s,this)})();a(o.next())}return _inherits(r,t),r.prototype.requestTransaction=function(e){this.transactionQueue.queue.push(e),null!=this.transactionQueue.onRequest&&this.transactionQueue.onRequest()},r.prototype.removeDatabase=regeneratorRuntime.mark(function n(){return regeneratorRuntime.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:return this.db.close(),e.next=3,indexedDB.deleteDatabase(this.namespace);case 3:case"end":return e.stop()}},n,this)}),r}(AbstractOperationStore);return t}(); //# sourceMappingURL=y.js.map \ No newline at end of file diff --git a/y.js.map b/y.js.map index f2616e79..56fd0aed 100644 --- a/y.js.map +++ b/y.js.map @@ -1 +1 @@ -{"version":3,"sources":["y.js","runtime.js","OperationStore.js","Operations.js","OperationStores/IndexedDB.js"],"names":["_inherits","subClass","superClass","TypeError","prototype","Object","create","constructor","value","enumerable","writable","configurable","__proto__","_classCallCheck","instance","Constructor","global","wrap","innerFn","outerFn","self","tryLocsList","generator","Generator","_invoke","makeInvokeMethod","Context","tryCatch","fn","obj","arg","type","call","err","GeneratorFunction","GeneratorFunctionPrototype","defineIteratorMethods","forEach","method","this","AwaitArgument","AsyncIterator","invoke","result","Promise","resolve","then","invokeNext","invokeThrow","unwrapped","enqueue","enqueueResult","previousPromise","invokeReturn","process","domain","bind","context","state","GenStateSuspendedStart","GenStateExecuting","Error","GenStateCompleted","doneResult","delegate","iterator","undefined","returnMethod","record","info","done","GenStateSuspendedYield","resultName","next","nextLoc","sent","dispatchException","abrupt","ContinueSentinel","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","push","resetTryEntry","completion","reset","values","iterable","iteratorMethod","iteratorSymbol","isNaN","length","i","hasOwn","hasOwnProperty","Symbol","inModule","module","runtime","regeneratorRuntime","exports","Gp","displayName","isGeneratorFunction","genFun","ctor","name","mark","awrap","async","iter","toString","keys","object","key","reverse","pop","prev","tempName","tempIndex","stop","rootEntry","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","catch","thrown","delegateYield","window","AbstractTransaction","store","addOperation","op","context$2$0","getState","id","clock","setState","operationAdded","AbstractOperationStore","listenersById","listenersByIdExecuteNow","listenersByIdRequestPending","whenOperationsExist","ids","f","args","listener","missing","_iterator","_isArray","Array","isArray","_i","_ref","sid","JSON","stringify","l","requestTransaction","callee$2$0","exeNow","ls","_iterator2","_isArray2","_i2","_ref2","_iterator3","_isArray3","_i3","_ref3","context$3$0","apply","t1","t2","parse","getOperation","t3","_iterator4","_isArray4","_i4","_ref4","Struct","Operation","user","context$1$0","t0","Insert","left","right","origin","setOperation","requiredOps","execute","callee$0$0","IndexedDB","Transaction","_AbstractTransaction","transaction","db","sv","objectStore","os","buffer","put","get","removeOperation","getStateVector","stateVector","cursorResult","cursor","openCursor","getStateSet","ss","_iterator5","_isArray5","_i5","_ref5","getOperations","startSS","ops","endSV","_iterator6","_isArray6","_i6","_ref6","endState","startPos","endPos","range","IDBKeyRange","bound","OperationStore","_AbstractOperationStore","namespace","handleTransactions","t","request","IDBRequest","IDBCursor","onsuccess","tGen","onerror","transactionQueue","queue","shift","onRequest","IDBOpenDBRequest","event","target","onupgradeneeded","createObjectStore","keyPath","transactionGen","cont","context$4$0","indexedDB","open","makeGen","removeDatabase","close","deleteDatabase"],"mappings":"AAUA,YAEA,SAASA,WAAUC,EAAUC,GAAc,GAA0B,kBAAfA,IAA4C,OAAfA,EAAuB,KAAM,IAAIC,WAAU,iEAAoED,GAAeD,GAASG,UAAYC,OAAOC,OAAOJ,GAAcA,EAAWE,WAAaG,aAAeC,MAAOP,EAAUQ,YAAY,EAAOC,UAAU,EAAMC,cAAc,KAAeT,IAAYD,EAASW,UAAYV,GAE3Z,QAASW,iBAAgBC,EAAUC,GAAe,KAAMD,YAAoBC,IAAgB,KAAM,IAAIZ,WAAU,sCCJhH,SAAAa,GAyBA,QAAAC,GAAAC,EAAAC,EAAAC,EAAAC,GAEA,GAAAC,GAAAjB,OAAAC,QAAAa,GAAAI,GAAAnB,UAOA,OALAkB,GAAAE,QAAAC,EACAP,EAAAE,GAAA,KACA,GAAAM,GAAAL,QAGAC,EAcA,QAAAK,GAAAC,EAAAC,EAAAC,GACA,IACA,OAAAC,KAAA,SAAAD,IAAAF,EAAAI,KAAAH,EAAAC,IACA,MAAAG,GACA,OAAAF,KAAA,QAAAD,IAAAG,IAiBA,QAAAV,MACA,QAAAW,MACA,QAAAC,MASA,QAAAC,GAAAhC,IACA,OAAA,QAAA,UAAAiC,QAAA,SAAAC,GACAlC,EAAAkC,GAAA,SAAAR,GACA,MAAAS,MAAAf,QAAAc,EAAAR,MA8BA,QAAAU,GAAAV,GACAS,KAAAT,IAAAA,EAGA,QAAAW,GAAAnB,GAGA,QAAAoB,GAAAJ,EAAAR,GACA,GAAAa,GAAArB,EAAAgB,GAAAR,GACAtB,EAAAmC,EAAAnC,KACA,OAAAA,aAAAgC,GACAI,QAAAC,QAAArC,EAAAsB,KAAAgB,KAAAC,EAAAC,GACAJ,QAAAC,QAAArC,GAAAsC,KAAA,SAAAG,GAEA,MADAN,GAAAnC,MAAAyC,EACAN,GACAK,GAYA,QAAAE,GAAAZ,EAAAR,GACA,GAAAqB,GAaAC,EAAAA,EAAAN,KAAA,WACA,MAAAJ,GAAAJ,EAAAR,KACA,GAAAc,SAAA,SAAAC,GACAA,EAAAH,EAAAJ,EAAAR,KAQA,OAFAsB,GAAAD,EAAA,SAAAE,GAEAF,EAlCA,gBAAAG,UAAAA,QAAAC,SACAb,EAAAY,QAAAC,OAAAC,KAAAd,GAGA,IAGAU,GAHAL,EAAAL,EAAAc,KAAAlC,EAAA,QACA0B,EAAAN,EAAAc,KAAAlC,EAAA,SACA+B,EAAAX,EAAAc,KAAAlC,EAAA,SAiCAiB,MAAAf,QAAA0B,EAoBA,QAAAzB,GAAAP,EAAAE,EAAAqC,GACA,GAAAC,GAAAC,CAEA,OAAA,UAAArB,EAAAR,GACA,GAAA4B,IAAAE,EACA,KAAA,IAAAC,OAAA,+BAGA,IAAAH,IAAAI,EAGA,MAAAC,IAGA,QAAA,CACA,GAAAC,GAAAP,EAAAO,QACA,IAAAA,EAAA,CACA,GAAA,WAAA1B,GACA,UAAAA,GAAA0B,EAAAC,SAAA3B,KAAA4B,EAAA,CAGAT,EAAAO,SAAA,IAIA,IAAAG,GAAAH,EAAAC,SAAA,SACA,IAAAE,EAAA,CACA,GAAAC,GAAAzC,EAAAwC,EAAAH,EAAAC,SAAAnC,EACA,IAAA,UAAAsC,EAAArC,KAAA,CAGAO,EAAA,QACAR,EAAAsC,EAAAtC,GACA,WAIA,GAAA,WAAAQ,EAGA,SAIA,GAAA8B,GAAAzC,EACAqC,EAAAC,SAAA3B,GACA0B,EAAAC,SACAnC,EAGA,IAAA,UAAAsC,EAAArC,KAAA,CACA0B,EAAAO,SAAA,KAIA1B,EAAA,QACAR,EAAAsC,EAAAtC,GACA,UAMAQ,EAAA,OACAR,EAAAoC,CAEA,IAAAG,GAAAD,EAAAtC,GACA,KAAAuC,EAAAC,KAKA,MADAZ,GAAAa,EACAF,CAJAZ,GAAAO,EAAAQ,YAAAH,EAAA7D,MACAiD,EAAAgB,KAAAT,EAAAU,QAMAjB,EAAAO,SAAA,KAGA,GAAA,SAAA1B,EACAoB,IAAAa,EACAd,EAAAkB,KAAA7C,QAEA2B,GAAAkB,SAGA,IAAA,UAAArC,EAAA,CACA,GAAAoB,IAAAC,EAEA,KADAD,GAAAI,EACAhC,CAGA2B,GAAAmB,kBAAA9C,KAGAQ,EAAA,OACAR,EAAAoC,OAGA,WAAA5B,GACAmB,EAAAoB,OAAA,SAAA/C,EAGA4B,GAAAE,CAEA,IAAAQ,GAAAzC,EAAAT,EAAAE,EAAAqC,EACA,IAAA,WAAAW,EAAArC,KAAA,CAGA2B,EAAAD,EAAAa,KACAR,EACAS,CAEA,IAAAF,IACA7D,MAAA4D,EAAAtC,IACAwC,KAAAb,EAAAa,KAGA,IAAAF,EAAAtC,MAAAgD,EAOA,MAAAT,EANAZ,GAAAO,UAAA,SAAA1B,IAGAR,EAAAoC,OAMA,UAAAE,EAAArC,OACA2B,EAAAI,EAGAxB,EAAA,QACAR,EAAAsC,EAAAtC,OAkBA,QAAAiD,GAAAC,GACA,GAAAC,IAAAC,OAAAF,EAAA,GAEA,KAAAA,KACAC,EAAAE,SAAAH,EAAA,IAGA,IAAAA,KACAC,EAAAG,WAAAJ,EAAA,GACAC,EAAAI,SAAAL,EAAA,IAGAzC,KAAA+C,WAAAC,KAAAN,GAGA,QAAAO,GAAAP,GACA,GAAAb,GAAAa,EAAAQ,cACArB,GAAArC,KAAA,eACAqC,GAAAtC,IACAmD,EAAAQ,WAAArB,EAGA,QAAA1C,GAAAL,GAIAkB,KAAA+C,aAAAJ,OAAA,SACA7D,EAAAgB,QAAA0C,EAAAxC,MACAA,KAAAmD,QA8BA,QAAAC,GAAAC,GACA,GAAAA,EAAA,CACA,GAAAC,GAAAD,EAAAE,EACA,IAAAD,EACA,MAAAA,GAAA7D,KAAA4D,EAGA,IAAA,kBAAAA,GAAAnB,KACA,MAAAmB,EAGA,KAAAG,MAAAH,EAAAI,QAAA,CACA,GAAAC,GAAA,GAAAxB,EAAA,QAAAA,KACA,OAAAwB,EAAAL,EAAAI,QACA,GAAAE,EAAAlE,KAAA4D,EAAAK,GAGA,MAFAxB,GAAAjE,MAAAoF,EAAAK,GACAxB,EAAAH,MAAA,EACAG,CAOA,OAHAA,GAAAjE,MAAA0D,EACAO,EAAAH,MAAA,EAEAG,EAGA,OAAAA,GAAAA,KAAAA,GAKA,OAAAA,KAAAV,GAIA,QAAAA,KACA,OAAAvD,MAAA0D,EAAAI,MAAA,GAhbA,GACAJ,GADAgC,EAAA7F,OAAAD,UAAA+F,eAEAL,EACA,kBAAAM,SAAAA,OAAAnC,UAAA,aAEAoC,EAAA,gBAAAC,QACAC,EAAAvF,EAAAwF,kBACA,IAAAD,EAQA,YAPAF,IAGAC,OAAAG,QAAAF,GASAA,GAAAvF,EAAAwF,mBAAAH,EAAAC,OAAAG,WAaAF,EAAAtF,KAAAA,CAoBA,IAAA0C,GAAA,iBACAY,EAAA,iBACAX,EAAA,YACAE,EAAA,YAIAgB,KAUA4B,EAAAvE,EAAA/B,UAAAmB,EAAAnB,SACA8B,GAAA9B,UAAAsG,EAAAnG,YAAA4B,EACAA,EAAA5B,YAAA2B,EACAA,EAAAyE,YAAA,oBAYAJ,EAAAK,oBAAA,SAAAC,GACA,GAAAC,GAAA,kBAAAD,IAAAA,EAAAtG,WACA,OAAAuG,GACAA,IAAA5E,GAGA,uBAAA4E,EAAAH,aAAAG,EAAAC,OACA,GAGAR,EAAAS,KAAA,SAAAH,GAGA,MAFAA,GAAAjG,UAAAuB,EACA0E,EAAAzG,UAAAC,OAAAC,OAAAoG,GACAG,GAQAN,EAAAU,MAAA,SAAAnF,GACA,MAAA,IAAAU,GAAAV,IA+DAM,EAAAK,EAAArC,WAKAmG,EAAAW,MAAA,SAAAhG,EAAAC,EAAAC,EAAAC,GACA,GAAA8F,GAAA,GAAA1E,GACAxB,EAAAC,EAAAC,EAAAC,EAAAC,GAGA,OAAAkF,GAAAK,oBAAAzF,GACAgG,EACAA,EAAA1C,OAAA3B,KAAA,SAAAH,GACA,MAAAA,GAAA2B,KAAA3B,EAAAnC,MAAA2G,EAAA1C,UAgJArC,EAAAsE,GAEAA,EAAAZ,GAAA,WACA,MAAAvD,OAGAmE,EAAAU,SAAA,WACA,MAAA,sBAkCAb,EAAAc,KAAA,SAAAC,GACA,GAAAD,KACA,KAAA,GAAAE,KAAAD,GACAD,EAAA9B,KAAAgC,EAMA,OAJAF,GAAAG,UAIA,QAAA/C,KACA,KAAA4C,EAAArB,QAAA,CACA,GAAAuB,GAAAF,EAAAI,KACA,IAAAF,IAAAD,GAGA,MAFA7C,GAAAjE,MAAA+G,EACA9C,EAAAH,MAAA,EACAG,EAQA,MADAA,GAAAH,MAAA,EACAG,IAsCA8B,EAAAZ,OAAAA,EAMAjE,EAAAtB,WACAG,YAAAmB,EAEAgE,MAAA,WACAnD,KAAAmF,KAAA,EACAnF,KAAAkC,KAAA,EACAlC,KAAAoC,KAAAT,EACA3B,KAAA+B,MAAA,EACA/B,KAAAyB,SAAA,KAEAzB,KAAA+C,WAAAjD,QAAAmD,EAIA,KAAA,GAAAmC,GAAAC,EAAA,EACA1B,EAAAlE,KAAAO,KAAAoF,EAAA,IAAAC,IAAA,GAAAA,IACAA,EACArF,KAAAoF,GAAA,MAIAE,KAAA,WACAtF,KAAA+B,MAAA,CAEA,IAAAwD,GAAAvF,KAAA+C,WAAA,GACAyC,EAAAD,EAAArC,UACA,IAAA,UAAAsC,EAAAhG,KACA,KAAAgG,GAAAjG,GAGA,OAAAS,MAAAyF,MAGApD,kBAAA,SAAAqD,GAMA,QAAAC,GAAAC,EAAAC,GAIA,MAHAhE,GAAArC,KAAA,QACAqC,EAAAtC,IAAAmG,EACAxE,EAAAgB,KAAA0D,IACAC,EATA,GAAA7F,KAAA+B,KACA,KAAA2D,EAWA,KAAA,GARAxE,GAAAlB,KAQA0D,EAAA1D,KAAA+C,WAAAU,OAAA,EAAAC,GAAA,IAAAA,EAAA,CACA,GAAAhB,GAAA1C,KAAA+C,WAAAW,GACA7B,EAAAa,EAAAQ,UAEA,IAAA,SAAAR,EAAAC,OAIA,MAAAgD,GAAA,MAGA,IAAAjD,EAAAC,QAAA3C,KAAAmF,KAAA,CACA,GAAAW,GAAAnC,EAAAlE,KAAAiD,EAAA,YACAqD,EAAApC,EAAAlE,KAAAiD,EAAA,aAEA,IAAAoD,GAAAC,EAAA,CACA,GAAA/F,KAAAmF,KAAAzC,EAAAE,SACA,MAAA+C,GAAAjD,EAAAE,UAAA,EACA,IAAA5C,KAAAmF,KAAAzC,EAAAG,WACA,MAAA8C,GAAAjD,EAAAG,gBAGA,IAAAiD,GACA,GAAA9F,KAAAmF,KAAAzC,EAAAE,SACA,MAAA+C,GAAAjD,EAAAE,UAAA,OAGA,CAAA,IAAAmD,EAMA,KAAA,IAAAzE,OAAA,yCALA,IAAAtB,KAAAmF,KAAAzC,EAAAG,WACA,MAAA8C,GAAAjD,EAAAG,gBAUAP,OAAA,SAAA9C,EAAAD,GACA,IAAA,GAAAmE,GAAA1D,KAAA+C,WAAAU,OAAA,EAAAC,GAAA,IAAAA,EAAA,CACA,GAAAhB,GAAA1C,KAAA+C,WAAAW,EACA,IAAAhB,EAAAC,QAAA3C,KAAAmF,MACAxB,EAAAlE,KAAAiD,EAAA,eACA1C,KAAAmF,KAAAzC,EAAAG,WAAA,CACA,GAAAmD,GAAAtD,CACA,QAIAsD,IACA,UAAAxG,GACA,aAAAA,IACAwG,EAAArD,QAAApD,GACAA,GAAAyG,EAAAnD,aAGAmD,EAAA,KAGA,IAAAnE,GAAAmE,EAAAA,EAAA9C,aAUA,OATArB,GAAArC,KAAAA,EACAqC,EAAAtC,IAAAA,EAEAyG,EACAhG,KAAAkC,KAAA8D,EAAAnD,WAEA7C,KAAAiG,SAAApE,GAGAU,GAGA0D,SAAA,SAAApE,EAAAiB,GACA,GAAA,UAAAjB,EAAArC,KACA,KAAAqC,GAAAtC,GAGA,WAAAsC,EAAArC,MACA,aAAAqC,EAAArC,KACAQ,KAAAkC,KAAAL,EAAAtC,IACA,WAAAsC,EAAArC,MACAQ,KAAAyF,KAAA5D,EAAAtC,IACAS,KAAAkC,KAAA,OACA,WAAAL,EAAArC,MAAAsD,IACA9C,KAAAkC,KAAAY,IAIAoD,OAAA,SAAArD,GACA,IAAA,GAAAa,GAAA1D,KAAA+C,WAAAU,OAAA,EAAAC,GAAA,IAAAA,EAAA,CACA,GAAAhB,GAAA1C,KAAA+C,WAAAW,EACA,IAAAhB,EAAAG,aAAAA,EAGA,MAFA7C,MAAAiG,SAAAvD,EAAAQ,WAAAR,EAAAI,UACAG,EAAAP,GACAH,IAKA4D,QAAA,SAAAxD,GACA,IAAA,GAAAe,GAAA1D,KAAA+C,WAAAU,OAAA,EAAAC,GAAA,IAAAA,EAAA,CACA,GAAAhB,GAAA1C,KAAA+C,WAAAW,EACA,IAAAhB,EAAAC,SAAAA,EAAA,CACA,GAAAd,GAAAa,EAAAQ,UACA,IAAA,UAAArB,EAAArC,KAAA,CACA,GAAA4G,GAAAvE,EAAAtC,GACA0D,GAAAP,GAEA,MAAA0D,IAMA,KAAA,IAAA9E,OAAA,0BAGA+E,cAAA,SAAAhD,EAAApB,EAAAE,GAOA,MANAnC,MAAAyB,UACAC,SAAA0B,EAAAC,GACApB,WAAAA,EACAE,QAAAA,GAGAI,KAOA,gBAAA9D,QAAAA,OACA,gBAAA6H,QAAAA,OACA,gBAAAzH,MAAAA,KAAA8C,ODxBA,IE3lBA4E,qBAAA,WACA,QADAA,GACAC,GF8lBIlI,gBAAgB0B,KE/lBpBuG,GAEAvG,KAAAwG,MAAAA,EF+nBE,MEjoBFD,GAAA1I,UAKA4I,aAAAxC,mBAAAQ,KAAA,QAAAgC,GAAAC,GFimBI,GEhmBJvF,EFimBI,OAAO8C,oBAAmBvF,KAAK,SAAuBiI,GACpD,OAAU,OAAQA,EAAYxB,KAAOwB,EAAYzE,MAC/C,IAAK,GAGH,GEtmBVf,EAAAnB,KAAA4G,SAAAF,EAAAG,GAAA,IACAH,EAAAG,GAAA,KAAA1F,EAAA2F,MAAA,CFsmBYH,EAAYzE,KAAO,CACnB,OAIF,ME1mBVf,GAAA2F,QF0mBiBH,EAAYN,cEzmB7BrG,KAAA+G,SAAA5F,GAAA,KAAA,EF2mBQ,KAAK,GAEH,ME5mBVnB,MAAAwG,MAAAQ,eAAAN,GF4mBiBC,EAAYrE,OAAO,UE3mBpC,EF6mBQ,KAAK,GACH,MAAOqE,GAAYrE,OAAO,UE5mBpC,EF8mBQ,KAAK,GACL,IAAK,MACH,MAAOqE,GAAYrB,SAEtBmB,EAAczG,QE/nBrBuG,KAyBAU,uBAAA,WACA,QADAA,KF+mBI3I,gBAAgB0B,KE/mBpBiH,GAGAjH,KAAAkH,iBAEAlH,KAAAmH,2BAEAnH,KAAAoH,6BAAA,EFi1BE,MEx1BFH,GAAApJ,UAqBAwJ,oBAAA,SAAAC,EAAAC,EAAAC,GACA,GAAAF,EAAA7D,OAAA,EAOA,IAAA,GANAgE,IACAF,EAAAA,EACAC,KAAAA,MACAE,QAAAJ,EAAA7D,QAGAkE,EAAAL,EAAAM,EAAAC,MAAAC,QAAAH,GAAAI,EAAA,EAAAJ,EAAAC,EAAAD,EAAAA,EAAA9D,OAAAnC,cAAA,CFinBQ,GAAIsG,EAEJ,IAAIJ,EAAU,CACZ,GAAIG,GAAMJ,EAAUlE,OAAQ,KAC5BuE,GAAOL,EAAUI,SACZ,CAEL,GADAA,EAAKJ,EAAUzF,OACX6F,EAAGhG,KAAM,KACbiG,GAAOD,EAAG9J,MAGZ,GE5nBR4I,GAAAmB,EACAC,EAAAC,KAAAC,UAAAtB,GACAuB,EAAApI,KAAAkH,cAAAe,EACA,OAAAG,IACAA,KACApI,KAAAkH,cAAAe,GAAAG,GAEAA,EAAApF,KAAAyE,OAGAzH,MAAAmH,wBAAAnE,MACAuE,EAAAA,EACAC,KAAAA,OAIA,KAAAxH,KAAAoH,4BAAA,CAIApH,KAAAoH,6BAAA,CACA,IAAAZ,GAAAxG,IAEAA,MAAAqI,mBAAApE,mBAAAQ,KAAA,QAAA6D,KF8nBM,GE7nBNC,GAGAC,EAAAC,EAAAC,EAAAC,EAAAC,EAeAnB,EANAQ,EACAG,EACAvB,EAAAgC,EAAAC,EAAAC,EAAAC,CFinBM,OAAO/E,oBAAmBvF,KAAK,SAAqBuK,GAClD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GEjoBfqG,EAAA/B,EAAAW,wBACAX,EAAAW,2BAEAqB,EAAAhC,EAAAU,cACAV,EAAAU,iBAEAV,EAAAY,6BAAA,EFsoBYqB,EEpoBZF,EAAAG,EAAAb,MAAAC,QAAAW,GAAAE,EAAA,EAAAF,EAAAC,EAAAD,EAAAA,EAAA5E,OAAAnC,WFsoBU,KAAK,GACH,IAAKgH,EAAW,CACdO,EAAY/G,KAAO,EACnB,OAGF,KAAMyG,GAAOF,EAAWhF,QAAS,CAC/BwF,EAAY/G,KAAO,CACnB,OAGF,MAAO+G,GAAY3G,OAAO,QAAS,GAErC,KAAK,GACHsG,EAAQH,EAAWE,KACnBM,EAAY/G,KAAO,EACnB,MAEF,KAAK,IAGH,GAFAyG,EAAMF,EAAWvG,QAEZyG,EAAI5G,KAAM,CACbkH,EAAY/G,KAAO,EACnB,OAGF,MAAO+G,GAAY3G,OAAO,QAAS,GAErC,KAAK,IACHsG,EAAQD,EAAI1K,KAEd,KAAK,IAEH,MEvqBZwJ,GAAAmB,EFuqBmBK,EAAY5C,cEtqB/BoB,EAAAF,EAAA2B,MAAAlJ,KAAAyH,EAAAD,MAAA,KAAA,GFwqBU,KAAK,IACHyB,EAAY/G,KAAO,CACnB,MAEF,KAAK,IACH+G,EAAYE,GAAKlF,mBAAmBa,KE1qBhD0D,EF4qBU,KAAK,IACH,IAAKS,EAAYG,GAAKH,EAAYE,MAAMpH,KAAM,CAC5CkH,EAAY/G,KAAO,EACnB,OAMF,MErrBZ+F,GAAAgB,EAAAG,GAAAnL,MACAmK,EAAAI,EAAAP,GACApB,EAAAqB,KAAAmB,MAAApB,GFmrBmBgB,EAAY5C,cElrB/BrG,KAAAsJ,aAAAzC,GAAA,KAAA,GForBU,KAAK,IACH,GErrBZ,MFqrBkBoC,EAAYM,GErrB9B,CFsrBcN,EAAY/G,KAAO,EACnB,OEtrBdsE,EAAAU,cAAAe,GAAAG,EF0rBYa,EAAY/G,KAAO,EACnB,MAEF,KAAK,IACH2G,EE5rBZT,EAAAU,EAAAjB,MAAAC,QAAAe,GAAAE,EAAA,EAAAF,EAAAC,EAAAD,EAAAA,EAAAhF,OAAAnC,WF8rBU,KAAK,IACH,IAAKoH,EAAW,CACdG,EAAY/G,KAAO,EACnB,OAGF,KAAM6G,GAAOF,EAAWpF,QAAS,CAC/BwF,EAAY/G,KAAO,EACnB,OAGF,MAAO+G,GAAY3G,OAAO,QAAS,GAErC,KAAK,IACH0G,EAAQH,EAAWE,KACnBE,EAAY/G,KAAO,EACnB,MAEF,KAAK,IAGH,GAFA6G,EAAMF,EAAW3G,QAEZ6G,EAAIhH,KAAM,CACbkH,EAAY/G,KAAO,EACnB,OAGF,MAAO+G,GAAY3G,OAAO,QAAS,GAErC,KAAK,IACH0G,EAAQD,EAAI9K,KAEd,KAAK,IAGH,GEhuBZwJ,EAAAuB,EACA,MAAAvB,EAAAC,QAAA,CFguBcuB,EAAY/G,KAAO,EACnB,OAGF,MAAO+G,GAAY5C,cEnuB/BoB,EAAAF,EAAA2B,MAAAlJ,KAAAyH,EAAAD,MAAA,KAAA,GFquBU,KAAK,IACHyB,EAAY/G,KAAO,EACnB,MAEF,KAAK,IACH+G,EAAY/G,KAAO,EACnB,MAEF,KAAK,IACL,IAAK,MACH,MAAO+G,GAAY3D,SAEtBgD,EAAYtI,WE1zBrBiH,EAAApJ,UAiFAmJ,eAAA,SAAAN,GACA,GAAA0B,GAAApI,KAAAkH,cAAAR,EAAAG,GACA,IAAA,MAAAuB,EACA,IAAA,GAAAoB,GAAApB,EAAAqB,EAAA5B,MAAAC,QAAA0B,GAAAE,EAAA,EAAAF,EAAAC,EAAAD,EAAAA,EAAA3F,OAAAnC,cAAA,CFgvBQ,GAAIiI,EAEJ,IAAIF,EAAW,CACb,GAAIC,GAAOF,EAAW/F,OAAQ,KAC9BkG,GAAQH,EAAWE,SACd,CAEL,GADAA,EAAMF,EAAWtH,OACbwH,EAAI3H,KAAM,KACd4H,GAAQD,EAAIzL,MAGd,GE3vBRwJ,GAAAkC,CACA,OAAAlC,EAAAC,SACA1H,KAAAqH,uBAAAI,EAAAF,EAAAE,EAAAD,QAtFAP,KCrBA2C,QACAC,WACA9L,OAAAkG,mBAAAQ,KAAA,QAAA1G,GAAA2I,EAAAoD,GHq3BM,GGp3BN3I,EHq3BM,OAAO8C,oBAAmBvF,KAAK,SAAiBqL,GAC9C,OAAU,OAAQA,EAAY5E,KAAO4E,EAAY7H,MAC/C,IAAK,GACH,MAAO6H,GAAY1D,cGx3B/BrG,KAAA4G,SAAAkD,GAAA,KAAA,EH03BU,KAAK,GAIH,MG93BZ3I,GAAA4I,EAAAC,GACAtD,EAAAG,IAAAiD,EAAA3I,EAAA2F,OH63BmBiD,EAAY1D,cG53B/BrG,KAAAyG,aAAAC,GAAA,KAAA,EH83BU,KAAK,GACH,MAAOqD,GAAYzH,OAAO,SAAUyH,EAAYZ,GAElD,KAAK,GACL,IAAK,MACH,MAAOY,GAAYzE,SAEtBvH,EAAQiC,SGl4BjBiK,QACAlM,OAAAkG,mBAAAQ,KAAA,QAAA1G,GAAA2I,EACAoD,EACAI,EACAC,GHm4BM,MAAOlG,oBAAmBvF,KAAK,SAAiBqL,GAC9C,OAAU,OAAQA,EAAY5E,KAAO4E,EAAY7H,MAC/C,IAAK,GAKH,MGz4BZwE,GAAAwD,KAAAA,EAAAA,EAAArD,GAAA,KACAH,EAAA0D,OAAA1D,EAAAwD,KACAxD,EAAAyD,MAAAA,EAAAA,EAAAtD,GAAA,KACAH,EAAAlH,KAAA,SHs4BmBuK,EAAY1D,cGr4B/BuD,OAAAC,UAAA9L,OAAA2I,EAAAoD,GAAA,KAAA,EHu4BU,KAAK,GACH,GGt4BZ,MAAAI,EAAA,CHu4BcH,EAAY7H,KAAO,CACnB,OAIF,MG34BZgI,GAAAC,MAAAzD,EAAAG,GH24BmBkD,EAAY1D,cG14B/BrG,KAAAqK,aAAAH,GAAA,KAAA,EH44BU,KAAK,GACH,GG34BZ,MAAAC,EAAA,CH44BcJ,EAAY7H,KAAO,EACnB,OAIF,MGh5BZiI,GAAAD,KAAAxD,EAAAG,GHg5BmBkD,EAAY1D,cG/4B/BrG,KAAAqK,aAAAF,GAAA,KAAA,GHi5BU,KAAK,IACH,MAAOJ,GAAYzH,OAAO,SGh5BtCoE,EHk5BU,KAAK,IACL,IAAK,MACH,MAAOqD,GAAYzE,SAEtBvH,EAAQiC,QGp5BjBsK,YAAA,SAAA5D,EAAAY,GAGA,MAFAA,GAAAtE,KAAA0D,EAAAwD,MACA5C,EAAAtE,KAAA0D,EAAAyD,OACA7C,GAEAiD,QAAAtG,mBAAAQ,KAAA,QAAA8F,GAAA7D,GHu5BM,MAAOzC,oBAAmBvF,KAAK,SAAkBqL,GAC/C,OAAU,OAAQA,EAAY5E,KAAO4E,EAAY7H,MAC/C,IAAK,GACH,MAAO6H,GAAYzH,OAAO,SGz5BtCoE,EH25BU,KAAK,GACL,IAAK,MACH,MAAOqD,GAAYzE,SAEtBiF,EAASvK,UIj7BlBL,kBAAAsE,mBAAAQ,KAAA,QAAA+F,KJy7BE,MAAOvG,oBAAmBvF,KAAK,SAAqBqL,GAClD,OAAU,OAAQA,EAAY5E,KAAO4E,EAAY7H,MAC/C,IAAK,GACL,IAAK,MACH,MAAO6H,GAAYzE,SAEtBkF,EAAYxK,QI/7BjBhC,YAEAyM,UAAA,WJm8BE,GIl8BFC,GAAA,SAAAC,GAMA,QANAD,GAMAlE,GJ87BMlI,gBAAgB0B,KIp8BtB0K,GAOAC,EAAAlL,KAAAO,KAAAwG,GACAxG,KAAA4K,YAAApE,EAAAqE,GAAAD,aAAA,iBAAA,eAAA,aACA5K,KAAA8K,GAAA9K,KAAA4K,YAAAG,YAAA,eACA/K,KAAAgL,GAAAhL,KAAA4K,YAAAG,YAAA,kBACA/K,KAAAiL,UJsuCI,MApSAxN,WI78BJiN,EAAAC,GAAAD,EAAA7M,UAaAwM,aAAApG,mBAAAQ,KAAA,QAAA4F,GAAA3D,GJm8BM,MAAOzC,oBAAmBvF,KAAK,SAAuBuK,GACpD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GAEH,MADA+G,GAAY/G,KAAO,EIr8B/BlC,KAAAgL,GAAAE,IAAAxE,EJw8BU,KAAK,GAEH,MIz8BZ1G,MAAAiL,OAAA/C,KAAAC,UAAAzB,EAAAG,KAAAH,EJy8BmBuC,EAAY3G,OAAO,SIx8BtCoE,EJ08BU,KAAK,GACL,IAAK,MACH,MAAOuC,GAAY3D,SAEtB+E,EAAcrK,QI99BvB0K,EAAA7M,UAkBAyL,aAAArF,mBAAAQ,KAAA,QAAA6E,GAAAzC,GJ+8BM,GI98BNH,EJ+8BM,OAAOzC,oBAAmBvF,KAAK,SAAuBuK,GACpD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GAGH,GIp9BZwE,EAAA1G,KAAAiL,OAAA/C,KAAAC,UAAAtB,IACA,MAAAH,EAAA,CJo9BcuC,EAAY/G,KAAO,CACnB,OAIF,MADA+G,GAAY/G,KAAO,EIv9B/BlC,KAAAgL,GAAAG,IAAAtE,EJ09BU,KAAK,GI19BfH,EAAAuC,EAAA7G,KACApC,KAAAiL,OAAA/C,KAAAC,UAAAtB,IAAAH,CJ89BU,KAAK,GACH,MAAOuC,GAAY3G,OAAO,SI79BtCoE,EJ+9BU,KAAK,GACL,IAAK,MACH,MAAOuC,GAAY3D,SAEtBgE,EAActJ,QI3/BvB0K,EAAA7M,UA0BAuN,gBAAAnH,mBAAAQ,KAAA,QAAA2G,GAAAvE,GJo+BM,MAAO5C,oBAAmBvF,KAAK,SAA0BuK,GACvD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GAGH,MIx+BZlC,MAAAiL,OAAA/C,KAAAC,UAAAtB,IAAA,KJu+BYoC,EAAY/G,KAAO,EIt+B/BlC,KAAAgL,GAAA,UAAAnE,EJy+BU,KAAK,GACH,MAAOoC,GAAY3G,OAAO,SAAU2G,EAAY7G,KAElD,KAAK,GACL,IAAK,MACH,MAAO6G,GAAY3D,SAEtB8F,EAAiBpL,QI5gC1B0K,EAAA7M,UA8BAkJ,SAAA9C,mBAAAQ,KAAA,QAAAsC,GAAA5F,GJi/BM,MAAO8C,oBAAmBvF,KAAK,SAAmBuK,GAChD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GAEH,MADA+G,GAAY/G,KAAO,EIn/B/BlC,KAAA8K,GAAAI,IAAA/J,EJs/BU,KAAK,GACH,MAAO8H,GAAY3G,OAAO,SAAU2G,EAAY7G,KAElD,KAAK,GACL,IAAK,MACH,MAAO6G,GAAY3D,SAEtByB,EAAU/G,QI5hCnB0K,EAAA7M,UAiCA+I,SAAA3C,mBAAAQ,KAAA,QAAAmC,GAAAkD,GJ8/BM,GI7/BN3I,EJ8/BM,OAAO8C,oBAAmBvF,KAAK,SAAmBuK,GAChD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GAEH,MADA+G,GAAY/G,KAAO,EIhgC/BlC,KAAA8K,GAAAK,IAAArB,EJmgCU,KAAK,GAGH,GAFAb,EAAYe,GIpgCxB7I,EAAA8H,EAAA7G,KAAA,MJsgCkB6G,EAAYe,GItgC9B,CJugCcf,EAAY/G,KAAO,CACnB,OAGF,MAAO+G,GAAY3G,OAAO,SI1gCtCnB,EJ4gCU,KAAK,GACH,MAAO8H,GAAY3G,OAAO,UI1gCtCwH,KAAAA,EACAhD,MAAA,GJ8gCU,KAAK,GACL,IAAK,MACH,MAAOmC,GAAY3D,SAEtBsB,EAAU5G,QI1jCnB0K,EAAA7M,UA4CAwN,eAAApH,mBAAAQ,KAAA,QAAA4G,KJihCM,GIhhCNC,GACAC,EACAC,CJ+gCM,OAAOvH,oBAAmBvF,KAAK,SAAyBuK,GACtD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GInhCfoJ,KACAC,EAAAvL,KAAA8K,GAAAW,YJshCU,KAAK,GAEH,MADAxC,GAAY/G,KAAO,EIrhC/BqJ,CJwhCU,KAAK,GAGH,GAFAtC,EAAYe,GIzhCxBwB,EAAAvC,EAAA7G,KAAA,MJ2hCkB6G,EAAYe,GI3hC9B,CJ4hCcf,EAAY/G,KAAO,EACnB,OI5hCdoJ,EAAAtI,KAAAwI,EAAAvN,OACAuN,EAAA,cJgiCYvC,EAAY/G,KAAO,CACnB,MAEF,KAAK,IACH,MAAO+G,GAAY3G,OAAO,SIliCtCgJ,EJoiCU,KAAK,IACL,IAAK,MACH,MAAOrC,GAAY3D,SAEtB+F,EAAgBrL,QI5lCzB0K,EAAA7M,UAsDA6N,YAAAzH,mBAAAQ,KAAA,QAAAiH,KJyiCM,GIxiCNZ,GACAa,EAAAC,EAAAC,EAAAC,EAAAC,EACA5K,CJwiCM,OAAO8C,oBAAmBvF,KAAK,SAAsBuK,GACnD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GACH,MAAO+G,GAAY5C,cI7iC/BrG,KAAAqL,iBAAA,KAAA,EJ+iCU,KAAK,GI/iCfP,EAAA7B,EAAAe,GACA2B,KJijCYC,EIhjCZd,EAAAe,EAAAhE,MAAAC,QAAA8D,GAAAE,EAAA,EAAAF,EAAAC,EAAAD,EAAAA,EAAA/H,OAAAnC,WJkjCU,KAAK,GACH,IAAKmK,EAAW,CACd5C,EAAY/G,KAAO,EACnB,OAGF,KAAM4J,GAAOF,EAAWnI,QAAS,CAC/BwF,EAAY/G,KAAO,CACnB,OAGF,MAAO+G,GAAY3G,OAAO,QAAS,GAErC,KAAK,GACHyJ,EAAQH,EAAWE,KACnB7C,EAAY/G,KAAO,EACnB,MAEF,KAAK,IAGH,GAFA4J,EAAMF,EAAW1J,QAEZ4J,EAAI/J,KAAM,CACbkH,EAAY/G,KAAO,EACnB,OAGF,MAAO+G,GAAY3G,OAAO,QAAS,GAErC,KAAK,IACHyJ,EAAQD,EAAI7N,KAEd,KAAK,IIjlCfkD,EAAA4K,EACAJ,EAAAxK,EAAA2I,MAAA3I,EAAA2F,KJqlCU,KAAK,IACHmC,EAAY/G,KAAO,CACnB,MAEF,KAAK,IACH,MAAO+G,GAAY3G,OAAO,SIxlCtCqJ,EJ0lCU,KAAK,IACL,IAAK,MACH,MAAO1C,GAAY3D,SAEtBoG,EAAa1L,QI1pCtB0K,EAAA7M,UA+DAmO,cAAA/H,mBAAAQ,KAAA,QAAAuH,GAAAC,GJ8lCM,GI1lCNC,GAEAC,EAAAC,EAAAC,EAAAC,EAAAC,EACAC,EACA1C,EACA2C,EACAC,EACAC,EACApB,EACAC,CJmlCM,OAAOvH,oBAAmBvF,KAAK,SAAwBuK,GACrD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GAKH,MItmCZ,OAAA+J,IACAA,MAEAC,KJmmCmBjD,EAAY5C,cIjmC/BrG,KAAAqL,iBAAA,KAAA,EJmmCU,KAAK,GInmCfc,EAAAlD,EAAAe,GJqmCYoC,EIpmCZD,EAAAE,EAAAxE,MAAAC,QAAAsE,GAAAE,EAAA,EAAAF,EAAAC,EAAAD,EAAAA,EAAAvI,OAAAnC,WJsmCU,KAAK,GACH,IAAK2K,EAAW,CACdpD,EAAY/G,KAAO,EACnB,OAGF,KAAMoK,GAAOF,EAAW3I,QAAS,CAC/BwF,EAAY/G,KAAO,CACnB,OAGF,MAAO+G,GAAY3G,OAAO,QAAS,GAErC,KAAK,GACHiK,EAAQH,EAAWE,KACnBrD,EAAY/G,KAAO,EACnB,MAEF,KAAK,IAGH,GAFAoK,EAAMF,EAAWlK,QAEZoK,EAAIvK,KAAM,CACbkH,EAAY/G,KAAO,EACnB,OAGF,MAAO+G,GAAY3G,OAAO,QAAS,GAErC,KAAK,IACHiK,EAAQD,EAAIrO,KAEd,KAAK,IIroCfuO,EAAAD,EACAzC,EAAA0C,EAAA1C,KACA2C,EAAAR,EAAAnC,IAAA,EACA4C,EAAAF,EAAA1F,MACA6F,EAAAC,YAAAC,OAAA/C,EAAA2C,IAAA3C,EAAA4C,IACAnB,EAAAvL,KAAAgL,GAAAS,WAAAkB,EJwoCU,KAAK,IAEH,MADA1D,GAAY/G,KAAO,GIvoC/BqJ,CJ0oCU,KAAK,IAGH,GAFAtC,EAAYE,GI3oCxBqC,EAAAvC,EAAA7G,KAAA,MJ6oCkB6G,EAAYE,GI7oC9B,CJ8oCcF,EAAY/G,KAAO,EACnB,OI9oCdgK,EAAAlJ,KAAAwI,EAAAvN,OACAuN,EAAA,cJkpCYvC,EAAY/G,KAAO,EACnB,MAEF,KAAK,IACH+G,EAAY/G,KAAO,CACnB,MAEF,KAAK,IACH,MAAO+G,GAAY3G,OAAO,SIvpCtC4J,EJypCU,KAAK,IACL,IAAK,MACH,MAAOjD,GAAY3D,SAEtB0G,EAAehM,QI/uCxB0K,GAAAnE,qBAqFAuG,EAAA,SAAAC,GAIA,QAJAD,GAIAE,GA2BA,QAAAC,GAAAC,GACA,GAAAC,GAAAD,EAAAjP,KACAiP,GAAAnL,OACAoL,EAAAnP,cAAAoP,YACAD,EAAAnP,cAAAqP,WACAF,EAAAG,UAAA,WACAL,EAAAM,EAAArL,KAAAiL,EAAA/M,UAEA+M,EAAAK,QAAA,SAAA9N,GACA6N,EAAA,SAAA7N,KAEAyN,IAAA3G,EAAAiH,iBACAN,EAAAO,MAAAjK,OAAA,EACAwJ,EAAAM,EAAArL,KAAAiL,EAAAO,MAAAC,UAEAR,EAAAS,UAAA,WACAT,EAAAS,UAAA,KACAX,EAAAM,EAAArL,KAAAiL,EAAAO,MAAAC,WAGAR,EAAAnP,cAAA6P,kBACAV,EAAAG,UAAA,SAAAQ,GACA,GAAAjD,GAAAiD,EAAAC,OAAA3N,MACA6M,GAAAM,EAAArL,KAAA2I,KAEAsC,EAAAK,QAAA,WACAD,EAAA,SAAA,sCAEAJ,EAAAa,gBAAA,SAAAF,GACA,GAAAjD,GAAAiD,EAAAC,OAAA3N,MACAyK,GAAAoD,kBAAA,kBAAAC,QAAA,OACArD,EAAAoD,kBAAA,eAAAC,QAAA,WAGAX,EAAA,SAAA,iCJgmCMjP,gBAAgB0B,KIjqCtB8M,GAKAC,EAAAtN,KAAAO,MACAA,KAAAgN,UAAAA,EACAhN,KAAAyN,kBACAC,SACAE,UAAA,KAGA,IAAApH,GAAAxG,KAEAuN,EAAAtJ,mBAAAQ,KAAA,QAAA0J,KJ+pCQ,GI7pCRV,GAEA7C,EACAwD,EAEAjB,CJypCQ,OAAOlJ,oBAAmBvF,KAAK,SAAyB2P,GACtD,OAAU,OAAQA,EAAYlJ,KAAOkJ,EAAYnM,MAC/C,IAAK,GAEH,MADAmM,GAAYnM,KAAO,EIlqCjCoM,UAAAC,KAAAvB,EAAA,EJqqCY,KAAK,GIrqCjBxG,EAAAqE,GAAAwD,EAAAjM,KACAqL,EAAAjH,EAAAiH,iBAEA7C,EAAA,KACAwD,GAAA,CJuqCY,KAAK,GACH,IIvqCdA,EAAA,CJwqCgBC,EAAYnM,KAAO,EACnB,OAIF,MADAmM,GAAYnM,KAAO,EI3qCjCuL,CJ8qCY,KAAK,GAKH,MInrCdN,GAAAkB,EAAAjM,KACAwI,EAAA,GAAAF,GAAAlE,GJkrCqB6H,EAAYhI,cIhrCjC8G,EAAA1N,KAAAmL,GAAA,KAAA,GJkrCY,KAAK,IACHyD,EAAYnM,KAAO,CACnB,MAEF,KAAK,IACL,IAAK,MACH,MAAOmM,GAAY/I,SIlsCjC6I,EAAAnO,SAsDAiN,GAAAM,EAAArL,QJ+sCI,MAvBAzE,WI5vCJqP,EAAAC,GAAAD,EAAAjP,UAuEAwK,mBAAA,SAAAmG,GACAxO,KAAAyN,iBAAAC,MAAA1K,KAAAwL,GACA,MAAAxO,KAAAyN,iBAAAG,WACA5N,KAAAyN,iBAAAG,aA1EAd,EAAAjP,UA6EA4Q,eAAAxK,mBAAAQ,KAAA,QAAAgK,KJyrCM,MAAOxK,oBAAmBvF,KAAK,SAAyBuK,GACtD,OAAU,OAAQA,EAAY9D,KAAO8D,EAAY/G,MAC/C,IAAK,GAGH,MI7rCZlC,MAAA6K,GAAA6D,QJ4rCYzF,EAAY/G,KAAO,EI3rC/BoM,UAAAK,eAAA3O,KAAAgN,UJ8rCU,KAAK,GACL,IAAK,MACH,MAAO/D,GAAY3D,SAEtBmJ,EAAgBzO,QIjxCzB8M,GAAA7F,uBAkFA,OAAA6F","file":"y.js","sourcesContent":[null,"/**\n * Copyright (c) 2014, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * https://raw.github.com/facebook/regenerator/master/LICENSE file. An\n * additional grant of patent rights can be found in the PATENTS file in\n * the same directory.\n */\n\n!(function(global) {\n \"use strict\";\n\n var hasOwn = Object.prototype.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var iteratorSymbol =\n typeof Symbol === \"function\" && Symbol.iterator || \"@@iterator\";\n\n var inModule = typeof module === \"object\";\n var runtime = global.regeneratorRuntime;\n if (runtime) {\n if (inModule) {\n // If regeneratorRuntime is defined globally and we're in a module,\n // make the exports object identical to regeneratorRuntime.\n module.exports = runtime;\n }\n // Don't bother evaluating the rest of this file if the runtime was\n // already defined globally.\n return;\n }\n\n // Define the runtime globally (as expected by generated code) as either\n // module.exports (if we're in a module) or a new, empty object.\n runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided, then outerFn.prototype instanceof Generator.\n var generator = Object.create((outerFn || Generator).prototype);\n\n generator._invoke = makeInvokeMethod(\n innerFn, self || null,\n new Context(tryLocsList || [])\n );\n\n return generator;\n }\n runtime.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype;\n GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n GeneratorFunctionPrototype.constructor = GeneratorFunction;\n GeneratorFunction.displayName = \"GeneratorFunction\";\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n prototype[method] = function(arg) {\n return this._invoke(method, arg);\n };\n });\n }\n\n runtime.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n runtime.mark = function(genFun) {\n genFun.__proto__ = GeneratorFunctionPrototype;\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `value instanceof AwaitArgument` to determine if the yielded value is\n // meant to be awaited. Some may consider the name of this method too\n // cutesy, but they are curmudgeons.\n runtime.awrap = function(arg) {\n return new AwaitArgument(arg);\n };\n\n function AwaitArgument(arg) {\n this.arg = arg;\n }\n\n function AsyncIterator(generator) {\n // This invoke function is written in a style that assumes some\n // calling function (or Promise) will handle exceptions.\n function invoke(method, arg) {\n var result = generator[method](arg);\n var value = result.value;\n return value instanceof AwaitArgument\n ? Promise.resolve(value.arg).then(invokeNext, invokeThrow)\n : Promise.resolve(value).then(function(unwrapped) {\n result.value = unwrapped;\n return result;\n }, invokeThrow);\n }\n\n if (typeof process === \"object\" && process.domain) {\n invoke = process.domain.bind(invoke);\n }\n\n var invokeNext = invoke.bind(generator, \"next\");\n var invokeThrow = invoke.bind(generator, \"throw\");\n var invokeReturn = invoke.bind(generator, \"return\");\n var previousPromise;\n\n function enqueue(method, arg) {\n var enqueueResult =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(function() {\n return invoke(method, arg);\n }) : new Promise(function(resolve) {\n resolve(invoke(method, arg));\n });\n\n // Avoid propagating enqueueResult failures to Promises returned by\n // later invocations of the iterator, and call generator.return() to\n // allow the generator a chance to clean up.\n previousPromise = enqueueResult[\"catch\"](invokeReturn);\n\n return enqueueResult;\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n runtime.async = function(innerFn, outerFn, self, tryLocsList) {\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList)\n );\n\n return runtime.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n if (method === \"return\" ||\n (method === \"throw\" && delegate.iterator[method] === undefined)) {\n // A return or throw (when the delegate iterator has no throw\n // method) always terminates the yield* loop.\n context.delegate = null;\n\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n var returnMethod = delegate.iterator[\"return\"];\n if (returnMethod) {\n var record = tryCatch(returnMethod, delegate.iterator, arg);\n if (record.type === \"throw\") {\n // If the return method threw an exception, let that\n // exception prevail over the original return or throw.\n method = \"throw\";\n arg = record.arg;\n continue;\n }\n }\n\n if (method === \"return\") {\n // Continue with the outer return, now that the delegate\n // iterator has been terminated.\n continue;\n }\n }\n\n var record = tryCatch(\n delegate.iterator[method],\n delegate.iterator,\n arg\n );\n\n if (record.type === \"throw\") {\n context.delegate = null;\n\n // Like returning generator.throw(uncaught), but without the\n // overhead of an extra function call.\n method = \"throw\";\n arg = record.arg;\n continue;\n }\n\n // Delegate generator ran and handled its own exceptions so\n // regardless of what the method was, we continue as if it is\n // \"next\" with an undefined arg.\n method = \"next\";\n arg = undefined;\n\n var info = record.arg;\n if (info.done) {\n context[delegate.resultName] = info.value;\n context.next = delegate.nextLoc;\n } else {\n state = GenStateSuspendedYield;\n return info;\n }\n\n context.delegate = null;\n }\n\n if (method === \"next\") {\n if (state === GenStateSuspendedYield) {\n context.sent = arg;\n } else {\n delete context.sent;\n }\n\n } else if (method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw arg;\n }\n\n if (context.dispatchException(arg)) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n method = \"next\";\n arg = undefined;\n }\n\n } else if (method === \"return\") {\n context.abrupt(\"return\", arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n var info = {\n value: record.arg,\n done: context.done\n };\n\n if (record.arg === ContinueSentinel) {\n if (context.delegate && method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n arg = undefined;\n }\n } else {\n return info;\n }\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(arg) call above.\n method = \"throw\";\n arg = record.arg;\n }\n }\n };\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n Gp[iteratorSymbol] = function() {\n return this;\n };\n\n Gp.toString = function() {\n return \"[object Generator]\";\n };\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset();\n }\n\n runtime.keys = function(object) {\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n runtime.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function() {\n this.prev = 0;\n this.next = 0;\n this.sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.tryEntries.forEach(resetTryEntry);\n\n // Pre-initialize at least 20 temporary variables to enable hidden\n // class optimizations for simple generators.\n for (var tempIndex = 0, tempName;\n hasOwn.call(this, tempName = \"t\" + tempIndex) || tempIndex < 20;\n ++tempIndex) {\n this[tempName] = null;\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n return !!caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.next = finallyEntry.finallyLoc;\n } else {\n this.complete(record);\n }\n\n return ContinueSentinel;\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = record.arg;\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n return ContinueSentinel;\n }\n };\n})(\n // Among the various tricks for obtaining a reference to the global\n // object, this seems to be the most reliable technique that does not\n // use indirect eval (which violates Content Security Policy).\n typeof global === \"object\" ? global :\n typeof window === \"object\" ? window :\n typeof self === \"object\" ? self : this\n);\n","/* @flow */\nclass AbstractTransaction { //eslint-disable-line no-unused-vars\n constructor (store : OperationStore) {\n this.store = store;\n }\n // Throws if operation is not expected.\n *addOperation (op) {\n var state = this.getState(op.id[0]);\n if (op.id[1] === state.clock){\n state.clock++;\n yield* this.setState(state);\n this.store.operationAdded(op);\n return true;\n } else {\n return false;\n }\n }\n}\n\ntype Listener = {\n f : GeneratorFunction, // is called when all operations are available\n missing : number // number of operations that are missing\n}\n\ntype Id = [string, number];\n\nclass AbstractOperationStore { //eslint-disable-line no-unused-vars\n constructor () {\n // E.g. this.listenersById[id] : Array<Listener>\n this.listenersById = {};\n // Execute the next time a transaction is requested\n this.listenersByIdExecuteNow = [];\n // A transaction is requested\n this.listenersByIdRequestPending = false;\n /* To make things more clear, the following naming conventions:\n * ls : we put this.listenersById on ls\n * l : Array<Listener>\n * id : Id (can't use as property name)\n * sid : String (converted from id via JSON.stringify\n so we can use it as a property name)\n\n Always remember to first overwrite over\n a property before you iterate over it!\n */\n }\n // f is called as soon as every operation requested is available.\n // Note that Transaction can (and should) buffer requests.\n whenOperationsExist (ids : Array<Id>, f : GeneratorFunction, args : Array<any>) {\n if (ids.length > 0) {\n let listener : Listener = {\n f: f,\n args: args || [],\n missing: ids.length\n };\n\n for (let id of ids) {\n let sid = JSON.stringify(id);\n let l = this.listenersById[sid];\n if (l == null){\n l = [];\n this.listenersById[sid] = l;\n }\n l.push(listener);\n }\n } else {\n this.listenersByIdExecuteNow.push({\n f: f,\n args: args || []\n });\n }\n\n if (this.listenersByIdRequestPending){\n return;\n }\n\n this.listenersByIdRequestPending = true;\n var store = this;\n\n this.requestTransaction(function*(){\n var exeNow = store.listenersByIdExecuteNow;\n store.listenersByIdExecuteNow = [];\n\n var ls = store.listenersById;\n store.listenersById = {};\n\n store.listenersByIdRequestPending = false;\n\n for (let listener of exeNow) {\n yield* listener.f.apply(this, listener.args);\n }\n\n for (var sid in ls){\n var l = ls[sid];\n var id = JSON.parse(sid);\n if ((yield* this.getOperation(id)) == null){\n store.listenersById[sid] = l;\n } else {\n for (let listener of l) {\n if (--listener.missing === 0){\n yield* listener.f.apply(this, listener.args);\n }\n }\n }\n }\n });\n }\n // called by a transaction when an operation is added\n operationAdded (op) {\n var l = this.listenersById[op.id];\n if (l != null) {\n for (var listener of l){\n if (--listener.missing === 0){\n this.whenOperationsExist([], listener.f, listener.args);\n }\n }\n }\n }\n}\n","/* @flow */\n\n// Op is anything that we could get from the OperationStore.\ntype Op = Object;\n\nvar Struct = {\n Operation: { //eslint-disable-line no-unused-vars\n create: function*(op : Op, user : string) : Struct.Operation {\n var state = yield* this.getState(user);\n op.id = [user, state.clock];\n return yield* this.addOperation(op);\n }\n },\n Insert: {\n create: function*( op : Op,\n user : string,\n left : Struct.Insert,\n right : Struct.Insert) : Struct.Insert {\n op.left = left ? left.id : null;\n op.origin = op.left;\n op.right = right ? right.id : null;\n op.type = \"Insert\";\n yield* Struct.Operation.create(op, user);\n\n if (left != null) {\n left.right = op.id;\n yield* this.setOperation(left);\n }\n if (right != null) {\n right.left = op.id;\n yield* this.setOperation(right);\n }\n return op;\n },\n requiredOps: function(op, ids){\n ids.push(op.left);\n ids.push(op.right);\n return ids;\n },\n execute: function*(op){\n return op;\n }\n }\n};\n","\ntype State = {\n user: string,\n clock: number\n};\n\ntype StateVector = Array<State>;\n\ntype StateSet = Object;\n\ntype IDBTransaction = Function;\ntype IDBObjectStore = Function;\ntype IDBRequest = Function;\ntype IDBCursor = Function;\ntype IDBKeyRange = Function;\n\ntype IDBOpenDBRequest = Function;\n\ndeclare var indexedDB : Object;\n\ndeclare var setTimeout : Function;\n\nvar GeneratorFunction = (function*(){}).constructor;\n\nvar IndexedDB = (function(){ //eslint-disable-line no-unused-vars\n class Transaction extends AbstractTransaction { //eslint-disable-line\n transaction: IDBTransaction;\n sv: IDBObjectStore;\n os: IDBObjectStore;\n store: OperationStore;\n\n constructor (store : OperationStore) {\n super(store);\n this.transaction = store.db.transaction([\"OperationStore\", \"StateVector\"], \"readwrite\");\n this.sv = this.transaction.objectStore(\"StateVector\");\n this.os = this.transaction.objectStore(\"OperationStore\");\n this.buffer = {};\n }\n *setOperation (op) {\n yield this.os.put(op);\n this.buffer[JSON.stringify(op.id)] = op;\n return op;\n }\n *getOperation (id) {\n var op = this.buffer[JSON.stringify(id)];\n if (op == null) {\n op = yield this.os.get(id);\n this.buffer[JSON.stringify(id)] = op;\n }\n return op;\n }\n *removeOperation (id) {\n this.buffer[JSON.stringify(id)] = null;\n return yield this.os.delete(id);\n }\n *setState (state : State) : State {\n return yield this.sv.put(state);\n }\n *getState (user : string) : State {\n var state;\n if ((state = yield this.sv.get(user)) != null){\n return state;\n } else {\n return {\n user: user,\n clock: 0\n };\n }\n }\n *getStateVector () : StateVector {\n var stateVector = [];\n var cursorResult = this.sv.openCursor();\n var cursor;\n while ((cursor = yield cursorResult) != null) {\n stateVector.push(cursor.value);\n cursor.continue();\n }\n return stateVector;\n }\n *getStateSet () : StateSet {\n var sv : StateVector = yield* this.getStateVector();\n var ss : StateSet = {};\n for (var state of sv){\n ss[state.user] = state.clock;\n }\n return ss;\n }\n\n *getOperations (startSS : StateSet) {\n if (startSS == null){\n startSS = {};\n }\n var ops = [];\n\n var endSV : StateVector = yield* this.getStateVector();\n for (var endState of endSV) {\n var user = endState.user;\n var startPos = startSS[user] || 0;\n var endPos = endState.clock;\n var range = IDBKeyRange.bound([user, startPos], [user, endPos]);\n var cursorResult = this.os.openCursor(range);\n var cursor;\n while ((cursor = yield cursorResult) != null) {\n ops.push(cursor.value);\n cursor.continue();\n }\n }\n return ops;\n }\n }\n class OperationStore extends AbstractOperationStore { //eslint-disable-line no-undef\n namespace: string;\n ready: Promise;\n whenReadyListeners: Array<Function>;\n constructor (namespace : string) {\n super();\n this.namespace = namespace;\n this.transactionQueue = {\n queue: [],\n onRequest: null\n };\n\n var store = this;\n\n var tGen = (function *transactionGen(){\n store.db = yield indexedDB.open(namespace, 3);\n var transactionQueue = store.transactionQueue;\n\n var transaction = null;\n var cont = true;\n while (cont) {\n var request = yield transactionQueue;\n transaction = new Transaction(store);\n\n yield* request.call(transaction);/*\n while (transactionQueue.queue.length > 0) {\n yield* transactionQueue.queue.shift().call(transaction);\n }*/\n }\n })();\n\n function handleTransactions(t){ //eslint-disable-line no-unused-vars\n var request = t.value;\n if (t.done){\n } else if (request.constructor === IDBRequest\n || request.constructor === IDBCursor ) {\n request.onsuccess = function(){\n handleTransactions(tGen.next(request.result));\n };\n request.onerror = function(err){\n tGen.throw(err);\n };\n } else if (request === store.transactionQueue) {\n if (request.queue.length > 0){\n handleTransactions(tGen.next(request.queue.shift()));\n } else {\n request.onRequest = function(){\n request.onRequest = null;\n handleTransactions(tGen.next(request.queue.shift()));\n };\n }\n } else if ( request.constructor === IDBOpenDBRequest ) {\n request.onsuccess = function(event){\n var db = event.target.result;\n handleTransactions(tGen.next(db));\n };\n request.onerror = function(){\n tGen.throw(\"Couldn't open IndexedDB database!\");\n };\n request.onupgradeneeded = function(event){\n var db = event.target.result;\n db.createObjectStore(\"OperationStore\", {keyPath: \"id\"});\n db.createObjectStore(\"StateVector\", {keyPath: \"user\"});\n };\n } else {\n tGen.throw(\"You can not yield this type!\");\n }\n }\n handleTransactions(tGen.next());\n\n }\n requestTransaction (makeGen : Function) {\n this.transactionQueue.queue.push(makeGen);\n if (this.transactionQueue.onRequest != null) {\n this.transactionQueue.onRequest();\n }\n }\n *removeDatabase () {\n this.db.close();\n yield indexedDB.deleteDatabase(this.namespace);\n }\n }\n return OperationStore;\n})();\n"],"sourceRoot":"/source/"} \ No newline at end of file +{"version":3,"sources":["y.js","runtime.js","OperationStore.js","Operations.js","OperationStores/IndexedDB.js"],"names":["_inherits","subClass","superClass","TypeError","prototype","Object","create","constructor","value","enumerable","writable","configurable","__proto__","_classCallCheck","instance","Constructor","global","wrap","innerFn","outerFn","self","tryLocsList","generator","Generator","_invoke","makeInvokeMethod","Context","tryCatch","fn","obj","arg","type","call","err","GeneratorFunction","GeneratorFunctionPrototype","defineIteratorMethods","forEach","method","this","AwaitArgument","AsyncIterator","invoke","result","Promise","resolve","then","invokeNext","invokeThrow","unwrapped","enqueue","enqueueResult","previousPromise","invokeReturn","process","domain","bind","context","state","GenStateSuspendedStart","GenStateExecuting","Error","GenStateCompleted","doneResult","delegate","iterator","undefined","returnMethod","record","info","done","GenStateSuspendedYield","resultName","next","nextLoc","sent","dispatchException","abrupt","ContinueSentinel","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","push","resetTryEntry","completion","reset","values","iterable","iteratorMethod","iteratorSymbol","isNaN","length","i","hasOwn","hasOwnProperty","Symbol","inModule","module","runtime","regeneratorRuntime","exports","Gp","displayName","isGeneratorFunction","genFun","ctor","name","mark","awrap","async","iter","toString","keys","object","key","reverse","pop","prev","tempName","tempIndex","stop","rootEntry","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","catch","thrown","delegateYield","window","AbstractTransaction","store","addOperation","op","context$2$0","getState","id","clock","setState","operationAdded","AbstractOperationStore","listenersById","listenersByIdExecuteNow","listenersByIdRequestPending","whenOperationsExist","ids","f","args","listener","missing","_iterator","_isArray","Array","isArray","_i","_ref","sid","JSON","stringify","l","requestTransaction","callee$2$0","exeNow","ls","_iterator2","_isArray2","_i2","_ref2","_iterator3","_isArray3","_i3","_ref3","context$3$0","apply","t1","t2","parse","getOperation","t3","_iterator4","_isArray4","_i4","_ref4","Struct","Operation","user","context$1$0","t0","Insert","left","right","origin","setOperation","requiredOps","execute","IndexedDB","Transaction","_AbstractTransaction","transaction","db","sv","objectStore","os","buffer","put","get","removeOperation","getStateVector","stateVector","cursorResult","cursor","openCursor","getStateSet","ss","_iterator5","_isArray5","_i5","_ref5","getOperations","startSS","ops","endSV","_iterator6","_isArray6","_i6","_ref6","endState","startPos","endPos","range","IDBKeyRange","bound","OperationStore","_AbstractOperationStore","namespace","handleTransactions","t","request","IDBRequest","IDBCursor","onsuccess","tGen","onerror","transactionQueue","queue","shift","onRequest","IDBOpenDBRequest","event","target","onupgradeneeded","createObjectStore","keyPath","transactionGen","cont","context$4$0","indexedDB","open","makeGen","removeDatabase","close","deleteDatabase"],"mappings":"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","file":"y.js","sourcesContent":[null,"/**\n * Copyright (c) 2014, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * https://raw.github.com/facebook/regenerator/master/LICENSE file. An\n * additional grant of patent rights can be found in the PATENTS file in\n * the same directory.\n */\n\n!(function(global) {\n \"use strict\";\n\n var hasOwn = Object.prototype.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var iteratorSymbol =\n typeof Symbol === \"function\" && Symbol.iterator || \"@@iterator\";\n\n var inModule = typeof module === \"object\";\n var runtime = global.regeneratorRuntime;\n if (runtime) {\n if (inModule) {\n // If regeneratorRuntime is defined globally and we're in a module,\n // make the exports object identical to regeneratorRuntime.\n module.exports = runtime;\n }\n // Don't bother evaluating the rest of this file if the runtime was\n // already defined globally.\n return;\n }\n\n // Define the runtime globally (as expected by generated code) as either\n // module.exports (if we're in a module) or a new, empty object.\n runtime = global.regeneratorRuntime = inModule ? module.exports : {};\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided, then outerFn.prototype instanceof Generator.\n var generator = Object.create((outerFn || Generator).prototype);\n\n generator._invoke = makeInvokeMethod(\n innerFn, self || null,\n new Context(tryLocsList || [])\n );\n\n return generator;\n }\n runtime.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype;\n GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n GeneratorFunctionPrototype.constructor = GeneratorFunction;\n GeneratorFunction.displayName = \"GeneratorFunction\";\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n prototype[method] = function(arg) {\n return this._invoke(method, arg);\n };\n });\n }\n\n runtime.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n runtime.mark = function(genFun) {\n genFun.__proto__ = GeneratorFunctionPrototype;\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `value instanceof AwaitArgument` to determine if the yielded value is\n // meant to be awaited. Some may consider the name of this method too\n // cutesy, but they are curmudgeons.\n runtime.awrap = function(arg) {\n return new AwaitArgument(arg);\n };\n\n function AwaitArgument(arg) {\n this.arg = arg;\n }\n\n function AsyncIterator(generator) {\n // This invoke function is written in a style that assumes some\n // calling function (or Promise) will handle exceptions.\n function invoke(method, arg) {\n var result = generator[method](arg);\n var value = result.value;\n return value instanceof AwaitArgument\n ? Promise.resolve(value.arg).then(invokeNext, invokeThrow)\n : Promise.resolve(value).then(function(unwrapped) {\n result.value = unwrapped;\n return result;\n }, invokeThrow);\n }\n\n if (typeof process === \"object\" && process.domain) {\n invoke = process.domain.bind(invoke);\n }\n\n var invokeNext = invoke.bind(generator, \"next\");\n var invokeThrow = invoke.bind(generator, \"throw\");\n var invokeReturn = invoke.bind(generator, \"return\");\n var previousPromise;\n\n function enqueue(method, arg) {\n var enqueueResult =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(function() {\n return invoke(method, arg);\n }) : new Promise(function(resolve) {\n resolve(invoke(method, arg));\n });\n\n // Avoid propagating enqueueResult failures to Promises returned by\n // later invocations of the iterator, and call generator.return() to\n // allow the generator a chance to clean up.\n previousPromise = enqueueResult[\"catch\"](invokeReturn);\n\n return enqueueResult;\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n runtime.async = function(innerFn, outerFn, self, tryLocsList) {\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList)\n );\n\n return runtime.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n if (method === \"return\" ||\n (method === \"throw\" && delegate.iterator[method] === undefined)) {\n // A return or throw (when the delegate iterator has no throw\n // method) always terminates the yield* loop.\n context.delegate = null;\n\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n var returnMethod = delegate.iterator[\"return\"];\n if (returnMethod) {\n var record = tryCatch(returnMethod, delegate.iterator, arg);\n if (record.type === \"throw\") {\n // If the return method threw an exception, let that\n // exception prevail over the original return or throw.\n method = \"throw\";\n arg = record.arg;\n continue;\n }\n }\n\n if (method === \"return\") {\n // Continue with the outer return, now that the delegate\n // iterator has been terminated.\n continue;\n }\n }\n\n var record = tryCatch(\n delegate.iterator[method],\n delegate.iterator,\n arg\n );\n\n if (record.type === \"throw\") {\n context.delegate = null;\n\n // Like returning generator.throw(uncaught), but without the\n // overhead of an extra function call.\n method = \"throw\";\n arg = record.arg;\n continue;\n }\n\n // Delegate generator ran and handled its own exceptions so\n // regardless of what the method was, we continue as if it is\n // \"next\" with an undefined arg.\n method = \"next\";\n arg = undefined;\n\n var info = record.arg;\n if (info.done) {\n context[delegate.resultName] = info.value;\n context.next = delegate.nextLoc;\n } else {\n state = GenStateSuspendedYield;\n return info;\n }\n\n context.delegate = null;\n }\n\n if (method === \"next\") {\n if (state === GenStateSuspendedYield) {\n context.sent = arg;\n } else {\n delete context.sent;\n }\n\n } else if (method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw arg;\n }\n\n if (context.dispatchException(arg)) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n method = \"next\";\n arg = undefined;\n }\n\n } else if (method === \"return\") {\n context.abrupt(\"return\", arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n var info = {\n value: record.arg,\n done: context.done\n };\n\n if (record.arg === ContinueSentinel) {\n if (context.delegate && method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n arg = undefined;\n }\n } else {\n return info;\n }\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(arg) call above.\n method = \"throw\";\n arg = record.arg;\n }\n }\n };\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n Gp[iteratorSymbol] = function() {\n return this;\n };\n\n Gp.toString = function() {\n return \"[object Generator]\";\n };\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset();\n }\n\n runtime.keys = function(object) {\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n runtime.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function() {\n this.prev = 0;\n this.next = 0;\n this.sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.tryEntries.forEach(resetTryEntry);\n\n // Pre-initialize at least 20 temporary variables to enable hidden\n // class optimizations for simple generators.\n for (var tempIndex = 0, tempName;\n hasOwn.call(this, tempName = \"t\" + tempIndex) || tempIndex < 20;\n ++tempIndex) {\n this[tempName] = null;\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n return !!caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.next = finallyEntry.finallyLoc;\n } else {\n this.complete(record);\n }\n\n return ContinueSentinel;\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = record.arg;\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n return ContinueSentinel;\n }\n };\n})(\n // Among the various tricks for obtaining a reference to the global\n // object, this seems to be the most reliable technique that does not\n // use indirect eval (which violates Content Security Policy).\n typeof global === \"object\" ? global :\n typeof window === \"object\" ? window :\n typeof self === \"object\" ? self : this\n);\n","/* @flow */\nclass AbstractTransaction { //eslint-disable-line no-unused-vars\n constructor (store : OperationStore) {\n this.store = store;\n }\n // Throws if operation is not expected.\n *addOperation (op) {\n var state = this.getState(op.id[0]);\n if (op.id[1] === state.clock){\n state.clock++;\n yield* this.setState(state);\n this.store.operationAdded(op);\n return true;\n } else {\n return false;\n }\n }\n}\n\ntype Listener = {\n f : GeneratorFunction, // is called when all operations are available\n missing : number // number of operations that are missing\n}\n\ntype Id = [string, number];\n\nclass AbstractOperationStore { //eslint-disable-line no-unused-vars\n constructor () {\n // E.g. this.listenersById[id] : Array<Listener>\n this.listenersById = {};\n // Execute the next time a transaction is requested\n this.listenersByIdExecuteNow = [];\n // A transaction is requested\n this.listenersByIdRequestPending = false;\n /* To make things more clear, the following naming conventions:\n * ls : we put this.listenersById on ls\n * l : Array<Listener>\n * id : Id (can't use as property name)\n * sid : String (converted from id via JSON.stringify\n so we can use it as a property name)\n\n Always remember to first overwrite over\n a property before you iterate over it!\n */\n }\n // f is called as soon as every operation requested is available.\n // Note that Transaction can (and should) buffer requests.\n whenOperationsExist (ids : Array<Id>, f : GeneratorFunction, args : Array<any>) {\n if (ids.length > 0) {\n let listener : Listener = {\n f: f,\n args: args || [],\n missing: ids.length\n };\n\n for (let id of ids) {\n let sid = JSON.stringify(id);\n let l = this.listenersById[sid];\n if (l == null){\n l = [];\n this.listenersById[sid] = l;\n }\n l.push(listener);\n }\n } else {\n this.listenersByIdExecuteNow.push({\n f: f,\n args: args || []\n });\n }\n\n if (this.listenersByIdRequestPending){\n return;\n }\n\n this.listenersByIdRequestPending = true;\n var store = this;\n\n this.requestTransaction(function*(){\n var exeNow = store.listenersByIdExecuteNow;\n store.listenersByIdExecuteNow = [];\n\n var ls = store.listenersById;\n store.listenersById = {};\n\n store.listenersByIdRequestPending = false;\n\n for (let listener of exeNow) {\n yield* listener.f.apply(this, listener.args);\n }\n\n for (var sid in ls){\n var l = ls[sid];\n var id = JSON.parse(sid);\n if ((yield* this.getOperation(id)) == null){\n store.listenersById[sid] = l;\n } else {\n for (let listener of l) {\n if (--listener.missing === 0){\n yield* listener.f.apply(this, listener.args);\n }\n }\n }\n }\n });\n }\n // called by a transaction when an operation is added\n operationAdded (op) {\n var l = this.listenersById[op.id];\n if (l != null) {\n for (var listener of l){\n if (--listener.missing === 0){\n this.whenOperationsExist([], listener.f, listener.args);\n }\n }\n }\n }\n}\n","/* @flow */\n\n// Op is anything that we could get from the OperationStore.\ntype Op = Object;\n\nvar Struct = {\n Operation: { //eslint-disable-line no-unused-vars\n create: function*(op : Op, user : string) : Struct.Operation {\n var state = yield* this.getState(user);\n op.id = [user, state.clock];\n return yield* this.addOperation(op);\n }\n },\n Insert: {\n create: function*( op : Op,\n user : string,\n left : Struct.Insert,\n right : Struct.Insert) : Struct.Insert {\n op.left = left ? left.id : null;\n op.origin = op.left;\n op.right = right ? right.id : null;\n op.type = \"Insert\";\n yield* Struct.Operation.create(op, user);\n\n if (left != null) {\n left.right = op.id;\n yield* this.setOperation(left);\n }\n if (right != null) {\n right.left = op.id;\n yield* this.setOperation(right);\n }\n return op;\n },\n requiredOps: function(op, ids){\n ids.push(op.left);\n ids.push(op.right);\n return ids;\n },\n execute: function*(op){\n return op;\n }\n }\n};\n","\ntype State = {\n user: string,\n clock: number\n};\n\ntype StateVector = Array<State>;\n\ntype StateSet = Object;\n\ntype IDBTransaction = Function;\ntype IDBObjectStore = Function;\ntype IDBRequest = Function;\ntype IDBCursor = Function;\ntype IDBKeyRange = Function;\n\ntype IDBOpenDBRequest = Function;\n\ndeclare var indexedDB : Object;\n\nvar IndexedDB = (function(){ //eslint-disable-line no-unused-vars\n class Transaction extends AbstractTransaction { //eslint-disable-line\n transaction: IDBTransaction;\n sv: IDBObjectStore;\n os: IDBObjectStore;\n store: OperationStore;\n\n constructor (store : OperationStore) {\n super(store);\n this.transaction = store.db.transaction([\"OperationStore\", \"StateVector\"], \"readwrite\");\n this.sv = this.transaction.objectStore(\"StateVector\");\n this.os = this.transaction.objectStore(\"OperationStore\");\n this.buffer = {};\n }\n *setOperation (op) {\n yield this.os.put(op);\n this.buffer[JSON.stringify(op.id)] = op;\n return op;\n }\n *getOperation (id) {\n var op = this.buffer[JSON.stringify(id)];\n if (op == null) {\n op = yield this.os.get(id);\n this.buffer[JSON.stringify(id)] = op;\n }\n return op;\n }\n *removeOperation (id) {\n this.buffer[JSON.stringify(id)] = null;\n return yield this.os.delete(id);\n }\n *setState (state : State) : State {\n return yield this.sv.put(state);\n }\n *getState (user : string) : State {\n var state;\n if ((state = yield this.sv.get(user)) != null){\n return state;\n } else {\n return {\n user: user,\n clock: 0\n };\n }\n }\n *getStateVector () : StateVector {\n var stateVector = [];\n var cursorResult = this.sv.openCursor();\n var cursor;\n while ((cursor = yield cursorResult) != null) {\n stateVector.push(cursor.value);\n cursor.continue();\n }\n return stateVector;\n }\n *getStateSet () : StateSet {\n var sv : StateVector = yield* this.getStateVector();\n var ss : StateSet = {};\n for (var state of sv){\n ss[state.user] = state.clock;\n }\n return ss;\n }\n\n *getOperations (startSS : StateSet) {\n if (startSS == null){\n startSS = {};\n }\n var ops = [];\n\n var endSV : StateVector = yield* this.getStateVector();\n for (var endState of endSV) {\n var user = endState.user;\n var startPos = startSS[user] || 0;\n var endPos = endState.clock;\n var range = IDBKeyRange.bound([user, startPos], [user, endPos]);\n var cursorResult = this.os.openCursor(range);\n var cursor;\n while ((cursor = yield cursorResult) != null) {\n ops.push(cursor.value);\n cursor.continue();\n }\n }\n return ops;\n }\n }\n class OperationStore extends AbstractOperationStore { //eslint-disable-line no-undef\n namespace: string;\n ready: Promise;\n whenReadyListeners: Array<Function>;\n constructor (namespace : string) {\n super();\n this.namespace = namespace;\n this.transactionQueue = {\n queue: [],\n onRequest: null\n };\n\n var store = this;\n\n var tGen = (function *transactionGen(){\n store.db = yield indexedDB.open(namespace, 3);\n var transactionQueue = store.transactionQueue;\n\n var transaction = null;\n var cont = true;\n while (cont) {\n var request = yield transactionQueue;\n transaction = new Transaction(store);\n\n yield* request.call(transaction);/*\n while (transactionQueue.queue.length > 0) {\n yield* transactionQueue.queue.shift().call(transaction);\n }*/\n }\n })();\n\n function handleTransactions(t){ //eslint-disable-line no-unused-vars\n var request = t.value;\n if (t.done){\n return;\n } else if (request.constructor === IDBRequest\n || request.constructor === IDBCursor ) {\n request.onsuccess = function(){\n handleTransactions(tGen.next(request.result));\n };\n request.onerror = function(err){\n tGen.throw(err);\n };\n } else if (request === store.transactionQueue) {\n if (request.queue.length > 0){\n handleTransactions(tGen.next(request.queue.shift()));\n } else {\n request.onRequest = function(){\n request.onRequest = null;\n handleTransactions(tGen.next(request.queue.shift()));\n };\n }\n } else if ( request.constructor === IDBOpenDBRequest ) {\n request.onsuccess = function(event){\n var db = event.target.result;\n handleTransactions(tGen.next(db));\n };\n request.onerror = function(){\n tGen.throw(\"Couldn't open IndexedDB database!\");\n };\n request.onupgradeneeded = function(event){\n var db = event.target.result;\n db.createObjectStore(\"OperationStore\", {keyPath: \"id\"});\n db.createObjectStore(\"StateVector\", {keyPath: \"user\"});\n };\n } else {\n tGen.throw(\"You can not yield this type!\");\n }\n }\n handleTransactions(tGen.next());\n\n }\n requestTransaction (makeGen : Function) {\n this.transactionQueue.queue.push(makeGen);\n if (this.transactionQueue.onRequest != null) {\n this.transactionQueue.onRequest();\n }\n }\n *removeDatabase () {\n this.db.close();\n yield indexedDB.deleteDatabase(this.namespace);\n }\n }\n return OperationStore;\n})();\n"],"sourceRoot":"/source/"} \ No newline at end of file -- GitLab