Index: Source/devtools/front_end/cm/closebrackets.js |
diff --git a/Source/devtools/front_end/cm/closebrackets.js b/Source/devtools/front_end/cm/closebrackets.js |
index 88718b77292edda0deea2d8d17674ef5963dbc5f..6cabed6ecad4807989c7e3826076995bb82dad73 100644 |
--- a/Source/devtools/front_end/cm/closebrackets.js |
+++ b/Source/devtools/front_end/cm/closebrackets.js |
@@ -1,8 +1,17 @@ |
-(function() { |
+(function(mod) { |
+ if (typeof exports == "object" && typeof module == "object") // CommonJS |
+ mod(require("../../lib/codemirror")); |
+ else if (typeof define == "function" && define.amd) // AMD |
+ define(["../../lib/codemirror"], mod); |
+ else // Plain browser env |
+ mod(CodeMirror); |
+})(function(CodeMirror) { |
var DEFAULT_BRACKETS = "()[]{}''\"\""; |
var DEFAULT_EXPLODE_ON_ENTER = "[]{}"; |
var SPACE_CHAR_REGEX = /\s/; |
+ var Pos = CodeMirror.Pos; |
+ |
CodeMirror.defineOption("autoCloseBrackets", false, function(cm, val, old) { |
if (old != CodeMirror.Init && old) |
cm.removeKeyMap("autoCloseBrackets"); |
@@ -19,8 +28,8 @@ |
}); |
function charsAround(cm, pos) { |
- var str = cm.getRange(CodeMirror.Pos(pos.line, pos.ch - 1), |
- CodeMirror.Pos(pos.line, pos.ch + 1)); |
+ var str = cm.getRange(Pos(pos.line, pos.ch - 1), |
+ Pos(pos.line, pos.ch + 1)); |
return str.length == 2 ? str : null; |
} |
@@ -28,55 +37,103 @@ |
var map = { |
name : "autoCloseBrackets", |
Backspace: function(cm) { |
- if (cm.somethingSelected()) return CodeMirror.Pass; |
- var cur = cm.getCursor(), around = charsAround(cm, cur); |
- if (around && pairs.indexOf(around) % 2 == 0) |
- cm.replaceRange("", CodeMirror.Pos(cur.line, cur.ch - 1), CodeMirror.Pos(cur.line, cur.ch + 1)); |
- else |
- return CodeMirror.Pass; |
+ if (cm.getOption("disableInput")) return CodeMirror.Pass; |
+ var ranges = cm.listSelections(); |
+ for (var i = 0; i < ranges.length; i++) { |
+ if (!ranges[i].empty()) return CodeMirror.Pass; |
+ var around = charsAround(cm, ranges[i].head); |
+ if (!around || pairs.indexOf(around) % 2 != 0) return CodeMirror.Pass; |
+ } |
+ for (var i = ranges.length - 1; i >= 0; i--) { |
+ var cur = ranges[i].head; |
+ cm.replaceRange("", Pos(cur.line, cur.ch - 1), Pos(cur.line, cur.ch + 1)); |
+ } |
} |
}; |
var closingBrackets = ""; |
for (var i = 0; i < pairs.length; i += 2) (function(left, right) { |
if (left != right) closingBrackets += right; |
- function surround(cm) { |
- var selection = cm.getSelection(); |
- cm.replaceSelection(left + selection + right); |
- } |
- function maybeOverwrite(cm) { |
- var cur = cm.getCursor(), ahead = cm.getRange(cur, CodeMirror.Pos(cur.line, cur.ch + 1)); |
- if (ahead != right || cm.somethingSelected()) return CodeMirror.Pass; |
- else cm.execCommand("goCharRight"); |
- } |
map["'" + left + "'"] = function(cm) { |
- if (left == "'" && cm.getTokenAt(cm.getCursor()).type == "comment") |
- return CodeMirror.Pass; |
- if (cm.somethingSelected()) return surround(cm); |
- if (left == right && maybeOverwrite(cm) != CodeMirror.Pass) return; |
- var cur = cm.getCursor(), ahead = CodeMirror.Pos(cur.line, cur.ch + 1); |
- var line = cm.getLine(cur.line), nextChar = line.charAt(cur.ch), curChar = cur.ch > 0 ? line.charAt(cur.ch - 1) : ""; |
- if (left == right && CodeMirror.isWordChar(curChar)) |
- return CodeMirror.Pass; |
- if (line.length == cur.ch || closingBrackets.indexOf(nextChar) >= 0 || SPACE_CHAR_REGEX.test(nextChar)) |
- cm.replaceSelection(left + right, {head: ahead, anchor: ahead}); |
- else |
- return CodeMirror.Pass; |
+ if (cm.getOption("disableInput")) return CodeMirror.Pass; |
+ var ranges = cm.listSelections(), type, next; |
+ for (var i = 0; i < ranges.length; i++) { |
+ var range = ranges[i], cur = range.head, curType; |
+ if (left == "'" && cm.getTokenTypeAt(cur) == "comment") |
+ return CodeMirror.Pass; |
+ var next = cm.getRange(cur, Pos(cur.line, cur.ch + 1)); |
+ if (!range.empty()) |
+ curType = "surround"; |
+ else if (left == right && next == right) { |
+ if (cm.getRange(cur, Pos(cur.line, cur.ch + 3)) == left + left + left) |
+ curType = "skipThree"; |
+ else |
+ curType = "skip"; |
+ } else if (left == right && cur.ch > 1 && |
+ cm.getRange(Pos(cur.line, cur.ch - 2), cur) == left + left) |
+ curType = "addFour"; |
+ else if (left == right && CodeMirror.isWordChar(next)) |
+ return CodeMirror.Pass; |
+ else if (cm.getLine(cur.line).length == cur.ch || closingBrackets.indexOf(next) >= 0 || SPACE_CHAR_REGEX.test(next)) |
+ curType = "both"; |
+ else |
+ return CodeMirror.Pass; |
+ if (!type) type = curType; |
+ else if (type != curType) return CodeMirror.Pass; |
+ } |
+ |
+ cm.operation(function() { |
+ if (type == "skip") { |
+ cm.execCommand("goCharRight"); |
+ } else if (type == "skipThree") { |
+ for (var i = 0; i < 3; i++) |
+ cm.execCommand("goCharRight"); |
+ } else if (type == "surround") { |
+ var sels = cm.getSelections(); |
+ for (var i = 0; i < sels.length; i++) |
+ sels[i] = left + sels[i] + right; |
+ cm.replaceSelections(sels, "around"); |
+ } else if (type == "both") { |
+ cm.replaceSelection(left + right, null); |
+ cm.execCommand("goCharLeft"); |
+ } else if (type == "addFour") { |
+ cm.replaceSelection(left + left + left + left, "before"); |
+ cm.execCommand("goCharRight"); |
+ } |
+ }); |
+ }; |
+ if (left != right) map["'" + right + "'"] = function(cm) { |
+ var ranges = cm.listSelections(); |
+ for (var i = 0; i < ranges.length; i++) { |
+ var range = ranges[i]; |
+ if (!range.empty() || |
+ cm.getRange(range.head, Pos(range.head.line, range.head.ch + 1)) != right) |
+ return CodeMirror.Pass; |
+ } |
+ cm.execCommand("goCharRight"); |
}; |
- if (left != right) map["'" + right + "'"] = maybeOverwrite; |
})(pairs.charAt(i), pairs.charAt(i + 1)); |
return map; |
} |
function buildExplodeHandler(pairs) { |
return function(cm) { |
- var cur = cm.getCursor(), around = charsAround(cm, cur); |
- if (!around || pairs.indexOf(around) % 2 != 0) return CodeMirror.Pass; |
+ if (cm.getOption("disableInput")) return CodeMirror.Pass; |
+ var ranges = cm.listSelections(); |
+ for (var i = 0; i < ranges.length; i++) { |
+ if (!ranges[i].empty()) return CodeMirror.Pass; |
+ var around = charsAround(cm, ranges[i].head); |
+ if (!around || pairs.indexOf(around) % 2 != 0) return CodeMirror.Pass; |
+ } |
cm.operation(function() { |
- var newPos = CodeMirror.Pos(cur.line + 1, 0); |
- cm.replaceSelection("\n\n", {anchor: newPos, head: newPos}, "+input"); |
- cm.indentLine(cur.line + 1, null, true); |
- cm.indentLine(cur.line + 2, null, true); |
+ cm.replaceSelection("\n\n", null); |
+ cm.execCommand("goCharLeft"); |
+ ranges = cm.listSelections(); |
+ for (var i = 0; i < ranges.length; i++) { |
+ var line = ranges[i].head.line; |
+ cm.indentLine(line, null, true); |
+ cm.indentLine(line + 1, null, true); |
+ } |
}); |
}; |
} |
-})(); |
+}); |