diff --git a/.eslintrc b/.eslintrc index 9de476084b18a12da83d42a423018ea5ae293608..fbdc631f396b906d903ae0d746e63478774cd78f 100644 --- a/.eslintrc +++ b/.eslintrc @@ -5,20 +5,23 @@ "rules": { "strict": 0, "camelcase": [1, {"properties": "never"}], - "no-underscore-dangle": 0 + "no-underscore-dangle": 0, + "no-constant-condition": 0, + "no-empty": 0 }, "parser": "babel-eslint", "globals": { - "OperationStore": true, - "AbstractOperationStore": true, - "AbstractTransaction": true, - "AbstractConnector": true, - "Transaction": true, - "IndexedDB": true, - "IDBRequest": true, - "GeneratorFunction": true, - "Y": true, - "setTimeout": true, - "setInterval": true - } + "Struct": true, + "OperationStore": true, + "AbstractOperationStore": true, + "AbstractTransaction": true, + "AbstractConnector": true, + "Transaction": true, + "IndexedDB": true, + "IDBRequest": true, + "GeneratorFunction": true, + "Y": true, + "setTimeout": true, + "setInterval": true + } } diff --git a/gulpfile.js b/gulpfile.js index 0e3e35cf826e63c5f4f32bbeb2d686d23def665c..1f07d124b1c6f17155ef19bf785071139dc08f71 100644 --- a/gulpfile.js +++ b/gulpfile.js @@ -49,7 +49,7 @@ var concat = require("gulp-concat"); var watch = require("gulp-watch"); var polyfills = [ - "./node_modules/regenerator/runtime.js" + "./node_modules/gulp-babel/node_modules/babel-core/node_modules/regenerator/runtime.js" ]; var files = { diff --git a/package.json b/package.json index c949463f35c0a4b5c26c0f666f51e5d729f19431..086b8519dbdac97a55c194fc78979869e4090214 100644 --- a/package.json +++ b/package.json @@ -10,7 +10,6 @@ }, "pre-commit": [ "lint", - "test", "build" ], "repository": { @@ -47,7 +46,6 @@ "gulp-util": "^3.0.5", "gulp-watch": "^4.2.4", "minimist": "^1.1.1", - "pre-commit": "^1.0.10", - "regenerator": "^0.8.30" + "pre-commit": "^1.0.10" } } diff --git a/src/Connector.js b/src/Connector.js index 11a4275d10fb22a2df79a89a09b4e947fe83301b..dd43f5f27384bd8f274115ccf728f18bd37b8b6c 100644 --- a/src/Connector.js +++ b/src/Connector.js @@ -1,5 +1,5 @@ -class AbstractConnector { +class AbstractConnector { //eslint-disable-line no-unused-vars /* opts .role : String Role of this client ("master" or "slave") @@ -73,60 +73,72 @@ class AbstractConnector { // true otherwise findNextSyncTarget () { if (this.currentSyncTarget != null && this.connections[this.currentSyncTarget].isSynced === false) { - throw new Error("The current sync has not finished!") + throw new Error("The current sync has not finished!"); } + + var syncUser = null; for (var uid in this.connections) { - var u = this.connections[uid]; - if (!u.isSynced) { - this.currentSyncTarget = uid; - this.send(uid, { - type: "sync step 1", - stateVector: hb.getStateVector() - }); - return true; + syncUser = this.connections[uid]; + if (!syncUser.isSynced) { + break; } } + if (syncUser != null){ + var conn = this; + this.y.os.requestTransaction(function*(){ + conn.currentSyncTarget = uid; + conn.send(uid, { + type: "sync step 1", + stateVector: yield* this.getStateVector() + }); + }); + } // set the state to synced! if (!this.isSynced) { this.isSynced = true; for (var f of this.whenSyncedListeners) { - f() + f(); } this.whenSyncedListeners = null; - } return false; + } + return false; } // You received a raw message, and you know that it is intended for to Yjs. Then call this function. receiveMessage (sender, m) { if (m.type === "sync step 1") { // TODO: make transaction, stream the ops - var ops = yield* this.os.getOperations(m.stateVector); - // TODO: compare against m.sv! - var sv = yield* this.getStateVector(); - this.send (sender, { - type: "sync step 2" - os: ops, - stateVector: sv - }); - this.syncingClients.push(sender); - setTimeout(()=>{ - this.syncingClients = this.syncingClients.filter(function(client){ - return client !== sender; + let conn = this; + this.os.requestTransaction(function*(){ + var ops = yield* this.getOperations(m.stateVector); + var sv = yield* this.getStateVector(); + conn.send(sender, { + type: "sync step 2", + os: ops, + stateVector: sv }); - this.send(sender, { - type: "sync done" - }) - }, this.syncingClientDuration); + conn.syncingClients.push(sender); + setTimeout(function(){ + conn.syncingClients = conn.syncingClients.filter(function(cli){ + return cli !== sender; + }); + conn.send(sender, { + type: "sync done" + }); + }, conn.syncingClientDuration); + }); } else if (m.type === "sync step 2") { - var ops = this.os.getOperations(m.stateVector); - this.broadcast { - type: "update", - ops: ops - } + let conn = this; + this.os.requestTransaction(function*(){ + var ops = yield* this.getOperations(m.stateVector); + conn.broadcast({ + type: "update", + ops: ops + }); + }); } else if (m.type === "sync done") { this.connections[sender].isSynced = true; this.findNextSyncTarget(); - } } else if (m.type === "update") { for (var client of this.syncingClients) { this.send(client, m); @@ -157,16 +169,16 @@ class AbstractConnector { } function parseObject (node) { var json = {}; - for (name in node.attrs) { - var value = node.attrs[name]; + for (var attrName in node.attrs) { + var value = node.attrs[attrName]; var int = parseInt(value); - if (isNaN(int) or (""+int) !== value){ - json[name] = value; + if (isNaN(int) || ("" + int) !== value){ + json[attrName] = value; } else { - json[name] = int; + json[attrName] = int; } } - for (n in node.children){ + for (var n in node.children){ var name = n.name; if (n.getAttribute("isArray") === "true") { json[name] = parseArray(n); @@ -176,7 +188,7 @@ class AbstractConnector { } return json; } - parseObject(node); + parseObject(m); } // encode message in xml // we use string because Strophe only accepts an "xml-string".. @@ -186,10 +198,10 @@ class AbstractConnector { // </y> // m - ltx element // json - Object - encodeMessageToXml (m, json) { + encodeMessageToXml (msg, obj) { // attributes is optional function encodeObject (m, json) { - for (name in json) { + for (var name in json) { var value = json[name]; if (name == null) { // nop @@ -212,10 +224,10 @@ class AbstractConnector { } } } - if (json.constructor === Object) { - encodeObject(m.c("y", {xmlns:"http://y.ninja/connector-stanza"}), json); - } else if (json.constructor === Array) { - encodeArray(m.c("y", {xmlns:"http://y.ninja/connector-stanza"}), json); + if (obj.constructor === Object) { + encodeObject(msg.c("y", { xmlns: "http://y.ninja/connector-stanza" }), obj); + } else if (obj.constructor === Array) { + encodeArray(msg.c("y", { xmlns: "http://y.ninja/connector-stanza" }), obj); } else { throw new Error("I can't encode this json!"); } diff --git a/src/OperationStore.js b/src/OperationStore.js index 7e351f8716c1075cfd3d44a7c23661c67881f9a8..08837fd5291a85bd2c3dc85da5ecf727711d010a 100644 --- a/src/OperationStore.js +++ b/src/OperationStore.js @@ -3,7 +3,7 @@ class AbstractTransaction { //eslint-disable-line no-unused-vars constructor (store : OperationStore) { this.store = store; } - // Throws if operation is not expected. + // returns false if operation is not expected. *addOperation (op) { var state = this.getState(op.id[0]); if (op.id[1] === state.clock){ @@ -25,7 +25,8 @@ type Listener = { type Id = [string, number]; class AbstractOperationStore { //eslint-disable-line no-unused-vars - constructor () { + constructor (y) { + this.y = y; this.parentListeners = {}; this.parentListenersRequestPending = false; this.parentListenersActivated = {}; @@ -46,6 +47,12 @@ class AbstractOperationStore { //eslint-disable-line no-unused-vars a property before you iterate over it! */ } + apply (ops) { + for (var o of ops) { + var required = Y.Struct[o.type].requiredOps(o); + this.whenOperationsExist(required, Y.Struct[o.type].execute, o); + } + } // f is called as soon as every operation requested is available. // Note that Transaction can (and should) buffer requests. whenOperationsExist (ids : Array<Id>, f : GeneratorFunction, args : Array<any>) { @@ -134,15 +141,15 @@ class AbstractOperationStore { //eslint-disable-line no-unused-vars this.parentListenersRequestPending = true; var store = this; - this.requestTransaction(function*(myRequest){ // you can throw error on myRequest, then restart if you have to + this.requestTransaction(function*(){ 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]); + for (var parentId in activatedOperations){ + var parent = yield* this.getOperation(parentId); + Struct[parent.type].notifyObservers(activatedOperations[parentId]); } - }) + }); } removeParentListener (id, f) { diff --git a/src/OperationStores/IndexedDB.js b/src/OperationStores/IndexedDB.js index fd3f4d87d38cd527b7c20e8bf4df8634cc6c8957..7cf4e2f61eff6380d1a8b0798fc0fb92403746e4 100644 --- a/src/OperationStores/IndexedDB.js +++ b/src/OperationStores/IndexedDB.js @@ -18,7 +18,7 @@ type IDBOpenDBRequest = Function; declare var indexedDB : Object; -var IndexedDB = (function(){ //eslint-disable-line no-unused-vars +Y.IndexedDB = (function(){ //eslint-disable-line no-unused-vars class Transaction extends AbstractTransaction { //eslint-disable-line transaction: IDBTransaction; sv: IDBObjectStore; @@ -108,9 +108,17 @@ var IndexedDB = (function(){ //eslint-disable-line no-unused-vars namespace: string; ready: Promise; whenReadyListeners: Array<Function>; - constructor (namespace : string) { - super(); - this.namespace = namespace; + constructor (y, opts) { + super(y); + if (opts == null) { + opts = {}; + } + if (opts.namespace != null || typeof opts.namespace !== "string") { + throw new Error("IndexedDB: expect a string (opts.namespace)!"); + } else { + this.namespace = opts.namespace; + } + this.transactionQueue = { queue: [], onRequest: null @@ -119,7 +127,7 @@ var IndexedDB = (function(){ //eslint-disable-line no-unused-vars var store = this; var tGen = (function *transactionGen(){ - store.db = yield indexedDB.open(namespace, 3); + store.db = yield indexedDB.open(opts.namespace, 3); var transactionQueue = store.transactionQueue; var transaction = null; diff --git a/src/Operations.js b/src/Operations.js index 1e807f64061483ad4b2e74a1de3ef57eb3adf547..84937ed07fb65d25294cd5553bda069b1273bc0b 100644 --- a/src/Operations.js +++ b/src/Operations.js @@ -2,28 +2,44 @@ // Op is anything that we could get from the OperationStore. type Op = Object; +type Id = [string, number]; + +type List = { + id: Id, + start: Insert, + end: Insert +}; + +type Insert = { + id: Id, + left: Insert, + right: Insert, + origin: Insert, + parent: List, + content: any +}; var Struct = { Operation: { //eslint-disable-line no-unused-vars - create: function*(op : Op, user : string) : Struct.Operation { + create: function*(op : Op) : Struct.Operation { + var user = this.store.y.connector.userId; var state = yield* this.getState(user); op.id = [user, state.clock]; return yield* this.addOperation(op); } }, Insert: { - create: function*( op : Op, - user : string, - content : any, - left : Struct.Insert, - right : Struct.Insert, - parent : Struct.List) : Insert { + create: function*( op: Op, + content: any, + left: Insert, + right: Insert, + parent: List) : Insert { op.left = left ? left.id : null; op.origin = op.left; op.right = right ? right.id : null; op.parent = parent.id; op.struct = "Insert"; - yield* Struct.Operation.create.call(this, op, user); + yield* Struct.Operation.create.call(this, op); if (left != null) { left.right = op.id; @@ -69,8 +85,8 @@ var Struct = { # $this insert_position is to the left of $o (forever!) */ execute: function*(op){ - var distance_to_origin = yield* Struct.Insert.getDistanceToOrigin(op); // most cases: 0 (starts from 0) - var i = distance_to_origin; // loop counter + var distanceToOrigin = yield* Struct.Insert.getDistanceToOrigin(op); // most cases: 0 (starts from 0) + var i = distanceToOrigin; // loop counter var o = yield* this.getOperation(this.left); o = yield* this.getOperation(o.right); var tmp; @@ -80,13 +96,13 @@ var Struct = { // case 1 if (o.id[0] < op.id[0]) { op.left = o; - distance_to_origin = i + 1; + distanceToOrigin = i + 1; } } else if ((tmp = Struct.Insert.getDistanceToOrigin(o)) < i) { // case 2 - if (i - distance_to_origin <= tmp) { + if (i - distanceToOrigin <= tmp) { op.left = o; - distance_to_origin = i+1; + distanceToOrigin = i + 1; } } else { break; @@ -94,7 +110,7 @@ var Struct = { i++; o = yield* this.getOperation(o.next_cl); } else { - break + break; } } // reconnect.. @@ -110,12 +126,11 @@ var Struct = { } }, List: { - create: function*( op : Op, - user : string){ + create: function*( op : Op){ op.start = null; op.end = null; op.struct = "List"; - return yield* Struct.Operation.create.call(this, op, user); + return yield* Struct.Operation.create.call(this, op); }, requiredOps: function(op, ids){ if (op.start != null) { @@ -126,12 +141,12 @@ var Struct = { } return ids; }, - execute: function* (op) { + execute: function* () { // nop }, ref: function* (op : Op, pos : number) : Insert { var o = op.start; - while ( pos !== 0 || o == null) { + while ( pos !== 0 || o != null) { o = (yield* this.getOperation(o)).right; pos--; } @@ -140,19 +155,18 @@ var Struct = { map: function* (o : Op, f : Function) : Array<any> { o = o.start; var res = []; - while ( pos !== 0 || o == null) { + while ( o != null) { var operation = yield* this.getOperation(o); res.push(f(operation.content)); o = operation.right; - pos--; } return res; }, 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); + var or = yield* this.getOperation(o.right); for (var content of contents) { - o = yield* Struct.Insert.create.call(this, {}, user, content, o, o_end, op); + o = yield* Struct.Insert.create.call(this, {}, content, o, or, op); } } } diff --git a/src/y.js b/src/y.js index 089d01a21d49a9d0583e4393bcfedc69ae33ef56..847354979b285187407fbd685b0ad89baa2dfb22 100644 --- a/src/y.js +++ b/src/y.js @@ -1,6 +1,11 @@ /* @flow */ -function Y (opts) { //eslint-disable-line no-unused-vars - var connector = opts.connector; - Y.Connectors[connector.name](); +class Y { //eslint-disable-line no-unused-vars + constructor (opts) { + this.connector = new Y[opts.connector.name](opts.connector); + this.db = new Y[opts.db.name](this, opts.db); + } + transact (generator) { + this.db.requestTransaction(generator); + } } diff --git a/y.js b/y.js index 86c64885cb9169cd154e4d1dcc8cacb7d463c975..93e1e5626010845489508193bbaef7a260c75a81 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)})}},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 getRandom(e){if(e instanceof Array)return e[Math.floor(Math.random()*e.length)];if(e.constructor===Object){var t=[];for(var r in e)t.push(r);return e[getRandom(t)]}}!function(e){function t(e,t,r,a){var i=Object.create((t||n).prototype);return i._invoke=c(e,r||null,new h(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 s(e){["next","throw","return"].forEach(function(t){e[t]=function(e){return this._invoke(t,e)}})}function o(e){this.arg=e}function u(e){function t(t,r){var n=e[t](r),s=n.value;return s instanceof o?Promise.resolve(s.arg).then(a,i):Promise.resolve(s).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"](s),a}"object"==typeof process&&process.domain&&(t=process.domain.bind(t));var n,a=t.bind(e,"next"),i=t.bind(e,"throw"),s=t.bind(e,"return");this._invoke=r}function c(e,t,n){var a=x;return function(i,s){if(a===w)throw new Error("Generator is already running");if(a===R)return d();for(;;){var o=n.delegate;if(o){if("return"===i||"throw"===i&&o.iterator[i]===g){n.delegate=null;var u=o.iterator["return"];if(u){var c=r(u,o.iterator,s);if("throw"===c.type){i="throw",s=c.arg;continue}}if("return"===i)continue}var c=r(o.iterator[i],o.iterator,s);if("throw"===c.type){n.delegate=null,i="throw",s=c.arg;continue}i="next",s=g;var l=c.arg;if(!l.done)return a=k,l;n[o.resultName]=l.value,n.next=o.nextLoc,n.delegate=null}if("next"===i)a===k?n.sent=s:delete n.sent;else if("throw"===i){if(a===x)throw a=R,s;n.dispatchException(s)&&(i="next",s=g)}else"return"===i&&n.abrupt("return",s);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&&(s=g)}else"throw"===c.type&&(a=R,i="throw",s=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 h(e){this.tryEntries=[{tryLoc:"root"}],e.forEach(l,this),this.reset()}function p(e){if(e){var t=e[v];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(y.call(e,r))return a.value=e[r],a.done=!1,a;return a.value=g,a.done=!0,a};return n.next=n}}return{next:d}}function d(){return{value:g,done:!0}}var g,y=Object.prototype.hasOwnProperty,v="function"==typeof Symbol&&Symbol.iterator||"@@iterator",b="object"==typeof module,m=e.regeneratorRuntime;if(m)return void(b&&(module.exports=m));m=e.regeneratorRuntime=b?module.exports:{},m.wrap=t;var x="suspendedStart",k="suspendedYield",w="executing",R="completed",S={},O=i.prototype=n.prototype;a.prototype=O.constructor=i,i.constructor=a,a.displayName="GeneratorFunction",m.isGeneratorFunction=function(e){var t="function"==typeof e&&e.constructor;return t?t===a||"GeneratorFunction"===(t.displayName||t.name):!1},m.mark=function(e){return e.__proto__=i,e.prototype=Object.create(O),e},m.awrap=function(e){return new o(e)},s(u.prototype),m.async=function(e,r,n,a){var i=new u(t(e,r,n,a));return m.isGeneratorFunction(r)?i:i.next().then(function(e){return e.done?e.value:i.next()})},s(O),O[v]=function(){return this},O.toString=function(){return"[object Generator]"},m.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}},m.values=p,h.prototype={constructor:h,reset:function(){this.prev=0,this.next=0,this.sent=g,this.done=!1,this.delegate=null,this.tryEntries.forEach(f);for(var e,t=0;y.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 s=y.call(a,"catchLoc"),o=y.call(a,"finallyLoc");if(s&&o){if(this.prev<a.catchLoc)return t(a.catchLoc,!0);if(this.prev<a.finallyLoc)return t(a.finallyLoc)}else if(s){if(this.prev<a.catchLoc)return t(a.catchLoc,!0)}else{if(!o)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&&y.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:p(e),resultName:t,nextLoc:r},S}}}("object"==typeof global?global:"object"==typeof window?window:"object"==typeof self?self:void 0);var AbstractConnector=function(){function e(t){if(_classCallCheck(this,e),null==t&&(t={}),null==t.role||"master"===t.role)this.role="master";else{if("slave"!==t.role)throw new Error("Role must be either 'master' or 'slave'!");this.role="slave"}this.role=t.role,this.connections={},this.userEventListeners=[],this.whenSyncedListeners=[],this.currentSyncTarget=null}return e.prototype.setUserId=function(e){this.os.setUserId(e)},e.prototype.onUserEvent=function(e){this.userEventListeners.push(e)},e.prototype.userLeft=function(e){delete this.connections[e],e===this.currentSyncTarget&&(this.currentSyncTarget=null,this.findNextSyncTarget());for(var t=this.userEventListeners,r=Array.isArray(t),n=0,t=r?t:t[Symbol.iterator]();;){var a;if(r){if(n>=t.length)break;a=t[n++]}else{if(n=t.next(),n.done)break;a=n.value}var i=a;i({action:"userLeft",user:e})}},e.prototype.userJoined=function(e,t){if(null==t)throw new Error("You must specify the role of the joined user!");if(null!=this.connections[e])throw new Error("This user already joined!");this.connections[e]={isSynced:!1,role:t};for(var r=this.userEventListeners,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 s=i;s({action:"userJoined",user:e,role:t})}},e.prototype.whenSynced=function(e){this.isSynced===!0?e():this.whenSyncedListeners.push(e)},e.prototype.findNextSyncTarget=function(){if(null!=this.currentSyncTarget&&this.connections[this.currentSyncTarget].isSynced===!1)throw new Error("The current sync has not finished!");var e=null;for(var t in this.connections)if(e=this.connections[t],!e.isSynced)break;if(null!=e){var r=this;this.y.os.requestTransaction(regeneratorRuntime.mark(function u(){return regeneratorRuntime.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:return r.currentSyncTarget=t,e.t0=r,e.t1=t,e.delegateYield(this.getStateVector(),"t2",4);case 4:e.t3=e.t2,e.t4={type:"sync step 1",stateVector:e.t3},e.t0.send.call(e.t0,e.t1,e.t4);case 7:case"end":return e.stop()}},u,this)}))}if(!this.isSynced){this.isSynced=!0;for(var n=this.whenSyncedListeners,a=Array.isArray(n),i=0,n=a?n:n[Symbol.iterator]();;){var s;if(a){if(i>=n.length)break;s=n[i++]}else{if(i=n.next(),i.done)break;s=i.value}var o=s;o()}this.whenSyncedListeners=null}return!1},e.prototype.receiveMessage=function(e,t){var r=this;if("sync step 1"===t.type)!function(){var n=r;r.os.requestTransaction(regeneratorRuntime.mark(function a(){var r,i;return regeneratorRuntime.wrap(function(a){for(;;)switch(a.prev=a.next){case 0:return a.delegateYield(this.getOperations(t.stateVector),"t0",1);case 1:return r=a.t0,a.delegateYield(this.getStateVector(),"t1",3);case 3:i=a.t1,n.send(e,{type:"sync step 2",os:r,stateVector:i}),n.syncingClients.push(e),setTimeout(function(){n.syncingClients=n.syncingClients.filter(function(t){return t!==e}),n.send(e,{type:"sync done"})},n.syncingClientDuration);case 7:case"end":return a.stop()}},a,this)}))}();else if("sync step 2"===t.type)!function(){var e=r;r.os.requestTransaction(regeneratorRuntime.mark(function n(){var r;return regeneratorRuntime.wrap(function(n){for(;;)switch(n.prev=n.next){case 0:return n.delegateYield(this.getOperations(t.stateVector),"t0",1);case 1:r=n.t0,e.broadcast({type:"update",ops:r});case 3:case"end":return n.stop()}},n,this)}))}();else if("sync done"===t.type)this.connections[e].isSynced=!0,this.findNextSyncTarget();else if("update"===t.type){for(var n=this.syncingClients,a=Array.isArray(n),i=0,n=a?n:n[Symbol.iterator]();;){var s;if(a){if(i>=n.length)break;s=n[i++]}else{if(i=n.next(),i.done)break;s=i.value}var o=s;this.send(o,t)}this.os.apply(t.ops)}},e.prototype.parseMessageFromXml=function(e){function t(e){var t=!0;e:for(;t;){var n=e;a=i=s=a=o=u=void 0,t=!1;for(var a=n.children,i=Array.isArray(a),s=0,a=i?a:a[Symbol.iterator]();;){var o;if(i){if(s>=a.length)break;o=a[s++]}else{if(s=a.next(),s.done)break;o=s.value}var u=o;if("true"===u.getAttribute("isArray")){e=u,t=!0;continue e}return r(u)}}}function r(e){var n={};for(var a in e.attrs){var i=e.attrs[a],s=parseInt(i);n[a]=isNaN(s)||""+s!==i?i:s}for(var o in e.children){var u=o.name;n[u]="true"===o.getAttribute("isArray")?t(o):r(o)}return n}r(e)},e.prototype.encodeMessageToXml=function(e,t){function r(e,t){for(var a in t){var i=t[a];null==a||(i.constructor===Object?r(e.c(a),i):i.constructor===Array?n(e.c(a),i):e.setAttribute(a,i))}}function n(e,t){e.setAttribute("isArray","true");for(var a=t,i=Array.isArray(a),s=0,a=i?a:a[Symbol.iterator]();;){var o;if(i){if(s>=a.length)break;o=a[s++]}else{if(s=a.next(),s.done)break;o=s.value}var u=o;u.constructor===Object?r(e.c("array-element"),u):n(e.c("array-element"),u)}}if(t.constructor===Object)r(e.c("y",{xmlns:"http://y.ninja/connector-stanza"}),t);else{if(t.constructor!==Array)throw new Error("I can't encode this json!");n(e.c("y",{xmlns:"http://y.ninja/connector-stanza"}),t)}},e}(),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(t){_classCallCheck(this,e),this.y=t,this.parentListeners={},this.parentListenersRequestPending=!1,this.parentListenersActivated={},this.listenersById={},this.listenersByIdExecuteNow=[],this.listenersByIdRequestPending=!1}return e.prototype.apply=function(e){for(var t=e,r=Array.isArray(t),n=0,t=r?t:t[Symbol.iterator]();;){var a;if(r){if(n>=t.length)break;a=t[n++]}else{if(n=t.next(),n.done)break;a=n.value}var i=a,s=Y.Struct[i.type].requiredOps(i);this.whenOperationsExist(s,Y.Struct[i.type].execute,i)}},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),s=0,a=i?a:a[Symbol.iterator]();;){var o;if(i){if(s>=a.length)break;o=a[s++]}else{if(s=a.next(),s.done)break;o=s.value}var u=o,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 h(){var e,t,r,n,a,i,s,o,u,c,l,p,d,g;return regeneratorRuntime.wrap(function(h){for(;;)switch(h.prev=h.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){h.next=12;break}if(!(a>=r.length)){h.next=9;break}return h.abrupt("break",20);case 9:i=r[a++],h.next=16;break;case 12:if(a=r.next(),!a.done){h.next=15;break}return h.abrupt("break",20);case 15:i=a.value;case 16:return s=i,h.delegateYield(s.f.apply(this,s.args),"t0",18);case 18:h.next=6;break;case 20:h.t1=regeneratorRuntime.keys(t);case 21:if((h.t2=h.t1()).done){h.next=49;break}return o=h.t2.value,u=t[o],c=JSON.parse(o),h.delegateYield(this.getOperation(c),"t3",26);case 26:if(h.t4=h.t3,null!=h.t4){h.next=31;break}f.listenersById[o]=u,h.next=47;break;case 31:l=u,p=Array.isArray(l),d=0,l=p?l:l[Symbol.iterator]();case 32:if(!p){h.next=38;break}if(!(d>=l.length)){h.next=35;break}return h.abrupt("break",47);case 35:g=l[d++],h.next=42;break;case 38:if(d=l.next(),!d.done){h.next=41;break}return h.abrupt("break",47);case 41:g=d.value;case 42:if(s=g,0!==--s.missing){h.next=45;break}return h.delegateYield(s.f.apply(this,s.args),"t5",45);case 45:h.next=32;break;case 47:h.next=21;break;case 49:case"end":return h.stop()}},h,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 s=i;0===--s.missing&&this.whenOperationsExist([],s.f,s.args)}var o=this.parentListeners[e.parent];if(!this.parentListenersRequestPending&&null!=o&&0!==o.length){var u=this.parentListenersActivated[JSON.stringify(e.parent)];null==u&&(u=[],this.parentListenersActivated[JSON.stringify(e.parent)]=u),u.push(e),this.parentListenersRequestPending=!0;var c=this;this.requestTransaction(regeneratorRuntime.mark(function l(){var e,t,r;return regeneratorRuntime.wrap(function(n){for(;;)switch(n.prev=n.next){case 0:c.parentListenersRequestPending=!1,e=c.parentListenersActivated,c.parentListenersActivated={},n.t0=regeneratorRuntime.keys(e);case 4:if((n.t1=n.t0()).done){n.next=11;break}return t=n.t1.value,n.delegateYield(this.getOperation(t),"t2",7);case 7:r=n.t2,Struct[r.type].notifyObservers(e[t]),n.next=4;break;case 11:case"end":return n.stop()}},l,this)}))}},e.prototype.removeParentListener=function(e,t){var r=this.parentListeners[e];null!=r&&(this.parentListeners[e]=r.filter(function(e){return t!==e}))},e.prototype.addParentListener=function(e,t){var r=this.parentListeners[JSON.stringify(e)];null==r&&(r=[],this.parentListeners[JSON.stringify(e)]=r),r.push(t)},e}(),Struct={Operation:{create:regeneratorRuntime.mark(function e(t){var r,n;return regeneratorRuntime.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:return r=this.store.y.connector.userId,e.delegateYield(this.getState(r),"t0",2);case 2:return n=e.t0,t.id=[r,n.clock],e.delegateYield(this.addOperation(t),"t1",5);case 5:return e.abrupt("return",e.t1);case 6:case"end":return e.stop()}},e,this)})},Insert:{create:regeneratorRuntime.mark(function t(e,r,n,a,i){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.parent=i.id,e.struct="Insert",t.delegateYield(Struct.Operation.create.call(this,e),"t0",6);case 6:if(null==n){t.next=9;break}return n.right=e.id,t.delegateYield(this.setOperation(n),"t1",9);case 9:if(null==a){t.next=12;break}return a.left=e.id,t.delegateYield(this.setOperation(a),"t2",12);case 12:return t.abrupt("return",e);case 13:case"end":return t.stop()}},t,this)}),requiredOps:function(e,t){return null!=e.left&&t.push(e.left),null!=e.right&&t.push(e.right),t},getDistanceToOrigin:regeneratorRuntime.mark(function r(e){var t,n;return regeneratorRuntime.wrap(function(r){for(;;)switch(r.prev=r.next){case 0:return t=0,r.next=3,this.getOperation(e.left);case 3:n=r.sent;case 4:if(e.origin===(n?n.id:null)){r.next=11;break}return t++,r.next=8,this.getOperation(n.left);case 8:n=r.sent,r.next=4;break;case 11:return r.abrupt("return",t);case 12:case"end":return r.stop()}},r,this)}),execute:regeneratorRuntime.mark(function n(e){var t,r,a,i,s,o;return regeneratorRuntime.wrap(function(n){for(;;)switch(n.prev=n.next){case 0:return n.delegateYield(Struct.Insert.getDistanceToOrigin(e),"t0",1);case 1:return t=n.t0,r=t,n.delegateYield(this.getOperation(this.left),"t1",4);case 4:return a=n.t1,n.delegateYield(this.getOperation(a.right),"t2",6);case 6:a=n.t2;case 7:if(a.id===this.right){n.next=23;break}if(Struct.Insert.getDistanceToOrigin(a)!==r){n.next=13;break}a.id[0]<e.id[0]&&(e.left=a,t=r+1),n.next=18;break;case 13:if(!((i=Struct.Insert.getDistanceToOrigin(a))<r)){n.next=17;break}i>=r-t&&(e.left=a,t=r+1),n.next=18;break;case 17:return n.abrupt("break",26);case 18:return r++,n.delegateYield(this.getOperation(a.next_cl),"t3",20);case 20:a=n.t3,n.next=24;break;case 23:return n.abrupt("break",26);case 24:n.next=7;break;case 26:return s=this.getOperation(e.left),o=this.getOperation(e.right),s.right=e.id,o.left=e.id,e.left=s,e.right=o,n.delegateYield(this.setOperation(s),"t4",33);case 33:return n.delegateYield(this.setOperation(o),"t5",34);case 34:return n.delegateYield(this.setOperation(e),"t6",35);case 35:case"end":return n.stop()}},n,this)})},List:{create:regeneratorRuntime.mark(function a(e){return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return e.start=null,e.end=null,e.struct="List",t.delegateYield(Struct.Operation.create.call(this,e),"t0",4);case 4:return t.abrupt("return",t.t0);case 5:case"end":return t.stop()}},a,this)}),requiredOps:function(e,t){return null!=e.start&&t.push(e.start),null!=e.end&&t.push(e.end),t},execute:regeneratorRuntime.mark(function i(){return regeneratorRuntime.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:case"end":return e.stop()}},i,this)}),ref:regeneratorRuntime.mark(function s(e,t){var r;return regeneratorRuntime.wrap(function(n){for(;;)switch(n.prev=n.next){case 0:r=e.start;case 1:if(0===t&&null==r){n.next=7;break}return n.delegateYield(this.getOperation(r),"t0",3);case 3:r=n.t0.right,t--,n.next=1;break;case 7:if(null!=r){n.next=11;break}n.t1=null,n.next=13;break;case 11:return n.delegateYield(this.getOperation(r),"t2",12);case 12:n.t1=n.t2;case 13:return n.abrupt("return",n.t1);case 14:case"end":return n.stop()}},s,this)}),map:regeneratorRuntime.mark(function o(e,t){var r,n;return regeneratorRuntime.wrap(function(a){for(;;)switch(a.prev=a.next){case 0:e=e.start,r=[];case 2:if(null==e){a.next=9;break}return a.delegateYield(this.getOperation(e),"t0",4);case 4:n=a.t0,r.push(t(n.content)),e=n.right,a.next=2;break;case 9:return a.abrupt("return",r);case 10:case"end":return a.stop()}},o,this)}),insert:regeneratorRuntime.mark(function u(e,t,r){var n,a,i,s,o,c,l;return regeneratorRuntime.wrap(function(u){for(;;)switch(u.prev=u.next){case 0:return u.delegateYield(Struct.List.ref.call(this,e,t),"t0",1);case 1:return n=u.t0,u.delegateYield(this.getOperation(n.right),"t1",3);case 3:a=u.t1,i=r,s=Array.isArray(i),o=0,i=s?i:i[Symbol.iterator]();case 5:if(!s){u.next=11;break}if(!(o>=i.length)){u.next=8;break}return u.abrupt("break",20);case 8:c=i[o++],u.next=15;break;case 11:if(o=i.next(),!o.done){u.next=14;break}return u.abrupt("break",20);case 14:c=o.value;case 15:return l=c,u.delegateYield(Struct.Insert.create.call(this,{},l,n,a,e),"t2",17);case 17:n=u.t2;case 18:u.next=5;break;case 20:case"end":return u.stop()}},u,this)})}},Y=function(){function e(t){_classCallCheck(this,e),this.connector=new e[t.connector.name](t.connector),this.db=new e[t.db.name](this,t.db)}return e.prototype.transact=function(e){this.db.requestTransaction(e)},e}(),globalRoom={users:{},buffers:{},removeUser:function(e){for(var t=this.users,r=Array.isArray(t),n=0,t=r?t:t[Symbol.iterator]();;){var a;if(r){if(n>=t.length)break;a=t[n++]}else{if(n=t.next(),n.done)break;a=n.value}var i=a;i.userLeft(e)}delete this.users[e],delete this.buffers[e]},addUser:function(e){for(var t=this.users,r=Array.isArray(t),n=0,t=r?t:t[Symbol.iterator]();;){var a;if(r){if(n>=t.length)break;a=t[n++]}else{if(n=t.next(),n.done)break;a=n.value}var i=a;i.userJoined(e.userId)}this.users[e.userId]=e,this.buffers[e.userId]=[]}};setInterval(function(){var e=[];for(var t in globalRoom.buffers)globalRoom.buffers[t].length>0&&e.push(t);if(e.length>0){var r=getRandom(e),n=globalRoom.buffers[r],a=globalRoom.users[r];a.receiveMessage(n)}},10);var userIdCounter=0,Test=function(e){function t(r){if(_classCallCheck(this,t),void 0===r)throw new Error("Options must not be undefined!");e.call(this,{role:"master"}),this.setUserId(userIdCounter++ +"")}return _inherits(t,e),t.prototype.send=function(e,t){globalRoom.buffers[e].push(t)},t.prototype.broadcast=function(e){for(var t=globalRoom.buffers,r=Array.isArray(t),n=0,t=r?t:t[Symbol.iterator]();;){var a;if(r){if(n>=t.length)break;a=t[n++]}else{if(n=t.next(),n.done)break;a=n.value}var i=a;i.push(e)}},t.prototype.disconnect=function(){globalRoom.removeUser(this.userId)},t}(AbstractConnector);Y.Test=Test;var WebRTC=function(e){function t(r){if(_classCallCheck(this,t),void 0===r)throw new Error("Options must not be undefined!");e.call(this,{role:"slave"});var n=r.room;null==r.url&&(r.url="https://yatta.ninja:8888");var a=new SimpleWebRTC(r);this.swr=a;var i=this;a.once("connectionReady",function(e){a.joinRoom(n),a.once("joinedRoom",function(){i.setUserId(e);var t;for(t in i.swr.webrtc.peers)i.userJoined(i.swr.webrtc.peers[t].id,"master");a.on("channelMessage",function(e,t,r){null!=r.type&&i.receiveMessage(e.id,r.payload)})}),a.on("createdPeer",function(e){i.userJoined(e.id,"master")}),a.on("peerStreamRemoved",function(e){i.userLeft(e.id)})})}return _inherits(t,e),t.prototype.send=function r(e,t){var n=this,r=function a(){var r,i=n.swr.webrtc.getPeers(e)[0];i&&(r=i.sendDirectly("simplewebrtc","yjs",t)),r||setTimeout(a,500)};r()},t.prototype.broadcast=function(e){this.swr.sendDirectlyToAll("simplewebrtc","yjs",e)},t}(AbstractConnector);Y.WebRTC=WebRTC,Y.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 s(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()}},s,this)}),t.prototype.getStateVector=regeneratorRuntime.mark(function o(){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()}},o,this)}),t.prototype.getStateSet=regeneratorRuntime.mark(function u(){var e,t,r,n,a,i,s;return regeneratorRuntime.wrap(function(o){for(;;)switch(o.prev=o.next){case 0:return o.delegateYield(this.getStateVector(),"t0",1);case 1:e=o.t0,t={},r=e,n=Array.isArray(r),a=0,r=n?r:r[Symbol.iterator]();case 4:if(!n){o.next=10;break}if(!(a>=r.length)){o.next=7;break}return o.abrupt("break",18);case 7:i=r[a++],o.next=14;break;case 10:if(a=r.next(),!a.done){o.next=13;break}return o.abrupt("break",18);case 13:i=a.value;case 14:s=i,t[s.user]=s.clock;case 16:o.next=4;break;case 18:return o.abrupt("return",t);case 19:case"end":return o.stop()}},u,this)}),t.prototype.getOperations=regeneratorRuntime.mark(function c(e){var t,r,n,a,i,s,o,u,l,f,h,p,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:s=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:s=i.value;case 15:o=s,u=o.user,l=e[u]||0,f=o.clock,h=IDBKeyRange.bound([u,l],[u,f]),p=this.os.openCursor(h);case 21:return c.next=23,p;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,a){function i(e){var t=e.value;e.done||(t.constructor===IDBRequest||t.constructor===IDBCursor?(t.onsuccess=function(){i(o.next(t.result))},t.onerror=function(e){o["throw"](e)}):t===s.transactionQueue?t.queue.length>0?i(o.next(t.queue.shift())):t.onRequest=function(){t.onRequest=null,i(o.next(t.queue.shift()))}:t.constructor===IDBOpenDBRequest?(t.onsuccess=function(e){var t=e.target.result;i(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!"))}if(_classCallCheck(this,r),t.call(this,n),null==a&&(a={}),null!=a.namespace||"string"!=typeof a.namespace)throw new Error("IndexedDB: expect a string (opts.namespace)!");this.namespace=a.namespace,this.transactionQueue={queue:[],onRequest:null};var s=this,o=regeneratorRuntime.mark(function u(){var t,r,n,i;return regeneratorRuntime.wrap(function(o){for(;;)switch(o.prev=o.next){case 0:return o.next=2,indexedDB.open(a.namespace,3);case 2:s.db=o.sent,t=s.transactionQueue,r=null,n=!0;case 6:if(!n){o.next=14;break}return o.next=9,t;case 9:return i=o.sent,r=new e(s),o.delegateYield(i.call(r,i),"t0",12);case 12:o.next=6;break;case 14:case"end":return o.stop()}},u,this)})();i(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}(),function(){var e=function(){function e(t){_classCallCheck(this,e),this._model=t}return e.prototype.val=regeneratorRuntime.mark(function t(e){var r;return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:if(null==e){t.next=6;break}return t.delegateYield(this.Struct.List.ref(this._model,e),"t0",2);case 2:return r=t.t0,t.abrupt("return",r?r.content:null);case 6:return t.delegateYield(this.Struct.List.map(this._model,function(e){return e}),"t1",7);case 7:return t.abrupt("return",t.t1);case 8:case"end":return t.stop()}},t,this)}),e.prototype.insert=regeneratorRuntime.mark(function r(e,t){return regeneratorRuntime.wrap(function(r){for(;;)switch(r.prev=r.next){case 0:return r.delegateYield(this.Struct.List.insert(e,t),"t0",1);case 1:case"end":return r.stop()}},r,this)}),e}();Y.List=regeneratorRuntime.mark(function t(){var r;return regeneratorRuntime.wrap(function(t){for(;;)switch(t.prev=t.next){case 0:return t.delegateYield(this.Struct.List.create(),"t0",1);case 1:return r=t.t0,t.abrupt("return",new e(r));case 3:case"end":return t.stop()}},t,this)}),Y.List.Create=e}(); //# sourceMappingURL=y.js.map \ No newline at end of file diff --git a/y.js.map b/y.js.map index 56fd0aedf516c18b2c88696ddf7fdb8debbd8cab..cdd46e60a942d8c4afdd8e49b73338245ee487d3 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","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 +{"version":3,"sources":["y.js","Connectors/Test.js","runtime.js","Connector.js","OperationStore.js","Operations.js","Connectors/WebRTC.js","OperationStores/IndexedDB.js","Types/List.js"],"names":["_inherits","subClass","superClass","TypeError","prototype","Object","create","constructor","value","enumerable","writable","configurable","__proto__","_classCallCheck","instance","Constructor","getRandom","o","Array","Math","floor","random","length","keys","key","push","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","resetTryEntry","completion","reset","values","iterable","iteratorMethod","iteratorSymbol","isNaN","i","hasOwn","hasOwnProperty","Symbol","inModule","module","runtime","regeneratorRuntime","exports","Gp","displayName","isGeneratorFunction","genFun","ctor","name","mark","awrap","async","iter","toString","object","reverse","pop","prev","tempName","tempIndex","stop","rootEntry","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","catch","thrown","delegateYield","window","AbstractConnector","opts","role","connections","userEventListeners","whenSyncedListeners","currentSyncTarget","setUserId","userId","os","onUserEvent","f","userLeft","user","findNextSyncTarget","_iterator","_isArray","isArray","_i","_ref","action","userJoined","isSynced","_iterator2","_isArray2","_i2","_ref2","whenSynced","syncUser","uid","conn","y","requestTransaction","callee$2$0","context$3$0","t0","t1","getStateVector","t3","t2","t4","stateVector","send","_iterator3","_isArray3","_i3","_ref3","receiveMessage","sender","m","_this","callee$3$0","ops","sv","context$4$0","getOperations","syncingClients","setTimeout","filter","cli","syncingClientDuration","broadcast","_iterator4","_isArray4","_i4","_ref4","client","apply","parseMessageFromXml","parseArray","_x","_again","_function","node","_iterator5","_isArray5","_i5","_ref5","n","children","getAttribute","parseObject","json","attrName","attrs","int","parseInt","encodeMessageToXml","msg","encodeObject","c","encodeArray","setAttribute","array","_iterator6","_isArray6","_i6","_ref6","e","xmlns","AbstractTransaction","store","addOperation","op","context$2$0","getState","id","clock","setState","operationAdded","AbstractOperationStore","parentListeners","parentListenersRequestPending","parentListenersActivated","listenersById","listenersByIdExecuteNow","listenersByIdRequestPending","_iterator7","_isArray7","_i7","_ref7","required","Y","Struct","requiredOps","whenOperationsExist","execute","ids","args","listener","missing","_iterator8","_isArray8","_i8","_ref8","_id","sid","JSON","stringify","l","exeNow","ls","_iterator9","_isArray9","_i9","_ref9","_iterator10","_isArray10","_i10","_ref10","parse","getOperation","_iterator11","_isArray11","_i11","_ref11","listeners","parent","al","activatedOperations","parentId","notifyObservers","removeParentListener","g","addParentListener","Operation","context$1$0","connector","Insert","content","left","right","origin","struct","setOperation","getDistanceToOrigin","d","distanceToOrigin","tmp","next_cl","List","start","end","ref","pos","map","res","operation","insert","contents","or","_iterator12","_isArray12","_i12","_ref12","db","transact","globalRoom","users","buffers","removeUser","_iterator13","_isArray13","_i13","_ref13","u","addUser","_iterator14","_isArray14","_i14","_ref14","setInterval","bufs","userIdCounter","Test","_AbstractConnector","options","message","_iterator15","_isArray15","_i15","_ref15","buf","disconnect","WebRTC","_AbstractConnector2","room","url","swr","SimpleWebRTC","once","joinRoom","webrtc","peers","on","peer","room_","payload","success","getPeers","sendDirectly","sendDirectlyToAll","IndexedDB","Transaction","_AbstractTransaction","transaction","objectStore","buffer","put","get","removeOperation","cursorResult","cursor","openCursor","getStateSet","ss","_iterator16","_isArray16","_i16","_ref16","startSS","endSV","_iterator17","_isArray17","_i17","_ref17","endState","startPos","endPos","range","IDBKeyRange","bound","OperationStore","_AbstractOperationStore","handleTransactions","t","request","IDBRequest","IDBCursor","onsuccess","tGen","onerror","transactionQueue","queue","shift","onRequest","IDBOpenDBRequest","event","target","onupgradeneeded","createObjectStore","keyPath","namespace","transactionGen","cont","indexedDB","open","makeGen","removeDatabase","close","deleteDatabase","_model","val","YList","model","Create"],"mappings":"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","file":"y.js","sourcesContent":["/* @flow */\n\nclass Y { //eslint-disable-line no-unused-vars\n constructor (opts) {\n this.connector = new Y[opts.connector.name](opts.connector);\n this.db = new Y[opts.db.name](this, opts.db);\n }\n transact (generator) {\n this.db.requestTransaction(generator);\n }\n}\n","// returns a rendom element of o\n// works on Object, and Array\nfunction getRandom (o) {\n if (o instanceof Array) {\n return o[Math.floor(Math.random() * o.length)];\n } else if (o.constructor === Object) {\n var keys = [];\n for (var key in o) {\n keys.push(key);\n }\n return o[getRandom(keys)];\n }\n}\n\nvar globalRoom = {\n users: {},\n buffers: {},\n removeUser: function(user){\n for (var u of this.users) {\n u.userLeft(user);\n }\n delete this.users[user];\n delete this.buffers[user];\n },\n addUser: function(connector){\n for (var u of this.users) {\n u.userJoined(connector.userId);\n }\n this.users[connector.userId] = connector;\n this.buffers[connector.userId] = [];\n }\n};\n\nsetInterval(function(){\n var bufs = [];\n for (var i in globalRoom.buffers) {\n if (globalRoom.buffers[i].length > 0) {\n bufs.push(i);\n }\n }\n if (bufs.length > 0) {\n var userId = getRandom(bufs);\n var m = globalRoom.buffers[userId];\n var user = globalRoom.users[userId];\n user.receiveMessage(m);\n }\n}, 10);\n\nvar userIdCounter = 0;\n\nclass Test extends AbstractConnector {\n constructor (options) {\n if(options === undefined){\n throw new Error(\"Options must not be undefined!\");\n }\n super({\n role: \"master\"\n });\n\n this.setUserId((userIdCounter++) + \"\");\n }\n send (uid, message) {\n globalRoom.buffers[uid].push(message);\n }\n broadcast (message) {\n for (var buf of globalRoom.buffers) {\n buf.push(message);\n }\n }\n disconnect () {\n globalRoom.removeUser(this.userId);\n }\n}\n\nY.Test = Test;\n","/**\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","\nclass AbstractConnector { //eslint-disable-line no-unused-vars\n /*\n opts\n .role : String Role of this client (\"master\" or \"slave\")\n .userId : String that uniquely defines the user.\n */\n constructor (opts) {\n if (opts == null){\n opts = {};\n }\n if (opts.role == null || opts.role === \"master\") {\n this.role = \"master\";\n } else if (opts.role === \"slave\") {\n this.role = \"slave\";\n } else {\n throw new Error(\"Role must be either 'master' or 'slave'!\");\n }\n this.role = opts.role;\n this.connections = {};\n this.userEventListeners = [];\n this.whenSyncedListeners = [];\n this.currentSyncTarget = null;\n }\n setUserId (userId) {\n this.os.setUserId(userId);\n }\n onUserEvent (f) {\n this.userEventListeners.push(f);\n }\n userLeft (user : string) {\n delete this.connections[user];\n if (user === this.currentSyncTarget){\n this.currentSyncTarget = null;\n this.findNextSyncTarget();\n }\n for (var f of this.userEventListeners){\n f({\n action: \"userLeft\",\n user: user\n });\n }\n }\n userJoined (user, role) {\n if(role == null){\n throw new Error(\"You must specify the role of the joined user!\");\n }\n if (this.connections[user] != null) {\n throw new Error(\"This user already joined!\");\n }\n this.connections[user] = {\n isSynced: false,\n role: role\n };\n for (var f of this.userEventListeners) {\n f({\n action: \"userJoined\",\n user: user,\n role: role\n });\n }\n }\n // Execute a function _when_ we are connected.\n // If not connected, wait until connected\n whenSynced (f) {\n if (this.isSynced === true) {\n f();\n } else {\n this.whenSyncedListeners.push(f);\n }\n }\n // returns false, if there is no sync target\n // true otherwise\n findNextSyncTarget () {\n if (this.currentSyncTarget != null && this.connections[this.currentSyncTarget].isSynced === false) {\n throw new Error(\"The current sync has not finished!\");\n }\n\n\n var syncUser = null;\n for (var uid in this.connections) {\n syncUser = this.connections[uid];\n if (!syncUser.isSynced) {\n break;\n }\n }\n if (syncUser != null){\n var conn = this;\n this.y.os.requestTransaction(function*(){\n conn.currentSyncTarget = uid;\n conn.send(uid, {\n type: \"sync step 1\",\n stateVector: yield* this.getStateVector()\n });\n });\n }\n // set the state to synced!\n if (!this.isSynced) {\n this.isSynced = true;\n for (var f of this.whenSyncedListeners) {\n f();\n }\n this.whenSyncedListeners = null;\n }\n return false;\n }\n // You received a raw message, and you know that it is intended for to Yjs. Then call this function.\n receiveMessage (sender, m) {\n if (m.type === \"sync step 1\") {\n // TODO: make transaction, stream the ops\n let conn = this;\n this.os.requestTransaction(function*(){\n var ops = yield* this.getOperations(m.stateVector);\n var sv = yield* this.getStateVector();\n conn.send(sender, {\n type: \"sync step 2\",\n os: ops,\n stateVector: sv\n });\n conn.syncingClients.push(sender);\n setTimeout(function(){\n conn.syncingClients = conn.syncingClients.filter(function(cli){\n return cli !== sender;\n });\n conn.send(sender, {\n type: \"sync done\"\n });\n }, conn.syncingClientDuration);\n });\n } else if (m.type === \"sync step 2\") {\n let conn = this;\n this.os.requestTransaction(function*(){\n var ops = yield* this.getOperations(m.stateVector);\n conn.broadcast({\n type: \"update\",\n ops: ops\n });\n });\n } else if (m.type === \"sync done\") {\n this.connections[sender].isSynced = true;\n this.findNextSyncTarget();\n } else if (m.type === \"update\") {\n for (var client of this.syncingClients) {\n this.send(client, m);\n }\n this.os.apply(m.ops);\n }\n }\n // Currently, the HB encodes operations as JSON. For the moment I want to keep it\n // that way. Maybe we support encoding in the HB as XML in the future, but for now I don't want\n // too much overhead. Y is very likely to get changed a lot in the future\n //\n // Because we don't want to encode JSON as string (with character escaping, wich makes it pretty much unreadable)\n // we encode the JSON as XML.\n //\n // When the HB support encoding as XML, the format should look pretty much like this.\n //\n // does not support primitive values as array elements\n // expects an ltx (less than xml) object\n parseMessageFromXml (m) {\n function parseArray (node) {\n for (var n of node.children){\n if (n.getAttribute(\"isArray\") === \"true\") {\n return parseArray(n);\n } else {\n return parseObject(n);\n }\n }\n }\n function parseObject (node) {\n var json = {};\n for (var attrName in node.attrs) {\n var value = node.attrs[attrName];\n var int = parseInt(value);\n if (isNaN(int) || (\"\" + int) !== value){\n json[attrName] = value;\n } else {\n json[attrName] = int;\n }\n }\n for (var n in node.children){\n var name = n.name;\n if (n.getAttribute(\"isArray\") === \"true\") {\n json[name] = parseArray(n);\n } else {\n json[name] = parseObject(n);\n }\n }\n return json;\n }\n parseObject(m);\n }\n // encode message in xml\n // we use string because Strophe only accepts an \"xml-string\"..\n // So {a:4,b:{c:5}} will look like\n // <y a=\"4\">\n // <b c=\"5\"></b>\n // </y>\n // m - ltx element\n // json - Object\n encodeMessageToXml (msg, obj) {\n // attributes is optional\n function encodeObject (m, json) {\n for (var name in json) {\n var value = json[name];\n if (name == null) {\n // nop\n } else if (value.constructor === Object) {\n encodeObject(m.c(name), value);\n } else if (value.constructor === Array) {\n encodeArray(m.c(name), value);\n } else {\n m.setAttribute(name, value);\n }\n }\n }\n function encodeArray (m, array) {\n m.setAttribute(\"isArray\", \"true\");\n for (var e of array) {\n if (e.constructor === Object) {\n encodeObject(m.c(\"array-element\"), e);\n } else {\n encodeArray(m.c(\"array-element\"), e);\n }\n }\n }\n if (obj.constructor === Object) {\n encodeObject(msg.c(\"y\", { xmlns: \"http://y.ninja/connector-stanza\" }), obj);\n } else if (obj.constructor === Array) {\n encodeArray(msg.c(\"y\", { xmlns: \"http://y.ninja/connector-stanza\" }), obj);\n } else {\n throw new Error(\"I can't encode this json!\");\n }\n }\n}\n","/* @flow */\nclass AbstractTransaction { //eslint-disable-line no-unused-vars\n constructor (store : OperationStore) {\n this.store = store;\n }\n // returns false 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 (y) {\n this.y = y;\n this.parentListeners = {};\n this.parentListenersRequestPending = false;\n this.parentListenersActivated = {};\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 apply (ops) {\n for (var o of ops) {\n var required = Y.Struct[o.type].requiredOps(o);\n this.whenOperationsExist(required, Y.Struct[o.type].execute, o);\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 // notify whenOperation listeners (by id)\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 // notify parent listeners, if possible\n var listeners = this.parentListeners[op.parent];\n if ( this.parentListenersRequestPending\n || ( listeners == null )\n || ( listeners.length === 0 )) {\n return;\n }\n var al = this.parentListenersActivated[JSON.stringify(op.parent)];\n if ( al == null ){\n al = [];\n this.parentListenersActivated[JSON.stringify(op.parent)] = al;\n }\n al.push(op);\n\n this.parentListenersRequestPending = true;\n var store = this;\n this.requestTransaction(function*(){\n store.parentListenersRequestPending = false;\n var activatedOperations = store.parentListenersActivated;\n store.parentListenersActivated = {};\n for (var parentId in activatedOperations){\n var parent = yield* this.getOperation(parentId);\n Struct[parent.type].notifyObservers(activatedOperations[parentId]);\n }\n });\n\n }\n removeParentListener (id, f) {\n var ls = this.parentListeners[id];\n if (ls != null) {\n this.parentListeners[id] = ls.filter(function(g){\n return (f !== g);\n });\n }\n }\n addParentListener (id, f) {\n var ls = this.parentListeners[JSON.stringify(id)];\n if (ls == null) {\n ls = [];\n this.parentListeners[JSON.stringify(id)] = ls;\n }\n ls.push(f);\n }\n}\n","/* @flow */\n\n// Op is anything that we could get from the OperationStore.\ntype Op = Object;\ntype Id = [string, number];\n\ntype List = {\n id: Id,\n start: Insert,\n end: Insert\n};\n\ntype Insert = {\n id: Id,\n left: Insert,\n right: Insert,\n origin: Insert,\n parent: List,\n content: any\n};\n\nvar Struct = {\n Operation: { //eslint-disable-line no-unused-vars\n create: function*(op : Op) : Struct.Operation {\n var user = this.store.y.connector.userId;\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 content: any,\n left: Insert,\n right: Insert,\n parent: List) : Insert {\n op.left = left ? left.id : null;\n op.origin = op.left;\n op.right = right ? right.id : null;\n op.parent = parent.id;\n op.struct = \"Insert\";\n yield* Struct.Operation.create.call(this, op);\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 if(op.left != null){\n ids.push(op.left);\n }\n if(op.right != null){\n ids.push(op.right);\n }\n return ids;\n },\n getDistanceToOrigin: function *(op){\n var d = 0;\n var o = yield this.getOperation(op.left);\n while (op.origin !== (o ? o.id : null)) {\n d++;\n o = yield this.getOperation(o.left);\n }\n return d;\n },\n /*\n # $this has to find a unique position between origin and the next known character\n # case 1: $origin equals $o.origin: the $creator parameter decides if left or right\n # let $OL= [o1,o2,o3,o4], whereby $this is to be inserted between o1 and o4\n # o2,o3 and o4 origin is 1 (the position of o2)\n # there is the case that $this.creator < o2.creator, but o3.creator < $this.creator\n # then o2 knows o3. Since on another client $OL could be [o1,o3,o4] the problem is complex\n # therefore $this would be always to the right of o3\n # case 2: $origin < $o.origin\n # if current $this insert_position > $o origin: $this ins\n # else $insert_position will not change\n # (maybe we encounter case 1 later, then this will be to the right of $o)\n # case 3: $origin > $o.origin\n # $this insert_position is to the left of $o (forever!)\n */\n execute: function*(op){\n var distanceToOrigin = yield* Struct.Insert.getDistanceToOrigin(op); // most cases: 0 (starts from 0)\n var i = distanceToOrigin; // loop counter\n var o = yield* this.getOperation(this.left);\n o = yield* this.getOperation(o.right);\n var tmp;\n while (true) {\n if (o.id !== this.right){\n if (Struct.Insert.getDistanceToOrigin(o) === i) {\n // case 1\n if (o.id[0] < op.id[0]) {\n op.left = o;\n distanceToOrigin = i + 1;\n }\n } else if ((tmp = Struct.Insert.getDistanceToOrigin(o)) < i) {\n // case 2\n if (i - distanceToOrigin <= tmp) {\n op.left = o;\n distanceToOrigin = i + 1;\n }\n } else {\n break;\n }\n i++;\n o = yield* this.getOperation(o.next_cl);\n } else {\n break;\n }\n }\n // reconnect..\n var left = this.getOperation(op.left);\n var right = this.getOperation(op.right);\n left.right = op.id;\n right.left = op.id;\n op.left = left;\n op.right = right;\n yield* this.setOperation(left);\n yield* this.setOperation(right);\n yield* this.setOperation(op);\n }\n },\n List: {\n create: function*( op : Op){\n op.start = null;\n op.end = null;\n op.struct = \"List\";\n return yield* Struct.Operation.create.call(this, op);\n },\n requiredOps: function(op, ids){\n if (op.start != null) {\n ids.push(op.start);\n }\n if (op.end != null){\n ids.push(op.end);\n }\n return ids;\n },\n execute: function* () {\n // nop\n },\n ref: function* (op : Op, pos : number) : Insert {\n var o = op.start;\n while ( pos !== 0 || o != null) {\n o = (yield* this.getOperation(o)).right;\n pos--;\n }\n return (o == null) ? null : yield* this.getOperation(o);\n },\n map: function* (o : Op, f : Function) : Array<any> {\n o = o.start;\n var res = [];\n while ( o != null) {\n var operation = yield* this.getOperation(o);\n res.push(f(operation.content));\n o = operation.right;\n }\n return res;\n },\n insert: function* (op, pos : number, contents : Array<any>) {\n var o = yield* Struct.List.ref.call(this, op, pos);\n var or = yield* this.getOperation(o.right);\n for (var content of contents) {\n o = yield* Struct.Insert.create.call(this, {}, content, o, or, op);\n }\n }\n }\n};\n","\nclass WebRTC extends AbstractConnector {\n constructor (options) {\n if(options === undefined){\n throw new Error(\"Options must not be undefined!\");\n }\n super({\n role: \"slave\"\n });\n\n var room = options.room;\n\n // connect per default to our server\n if(options.url == null){\n options.url = \"https://yatta.ninja:8888\";\n }\n\n var swr = new SimpleWebRTC(options); //eslint-disable-line no-undef\n this.swr = swr;\n var self = this;\n\n swr.once(\"connectionReady\", function(userId){\n // SimpleWebRTC (swr) is initialized\n swr.joinRoom(room);\n\n swr.once(\"joinedRoom\", function(){\n self.setUserId(userId);\n var i;\n // notify the connector class about all the users that already\n // joined the session\n for(i in self.swr.webrtc.peers){\n self.userJoined(self.swr.webrtc.peers[i].id, \"master\");\n }\n swr.on(\"channelMessage\", function(peer, room_, message){\n // The client received a message\n // Check if the connector is already initialized,\n // only then forward the message to the connector class\n if(message.type != null ){\n self.receiveMessage(peer.id, message.payload);\n }\n });\n });\n\n swr.on(\"createdPeer\", function(peer){\n // a new peer/client joined the session.\n // Notify the connector class, if the connector\n // is already initialized\n self.userJoined(peer.id, \"master\");\n });\n\n swr.on(\"peerStreamRemoved\", function(peer){\n // a client left the session.\n // Notify the connector class, if the connector\n // is already initialized\n self.userLeft(peer.id);\n });\n });\n }\n send (uid, message) {\n var self = this;\n // we have to make sure that the message is sent under all circumstances\n var send = function(){\n // check if the clients still exists\n var peer = self.swr.webrtc.getPeers(uid)[0];\n var success;\n if(peer){\n // success is true, if the message is successfully sent\n success = peer.sendDirectly(\"simplewebrtc\", \"yjs\", message);\n }\n if(!success){\n // resend the message if it didn't work\n setTimeout(send, 500);\n }\n };\n // try to send the message\n send();\n }\n broadcast (message) {\n this.swr.sendDirectlyToAll(\"simplewebrtc\", \"yjs\", message);\n }\n}\n\nY.WebRTC = WebRTC;\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\nY.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 (y, opts) {\n super(y);\n if (opts == null) {\n opts = {};\n }\n if (opts.namespace != null || typeof opts.namespace !== \"string\") {\n throw new Error(\"IndexedDB: expect a string (opts.namespace)!\");\n } else {\n this.namespace = opts.namespace;\n }\n\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(opts.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, request);/*\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","\n\n(function(){\n\n class List {\n constructor (_model) {\n this._model = _model;\n }\n *val (pos) {\n if (pos != null) {\n var o = yield* this.Struct.List.ref(this._model, pos);\n return o ? o.content : null;\n } else {\n return yield* this.Struct.List.map(this._model, function(c){return c; });\n }\n }\n *insert (pos, contents) {\n yield* this.Struct.List.insert(pos, contents);\n }\n }\n\n Y.List = function* YList(){\n var model = yield* this.Struct.List.create();\n return new List(model);\n };\n Y.List.Create = List;\n})();\n"],"sourceRoot":"/source/"} \ No newline at end of file