diff --git a/lib/ace/commands/default_commands.js b/lib/ace/commands/default_commands.js index 9a748a39..7adae1e7 100644 --- a/lib/ace/commands/default_commands.js +++ b/lib/ace/commands/default_commands.js @@ -43,6 +43,14 @@ define(function(require, exports, module) { var lang = require("pilot/lang"); var canon = require("pilot/canon"); +function bindKey(win, mac) { + return { + win: win, + mac: mac, + sender: "editor" + } +} + canon.addCommand({ name: "null", exec: function(env, args, request) { } @@ -50,14 +58,17 @@ canon.addCommand({ canon.addCommand({ name: "selectall", + bindKey: bindKey("Ctrl-A", "Command-A"), exec: function(env, args, request) { env.editor.selectAll(); } }); canon.addCommand({ name: "removeline", + bindKey: bindKey("Ctrl-D", "Command-D"), exec: function(env, args, request) { env.editor.removeLines(); } }); canon.addCommand({ name: "gotoline", + bindKey: bindKey("Ctrl-L", "Command-L"), exec: function(env, args, request) { var line = parseInt(prompt("Enter line number:")); if (!isNaN(line)) { @@ -67,18 +78,22 @@ canon.addCommand({ }); canon.addCommand({ name: "togglecomment", + bindKey: bindKey("Ctrl-7", "Command-7"), exec: function(env, args, request) { env.editor.toggleCommentLines(); } }); canon.addCommand({ name: "findnext", + bindKey: bindKey("Ctrl-K", "Command-G"), exec: function(env, args, request) { env.editor.findNext(); } }); canon.addCommand({ name: "findprevious", + bindKey: bindKey("Ctrl-Shift-K", "Command-Shift-G"), exec: function(env, args, request) { env.editor.findPrevious(); } }); canon.addCommand({ name: "find", + bindKey: bindKey("Ctrl-F", "Command-F"), exec: function(env, args, request) { var needle = prompt("Find:"); env.editor.find(needle); @@ -86,6 +101,7 @@ canon.addCommand({ }); canon.addCommand({ name: "replace", + bindKey: bindKey("Ctrl-R", "Command-Option-F"), exec: function(env, args, request) { var needle = prompt("Find:"); if (!needle) @@ -98,6 +114,7 @@ canon.addCommand({ }); canon.addCommand({ name: "replaceall", + bindKey: bindKey("Ctrl-Shift-R", "Command-Shift-Option-F"), exec: function(env, args, request) { var needle = prompt("Find:"); if (!needle) @@ -110,166 +127,195 @@ canon.addCommand({ }); canon.addCommand({ name: "undo", + bindKey: bindKey("Ctrl-Z", "Command-Z"), exec: function(env, args, request) { env.editor.undo(); } }); canon.addCommand({ name: "redo", - exec: function(env, args, request) { env.editor.redo(); } -}); -canon.addCommand({ - name: "redo", + bindKey: bindKey("Ctrl-Shift-Z|Ctrl-Y", "Command-Shift-Z|Command-Y"), exec: function(env, args, request) { env.editor.redo(); } }); canon.addCommand({ name: "overwrite", + bindKey: bindKey("Insert", "Insert"), exec: function(env, args, request) { env.editor.toggleOverwrite(); } }); canon.addCommand({ name: "copylinesup", + bindKey: bindKey("Ctrl-Alt-Up", "Command-Option-Up"), exec: function(env, args, request) { env.editor.copyLinesUp(); } }); canon.addCommand({ name: "movelinesup", + bindKey: bindKey("Alt-Up", "Option-Up"), exec: function(env, args, request) { env.editor.moveLinesUp(); } }); canon.addCommand({ name: "selecttostart", + bindKey: bindKey("Alt-Shift-Up", "Command-Shift-Up"), exec: function(env, args, request) { env.editor.getSelection().selectFileStart(); } }); canon.addCommand({ name: "gotostart", + bindKey: bindKey("Ctrl-Home|Ctrl-Up", "Command-Home|Command-Up"), exec: function(env, args, request) { env.editor.navigateFileStart(); } }); canon.addCommand({ name: "selectup", + bindKey: bindKey("Shift-Up", "Shift-Up"), exec: function(env, args, request) { env.editor.getSelection().selectUp(); } }); canon.addCommand({ name: "golineup", + bindKey: bindKey("Up", "Up|Ctrl-P"), exec: function(env, args, request) { env.editor.navigateUp(args.times); } }); canon.addCommand({ name: "copylinesdown", + bindKey: bindKey("Ctrl-Alt-Down", "Command-Option-Down"), exec: function(env, args, request) { env.editor.copyLinesDown(); } }); canon.addCommand({ name: "movelinesdown", + bindKey: bindKey("Alt-Down", "Option-Down"), exec: function(env, args, request) { env.editor.moveLinesDown(); } }); canon.addCommand({ name: "selecttoend", + bindKey: bindKey("Alt-Shift-Down", "Command-Shift-Down"), exec: function(env, args, request) { env.editor.getSelection().selectFileEnd(); } }); canon.addCommand({ name: "gotoend", + bindKey: bindKey("Ctrl-End|Ctrl-Down", "Command-End|Command-Down"), exec: function(env, args, request) { env.editor.navigateFileEnd(); } }); canon.addCommand({ name: "selectdown", + bindKey: bindKey("Shift-Down", "Shift-Down"), exec: function(env, args, request) { env.editor.getSelection().selectDown(); } }); canon.addCommand({ name: "golinedown", + bindKey: bindKey("Down", "Down|Ctrl-N"), exec: function(env, args, request) { env.editor.navigateDown(args.times); } }); canon.addCommand({ name: "selectwordleft", + bindKey: bindKey("Ctrl-Shift-Left", "Option-Shift-Left"), exec: function(env, args, request) { env.editor.getSelection().selectWordLeft(); } }); canon.addCommand({ name: "gotowordleft", + bindKey: bindKey("Ctrl-Left", "Option-Left"), exec: function(env, args, request) { env.editor.navigateWordLeft(); } }); canon.addCommand({ name: "selecttolinestart", + bindKey: bindKey("Alt-Shift-Left", "Command-Shift-Left"), exec: function(env, args, request) { env.editor.getSelection().selectLineStart(); } }); canon.addCommand({ name: "gotolinestart", + bindKey: bindKey("Alt-Left|Home", "Command-Left|Home|Ctrl-A"), exec: function(env, args, request) { env.editor.navigateLineStart(); } }); canon.addCommand({ name: "selectleft", + bindKey: bindKey("Shift-Left", "Shift-Left"), exec: function(env, args, request) { env.editor.getSelection().selectLeft(); } }); canon.addCommand({ name: "gotoleft", + bindKey: bindKey("Left", "Left|Ctrl-B"), exec: function(env, args, request) { env.editor.navigateLeft(args.times); } }); canon.addCommand({ name: "selectwordright", + bindKey: bindKey("Ctrl-Shift-Right", "Option-Shift-Right"), exec: function(env, args, request) { env.editor.getSelection().selectWordRight(); } }); canon.addCommand({ name: "gotowordright", + bindKey: bindKey("Ctrl-Right", "Option-Right"), exec: function(env, args, request) { env.editor.navigateWordRight(); } }); canon.addCommand({ name: "selecttolineend", + bindKey: bindKey("Alt-Shift-Right", "Command-Shift-Right"), exec: function(env, args, request) { env.editor.getSelection().selectLineEnd(); } }); canon.addCommand({ name: "gotolineend", + bindKey: bindKey("Alt-Right|End", "Command-Right|End|Ctrl-E"), exec: function(env, args, request) { env.editor.navigateLineEnd(); } }); canon.addCommand({ name: "selectright", + bindKey: bindKey("Shift-Right", "Shift-Right"), exec: function(env, args, request) { env.editor.getSelection().selectRight(); } }); canon.addCommand({ name: "gotoright", + bindKey: bindKey("Right", "Right|Ctrl-Fyou "), exec: function(env, args, request) { env.editor.navigateRight(args.times); } }); canon.addCommand({ name: "selectpagedown", + bindKey: bindKey("Shift-PageDown", "Shift-PageDown"), exec: function(env, args, request) { env.editor.selectPageDown(); } }); canon.addCommand({ name: "pagedown", + bindKey: bindKey(null, "PageDown"), exec: function(env, args, request) { env.editor.scrollPageDown(); } }); canon.addCommand({ name: "gotopagedown", + bindKey: bindKey("PageDown", "Option-PageDown|Ctrl-V"), exec: function(env, args, request) { env.editor.gotoPageDown(); } }); canon.addCommand({ name: "selectpageup", + bindKey: bindKey("Shift-PageUp", "Shift-PageUp"), exec: function(env, args, request) { env.editor.selectPageUp(); } }); canon.addCommand({ name: "pageup", + bindKey: bindKey(null, "PageUp"), exec: function(env, args, request) { env.editor.scrollPageUp(); } }); canon.addCommand({ name: "gotopageup", + bindKey: bindKey("PageUp", "Option-PageUp"), exec: function(env, args, request) { env.editor.gotoPageUp(); } }); canon.addCommand({ name: "selectlinestart", + bindKey: bindKey("Shift-Home", "Shift-Home"), exec: function(env, args, request) { env.editor.getSelection().selectLineStart(); } }); -canon.addCommand({ - name: "gotolinestart", - exec: function(env, args, request) { env.editor.navigateLineStart(); } -}); canon.addCommand({ name: "selectlineend", + bindKey: bindKey("Shift-End", "Shift-End"), exec: function(env, args, request) { env.editor.getSelection().selectLineEnd(); } }); -canon.addCommand({ - name: "gotolineend", - exec: function(env, args, request) { env.editor.navigateLineEnd(); } -}); canon.addCommand({ name: "del", + bindKey: bindKey("Delete", "Delete|Ctrl-D"), exec: function(env, args, request) { env.editor.removeRight(); } }); canon.addCommand({ name: "backspace", + bindKey: bindKey( + "Ctrl-Backspace|Command-Backspace|Option-Backspace|Shift-Backspace|Backspace", + "Ctrl-Backspace|Command-Backspace|Shift-Backspace|Backspace|Ctrl-H" + ), exec: function(env, args, request) { env.editor.removeLeft(); } }); canon.addCommand({ name: "removetolinestart", + bindKey: bindKey("WIN", "MAC"), exec: function(env, args, request) { env.editor.removeToLineStart(); } }); canon.addCommand({ @@ -278,18 +324,22 @@ canon.addCommand({ }); canon.addCommand({ name: "removewordleft", + bindKey: bindKey(null, "Alt-Backspace|Ctrl-Alt-Backspace"), exec: function(env, args, request) { env.editor.removeWordLeft(); } }); canon.addCommand({ name: "removewordright", + bindKey: bindKey(null, "Alt-Delete"), exec: function(env, args, request) { env.editor.removeWordRight(); } }); canon.addCommand({ name: "outdent", + bindKey: bindKey("Shift-Tab", "Shift-Tab"), exec: function(env, args, request) { env.editor.blockOutdent(); } }); canon.addCommand({ name: "indent", + bindKey: bindKey("Tab", "Tab"), exec: function(env, args, request) { env.editor.indent(); } }); canon.addCommand({ @@ -300,14 +350,17 @@ canon.addCommand({ }); canon.addCommand({ name: "centerselection", + bindKey: bindKey(null, "Ctrl-L"), exec: function(env, args, request) { env.editor.centerSelection(); } }); canon.addCommand({ name: "splitline", + bindKey: bindKey(null, "Ctrl-O"), exec: function(env, args, request) { env.editor.splitLine(); } }); canon.addCommand({ name: "transposeletters", + bindKey: bindKey(null, "Ctrl-L"), exec: function(env, args, request) { env.editor.transposeLetters(); } }); diff --git a/lib/ace/keyboard/keybinding.js b/lib/ace/keyboard/keybinding.js index 87c93eb4..2fe89ca3 100644 --- a/lib/ace/keyboard/keybinding.js +++ b/lib/ace/keyboard/keybinding.js @@ -42,19 +42,13 @@ var useragent = require("pilot/useragent"); var keyUtil = require("pilot/keys"); var event = require("pilot/event"); var settings = require("pilot/settings").settings; -var HashHandler = require("ace/keyboard/hash_handler").HashHandler; -var default_mac = require("ace/keyboard/keybinding/default_mac").bindings; -var default_win = require("ace/keyboard/keybinding/default_win").bindings; var canon = require("pilot/canon"); require("ace/commands/default_commands"); -var KeyBinding = function(editor, config) { +var KeyBinding = function(editor) { this.$editor = editor; this.$data = { }; this.$keyboardHandler = null; - this.$defaulKeyboardHandler = new HashHandler(config || (useragent.isMac - ? default_mac - : default_win)); }; (function() { @@ -70,7 +64,9 @@ var KeyBinding = function(editor, config) { }; this.$callKeyboardHandler = function (e, hashId, keyOrText, keyCode) { - var toExecute; + var env = {editor: this.$editor}, + toExecute; + if (this.$keyboardHandler) { toExecute = this.$keyboardHandler.handleKeyboard(this.$data, hashId, keyOrText, keyCode, e); @@ -78,13 +74,23 @@ var KeyBinding = function(editor, config) { // If there is nothing to execute yet, then use the default keymapping. if (!toExecute || !toExecute.command) { - toExecute = this.$defaulKeyboardHandler. - handleKeyboard(this.$data, hashId, keyOrText, keyCode, e); + if (hashId != 0 || keyCode != 0) { + toExecute = { + command: canon.findKeyCommand(env, "editor", hashId, keyOrText) + } + } else { + toExecute = { + command: "inserttext", + args: { + text: keyOrText + } + } + } } if (toExecute) { var success = canon.exec(toExecute.command, - {editor: this.$editor}, "editor", toExecute.args); + env, "editor", toExecute.args); if (success) { return event.stopEvent(e); } diff --git a/lib/ace/keyboard/keybinding/default_mac.js b/lib/ace/keyboard/keybinding/default_mac.js deleted file mode 100644 index e0d7330b..00000000 --- a/lib/ace/keyboard/keybinding/default_mac.js +++ /dev/null @@ -1,97 +0,0 @@ -/* ***** BEGIN LICENSE BLOCK ***** - * Version: MPL 1.1/GPL 2.0/LGPL 2.1 - * - * The contents of this file are subject to the Mozilla Public License Version - * 1.1 (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.mozilla.org/MPL/ - * - * Software distributed under the License is distributed on an "AS IS" basis, - * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License - * for the specific language governing rights and limitations under the - * License. - * - * The Original Code is Ajax.org Code Editor (ACE). - * - * The Initial Developer of the Original Code is - * Ajax.org B.V. - * Portions created by the Initial Developer are Copyright (C) 2010 - * the Initial Developer. All Rights Reserved. - * - * Contributor(s): - * Fabian Jakobs - * - * Alternatively, the contents of this file may be used under the terms of - * either the GNU General Public License Version 2 or later (the "GPL"), or - * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), - * in which case the provisions of the GPL or the LGPL are applicable instead - * of those above. If you wish to allow use of your version of this file only - * under the terms of either the GPL or the LGPL, and not to allow others to - * use your version of this file under the terms of the MPL, indicate your - * decision by deleting the provisions above and replace them with the notice - * and other provisions required by the GPL or the LGPL. If you do not delete - * the provisions above, a recipient may use your version of this file under - * the terms of any one of the MPL, the GPL or the LGPL. - * - * ***** END LICENSE BLOCK ***** */ - -define(function(require, exports, module) { - -exports.bindings = { - "selectall": "Command-A", - "removeline": "Command-D", - "gotoline": "Command-L", - "togglecomment": "Command-7", - "findnext": "Command-G", - "findprevious": "Command-Shift-G", - "find": "Command-F", - "replace": "Command-R", - "undo": "Command-Z", - "redo": "Command-Shift-Z|Command-Y", - "overwrite": "Insert", - "copylinesup": "Command-Option-Up", - "movelinesup": "Option-Up", - "selecttostart": "Command-Shift-Up", - "gotostart": "Command-Home|Command-Up", - "selectup": "Shift-Up", - "golineup": "Up|Ctrl-P", - "copylinesdown": "Command-Option-Down", - "movelinesdown": "Option-Down", - "selecttoend": "Command-Shift-Down", - "gotoend": "Command-End|Command-Down", - "selectdown": "Shift-Down", - "golinedown": "Down|Ctrl-N", - "selectwordleft": "Option-Shift-Left", - "gotowordleft": "Option-Left", - "selecttolinestart": "Command-Shift-Left", - "gotolinestart": "Command-Left|Home|Ctrl-A", - "selectleft": "Shift-Left", - "gotoleft": "Left|Ctrl-B", - "selectwordright": "Option-Shift-Right", - "gotowordright": "Option-Right", - "selecttolineend": "Command-Shift-Right", - "gotolineend": "Command-Right|End|Ctrl-E", - "selectright": "Shift-Right", - "gotoright": "Right|Ctrl-F", - "selectpagedown": "Shift-PageDown", - "pagedown": "PageDown", - "gotopagedown": "Option-PageDown|Ctrl-V", - "selectpageup": "Shift-PageUp", - "pageup": "PageUp", - "gotopageup": "Option-PageUp", - "selectlinestart": "Shift-Home", - "selectlineend": "Shift-End", - "del": "Delete|Ctrl-D", - "backspace": "Ctrl-Backspace|Command-Backspace|Shift-Backspace|Backspace|Ctrl-H", - "removetolineend": "Ctrl-K", - "removetolinestart": "Option-Backspace", - "removewordleft": "Alt-Backspace|Ctrl-Alt-Backspace", - "removewordright": "Alt-Delete", - "outdent": "Shift-Tab", - "indent": "Tab", - "transposeletters": "Ctrl-T", - "splitline": "Ctrl-O", - "centerselection": "Ctrl-L" -}; - -}); \ No newline at end of file diff --git a/lib/ace/keyboard/keybinding/default_win.js b/lib/ace/keyboard/keybinding/default_win.js deleted file mode 100644 index 7f1e706e..00000000 --- a/lib/ace/keyboard/keybinding/default_win.js +++ /dev/null @@ -1,88 +0,0 @@ -/* ***** BEGIN LICENSE BLOCK ***** - * Version: MPL 1.1/GPL 2.0/LGPL 2.1 - * - * The contents of this file are subject to the Mozilla Public License Version - * 1.1 (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.mozilla.org/MPL/ - * - * Software distributed under the License is distributed on an "AS IS" basis, - * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License - * for the specific language governing rights and limitations under the - * License. - * - * The Original Code is Ajax.org Code Editor (ACE). - * - * The Initial Developer of the Original Code is - * Ajax.org B.V. - * Portions created by the Initial Developer are Copyright (C) 2010 - * the Initial Developer. All Rights Reserved. - * - * Contributor(s): - * Fabian Jakobs - * - * Alternatively, the contents of this file may be used under the terms of - * either the GNU General Public License Version 2 or later (the "GPL"), or - * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), - * in which case the provisions of the GPL or the LGPL are applicable instead - * of those above. If you wish to allow use of your version of this file only - * under the terms of either the GPL or the LGPL, and not to allow others to - * use your version of this file under the terms of the MPL, indicate your - * decision by deleting the provisions above and replace them with the notice - * and other provisions required by the GPL or the LGPL. If you do not delete - * the provisions above, a recipient may use your version of this file under - * the terms of any one of the MPL, the GPL or the LGPL. - * - * ***** END LICENSE BLOCK ***** */ - -define(function(require, exports, module) { - -exports.bindings = { - "selectall": "Ctrl-A", - "removeline": "Ctrl-D", - "gotoline": "Ctrl-L", - "togglecomment": "Ctrl-7", - "findnext": "Ctrl-K", - "findprevious": "Ctrl-Shift-K", - "find": "Ctrl-F", - "replace": "Ctrl-R", - "undo": "Ctrl-Z", - "redo": "Ctrl-Shift-Z|Ctrl-Y", - "overwrite": "Insert", - "copylinesup": "Ctrl-Alt-Up", - "movelinesup": "Alt-Up", - "selecttostart": "Alt-Shift-Up", - "gotostart": "Ctrl-Home|Ctrl-Up", - "selectup": "Shift-Up", - "golineup": "Up", - "copylinesdown": "Ctrl-Alt-Down", - "movelinesdown": "Alt-Down", - "selecttoend": "Alt-Shift-Down", - "gotoend": "Ctrl-End|Ctrl-Down", - "selectdown": "Shift-Down", - "golinedown": "Down", - "selectwordleft": "Ctrl-Shift-Left", - "gotowordleft": "Ctrl-Left", - "selecttolinestart": "Alt-Shift-Left", - "gotolinestart": "Alt-Left|Home", - "selectleft": "Shift-Left", - "gotoleft": "Left", - "selectwordright": "Ctrl-Shift-Right", - "gotowordright": "Ctrl-Right", - "selecttolineend": "Alt-Shift-Right", - "gotolineend": "Alt-Right|End", - "selectright": "Shift-Right", - "gotoright": "Right", - "selectpagedown": "Shift-PageDown", - "gotopagedown": "PageDown", - "selectpageup": "Shift-PageUp", - "gotopageup": "PageUp", - "selectlinestart": "Shift-Home", - "selectlineend": "Shift-End", - "del": "Delete", - "backspace": "Ctrl-Backspace|Command-Backspace|Option-Backspace|Shift-Backspace|Backspace", - "outdent": "Shift-Tab", - "indent": "Tab" -}; - -}); diff --git a/support/pilot b/support/pilot index f23c4f45..5d07cccd 160000 --- a/support/pilot +++ b/support/pilot @@ -1 +1 @@ -Subproject commit f23c4f455198652db0fd46b9107da2fea8fd79ab +Subproject commit 5d07cccd2e8d0ca22b170693afda5199a69de062