зеркало из https://github.com/mozilla/pjs.git
Backed out changeset 8114f8011a9e (bug 712982)
This commit is contained in:
Родитель
c9740e8367
Коммит
a374fd9f1a
|
@ -307,8 +307,6 @@ SourceEditor.prototype = {
|
|||
{styleClass: rulerClass}, {styleClass: "rulerLines odd"},
|
||||
{styleClass: "rulerLines even"});
|
||||
|
||||
this._linesRuler.onClick = this._linesRulerClick.bind(this);
|
||||
this._linesRuler.onDblClick = this._linesRulerDblClick.bind(this);
|
||||
this._view.addRuler(this._linesRuler);
|
||||
}
|
||||
|
||||
|
@ -621,59 +619,6 @@ SourceEditor.prototype = {
|
|||
[this._currentLineAnnotation]);
|
||||
},
|
||||
|
||||
/**
|
||||
* The click event handler for the lines gutter. This function allows the user
|
||||
* to jump to a line or to perform line selection while holding the Shift key
|
||||
* down.
|
||||
*
|
||||
* @private
|
||||
* @param number aLineIndex
|
||||
* The line index where the click event occurred.
|
||||
* @param object aEvent
|
||||
* The DOM click event object.
|
||||
*/
|
||||
_linesRulerClick: function SE__linesRulerClick(aLineIndex, aEvent)
|
||||
{
|
||||
if (aLineIndex === undefined) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (aEvent.shiftKey) {
|
||||
let model = this._model;
|
||||
let selection = this.getSelection();
|
||||
let selectionLineStart = model.getLineAtOffset(selection.start);
|
||||
let selectionLineEnd = model.getLineAtOffset(selection.end);
|
||||
let newStart = aLineIndex <= selectionLineStart ?
|
||||
model.getLineStart(aLineIndex) : selection.start;
|
||||
let newEnd = aLineIndex <= selectionLineStart ?
|
||||
selection.end : model.getLineEnd(aLineIndex);
|
||||
this.setSelection(newStart, newEnd);
|
||||
} else {
|
||||
this.setCaretPosition(aLineIndex);
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* The dblclick event handler for the lines gutter. This function selects the
|
||||
* whole line where the event occurred.
|
||||
*
|
||||
* @private
|
||||
* @param number aLineIndex
|
||||
* The line index where the double click event occurred.
|
||||
* @param object aEvent
|
||||
* The DOM dblclick event object.
|
||||
*/
|
||||
_linesRulerDblClick: function SE__linesRulerDblClick(aLineIndex)
|
||||
{
|
||||
if (aLineIndex === undefined) {
|
||||
return;
|
||||
}
|
||||
|
||||
let newStart = this._model.getLineStart(aLineIndex);
|
||||
let newEnd = this._model.getLineEnd(aLineIndex);
|
||||
this.setSelection(newStart, newEnd);
|
||||
},
|
||||
|
||||
/**
|
||||
* Highlight the Orion annotations. This updates the annotation styler as
|
||||
* needed.
|
||||
|
|
|
@ -57,7 +57,6 @@ _BROWSER_TEST_FILES = \
|
|||
browser_bug703692_focus_blur.js \
|
||||
browser_bug725388_mouse_events.js \
|
||||
browser_bug707987_debugger_breakpoints.js \
|
||||
browser_bug712982_line_ruler_click.js \
|
||||
head.js \
|
||||
|
||||
libs:: $(_BROWSER_TEST_FILES)
|
||||
|
|
|
@ -1,74 +0,0 @@
|
|||
/* vim: set ts=2 et sw=2 tw=80: */
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
"use strict";
|
||||
|
||||
function test() {
|
||||
|
||||
let temp = {};
|
||||
Cu.import("resource:///modules/source-editor.jsm", temp);
|
||||
let SourceEditor = temp.SourceEditor;
|
||||
|
||||
let component = Services.prefs.getCharPref(SourceEditor.PREFS.COMPONENT);
|
||||
if (component == "textarea") {
|
||||
ok(true, "skip test for bug 712982: only applicable for non-textarea components");
|
||||
return;
|
||||
}
|
||||
|
||||
waitForExplicitFinish();
|
||||
|
||||
let editor;
|
||||
|
||||
const windowUrl = "data:text/xml,<?xml version='1.0'?>" +
|
||||
"<window xmlns='http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul'" +
|
||||
" title='test for bug 712982' width='600' height='500'><hbox flex='1'/></window>";
|
||||
const windowFeatures = "chrome,titlebar,toolbar,centerscreen,resizable,dialog=no";
|
||||
|
||||
let testWin = Services.ww.openWindow(null, windowUrl, "_blank", windowFeatures, null);
|
||||
testWin.addEventListener("load", function onWindowLoad() {
|
||||
testWin.removeEventListener("load", onWindowLoad, false);
|
||||
waitForFocus(initEditor, testWin);
|
||||
}, false);
|
||||
|
||||
function initEditor()
|
||||
{
|
||||
let hbox = testWin.document.querySelector("hbox");
|
||||
editor = new SourceEditor();
|
||||
editor.init(hbox, {showLineNumbers: true}, editorLoaded);
|
||||
}
|
||||
|
||||
function editorLoaded()
|
||||
{
|
||||
editor.focus();
|
||||
|
||||
editor.setText("line1\nline2\nline3\nline4");
|
||||
|
||||
editor.setCaretPosition(3);
|
||||
let pos = editor.getCaretPosition();
|
||||
ok(pos.line == 3 && pos.col == 0, "initial caret location is correct");
|
||||
|
||||
EventUtils.synthesizeMouse(editor.editorElement, 10, 10, {}, testWin);
|
||||
|
||||
is(editor.getCaretOffset(), 0, "click on line 0 worked");
|
||||
|
||||
editor.setCaretPosition(2);
|
||||
EventUtils.synthesizeMouse(editor.editorElement, 11, 11,
|
||||
{shiftKey: true}, testWin);
|
||||
is(editor.getSelectedText().trim(), "line1\nline2", "shift+click works");
|
||||
|
||||
editor.setCaretOffset(0);
|
||||
|
||||
EventUtils.synthesizeMouse(editor.editorElement, 10, 10,
|
||||
{clickCount: 2}, testWin);
|
||||
|
||||
is(editor.getSelectedText().trim(), "line1", "double click works");
|
||||
|
||||
editor.destroy();
|
||||
|
||||
testWin.close();
|
||||
testWin = editor = null;
|
||||
|
||||
waitForFocus(finish, window);
|
||||
}
|
||||
}
|
Загрузка…
Ссылка в новой задаче