Merge pull request #1340 from ajaxorg/wrap_bug

fix #1337
This commit is contained in:
Lennart Kats 2013-03-30 05:21:41 -07:00
commit 5a367bafb3
7 changed files with 38 additions and 97 deletions

9
.gitignore vendored
View file

@ -4,13 +4,8 @@
*.tmp
# Project files that should not be in the repo
.project
.settings/
.settings.xml
.settings
.c9settings.xml
.c9revisions
.settings.xml.old
.*
!/.gitignore
.*.gz
# A handy place to put stuff that git should ignore:

View file

@ -1,73 +0,0 @@
#!/usr/bin/env node
/* ***** BEGIN LICENSE BLOCK *****
* Ace is distributed under the BSD license:
*
* Copyright (c) 2010, Ajax.org B.V.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed by the Ajax.org B.V.
* 4. Neither the name of the Ajax.org B.V. nor the
* names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY AJAX.ORG B.V. ''AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL AJAX.ORG B.V. BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* ***** END LICENSE BLOCK ***** */
var buildAce = require("./Makefile.dryice").buildAce;
var fs = require("fs");
var ACE_HOME = __dirname;
function getVersion(path) {
if (fs.existsSync(path + "/.git-ref"))
return fs.readFileSync(path + "/.git-ref", "utf8");
if (fs.existsSync(path + "/.git/ORIG_HEAD"))
return fs.readFileSync(path + "/.git/ORIG_HEAD", "utf8");
if (fs.existsSync(path + "/.sourcemint/source.json")) {
var json = fs.readFileSync(path + "/.sourcemint/source.json", "utf8");
return JSON.parse(json).url.split("/").pop();
}
}
if (process.argv.indexOf("-c") > 0) try {
var version = getVersion(ACE_HOME);
var oldVersion = getVersion(ACE_HOME + "/build");
if (version && oldVersion == version) {
console.log("ace build is up to date");
process.exit(0);
}
fs.writeFileSync(ACE_HOME + "/build/.git-ref", version, "utf8");
} catch (e) {}
try {
buildAce({
compress: false,
noconflict: false,
suffix: "",
name: "ace"
});
} catch (err) {
console.error("--- Ace Build error ---");
console.error(err.stack);
process.exit(1);
}

View file

@ -1642,6 +1642,7 @@ var EditSession = function(text, mode) {
len = lastRow - firstRow;
}
this.$updating = true;
if (len != 0) {
if (action.indexOf("remove") != -1) {
this[useWrapMode ? "$wrapData" : "$rowLengthCache"].splice(firstRow, len);
@ -1734,6 +1735,7 @@ var EditSession = function(text, mode) {
if (useWrapMode && this.$wrapData.length != this.doc.getLength()) {
console.error("doc.getLength() and $wrapData.length have to be the same!");
}
this.$updating = false;
if (useWrapMode)
this.$updateWrapData(firstRow, lastRow);
@ -2402,8 +2404,8 @@ config.defineOptions(EditSession.prototype, "session", {
this.setUseWrapMode(false);
} else {
var col = typeof value == "number" ? value : null;
this.setUseWrapMode(true);
this.setWrapLimitRange(col, col);
this.setUseWrapMode(true);
}
this.$wrap = value;
},

View file

@ -384,11 +384,13 @@ function Folding() {
newFoldLine.start.column = folds[0].start.column;
}
if (this.$useWrapMode)
this.$updateWrapData(startRow, endRow);
else
this.$updateRowLengthCache(startRow, endRow);
if (!this.$updating) {
if (this.$useWrapMode)
this.$updateWrapData(startRow, endRow);
else
this.$updateRowLengthCache(startRow, endRow);
}
// Notify that fold data has changed.
this.$modified = true;
this._emit("changeFold", { data: fold });

View file

@ -899,7 +899,27 @@ module.exports = {
return session;
},
"test delete fold with wrap enabled": function() {
var session = new EditSession("");
session.setValue([
"This is some placeholder text that will be folded inline.",
"This is some placeholder text that will be folded inline.",
"More text.",
"<p>The cursor in this paragraph text will be offset by 1 row.<p>",
"<p>Everything after this will be offset as well due to the folds in the row before too.</p>"
].join("\n"));
session.addFold('...', new Range(0, 8, 0, 42));
session.addFold('...', new Range(1, 8, 1, 42));
session.addFold('...', new Range(3, 7, 3, 51));
session.setOption("wrap", 40);
session.remove(new Range(0,0, 2, 5));
// needed because adjustWrapLimit is called async from renderer
session.adjustWrapLimit(80);
assert.equal(session.$wrapData + "", [[], [], [40, 76]] + "");
},
"test add fold": function() {
var session = createFoldTestSession();
var fold;

View file

@ -1364,6 +1364,7 @@ var Editor = function(renderer, session) {
var sel = this.selection;
var doc = this.session;
var range = sel.getRange();
var reverse = sel.isBackwards();
if (range.isEmpty()) {
var row = range.start.row;
doc.duplicateLines(row, row);

View file

@ -45,16 +45,10 @@ var WorkerClient = function(topLevelNamespaces, mod, classname) {
workerUrl = config.moduleUrl(mod, "worker");
} else {
var normalizePath = this.$normalizePath;
if (typeof require.supports !== "undefined" && require.supports.indexOf("ucjs2-pinf-0") >= 0) {
// We are running in the sourcemint loader.
workerUrl = require.nameToUrl("ace/worker/worker_sourcemint");
} else {
// We are running in RequireJS.
// nameToUrl is renamed to toUrl in requirejs 2
if (require.nameToUrl && !require.toUrl)
require.toUrl = require.nameToUrl;
workerUrl = normalizePath(require.toUrl("ace/worker/worker.js", null, "_"));
}
// nameToUrl is renamed to toUrl in requirejs 2
if (require.nameToUrl && !require.toUrl)
require.toUrl = require.nameToUrl;
workerUrl = normalizePath(require.toUrl("ace/worker/worker.js", null, "_"));
var tlns = {};
topLevelNamespaces.forEach(function(ns) {