diff options
author | Alexander Sulfrian <alexander@sulfrian.net> | 2010-06-08 09:01:43 +0200 |
---|---|---|
committer | Alexander Sulfrian <alexander@sulfrian.net> | 2010-06-08 09:01:43 +0200 |
commit | d1fa08fdc9cb11dccee76d668ff85df30458c295 (patch) | |
tree | 1d19df6405103577d872902486792e8c23bce711 /trunk/infrastructure/com.etherpad/easysync2support.scala | |
parent | d7c5ad7d6263fd1baf9bfdbaa4c50b70ef2fbdb2 (diff) | |
parent | 70d1f9d6fcaefe611e778b8dbf3bafea8934aa08 (diff) | |
download | etherpad-d1fa08fdc9cb11dccee76d668ff85df30458c295.tar.gz etherpad-d1fa08fdc9cb11dccee76d668ff85df30458c295.tar.xz etherpad-d1fa08fdc9cb11dccee76d668ff85df30458c295.zip |
Merge remote branch 'upstream/master'
Conflicts:
etherpad/src/etherpad/control/pro/admin/pro_admin_control.js
etherpad/src/etherpad/control/pro/pro_main_control.js
etherpad/src/etherpad/control/pro_help_control.js
etherpad/src/etherpad/globals.js
etherpad/src/etherpad/legacy_urls.js
etherpad/src/etherpad/pne/pne_utils.js
etherpad/src/etherpad/pro/pro_utils.js
etherpad/src/main.js
etherpad/src/plugins/fileUpload/templates/fileUpload.ejs
etherpad/src/plugins/testplugin/templates/page.ejs
etherpad/src/static/css/pad2_ejs.css
etherpad/src/static/css/pro-help.css
etherpad/src/static/img/jun09/pad/protop.gif
etherpad/src/static/js/store.js
etherpad/src/themes/default/templates/framed/framedheader-pro.ejs
etherpad/src/themes/default/templates/main/home.ejs
etherpad/src/themes/default/templates/pro-help/main.ejs
etherpad/src/themes/default/templates/pro-help/pro-help-template.ejs
infrastructure/com.etherpad/licensing.scala
trunk/etherpad/src/etherpad/collab/ace/contentcollector.js
trunk/etherpad/src/etherpad/collab/ace/linestylefilter.js
trunk/etherpad/src/static/css/home-opensource.css
trunk/etherpad/src/static/js/ace.js
trunk/etherpad/src/static/js/linestylefilter_client.js
trunk/etherpad/src/templates/email/eepnet_license_info.ejs
trunk/etherpad/src/templates/pad/pad_body2.ejs
trunk/etherpad/src/templates/pad/pad_content.ejs
trunk/etherpad/src/templates/pad/padfull_body.ejs
trunk/etherpad/src/templates/pro/admin/pne-license-manager.ejs
Diffstat (limited to 'trunk/infrastructure/com.etherpad/easysync2support.scala')
-rw-r--r-- | trunk/infrastructure/com.etherpad/easysync2support.scala | 167 |
1 files changed, 0 insertions, 167 deletions
diff --git a/trunk/infrastructure/com.etherpad/easysync2support.scala b/trunk/infrastructure/com.etherpad/easysync2support.scala deleted file mode 100644 index 9f1c527..0000000 --- a/trunk/infrastructure/com.etherpad/easysync2support.scala +++ /dev/null @@ -1,167 +0,0 @@ -/** - * Copyright 2009 Google Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS-IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package com.etherpad; - -object Easysync2Support { - - def numToString(d: Int): String = java.lang.Integer.toString(d.toInt, 36); // lowercase - def stringToNum(s: String): Int = java.lang.Integer.parseInt(s, 36); - - def opAssembler() = new OpAssembler(); - - class OpAssembler() { - val buf = new StringBuilder(1000); - def append(op: Op) { - append(op.opcode, op.chars, op.lines, op.attribs); - } - def append(opcode: String, chars: Int, lines: Int, attribs: String) { - buf.append(attribs); - if (lines > 0) { - buf.append('|'); - buf.append(numToString(lines)); - } - buf.append(opcode); - buf.append(numToString(chars)); - } - override def toString(): String = buf.toString; - def clear() { buf.clear; } - } - - def isAlphanum(c: Char) = (c >= '0' && c <= '9' || c >= 'a' && c <= 'z'); - - case object OpParseError extends Error; - - def nextOpInString(str: String, startIndex: Int): Object = { - var i = startIndex; - - try { - def lookingAt(c: Char) = (i < str.length && str.charAt(i) == c); - def lookingAtAlphanum() = (i < str.length && isAlphanum(str.charAt(i))); - def atEnd() = (i >= str.length); - def readAlphanum(): Int = { - if (! lookingAtAlphanum()) { - throw OpParseError; - } - val start = i; - while (lookingAtAlphanum()) { - i += 1; - } - val end = i; - stringToNum(str.substring(start, end)); - } - - while (lookingAt('*')) { - i += 1; - if (! lookingAtAlphanum()) { - throw OpParseError; - } - while (lookingAtAlphanum()) { - i += 1; - } - } - val attribsEnd = i; - - var lines_ = 0; - if (lookingAt('|')) { - i += 1; - lines_ = readAlphanum(); - } - - if (lookingAt('?')) { - return new { val opcode = "?"; } - } - if (! (lookingAt('+') || lookingAt('-') || lookingAt('='))) { - throw OpParseError; - } - val opcode_ = str.substring(i, i+1); - i += 1; - val chars_ = readAlphanum(); - - return new Op(opcode_, chars_, lines_, str.substring(startIndex, attribsEnd)) { - val lastIndex = i; - }; - } - catch { case OpParseError => null } - } - - case class Op(var opcode: String, var chars: Int, var lines: Int, var attribs: String); - def newOp() = Op("", 0, 0, ""); - def clearOp(op: Op) { op.opcode = ""; op.chars = 0; op.lines = 0; op.attribs = ""; } - - // ported from easysync2.js - class MergingOpAssembler { - val assem = opAssembler(); - var bufOp = newOp(); - - var bufOpAdditionalCharsAfterNewline = 0; - - def flush(isEndDocument: Boolean) { - if (bufOp.opcode.length > 0) { - if (isEndDocument && bufOp.opcode == "=" && bufOp.attribs.length == 0) { - // final merged keep, leave it implicit - } - else { - assem.append(bufOp); - if (bufOpAdditionalCharsAfterNewline > 0) { - bufOp.chars = bufOpAdditionalCharsAfterNewline; - bufOp.lines = 0; - assem.append(bufOp); - bufOpAdditionalCharsAfterNewline = 0; - } - } - bufOp.opcode = ""; - } - } - def append(opcode: String, chars: Int, lines: Int, attribs: String) { - if (chars > 0) { - if (bufOp.opcode == opcode && bufOp.attribs == attribs) { - if (lines > 0) { - // bufOp and additional chars are all mergeable into a multi-line op - bufOp.chars += bufOpAdditionalCharsAfterNewline + chars; - bufOp.lines += lines; - bufOpAdditionalCharsAfterNewline = 0; - } - else if (bufOp.lines == 0) { - // both bufOp and op are in-line - bufOp.chars += chars; - } - else { - // append in-line text to multi-line bufOp - bufOpAdditionalCharsAfterNewline += chars; - } - } - else { - flush(false); - bufOp = Op(opcode, chars, lines, attribs); - } - } - } - def endDocument() { - flush(true); - } - override def toString() = { - flush(false); - assem.toString(); - } - def clear() { - assem.clear(); - clearOp(bufOp); - } - } - - def mergingOpAssembler() = new MergingOpAssembler(); -} |