ace-rails-ap 3.0.2 → 3.0.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (127) hide show
  1. checksums.yaml +4 -4
  2. data/lib/ace/rails/version.rb +1 -1
  3. data/vendor/assets/javascripts/ace/ace.js +403 -326
  4. data/vendor/assets/javascripts/ace/ext-language_tools.js +56 -40
  5. data/vendor/assets/javascripts/ace/ext-modelist.js +7 -3
  6. data/vendor/assets/javascripts/ace/ext-settings_menu.js +8 -4
  7. data/vendor/assets/javascripts/ace/ext-static_highlight.js +12 -5
  8. data/vendor/assets/javascripts/ace/keybinding-vim.js +5234 -1558
  9. data/vendor/assets/javascripts/ace/mode-abap.js +1 -1
  10. data/vendor/assets/javascripts/ace/mode-abc.js +261 -0
  11. data/vendor/assets/javascripts/ace/mode-actionscript.js +47 -1
  12. data/vendor/assets/javascripts/ace/mode-apache_conf.js +47 -1
  13. data/vendor/assets/javascripts/ace/mode-applescript.js +47 -1
  14. data/vendor/assets/javascripts/ace/mode-autohotkey.js +47 -1
  15. data/vendor/assets/javascripts/ace/mode-batchfile.js +47 -1
  16. data/vendor/assets/javascripts/ace/mode-c_cpp.js +101 -56
  17. data/vendor/assets/javascripts/ace/mode-coffee.js +3 -3
  18. data/vendor/assets/javascripts/ace/mode-coldfusion.js +114 -63
  19. data/vendor/assets/javascripts/ace/mode-csharp.js +99 -55
  20. data/vendor/assets/javascripts/ace/mode-css.js +98 -53
  21. data/vendor/assets/javascripts/ace/mode-curly.js +114 -63
  22. data/vendor/assets/javascripts/ace/mode-d.js +47 -1
  23. data/vendor/assets/javascripts/ace/mode-dart.js +103 -58
  24. data/vendor/assets/javascripts/ace/mode-diff.js +85 -85
  25. data/vendor/assets/javascripts/ace/mode-django.js +114 -63
  26. data/vendor/assets/javascripts/ace/mode-dockerfile.js +97 -52
  27. data/vendor/assets/javascripts/ace/mode-dot.js +47 -1
  28. data/vendor/assets/javascripts/ace/mode-eiffel.js +30 -37
  29. data/vendor/assets/javascripts/ace/mode-ejs.js +117 -63
  30. data/vendor/assets/javascripts/ace/mode-elm.js +47 -1
  31. data/vendor/assets/javascripts/ace/mode-erlang.js +47 -1
  32. data/vendor/assets/javascripts/ace/mode-forth.js +47 -1
  33. data/vendor/assets/javascripts/ace/mode-ftl.js +10 -7
  34. data/vendor/assets/javascripts/ace/mode-glsl.js +101 -56
  35. data/vendor/assets/javascripts/ace/mode-golang.js +96 -51
  36. data/vendor/assets/javascripts/ace/mode-groovy.js +98 -53
  37. data/vendor/assets/javascripts/ace/mode-haml.js +3 -0
  38. data/vendor/assets/javascripts/ace/mode-handlebars.js +114 -63
  39. data/vendor/assets/javascripts/ace/mode-haskell.js +49 -3
  40. data/vendor/assets/javascripts/ace/mode-haxe.js +96 -51
  41. data/vendor/assets/javascripts/ace/mode-html.js +114 -63
  42. data/vendor/assets/javascripts/ace/mode-html_ruby.js +117 -63
  43. data/vendor/assets/javascripts/ace/mode-io.js +47 -1
  44. data/vendor/assets/javascripts/ace/mode-jack.js +96 -51
  45. data/vendor/assets/javascripts/ace/mode-jade.js +10 -7
  46. data/vendor/assets/javascripts/ace/mode-java.js +98 -53
  47. data/vendor/assets/javascripts/ace/mode-javascript.js +98 -53
  48. data/vendor/assets/javascripts/ace/mode-json.js +99 -54
  49. data/vendor/assets/javascripts/ace/mode-jsoniq.js +98 -51
  50. data/vendor/assets/javascripts/ace/mode-jsp.js +106 -58
  51. data/vendor/assets/javascripts/ace/mode-jsx.js +96 -51
  52. data/vendor/assets/javascripts/ace/mode-julia.js +47 -1
  53. data/vendor/assets/javascripts/ace/mode-latex.js +1 -1
  54. data/vendor/assets/javascripts/ace/mode-lean.js +281 -0
  55. data/vendor/assets/javascripts/ace/mode-less.js +96 -51
  56. data/vendor/assets/javascripts/ace/mode-liquid.js +10 -7
  57. data/vendor/assets/javascripts/ace/mode-live_script.js +481 -0
  58. data/vendor/assets/javascripts/ace/mode-livescript.js +5 -8
  59. data/vendor/assets/javascripts/ace/mode-logiql.js +49 -50
  60. data/vendor/assets/javascripts/ace/mode-lsl.js +96 -51
  61. data/vendor/assets/javascripts/ace/mode-lua.js +3 -3
  62. data/vendor/assets/javascripts/ace/mode-luapage.js +117 -66
  63. data/vendor/assets/javascripts/ace/mode-makefile.js +1 -1
  64. data/vendor/assets/javascripts/ace/mode-markdown.js +134 -67
  65. data/vendor/assets/javascripts/ace/mode-mask.js +1985 -0
  66. data/vendor/assets/javascripts/ace/mode-mel.js +96 -51
  67. data/vendor/assets/javascripts/ace/mode-mips_assembler.js +235 -0
  68. data/vendor/assets/javascripts/ace/mode-mipsassembler.js +196 -0
  69. data/vendor/assets/javascripts/ace/mode-nix.js +101 -56
  70. data/vendor/assets/javascripts/ace/mode-objectivec.js +52 -6
  71. data/vendor/assets/javascripts/ace/mode-perl.js +47 -1
  72. data/vendor/assets/javascripts/ace/mode-pgsql.js +1 -1
  73. data/vendor/assets/javascripts/ace/mode-php.js +139 -85
  74. data/vendor/assets/javascripts/ace/mode-powershell.js +96 -51
  75. data/vendor/assets/javascripts/ace/mode-praat.js +47 -1
  76. data/vendor/assets/javascripts/ace/mode-prolog.js +47 -1
  77. data/vendor/assets/javascripts/ace/mode-protobuf.js +101 -56
  78. data/vendor/assets/javascripts/ace/mode-rdoc.js +1 -1
  79. data/vendor/assets/javascripts/ace/mode-rhtml.js +114 -63
  80. data/vendor/assets/javascripts/ace/mode-ruby.js +52 -50
  81. data/vendor/assets/javascripts/ace/mode-rust.js +57 -18
  82. data/vendor/assets/javascripts/ace/mode-scad.js +96 -51
  83. data/vendor/assets/javascripts/ace/mode-scala.js +98 -53
  84. data/vendor/assets/javascripts/ace/mode-scss.js +96 -51
  85. data/vendor/assets/javascripts/ace/mode-sh.js +97 -52
  86. data/vendor/assets/javascripts/ace/mode-sjs.js +98 -53
  87. data/vendor/assets/javascripts/ace/mode-smarty.js +114 -63
  88. data/vendor/assets/javascripts/ace/mode-soy_template.js +114 -63
  89. data/vendor/assets/javascripts/ace/mode-stylus.js +1 -1
  90. data/vendor/assets/javascripts/ace/mode-svg.js +132 -65
  91. data/vendor/assets/javascripts/ace/mode-tcl.js +47 -1
  92. data/vendor/assets/javascripts/ace/mode-twig.js +114 -63
  93. data/vendor/assets/javascripts/ace/mode-typescript.js +98 -53
  94. data/vendor/assets/javascripts/ace/mode-vala.js +96 -51
  95. data/vendor/assets/javascripts/ace/mode-velocity.js +114 -63
  96. data/vendor/assets/javascripts/ace/mode-vhdl.js +21 -21
  97. data/vendor/assets/javascripts/ace/mode-xml.js +34 -12
  98. data/vendor/assets/javascripts/ace/mode-xquery.js +98 -51
  99. data/vendor/assets/javascripts/ace/snippets/abc.js +38 -0
  100. data/vendor/assets/javascripts/ace/snippets/elixir.js +7 -0
  101. data/vendor/assets/javascripts/ace/snippets/elm.js +7 -0
  102. data/vendor/assets/javascripts/ace/snippets/lean.js +7 -0
  103. data/vendor/assets/javascripts/ace/snippets/live_script.js +7 -0
  104. data/vendor/assets/javascripts/ace/snippets/mask.js +7 -0
  105. data/vendor/assets/javascripts/ace/snippets/mips_assembler.js +7 -0
  106. data/vendor/assets/javascripts/ace/snippets/mipsassembler.js +7 -0
  107. data/vendor/assets/javascripts/ace/snippets/r.js +1 -1
  108. data/vendor/assets/javascripts/ace/theme-clouds_midnight.js +1 -1
  109. data/vendor/assets/javascripts/ace/theme-github.js +7 -1
  110. data/vendor/assets/javascripts/ace/theme-katzenmilch.js +3 -0
  111. data/vendor/assets/javascripts/ace/theme-kuroir.js +3 -0
  112. data/vendor/assets/javascripts/ace/worker-coffee.js +6 -7
  113. data/vendor/assets/javascripts/ace/worker-css.js +5 -5
  114. data/vendor/assets/javascripts/ace/worker-html.js +4354 -4354
  115. data/vendor/assets/javascripts/ace/worker-javascript.js +2435 -1397
  116. data/vendor/assets/javascripts/ace/worker-json.js +6 -7
  117. data/vendor/assets/javascripts/ace/worker-lua.js +11 -11
  118. data/vendor/assets/javascripts/ace/worker-php.js +4 -8
  119. data/vendor/assets/javascripts/ace/worker-xml.js +3809 -0
  120. data/vendor/assets/javascripts/ace/worker-xquery.js +38 -47
  121. metadata +18 -9
  122. data/vendor/assets/javascripts/ace/ext-options.js +0 -252
  123. data/vendor/assets/javascripts/ace/mode-html_completions.js +0 -309
  124. data/vendor/assets/javascripts/ace/mode-luahtml.js +0 -2415
  125. data/vendor/assets/javascripts/ace/mode-mushcode_high_rules.js +0 -569
  126. data/vendor/assets/javascripts/ace/mode-tmsnippet.js +0 -200
  127. data/vendor/assets/javascripts/ace/theme-kr.js +0 -105
@@ -92,8 +92,7 @@ define("ace/mode/livescript",["require","exports","module","ace/tokenizer","ace/
92
92
  }(require('../mode/text').Mode));
93
93
  keywordend = '(?![$\\w]|-[A-Za-z]|\\s*:(?![:=]))';
94
94
  stringfill = {
95
- token: 'string',
96
- regex: '.+'
95
+ defaultToken: 'string'
97
96
  };
98
97
  LiveScriptMode.Rules = {
99
98
  start: [
@@ -186,7 +185,7 @@ define("ace/mode/livescript",["require","exports","module","ace/tokenizer","ace/
186
185
  next: 'key'
187
186
  }, {
188
187
  token: 'keyword.operator',
189
- regex: '\\S+'
188
+ regex: '[\\^!|&%+\\-]+'
190
189
  }, {
191
190
  token: 'text',
192
191
  regex: '\\s+'
@@ -204,8 +203,7 @@ define("ace/mode/livescript",["require","exports","module","ace/tokenizer","ace/
204
203
  token: 'comment.regex',
205
204
  regex: '\\s+(?:#.*)?'
206
205
  }, {
207
- token: 'string.regex',
208
- regex: '\\S+'
206
+ defaultToken: 'string.regex'
209
207
  }
210
208
  ],
211
209
  key: [
@@ -218,7 +216,7 @@ define("ace/mode/livescript",["require","exports","module","ace/tokenizer","ace/
218
216
  next: 'start'
219
217
  }, {
220
218
  token: 'text',
221
- regex: '.',
219
+ regex: '',
222
220
  next: 'start'
223
221
  }
224
222
  ],
@@ -228,8 +226,7 @@ define("ace/mode/livescript",["require","exports","module","ace/tokenizer","ace/
228
226
  regex: '.*?\\*/',
229
227
  next: 'start'
230
228
  }, {
231
- token: 'comment.doc',
232
- regex: '.+'
229
+ defaultToken: 'comment.doc'
233
230
  }
234
231
  ],
235
232
  qdoc: [
@@ -194,6 +194,19 @@ var initContext = function(editor) {
194
194
  };
195
195
  };
196
196
 
197
+ var getWrapped = function(selection, selected, opening, closing) {
198
+ var rowDiff = selection.end.row - selection.start.row;
199
+ return {
200
+ text: opening + selected + closing,
201
+ selection: [
202
+ 0,
203
+ selection.start.column + 1,
204
+ rowDiff,
205
+ selection.end.column + (rowDiff ? 0 : 1)
206
+ ]
207
+ };
208
+ };
209
+
197
210
  var CstyleBehaviour = function() {
198
211
  this.add("braces", "insertion", function(state, action, editor, session, text) {
199
212
  var cursor = editor.getCursorPosition();
@@ -203,10 +216,7 @@ var CstyleBehaviour = function() {
203
216
  var selection = editor.getSelectionRange();
204
217
  var selected = session.doc.getTextRange(selection);
205
218
  if (selected !== "" && selected !== "{" && editor.getWrapBehavioursEnabled()) {
206
- return {
207
- text: '{' + selected + '}',
208
- selection: false
209
- };
219
+ return getWrapped(selection, selected, '{', '}');
210
220
  } else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
211
221
  if (/[\]\}\)]/.test(line[cursor.column]) || editor.inMultiSelectMode) {
212
222
  CstyleBehaviour.recordAutoInsert(editor, session, "}");
@@ -286,10 +296,7 @@ var CstyleBehaviour = function() {
286
296
  var selection = editor.getSelectionRange();
287
297
  var selected = session.doc.getTextRange(selection);
288
298
  if (selected !== "" && editor.getWrapBehavioursEnabled()) {
289
- return {
290
- text: '(' + selected + ')',
291
- selection: false
292
- };
299
+ return getWrapped(selection, selected, '(', ')');
293
300
  } else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
294
301
  CstyleBehaviour.recordAutoInsert(editor, session, ")");
295
302
  return {
@@ -334,10 +341,7 @@ var CstyleBehaviour = function() {
334
341
  var selection = editor.getSelectionRange();
335
342
  var selected = session.doc.getTextRange(selection);
336
343
  if (selected !== "" && editor.getWrapBehavioursEnabled()) {
337
- return {
338
- text: '[' + selected + ']',
339
- selection: false
340
- };
344
+ return getWrapped(selection, selected, '[', ']');
341
345
  } else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
342
346
  CstyleBehaviour.recordAutoInsert(editor, session, "]");
343
347
  return {
@@ -383,49 +387,44 @@ var CstyleBehaviour = function() {
383
387
  var selection = editor.getSelectionRange();
384
388
  var selected = session.doc.getTextRange(selection);
385
389
  if (selected !== "" && selected !== "'" && selected != '"' && editor.getWrapBehavioursEnabled()) {
386
- return {
387
- text: quote + selected + quote,
388
- selection: false
389
- };
390
- } else {
390
+ return getWrapped(selection, selected, quote, quote);
391
+ } else if (!selected) {
391
392
  var cursor = editor.getCursorPosition();
392
393
  var line = session.doc.getLine(cursor.row);
393
394
  var leftChar = line.substring(cursor.column-1, cursor.column);
394
- if (leftChar == '\\') {
395
+ var rightChar = line.substring(cursor.column, cursor.column + 1);
396
+
397
+ var token = session.getTokenAt(cursor.row, cursor.column);
398
+ var rightToken = session.getTokenAt(cursor.row, cursor.column + 1);
399
+ if (leftChar == "\\" && token && /escape/.test(token.type))
395
400
  return null;
401
+
402
+ var stringBefore = token && /string/.test(token.type);
403
+ var stringAfter = !rightToken || /string/.test(rightToken.type);
404
+
405
+ var pair;
406
+ if (rightChar == quote) {
407
+ pair = stringBefore !== stringAfter;
408
+ } else {
409
+ if (stringBefore && !stringAfter)
410
+ return null; // wrap string with different quote
411
+ if (stringBefore && stringAfter)
412
+ return null; // do not pair quotes inside strings
413
+ var wordRe = session.$mode.tokenRe;
414
+ wordRe.lastIndex = 0;
415
+ var isWordBefore = wordRe.test(leftChar);
416
+ wordRe.lastIndex = 0;
417
+ var isWordAfter = wordRe.test(leftChar);
418
+ if (isWordBefore || isWordAfter)
419
+ return null; // before or after alphanumeric
420
+ if (rightChar && !/[\s;,.})\]\\]/.test(rightChar))
421
+ return null; // there is rightChar and it isn't closing
422
+ pair = true;
396
423
  }
397
- var tokens = session.getTokens(selection.start.row);
398
- var col = 0, token;
399
- var quotepos = -1; // Track whether we're inside an open quote.
400
-
401
- for (var x = 0; x < tokens.length; x++) {
402
- token = tokens[x];
403
- if (token.type == "string") {
404
- quotepos = -1;
405
- } else if (quotepos < 0) {
406
- quotepos = token.value.indexOf(quote);
407
- }
408
- if ((token.value.length + col) > selection.start.column) {
409
- break;
410
- }
411
- col += tokens[x].value.length;
412
- }
413
- if (!token || (quotepos < 0 && token.type !== "comment" && (token.type !== "string" || ((selection.start.column !== token.value.length+col-1) && token.value.lastIndexOf(quote) === token.value.length-1)))) {
414
- if (!CstyleBehaviour.isSaneInsertion(editor, session))
415
- return;
416
- return {
417
- text: quote + quote,
418
- selection: [1,1]
419
- };
420
- } else if (token && token.type === "string") {
421
- var rightChar = line.substring(cursor.column, cursor.column + 1);
422
- if (rightChar == quote) {
423
- return {
424
- text: '',
425
- selection: [1, 1]
426
- };
427
- }
428
- }
424
+ return {
425
+ text: pair ? quote + quote : "",
426
+ selection: [1,1]
427
+ };
429
428
  }
430
429
  }
431
430
  });
@@ -167,6 +167,19 @@ var initContext = function(editor) {
167
167
  };
168
168
  };
169
169
 
170
+ var getWrapped = function(selection, selected, opening, closing) {
171
+ var rowDiff = selection.end.row - selection.start.row;
172
+ return {
173
+ text: opening + selected + closing,
174
+ selection: [
175
+ 0,
176
+ selection.start.column + 1,
177
+ rowDiff,
178
+ selection.end.column + (rowDiff ? 0 : 1)
179
+ ]
180
+ };
181
+ };
182
+
170
183
  var CstyleBehaviour = function() {
171
184
  this.add("braces", "insertion", function(state, action, editor, session, text) {
172
185
  var cursor = editor.getCursorPosition();
@@ -176,10 +189,7 @@ var CstyleBehaviour = function() {
176
189
  var selection = editor.getSelectionRange();
177
190
  var selected = session.doc.getTextRange(selection);
178
191
  if (selected !== "" && selected !== "{" && editor.getWrapBehavioursEnabled()) {
179
- return {
180
- text: '{' + selected + '}',
181
- selection: false
182
- };
192
+ return getWrapped(selection, selected, '{', '}');
183
193
  } else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
184
194
  if (/[\]\}\)]/.test(line[cursor.column]) || editor.inMultiSelectMode) {
185
195
  CstyleBehaviour.recordAutoInsert(editor, session, "}");
@@ -259,10 +269,7 @@ var CstyleBehaviour = function() {
259
269
  var selection = editor.getSelectionRange();
260
270
  var selected = session.doc.getTextRange(selection);
261
271
  if (selected !== "" && editor.getWrapBehavioursEnabled()) {
262
- return {
263
- text: '(' + selected + ')',
264
- selection: false
265
- };
272
+ return getWrapped(selection, selected, '(', ')');
266
273
  } else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
267
274
  CstyleBehaviour.recordAutoInsert(editor, session, ")");
268
275
  return {
@@ -307,10 +314,7 @@ var CstyleBehaviour = function() {
307
314
  var selection = editor.getSelectionRange();
308
315
  var selected = session.doc.getTextRange(selection);
309
316
  if (selected !== "" && editor.getWrapBehavioursEnabled()) {
310
- return {
311
- text: '[' + selected + ']',
312
- selection: false
313
- };
317
+ return getWrapped(selection, selected, '[', ']');
314
318
  } else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
315
319
  CstyleBehaviour.recordAutoInsert(editor, session, "]");
316
320
  return {
@@ -356,49 +360,44 @@ var CstyleBehaviour = function() {
356
360
  var selection = editor.getSelectionRange();
357
361
  var selected = session.doc.getTextRange(selection);
358
362
  if (selected !== "" && selected !== "'" && selected != '"' && editor.getWrapBehavioursEnabled()) {
359
- return {
360
- text: quote + selected + quote,
361
- selection: false
362
- };
363
- } else {
363
+ return getWrapped(selection, selected, quote, quote);
364
+ } else if (!selected) {
364
365
  var cursor = editor.getCursorPosition();
365
366
  var line = session.doc.getLine(cursor.row);
366
367
  var leftChar = line.substring(cursor.column-1, cursor.column);
367
- if (leftChar == '\\') {
368
+ var rightChar = line.substring(cursor.column, cursor.column + 1);
369
+
370
+ var token = session.getTokenAt(cursor.row, cursor.column);
371
+ var rightToken = session.getTokenAt(cursor.row, cursor.column + 1);
372
+ if (leftChar == "\\" && token && /escape/.test(token.type))
368
373
  return null;
374
+
375
+ var stringBefore = token && /string/.test(token.type);
376
+ var stringAfter = !rightToken || /string/.test(rightToken.type);
377
+
378
+ var pair;
379
+ if (rightChar == quote) {
380
+ pair = stringBefore !== stringAfter;
381
+ } else {
382
+ if (stringBefore && !stringAfter)
383
+ return null; // wrap string with different quote
384
+ if (stringBefore && stringAfter)
385
+ return null; // do not pair quotes inside strings
386
+ var wordRe = session.$mode.tokenRe;
387
+ wordRe.lastIndex = 0;
388
+ var isWordBefore = wordRe.test(leftChar);
389
+ wordRe.lastIndex = 0;
390
+ var isWordAfter = wordRe.test(leftChar);
391
+ if (isWordBefore || isWordAfter)
392
+ return null; // before or after alphanumeric
393
+ if (rightChar && !/[\s;,.})\]\\]/.test(rightChar))
394
+ return null; // there is rightChar and it isn't closing
395
+ pair = true;
369
396
  }
370
- var tokens = session.getTokens(selection.start.row);
371
- var col = 0, token;
372
- var quotepos = -1; // Track whether we're inside an open quote.
373
-
374
- for (var x = 0; x < tokens.length; x++) {
375
- token = tokens[x];
376
- if (token.type == "string") {
377
- quotepos = -1;
378
- } else if (quotepos < 0) {
379
- quotepos = token.value.indexOf(quote);
380
- }
381
- if ((token.value.length + col) > selection.start.column) {
382
- break;
383
- }
384
- col += tokens[x].value.length;
385
- }
386
- if (!token || (quotepos < 0 && token.type !== "comment" && (token.type !== "string" || ((selection.start.column !== token.value.length+col-1) && token.value.lastIndexOf(quote) === token.value.length-1)))) {
387
- if (!CstyleBehaviour.isSaneInsertion(editor, session))
388
- return;
389
- return {
390
- text: quote + quote,
391
- selection: [1,1]
392
- };
393
- } else if (token && token.type === "string") {
394
- var rightChar = line.substring(cursor.column, cursor.column + 1);
395
- if (rightChar == quote) {
396
- return {
397
- text: '',
398
- selection: [1, 1]
399
- };
400
- }
401
- }
397
+ return {
398
+ text: pair ? quote + quote : "",
399
+ selection: [1,1]
400
+ };
402
401
  }
403
402
  }
404
403
  });
@@ -510,12 +509,35 @@ var FoldMode = exports.FoldMode = function(commentRegex) {
510
509
  oop.inherits(FoldMode, BaseFoldMode);
511
510
 
512
511
  (function() {
513
-
512
+
514
513
  this.foldingStartMarker = /(\{|\[)[^\}\]]*$|^\s*(\/\*)/;
515
514
  this.foldingStopMarker = /^[^\[\{]*(\}|\])|^[\s\*]*(\*\/)/;
515
+ this.singleLineBlockCommentRe= /^\s*(\/\*).*\*\/\s*$/;
516
+ this.tripleStarBlockCommentRe = /^\s*(\/\*\*\*).*\*\/\s*$/;
517
+ this.startRegionRe = /^\s*(\/\*|\/\/)#region\b/;
518
+ this._getFoldWidgetBase = this.getFoldWidget;
519
+ this.getFoldWidget = function(session, foldStyle, row) {
520
+ var line = session.getLine(row);
521
+
522
+ if (this.singleLineBlockCommentRe.test(line)) {
523
+ if (!this.startRegionRe.test(line) && !this.tripleStarBlockCommentRe.test(line))
524
+ return "";
525
+ }
526
+
527
+ var fw = this._getFoldWidgetBase(session, foldStyle, row);
528
+
529
+ if (!fw && this.startRegionRe.test(line))
530
+ return "start"; // lineCommentRegionStart
531
+
532
+ return fw;
533
+ };
516
534
 
517
535
  this.getFoldWidgetRange = function(session, foldStyle, row, forceMultiline) {
518
536
  var line = session.getLine(row);
537
+
538
+ if (this.startRegionRe.test(line))
539
+ return this.getCommentRegionBlock(session, line, row);
540
+
519
541
  var match = line.match(this.foldingStartMarker);
520
542
  if (match) {
521
543
  var i = match.index;
@@ -580,6 +602,29 @@ oop.inherits(FoldMode, BaseFoldMode);
580
602
 
581
603
  return new Range(startRow, startColumn, endRow, session.getLine(endRow).length);
582
604
  };
605
+
606
+ this.getCommentRegionBlock = function(session, line, row) {
607
+ var startColumn = line.search(/\s*$/);
608
+ var maxRow = session.getLength();
609
+ var startRow = row;
610
+
611
+ var re = /^\s*(?:\/\*|\/\/)#(end)?region\b/;
612
+ var depth = 1;
613
+ while (++row < maxRow) {
614
+ line = session.getLine(row);
615
+ var m = re.exec(line);
616
+ if (!m) continue;
617
+ if (m[1]) depth--;
618
+ else depth++;
619
+
620
+ if (!depth) break;
621
+ }
622
+
623
+ var endRow = row;
624
+ if (endRow > startRow) {
625
+ return new Range(startRow, startColumn, endRow, line.length);
626
+ }
627
+ };
583
628
 
584
629
  }).call(FoldMode.prototype);
585
630
 
@@ -408,11 +408,11 @@ oop.inherits(Mode, TextMode);
408
408
  var worker = new WorkerClient(["ace"], "ace/mode/lua_worker", "Worker");
409
409
  worker.attachToDocument(session.getDocument());
410
410
 
411
- worker.on("error", function(e) {
412
- session.setAnnotations([e.data]);
411
+ worker.on("annotate", function(e) {
412
+ session.setAnnotations(e.data);
413
413
  });
414
414
 
415
- worker.on("ok", function(e) {
415
+ worker.on("terminate", function() {
416
416
  session.clearAnnotations();
417
417
  });
418
418
 
@@ -176,7 +176,7 @@ var JavaScriptHighlightRules = function(options) {
176
176
  regex : /(\.)(s(?:h(?:ift|ow(?:Mod(?:elessDialog|alDialog)|Help))|croll(?:X|By(?:Pages|Lines)?|Y|To)?|t(?:op|rike)|i(?:n|zeToContent|debar|gnText)|ort|u(?:p|b(?:str(?:ing)?)?)|pli(?:ce|t)|e(?:nd|t(?:Re(?:sizable|questHeader)|M(?:i(?:nutes|lliseconds)|onth)|Seconds|Ho(?:tKeys|urs)|Year|Cursor|Time(?:out)?|Interval|ZOptions|Date|UTC(?:M(?:i(?:nutes|lliseconds)|onth)|Seconds|Hours|Date|FullYear)|FullYear|Active)|arch)|qrt|lice|avePreferences|mall)|h(?:ome|andleEvent)|navigate|c(?:har(?:CodeAt|At)|o(?:s|n(?:cat|textual|firm)|mpile)|eil|lear(?:Timeout|Interval)?|a(?:ptureEvents|ll)|reate(?:StyleSheet|Popup|EventObject))|t(?:o(?:GMTString|S(?:tring|ource)|U(?:TCString|pperCase)|Lo(?:caleString|werCase))|est|a(?:n|int(?:Enabled)?))|i(?:s(?:NaN|Finite)|ndexOf|talics)|d(?:isableExternalCapture|ump|etachEvent)|u(?:n(?:shift|taint|escape|watch)|pdateCommands)|j(?:oin|avaEnabled)|p(?:o(?:p|w)|ush|lugins.refresh|a(?:ddings|rse(?:Int|Float)?)|r(?:int|ompt|eference))|e(?:scape|nableExternalCapture|val|lementFromPoint|x(?:p|ec(?:Script|Command)?))|valueOf|UTC|queryCommand(?:State|Indeterm|Enabled|Value)|f(?:i(?:nd|le(?:ModifiedDate|Size|CreatedDate|UpdatedDate)|xed)|o(?:nt(?:size|color)|rward)|loor|romCharCode)|watch|l(?:ink|o(?:ad|g)|astIndexOf)|a(?:sin|nchor|cos|t(?:tachEvent|ob|an(?:2)?)|pply|lert|b(?:s|ort))|r(?:ou(?:nd|teEvents)|e(?:size(?:By|To)|calc|turnValue|place|verse|l(?:oad|ease(?:Capture|Events)))|andom)|g(?:o|et(?:ResponseHeader|M(?:i(?:nutes|lliseconds)|onth)|Se(?:conds|lection)|Hours|Year|Time(?:zoneOffset)?|Da(?:y|te)|UTC(?:M(?:i(?:nutes|lliseconds)|onth)|Seconds|Hours|Da(?:y|te)|FullYear)|FullYear|A(?:ttention|llResponseHeaders)))|m(?:in|ove(?:B(?:y|elow)|To(?:Absolute)?|Above)|ergeAttributes|a(?:tch|rgins|x))|b(?:toa|ig|o(?:ld|rderWidths)|link|ack))\b(?=\()/
177
177
  }, {
178
178
  token : ["punctuation.operator", "support.function.dom"],
179
- regex : /(\.)(s(?:ub(?:stringData|mit)|plitText|e(?:t(?:NamedItem|Attribute(?:Node)?)|lect))|has(?:ChildNodes|Feature)|namedItem|c(?:l(?:ick|o(?:se|neNode))|reate(?:C(?:omment|DATASection|aption)|T(?:Head|extNode|Foot)|DocumentFragment|ProcessingInstruction|E(?:ntityReference|lement)|Attribute))|tabIndex|i(?:nsert(?:Row|Before|Cell|Data)|tem)|open|delete(?:Row|C(?:ell|aption)|T(?:Head|Foot)|Data)|focus|write(?:ln)?|a(?:dd|ppend(?:Child|Data))|re(?:set|place(?:Child|Data)|move(?:NamedItem|Child|Attribute(?:Node)?)?)|get(?:NamedItem|Element(?:sBy(?:Name|TagName)|ById)|Attribute(?:Node)?)|blur)\b(?=\()/
179
+ regex : /(\.)(s(?:ub(?:stringData|mit)|plitText|e(?:t(?:NamedItem|Attribute(?:Node)?)|lect))|has(?:ChildNodes|Feature)|namedItem|c(?:l(?:ick|o(?:se|neNode))|reate(?:C(?:omment|DATASection|aption)|T(?:Head|extNode|Foot)|DocumentFragment|ProcessingInstruction|E(?:ntityReference|lement)|Attribute))|tabIndex|i(?:nsert(?:Row|Before|Cell|Data)|tem)|open|delete(?:Row|C(?:ell|aption)|T(?:Head|Foot)|Data)|focus|write(?:ln)?|a(?:dd|ppend(?:Child|Data))|re(?:set|place(?:Child|Data)|move(?:NamedItem|Child|Attribute(?:Node)?)?)|get(?:NamedItem|Element(?:sBy(?:Name|TagName|ClassName)|ById)|Attribute(?:Node)?)|blur)\b(?=\()/
180
180
  }, {
181
181
  token : ["punctuation.operator", "support.constant"],
182
182
  regex : /(\.)(s(?:ystemLanguage|cr(?:ipts|ollbars|een(?:X|Y|Top|Left))|t(?:yle(?:Sheets)?|atus(?:Text|bar)?)|ibling(?:Below|Above)|ource|uffixes|e(?:curity(?:Policy)?|l(?:ection|f)))|h(?:istory|ost(?:name)?|as(?:h|Focus))|y|X(?:MLDocument|SLDocument)|n(?:ext|ame(?:space(?:s|URI)|Prop))|M(?:IN_VALUE|AX_VALUE)|c(?:haracterSet|o(?:n(?:structor|trollers)|okieEnabled|lorDepth|mp(?:onents|lete))|urrent|puClass|l(?:i(?:p(?:boardData)?|entInformation)|osed|asses)|alle(?:e|r)|rypto)|t(?:o(?:olbar|p)|ext(?:Transform|Indent|Decoration|Align)|ags)|SQRT(?:1_2|2)|i(?:n(?:ner(?:Height|Width)|put)|ds|gnoreCase)|zIndex|o(?:scpu|n(?:readystatechange|Line)|uter(?:Height|Width)|p(?:sProfile|ener)|ffscreenBuffering)|NEGATIVE_INFINITY|d(?:i(?:splay|alog(?:Height|Top|Width|Left|Arguments)|rectories)|e(?:scription|fault(?:Status|Ch(?:ecked|arset)|View)))|u(?:ser(?:Profile|Language|Agent)|n(?:iqueID|defined)|pdateInterval)|_content|p(?:ixelDepth|ort|ersonalbar|kcs11|l(?:ugins|atform)|a(?:thname|dding(?:Right|Bottom|Top|Left)|rent(?:Window|Layer)?|ge(?:X(?:Offset)?|Y(?:Offset)?))|r(?:o(?:to(?:col|type)|duct(?:Sub)?|mpter)|e(?:vious|fix)))|e(?:n(?:coding|abledPlugin)|x(?:ternal|pando)|mbeds)|v(?:isibility|endor(?:Sub)?|Linkcolor)|URLUnencoded|P(?:I|OSITIVE_INFINITY)|f(?:ilename|o(?:nt(?:Size|Family|Weight)|rmName)|rame(?:s|Element)|gColor)|E|whiteSpace|l(?:i(?:stStyleType|n(?:eHeight|kColor))|o(?:ca(?:tion(?:bar)?|lName)|wsrc)|e(?:ngth|ft(?:Context)?)|a(?:st(?:M(?:odified|atch)|Index|Paren)|yer(?:s|X)|nguage))|a(?:pp(?:MinorVersion|Name|Co(?:deName|re)|Version)|vail(?:Height|Top|Width|Left)|ll|r(?:ity|guments)|Linkcolor|bove)|r(?:ight(?:Context)?|e(?:sponse(?:XML|Text)|adyState))|global|x|m(?:imeTypes|ultiline|enubar|argin(?:Right|Bottom|Top|Left))|L(?:N(?:10|2)|OG(?:10E|2E))|b(?:o(?:ttom|rder(?:Width|RightWidth|BottomWidth|Style|Color|TopWidth|LeftWidth))|ufferDepth|elow|ackground(?:Color|Image)))\b/
@@ -475,6 +475,19 @@ var initContext = function(editor) {
475
475
  };
476
476
  };
477
477
 
478
+ var getWrapped = function(selection, selected, opening, closing) {
479
+ var rowDiff = selection.end.row - selection.start.row;
480
+ return {
481
+ text: opening + selected + closing,
482
+ selection: [
483
+ 0,
484
+ selection.start.column + 1,
485
+ rowDiff,
486
+ selection.end.column + (rowDiff ? 0 : 1)
487
+ ]
488
+ };
489
+ };
490
+
478
491
  var CstyleBehaviour = function() {
479
492
  this.add("braces", "insertion", function(state, action, editor, session, text) {
480
493
  var cursor = editor.getCursorPosition();
@@ -484,10 +497,7 @@ var CstyleBehaviour = function() {
484
497
  var selection = editor.getSelectionRange();
485
498
  var selected = session.doc.getTextRange(selection);
486
499
  if (selected !== "" && selected !== "{" && editor.getWrapBehavioursEnabled()) {
487
- return {
488
- text: '{' + selected + '}',
489
- selection: false
490
- };
500
+ return getWrapped(selection, selected, '{', '}');
491
501
  } else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
492
502
  if (/[\]\}\)]/.test(line[cursor.column]) || editor.inMultiSelectMode) {
493
503
  CstyleBehaviour.recordAutoInsert(editor, session, "}");
@@ -567,10 +577,7 @@ var CstyleBehaviour = function() {
567
577
  var selection = editor.getSelectionRange();
568
578
  var selected = session.doc.getTextRange(selection);
569
579
  if (selected !== "" && editor.getWrapBehavioursEnabled()) {
570
- return {
571
- text: '(' + selected + ')',
572
- selection: false
573
- };
580
+ return getWrapped(selection, selected, '(', ')');
574
581
  } else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
575
582
  CstyleBehaviour.recordAutoInsert(editor, session, ")");
576
583
  return {
@@ -615,10 +622,7 @@ var CstyleBehaviour = function() {
615
622
  var selection = editor.getSelectionRange();
616
623
  var selected = session.doc.getTextRange(selection);
617
624
  if (selected !== "" && editor.getWrapBehavioursEnabled()) {
618
- return {
619
- text: '[' + selected + ']',
620
- selection: false
621
- };
625
+ return getWrapped(selection, selected, '[', ']');
622
626
  } else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
623
627
  CstyleBehaviour.recordAutoInsert(editor, session, "]");
624
628
  return {
@@ -664,49 +668,44 @@ var CstyleBehaviour = function() {
664
668
  var selection = editor.getSelectionRange();
665
669
  var selected = session.doc.getTextRange(selection);
666
670
  if (selected !== "" && selected !== "'" && selected != '"' && editor.getWrapBehavioursEnabled()) {
667
- return {
668
- text: quote + selected + quote,
669
- selection: false
670
- };
671
- } else {
671
+ return getWrapped(selection, selected, quote, quote);
672
+ } else if (!selected) {
672
673
  var cursor = editor.getCursorPosition();
673
674
  var line = session.doc.getLine(cursor.row);
674
675
  var leftChar = line.substring(cursor.column-1, cursor.column);
675
- if (leftChar == '\\') {
676
+ var rightChar = line.substring(cursor.column, cursor.column + 1);
677
+
678
+ var token = session.getTokenAt(cursor.row, cursor.column);
679
+ var rightToken = session.getTokenAt(cursor.row, cursor.column + 1);
680
+ if (leftChar == "\\" && token && /escape/.test(token.type))
676
681
  return null;
682
+
683
+ var stringBefore = token && /string/.test(token.type);
684
+ var stringAfter = !rightToken || /string/.test(rightToken.type);
685
+
686
+ var pair;
687
+ if (rightChar == quote) {
688
+ pair = stringBefore !== stringAfter;
689
+ } else {
690
+ if (stringBefore && !stringAfter)
691
+ return null; // wrap string with different quote
692
+ if (stringBefore && stringAfter)
693
+ return null; // do not pair quotes inside strings
694
+ var wordRe = session.$mode.tokenRe;
695
+ wordRe.lastIndex = 0;
696
+ var isWordBefore = wordRe.test(leftChar);
697
+ wordRe.lastIndex = 0;
698
+ var isWordAfter = wordRe.test(leftChar);
699
+ if (isWordBefore || isWordAfter)
700
+ return null; // before or after alphanumeric
701
+ if (rightChar && !/[\s;,.})\]\\]/.test(rightChar))
702
+ return null; // there is rightChar and it isn't closing
703
+ pair = true;
677
704
  }
678
- var tokens = session.getTokens(selection.start.row);
679
- var col = 0, token;
680
- var quotepos = -1; // Track whether we're inside an open quote.
681
-
682
- for (var x = 0; x < tokens.length; x++) {
683
- token = tokens[x];
684
- if (token.type == "string") {
685
- quotepos = -1;
686
- } else if (quotepos < 0) {
687
- quotepos = token.value.indexOf(quote);
688
- }
689
- if ((token.value.length + col) > selection.start.column) {
690
- break;
691
- }
692
- col += tokens[x].value.length;
693
- }
694
- if (!token || (quotepos < 0 && token.type !== "comment" && (token.type !== "string" || ((selection.start.column !== token.value.length+col-1) && token.value.lastIndexOf(quote) === token.value.length-1)))) {
695
- if (!CstyleBehaviour.isSaneInsertion(editor, session))
696
- return;
697
- return {
698
- text: quote + quote,
699
- selection: [1,1]
700
- };
701
- } else if (token && token.type === "string") {
702
- var rightChar = line.substring(cursor.column, cursor.column + 1);
703
- if (rightChar == quote) {
704
- return {
705
- text: '',
706
- selection: [1, 1]
707
- };
708
- }
709
- }
705
+ return {
706
+ text: pair ? quote + quote : "",
707
+ selection: [1,1]
708
+ };
710
709
  }
711
710
  }
712
711
  });
@@ -818,12 +817,35 @@ var FoldMode = exports.FoldMode = function(commentRegex) {
818
817
  oop.inherits(FoldMode, BaseFoldMode);
819
818
 
820
819
  (function() {
821
-
820
+
822
821
  this.foldingStartMarker = /(\{|\[)[^\}\]]*$|^\s*(\/\*)/;
823
822
  this.foldingStopMarker = /^[^\[\{]*(\}|\])|^[\s\*]*(\*\/)/;
823
+ this.singleLineBlockCommentRe= /^\s*(\/\*).*\*\/\s*$/;
824
+ this.tripleStarBlockCommentRe = /^\s*(\/\*\*\*).*\*\/\s*$/;
825
+ this.startRegionRe = /^\s*(\/\*|\/\/)#region\b/;
826
+ this._getFoldWidgetBase = this.getFoldWidget;
827
+ this.getFoldWidget = function(session, foldStyle, row) {
828
+ var line = session.getLine(row);
829
+
830
+ if (this.singleLineBlockCommentRe.test(line)) {
831
+ if (!this.startRegionRe.test(line) && !this.tripleStarBlockCommentRe.test(line))
832
+ return "";
833
+ }
834
+
835
+ var fw = this._getFoldWidgetBase(session, foldStyle, row);
836
+
837
+ if (!fw && this.startRegionRe.test(line))
838
+ return "start"; // lineCommentRegionStart
839
+
840
+ return fw;
841
+ };
824
842
 
825
843
  this.getFoldWidgetRange = function(session, foldStyle, row, forceMultiline) {
826
844
  var line = session.getLine(row);
845
+
846
+ if (this.startRegionRe.test(line))
847
+ return this.getCommentRegionBlock(session, line, row);
848
+
827
849
  var match = line.match(this.foldingStartMarker);
828
850
  if (match) {
829
851
  var i = match.index;
@@ -888,6 +910,29 @@ oop.inherits(FoldMode, BaseFoldMode);
888
910
 
889
911
  return new Range(startRow, startColumn, endRow, session.getLine(endRow).length);
890
912
  };
913
+
914
+ this.getCommentRegionBlock = function(session, line, row) {
915
+ var startColumn = line.search(/\s*$/);
916
+ var maxRow = session.getLength();
917
+ var startRow = row;
918
+
919
+ var re = /^\s*(?:\/\*|\/\/)#(end)?region\b/;
920
+ var depth = 1;
921
+ while (++row < maxRow) {
922
+ line = session.getLine(row);
923
+ var m = re.exec(line);
924
+ if (!m) continue;
925
+ if (m[1]) depth--;
926
+ else depth++;
927
+
928
+ if (!depth) break;
929
+ }
930
+
931
+ var endRow = row;
932
+ if (endRow > startRow) {
933
+ return new Range(startRow, startColumn, endRow, line.length);
934
+ }
935
+ };
891
936
 
892
937
  }).call(FoldMode.prototype);
893
938
 
@@ -963,7 +1008,7 @@ oop.inherits(Mode, TextMode);
963
1008
  var worker = new WorkerClient(["ace"], "ace/mode/javascript_worker", "JavaScriptWorker");
964
1009
  worker.attachToDocument(session.getDocument());
965
1010
 
966
- worker.on("jslint", function(results) {
1011
+ worker.on("annotate", function(results) {
967
1012
  session.setAnnotations(results.data);
968
1013
  });
969
1014
 
@@ -990,7 +1035,7 @@ var supportType = exports.supportType = "animation-fill-mode|alignment-adjust|al
990
1035
  var supportFunction = exports.supportFunction = "rgb|rgba|url|attr|counter|counters";
991
1036
  var supportConstant = exports.supportConstant = "absolute|after-edge|after|all-scroll|all|alphabetic|always|antialiased|armenian|auto|avoid-column|avoid-page|avoid|balance|baseline|before-edge|before|below|bidi-override|block-line-height|block|bold|bolder|border-box|both|bottom|box|break-all|break-word|capitalize|caps-height|caption|center|central|char|circle|cjk-ideographic|clone|close-quote|col-resize|collapse|column|consider-shifts|contain|content-box|cover|crosshair|cubic-bezier|dashed|decimal-leading-zero|decimal|default|disabled|disc|disregard-shifts|distribute-all-lines|distribute-letter|distribute-space|distribute|dotted|double|e-resize|ease-in|ease-in-out|ease-out|ease|ellipsis|end|exclude-ruby|fill|fixed|georgian|glyphs|grid-height|groove|hand|hanging|hebrew|help|hidden|hiragana-iroha|hiragana|horizontal|icon|ideograph-alpha|ideograph-numeric|ideograph-parenthesis|ideograph-space|ideographic|inactive|include-ruby|inherit|initial|inline-block|inline-box|inline-line-height|inline-table|inline|inset|inside|inter-ideograph|inter-word|invert|italic|justify|katakana-iroha|katakana|keep-all|last|left|lighter|line-edge|line-through|line|linear|list-item|local|loose|lower-alpha|lower-greek|lower-latin|lower-roman|lowercase|lr-tb|ltr|mathematical|max-height|max-size|medium|menu|message-box|middle|move|n-resize|ne-resize|newspaper|no-change|no-close-quote|no-drop|no-open-quote|no-repeat|none|normal|not-allowed|nowrap|nw-resize|oblique|open-quote|outset|outside|overline|padding-box|page|pointer|pre-line|pre-wrap|pre|preserve-3d|progress|relative|repeat-x|repeat-y|repeat|replaced|reset-size|ridge|right|round|row-resize|rtl|s-resize|scroll|se-resize|separate|slice|small-caps|small-caption|solid|space|square|start|static|status-bar|step-end|step-start|steps|stretch|strict|sub|super|sw-resize|table-caption|table-cell|table-column-group|table-column|table-footer-group|table-header-group|table-row-group|table-row|table|tb-rl|text-after-edge|text-before-edge|text-bottom|text-size|text-top|text|thick|thin|transparent|underline|upper-alpha|upper-latin|upper-roman|uppercase|use-script|vertical-ideographic|vertical-text|visible|w-resize|wait|whitespace|z-index|zero";
992
1037
  var supportConstantColor = exports.supportConstantColor = "aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|orange|purple|red|silver|teal|white|yellow";
993
- var supportConstantFonts = exports.supportConstantFonts = "arial|century|comic|courier|garamond|georgia|helvetica|impact|lucida|symbol|system|tahoma|times|trebuchet|utopia|verdana|webdings|sans-serif|serif|monospace";
1038
+ var supportConstantFonts = exports.supportConstantFonts = "arial|century|comic|courier|cursive|fantasy|garamond|georgia|helvetica|impact|lucida|symbol|system|tahoma|times|trebuchet|utopia|verdana|webdings|sans-serif|serif|monospace";
994
1039
 
995
1040
  var numRe = exports.numRe = "\\-?(?:(?:[0-9]+)|(?:[0-9]*\\.[0-9]+))";
996
1041
  var pseudoElements = exports.pseudoElements = "(\\:+)\\b(after|before|first-letter|first-line|moz-selection|selection)\\b";
@@ -1254,7 +1299,7 @@ oop.inherits(Mode, TextMode);
1254
1299
  var worker = new WorkerClient(["ace"], "ace/mode/css_worker", "Worker");
1255
1300
  worker.attachToDocument(session.getDocument());
1256
1301
 
1257
- worker.on("csslint", function(e) {
1302
+ worker.on("annotate", function(e) {
1258
1303
  session.setAnnotations(e.data);
1259
1304
  });
1260
1305
 
@@ -1279,6 +1324,9 @@ var oop = require("../lib/oop");
1279
1324
  var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
1280
1325
 
1281
1326
  var XmlHighlightRules = function(normalize) {
1327
+
1328
+ var tagRegex = "[a-zA-Z][-_a-zA-Z0-9]*";
1329
+
1282
1330
  this.$rules = {
1283
1331
  start : [
1284
1332
  {token : "string.cdata.xml", regex : "<\\!\\[CDATA\\[", next : "cdata"},
@@ -1288,7 +1336,7 @@ var XmlHighlightRules = function(normalize) {
1288
1336
  },
1289
1337
  {
1290
1338
  token : ["punctuation.instruction.xml", "keyword.instruction.xml"],
1291
- regex : "(<\\?)([-_a-zA-Z0-9]+)", next : "processing_instruction",
1339
+ regex : "(<\\?)(" + tagRegex + ")", next : "processing_instruction",
1292
1340
  },
1293
1341
  {token : "comment.xml", regex : "<\\!--", next : "comment"},
1294
1342
  {
@@ -1304,7 +1352,7 @@ var XmlHighlightRules = function(normalize) {
1304
1352
 
1305
1353
  xml_decl : [{
1306
1354
  token : "entity.other.attribute-name.decl-attribute-name.xml",
1307
- regex : "(?:[-_a-zA-Z0-9]+:)?[-_a-zA-Z0-9]+"
1355
+ regex : "(?:" + tagRegex + ":)?" + tagRegex + ""
1308
1356
  }, {
1309
1357
  token : "keyword.operator.decl-attribute-equals.xml",
1310
1358
  regex : "="
@@ -1340,7 +1388,7 @@ var XmlHighlightRules = function(normalize) {
1340
1388
  next: "pop"
1341
1389
  }, {
1342
1390
  token : ["punctuation.markup-decl.xml", "keyword.markup-decl.xml"],
1343
- regex : "(<\\!)([-_a-zA-Z0-9]+)",
1391
+ regex : "(<\\!)(" + tagRegex + ")",
1344
1392
  push : [{
1345
1393
  token : "text",
1346
1394
  regex : "\\s+"
@@ -1376,7 +1424,7 @@ var XmlHighlightRules = function(normalize) {
1376
1424
 
1377
1425
  tag : [{
1378
1426
  token : ["meta.tag.punctuation.tag-open.xml", "meta.tag.punctuation.end-tag-open.xml", "meta.tag.tag-name.xml"],
1379
- regex : "(?:(<)|(</))((?:[-_a-zA-Z0-9]+:)?[-_a-zA-Z0-9]+)",
1427
+ regex : "(?:(<)|(</))((?:" + tagRegex + ":)?" + tagRegex + ")",
1380
1428
  next: [
1381
1429
  {include : "attributes"},
1382
1430
  {token : "meta.tag.punctuation.tag-close.xml", regex : "/?>", next : "start"}
@@ -1407,7 +1455,7 @@ var XmlHighlightRules = function(normalize) {
1407
1455
 
1408
1456
  attributes: [{
1409
1457
  token : "entity.other.attribute-name.xml",
1410
- regex : "(?:[-_a-zA-Z0-9]+:)?[-_a-zA-Z0-9]+"
1458
+ regex : "(?:" + tagRegex + ":)?" + tagRegex + ""
1411
1459
  }, {
1412
1460
  token : "keyword.operator.attribute-equals.xml",
1413
1461
  regex : "="
@@ -1682,6 +1730,8 @@ var XmlBehaviour = function () {
1682
1730
  var token = iterator.getCurrentToken();
1683
1731
 
1684
1732
  if (token && token.type.indexOf("tag-close") !== -1) {
1733
+ if (token.value == "/>")
1734
+ return;
1685
1735
  while (token && token.type.indexOf("tag-name") === -1) {
1686
1736
  token = iterator.stepBackward();
1687
1737
  }
@@ -1935,9 +1985,6 @@ function is(token, type) {
1935
1985
  if (!tag || top.tagName == tag.tagName) {
1936
1986
  return stack.pop();
1937
1987
  }
1938
- else if (this.optionalEndTags.hasOwnProperty(tag.tagName)) {
1939
- return;
1940
- }
1941
1988
  else if (this.optionalEndTags.hasOwnProperty(top.tagName)) {
1942
1989
  stack.pop();
1943
1990
  continue;
@@ -1963,6 +2010,8 @@ function is(token, type) {
1963
2010
  row: row,
1964
2011
  column: firstTag.start.column + firstTag.tagName.length + 2
1965
2012
  };
2013
+ if (firstTag.start.row == firstTag.end.row)
2014
+ start.column = firstTag.end.column;
1966
2015
  while (tag = this._readTagForward(iterator)) {
1967
2016
  if (tag.selfClosing) {
1968
2017
  if (!stack.length) {
@@ -2004,6 +2053,8 @@ function is(token, type) {
2004
2053
  this._pop(stack, tag);
2005
2054
  if (stack.length == 0) {
2006
2055
  tag.start.column += tag.tagName.length + 2;
2056
+ if (tag.start.row == tag.end.row && tag.start.column < tag.end.column)
2057
+ tag.start.column = tag.end.column;
2007
2058
  return Range.fromPoints(tag.start, end);
2008
2059
  }
2009
2060
  }
@@ -2795,11 +2846,11 @@ oop.inherits(Mode, TextMode);
2795
2846
  var worker = new WorkerClient(["ace"], "ace/mode/lua_worker", "Worker");
2796
2847
  worker.attachToDocument(session.getDocument());
2797
2848
 
2798
- worker.on("error", function(e) {
2799
- session.setAnnotations([e.data]);
2849
+ worker.on("annotate", function(e) {
2850
+ session.setAnnotations(e.data);
2800
2851
  });
2801
2852
 
2802
- worker.on("ok", function(e) {
2853
+ worker.on("terminate", function() {
2803
2854
  session.clearAnnotations();
2804
2855
  });
2805
2856