emacs: fix exchangePointAndMark in normal select mode

This commit is contained in:
Robert Krahn 2014-03-24 16:16:54 -07:00
commit ea67201540

View file

@ -481,24 +481,25 @@ exports.handler.addCommands({
exchangePointAndMark: {
exec: function (editor, args) {
var restoreMarks = [];
editor.forEachSelection({
exec: function() {
var sel = editor.selection;
if (args.count) { // replace mark and point
var pos = {row: sel.lead.row, column: sel.lead.column};
restoreMarks.push(pos);
sel.clearSelection();
sel.moveCursorToPosition(editor.popEmacsMark());
} else if (sel.isEmpty()) { // move to mark, forget point
var lastMark = editor.popEmacsMark();
restoreMarks.push(lastMark);
sel.selectToPosition(lastMark);
} else { // just invert selection
sel.setSelectionRange(sel.getRange(), !sel.isBackwards());
}
}
});
if (editor.inMultiSelectMode) editor.forEachSelection({exec: doExchange});
else doExchange();
restoreMarks.reverse().forEach(function(p) { editor.pushEmacsMark(p); });
// -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
function doExchange() {
var sel = editor.selection;
if (args.count) { // replace mark and point
var pos = {row: sel.lead.row, column: sel.lead.column};
restoreMarks.push(pos);
sel.clearSelection();
sel.moveCursorToPosition(editor.popEmacsMark());
} else if (sel.isEmpty()) { // move to mark, forget point
var lastMark = editor.popEmacsMark();
restoreMarks.push(lastMark);
sel.selectToPosition(lastMark);
} else { // just invert selection
sel.setSelectionRange(sel.getRange(), !sel.isBackwards());
}
}
},
readOnly: true,
handlesCount: true,