replaceing AttributePoolFactory by AttributePool

This commit is contained in:
Matthias Bartelmeß 2012-03-18 09:05:46 +01:00
parent cccd8a923c
commit 8eb43a3ebf
11 changed files with 90 additions and 89 deletions

View file

@ -6,7 +6,7 @@ var mysql = require("mysql");
var async = require("async"); var async = require("async");
var Changeset = require("ep_etherpad-lite/static/js/Changeset"); var Changeset = require("ep_etherpad-lite/static/js/Changeset");
var randomString = require('ep_etherpad-lite/static/js/pad_utils').randomString; var randomString = require('ep_etherpad-lite/static/js/pad_utils').randomString;
var AttributePoolFactory = require("ep_etherpad-lite/static/js/AttributePoolFactory"); var AttributePool = require("ep_etherpad-lite/static/js/AttributePool");
var settingsFile = process.argv[2]; var settingsFile = process.argv[2];
var sqlOutputFile = process.argv[3]; var sqlOutputFile = process.argv[3];
@ -384,7 +384,7 @@ function convertPad(padId, callback)
} }
//generate the latest atext //generate the latest atext
var fullAPool = AttributePoolFactory.createAttributePool().fromJsonable(apool); var fullAPool = (new AttributePool()).fromJsonable(apool);
var keyRev = Math.floor(padmeta.head / padmeta.keyRevInterval) * padmeta.keyRevInterval; var keyRev = Math.floor(padmeta.head / padmeta.keyRevInterval) * padmeta.keyRevInterval;
var atext = changesetsMeta[keyRev].atext; var atext = changesetsMeta[keyRev].atext;
var curRev = keyRev; var curRev = keyRev;

View file

@ -5,7 +5,7 @@
var ERR = require("async-stacktrace"); var ERR = require("async-stacktrace");
var Changeset = require("ep_etherpad-lite/static/js/Changeset"); var Changeset = require("ep_etherpad-lite/static/js/Changeset");
var AttributePoolFactory = require("ep_etherpad-lite/static/js/AttributePoolFactory"); var AttributePool = require("ep_etherpad-lite/static/js/AttributePool");
var randomString = require('ep_etherpad-lite/static/js/pad_utils').randomString; var randomString = require('ep_etherpad-lite/static/js/pad_utils').randomString;
var db = require("./DB").db; var db = require("./DB").db;
var async = require("async"); var async = require("async");
@ -28,7 +28,7 @@ exports.cleanText = function (txt) {
var Pad = function Pad(id) { var Pad = function Pad(id) {
this.atext = Changeset.makeAText("\n"); this.atext = Changeset.makeAText("\n");
this.pool = AttributePoolFactory.createAttributePool(); this.pool = new AttributePool();
this.head = -1; this.head = -1;
this.chatHead = -1; this.chatHead = -1;
this.publicStatus = false; this.publicStatus = false;

View file

@ -22,7 +22,7 @@
var Changeset = require("ep_etherpad-lite/static/js/Changeset"); var Changeset = require("ep_etherpad-lite/static/js/Changeset");
var AttributePoolFactory = require("ep_etherpad-lite/static/js/AttributePoolFactory"); var AttributePool = require("ep_etherpad-lite/static/js/AttributePool");
function random() { function random() {
this.nextInt = function (maxValue) { this.nextInt = function (maxValue) {
@ -227,7 +227,7 @@ function runTests() {
return attribs; // it's already an attrib pool return attribs; // it's already an attrib pool
} else { } else {
// assume it's an array of attrib strings to be split and added // assume it's an array of attrib strings to be split and added
var p = AttributePoolFactory.createAttributePool(); var p = new AttributePool();
attribs.forEach(function (kv) { attribs.forEach(function (kv) {
p.putAttrib(kv.split(',')); p.putAttrib(kv.split(','));
}); });
@ -325,7 +325,7 @@ function runTests() {
runMutateAttributionTest(4, ['foo,bar', 'line,1', 'line,2', 'line,3', 'line,4', 'line,5'], "Z:5>1|2=2+1$x", ["?*1|1+1", "?*2|1+1", "*3|1+1", "?*4|1+1", "?*5|1+1"], ["?*1|1+1", "?*2|1+1", "+1*3|1+1", "?*4|1+1", "?*5|1+1"]); runMutateAttributionTest(4, ['foo,bar', 'line,1', 'line,2', 'line,3', 'line,4', 'line,5'], "Z:5>1|2=2+1$x", ["?*1|1+1", "?*2|1+1", "*3|1+1", "?*4|1+1", "?*5|1+1"], ["?*1|1+1", "?*2|1+1", "+1*3|1+1", "?*4|1+1", "?*5|1+1"]);
var testPoolWithChars = (function () { var testPoolWithChars = (function () {
var p = AttributePoolFactory.createAttributePool(); var p = new AttributePool();
p.putAttrib(['char', 'newline']); p.putAttrib(['char', 'newline']);
for (var i = 1; i < 36; i++) { for (var i = 1; i < 36; i++) {
p.putAttrib(['char', Changeset.numToString(i)]); p.putAttrib(['char', Changeset.numToString(i)]);
@ -560,7 +560,7 @@ function runTests() {
var rand = new random(); var rand = new random();
print("> testCompose#" + randomSeed); print("> testCompose#" + randomSeed);
var p = AttributePoolFactory.createAttributePool(); var p = new AttributePool();
var startText = randomMultiline(10, 20, rand) + '\n'; var startText = randomMultiline(10, 20, rand) + '\n';
@ -594,7 +594,7 @@ function runTests() {
(function simpleComposeAttributesTest() { (function simpleComposeAttributesTest() {
print("> simpleComposeAttributesTest"); print("> simpleComposeAttributesTest");
var p = AttributePoolFactory.createAttributePool(); var p = new AttributePool();
p.putAttrib(['bold', '']); p.putAttrib(['bold', '']);
p.putAttrib(['bold', 'true']); p.putAttrib(['bold', 'true']);
var cs1 = Changeset.checkRep("Z:2>1*1+1*1=1$x"); var cs1 = Changeset.checkRep("Z:2>1*1+1*1=1$x");
@ -604,7 +604,7 @@ function runTests() {
})(); })();
(function followAttributesTest() { (function followAttributesTest() {
var p = AttributePoolFactory.createAttributePool(); var p = new AttributePool();
p.putAttrib(['x', '']); p.putAttrib(['x', '']);
p.putAttrib(['x', 'abc']); p.putAttrib(['x', 'abc']);
p.putAttrib(['x', 'def']); p.putAttrib(['x', 'def']);
@ -633,7 +633,7 @@ function runTests() {
var rand = new random(); var rand = new random();
print("> testFollow#" + randomSeed); print("> testFollow#" + randomSeed);
var p = AttributePoolFactory.createAttributePool(); var p = new AttributePool();
var startText = randomMultiline(10, 20, rand) + '\n'; var startText = randomMultiline(10, 20, rand) + '\n';
@ -682,8 +682,8 @@ function runTests() {
(function testMoveOpsToNewPool() { (function testMoveOpsToNewPool() {
print("> testMoveOpsToNewPool"); print("> testMoveOpsToNewPool");
var pool1 = AttributePoolFactory.createAttributePool(); var pool1 = new AttributePool();
var pool2 = AttributePoolFactory.createAttributePool(); var pool2 = new AttributePool();
pool1.putAttrib(['baz', 'qux']); pool1.putAttrib(['baz', 'qux']);
pool1.putAttrib(['foo', 'bar']); pool1.putAttrib(['foo', 'bar']);
@ -738,7 +738,7 @@ function runTests() {
(function testOpAttributeValue() { (function testOpAttributeValue() {
print("> testOpAttributeValue"); print("> testOpAttributeValue");
var p = AttributePoolFactory.createAttributePool(); var p = new AttributePool();
p.putAttrib(['name', 'david']); p.putAttrib(['name', 'david']);
p.putAttrib(['color', 'green']); p.putAttrib(['color', 'green']);

View file

@ -23,7 +23,7 @@ var ERR = require("async-stacktrace");
var async = require("async"); var async = require("async");
var padManager = require("../db/PadManager"); var padManager = require("../db/PadManager");
var Changeset = require("ep_etherpad-lite/static/js/Changeset"); var Changeset = require("ep_etherpad-lite/static/js/Changeset");
var AttributePoolFactory = require("ep_etherpad-lite/static/js/AttributePoolFactory"); var AttributePool = require("ep_etherpad-lite/static/js/AttributePool");
var authorManager = require("../db/AuthorManager"); var authorManager = require("../db/AuthorManager");
var readOnlyManager = require("../db/ReadOnlyManager"); var readOnlyManager = require("../db/ReadOnlyManager");
var settings = require('../utils/Settings'); var settings = require('../utils/Settings');
@ -368,7 +368,7 @@ function handleUserChanges(client, message)
//get all Vars we need //get all Vars we need
var baseRev = message.data.baseRev; var baseRev = message.data.baseRev;
var wireApool = (AttributePoolFactory.createAttributePool()).fromJsonable(message.data.apool); var wireApool = (new AttributePool()).fromJsonable(message.data.apool);
var changeset = message.data.changeset; var changeset = message.data.changeset;
var r, apool, pad; var r, apool, pad;

View file

@ -23,7 +23,7 @@ var ERR = require("async-stacktrace");
var async = require("async"); var async = require("async");
var padManager = require("../db/PadManager"); var padManager = require("../db/PadManager");
var Changeset = require("ep_etherpad-lite/static/js/Changeset"); var Changeset = require("ep_etherpad-lite/static/js/Changeset");
var AttributePoolFactory = require("ep_etherpad-lite/static/js/AttributePoolFactory"); var AttributePool = require("ep_etherpad-lite/static/js/AttributePool");
var settings = require('../utils/Settings'); var settings = require('../utils/Settings');
var authorManager = require("../db/AuthorManager"); var authorManager = require("../db/AuthorManager");
var log4js = require('log4js'); var log4js = require('log4js');
@ -265,7 +265,7 @@ function getChangesetInfo(padId, startNum, endNum, granularity, callback)
var forwardsChangesets = []; var forwardsChangesets = [];
var backwardsChangesets = []; var backwardsChangesets = [];
var timeDeltas = []; var timeDeltas = [];
var apool = AttributePoolFactory.createAttributePool(); var apool = new AttributePool();
var pad; var pad;
var composedChangesets = {}; var composedChangesets = {};
var revisionDate = []; var revisionDate = [];

View file

@ -39,7 +39,7 @@
, "pad_modals.js" , "pad_modals.js"
, "pad_savedrevs.js" , "pad_savedrevs.js"
, "pad_impexp.js" , "pad_impexp.js"
, "AttributePoolFactory.js" , "AttributePool.js"
, "Changeset.js" , "Changeset.js"
, "domline.js" , "domline.js"
, "linestylefilter.js" , "linestylefilter.js"
@ -51,7 +51,7 @@
] ]
, "ace2_inner.js": [ , "ace2_inner.js": [
"ace2_common.js" "ace2_common.js"
, "AttributePoolFactory.js" , "AttributePool.js"
, "Changeset.js" , "Changeset.js"
, "security.js" , "security.js"
, "skiplist.js" , "skiplist.js"

View file

@ -22,69 +22,69 @@
* limitations under the License. * limitations under the License.
*/ */
exports.createAttributePool = function () { var AttributePool = function () {
var p = {}; this.numToAttrib = {}; // e.g. {0: ['foo','bar']}
p.numToAttrib = {}; // e.g. {0: ['foo','bar']} this.attribToNum = {}; // e.g. {'foo,bar': 0}
p.attribToNum = {}; // e.g. {'foo,bar': 0} this.nextNum = 0;
p.nextNum = 0; };
p.putAttrib = function (attrib, dontAddIfAbsent) { AttributePool.prototype.putAttrib = function (attrib, dontAddIfAbsent) {
var str = String(attrib); var str = String(attrib);
if (str in p.attribToNum) { if (str in this.attribToNum) {
return p.attribToNum[str]; return this.attribToNum[str];
} }
if (dontAddIfAbsent) { if (dontAddIfAbsent) {
return -1; return -1;
} }
var num = p.nextNum++; var num = this.nextNum++;
p.attribToNum[str] = num; this.attribToNum[str] = num;
p.numToAttrib[num] = [String(attrib[0] || ''), String(attrib[1] || '')]; this.numToAttrib[num] = [String(attrib[0] || ''), String(attrib[1] || '')];
return num; return num;
}; };
p.getAttrib = function (num) { AttributePool.prototype.getAttrib = function (num) {
var pair = p.numToAttrib[num]; var pair = this.numToAttrib[num];
if (!pair) { if (!pair) {
return pair; return pair;
} }
return [pair[0], pair[1]]; // return a mutable copy return [pair[0], pair[1]]; // return a mutable copy
}; };
p.getAttribKey = function (num) { AttributePool.prototype.getAttribKey = function (num) {
var pair = p.numToAttrib[num]; var pair = this.numToAttrib[num];
if (!pair) return ''; if (!pair) return '';
return pair[0]; return pair[0];
}; };
p.getAttribValue = function (num) { AttributePool.prototype.getAttribValue = function (num) {
var pair = p.numToAttrib[num]; var pair = this.numToAttrib[num];
if (!pair) return ''; if (!pair) return '';
return pair[1]; return pair[1];
}; };
p.eachAttrib = function (func) { AttributePool.prototype.eachAttrib = function (func) {
for (var n in p.numToAttrib) { for (var n in this.numToAttrib) {
var pair = p.numToAttrib[n]; var pair = this.numToAttrib[n];
func(pair[0], pair[1]); func(pair[0], pair[1]);
} }
}; };
p.toJsonable = function () { AttributePool.prototype.toJsonable = function () {
return { return {
numToAttrib: p.numToAttrib, numToAttrib: this.numToAttrib,
nextNum: p.nextNum nextNum: this.nextNum
};
}; };
};
p.fromJsonable = function (obj) { AttributePool.prototype.fromJsonable = function (obj) {
p.numToAttrib = obj.numToAttrib; this.numToAttrib = obj.numToAttrib;
p.nextNum = obj.nextNum; this.nextNum = obj.nextNum;
p.attribToNum = {}; this.attribToNum = {};
for (var n in p.numToAttrib) { for (var n in this.numToAttrib) {
p.attribToNum[String(p.numToAttrib[n])] = Number(n); this.attribToNum[String(this.numToAttrib[n])] = Number(n);
} }
return p; return this;
}; };
return p;
} module.exports = AttributePool;

View file

@ -25,7 +25,7 @@
* limitations under the License. * limitations under the License.
*/ */
var AttributePoolFactory = require("./AttributePoolFactory"); var AttributePool = require("./AttributePool");
var _opt = null; var _opt = null;
@ -1731,7 +1731,7 @@ exports.appendATextToAssembler = function (atext, assem) {
* @param pool {AtributePool} * @param pool {AtributePool}
*/ */
exports.prepareForWire = function (cs, pool) { exports.prepareForWire = function (cs, pool) {
var newPool = AttributePoolFactory.createAttributePool();; var newPool = new AttributePool();
var newCs = exports.moveOpsToNewPool(cs, pool, newPool); var newCs = exports.moveOpsToNewPool(cs, pool, newPool);
return { return {
translated: newCs, translated: newCs,

View file

@ -43,7 +43,7 @@ var colorutils = require('./colorutils').colorutils;
var makeContentCollector = require('./contentcollector').makeContentCollector; var makeContentCollector = require('./contentcollector').makeContentCollector;
var makeCSSManager = require('./cssmanager').makeCSSManager; var makeCSSManager = require('./cssmanager').makeCSSManager;
var domline = require('./domline').domline; var domline = require('./domline').domline;
var AttribPool = require('./AttributePoolFactory').createAttributePool; var AttribPool = require('./AttributePool');
var Changeset = require('./Changeset'); var Changeset = require('./Changeset');
var linestylefilter = require('./linestylefilter').linestylefilter; var linestylefilter = require('./linestylefilter').linestylefilter;
var newSkipList = require('./skiplist').newSkipList; var newSkipList = require('./skiplist').newSkipList;
@ -51,6 +51,7 @@ var undoModule = require('./undomodule').undoModule;
var makeVirtualLineView = require('./virtual_lines').makeVirtualLineView; var makeVirtualLineView = require('./virtual_lines').makeVirtualLineView;
function Ace2Inner(){ function Ace2Inner(){
var DEBUG = false; //$$ build script replaces the string "var DEBUG=true;//$$" with "var DEBUG=false;" var DEBUG = false; //$$ build script replaces the string "var DEBUG=true;//$$" with "var DEBUG=false;"
// changed to false // changed to false
var isSetUp = false; var isSetUp = false;

View file

@ -22,7 +22,7 @@
var makeCSSManager = require('./cssmanager').makeCSSManager; var makeCSSManager = require('./cssmanager').makeCSSManager;
var domline = require('./domline').domline; var domline = require('./domline').domline;
var AttribPool = require('./AttributePoolFactory').createAttributePool; var AttribPool = require('./AttributePool');
var Changeset = require('./Changeset'); var Changeset = require('./Changeset');
var linestylefilter = require('./linestylefilter').linestylefilter; var linestylefilter = require('./linestylefilter').linestylefilter;
var colorutils = require('./colorutils').colorutils; var colorutils = require('./colorutils').colorutils;

View file

@ -20,7 +20,7 @@
* limitations under the License. * limitations under the License.
*/ */
var AttribPool = require('./AttributePoolFactory').createAttributePool; var AttributePool = require('./AttributePool');
var Changeset = require('./Changeset'); var Changeset = require('./Changeset');
function makeChangesetTracker(scheduler, apool, aceCallbacksProvider) function makeChangesetTracker(scheduler, apool, aceCallbacksProvider)
@ -83,7 +83,7 @@ function makeChangesetTracker(scheduler, apool, aceCallbacksProvider)
baseAText = Changeset.cloneAText(atext); baseAText = Changeset.cloneAText(atext);
if (apoolJsonObj) if (apoolJsonObj)
{ {
var wireApool = (new AttribPool()).fromJsonable(apoolJsonObj); var wireApool = (new AttributePool()).fromJsonable(apoolJsonObj);
baseAText.attribs = Changeset.moveOpsToNewPool(baseAText.attribs, wireApool, apool); baseAText.attribs = Changeset.moveOpsToNewPool(baseAText.attribs, wireApool, apool);
} }
submittedChangeset = null; submittedChangeset = null;
@ -117,7 +117,7 @@ function makeChangesetTracker(scheduler, apool, aceCallbacksProvider)
if (apoolJsonObj) if (apoolJsonObj)
{ {
var wireApool = (new AttribPool()).fromJsonable(apoolJsonObj); var wireApool = (new AttributePool()).fromJsonable(apoolJsonObj);
c = Changeset.moveOpsToNewPool(c, wireApool, apool); c = Changeset.moveOpsToNewPool(c, wireApool, apool);
} }