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.
- checksums.yaml +4 -4
- data/lib/ace/rails/version.rb +1 -1
- data/vendor/assets/javascripts/ace/ace.js +403 -326
- data/vendor/assets/javascripts/ace/ext-language_tools.js +56 -40
- data/vendor/assets/javascripts/ace/ext-modelist.js +7 -3
- data/vendor/assets/javascripts/ace/ext-settings_menu.js +8 -4
- data/vendor/assets/javascripts/ace/ext-static_highlight.js +12 -5
- data/vendor/assets/javascripts/ace/keybinding-vim.js +5234 -1558
- data/vendor/assets/javascripts/ace/mode-abap.js +1 -1
- data/vendor/assets/javascripts/ace/mode-abc.js +261 -0
- data/vendor/assets/javascripts/ace/mode-actionscript.js +47 -1
- data/vendor/assets/javascripts/ace/mode-apache_conf.js +47 -1
- data/vendor/assets/javascripts/ace/mode-applescript.js +47 -1
- data/vendor/assets/javascripts/ace/mode-autohotkey.js +47 -1
- data/vendor/assets/javascripts/ace/mode-batchfile.js +47 -1
- data/vendor/assets/javascripts/ace/mode-c_cpp.js +101 -56
- data/vendor/assets/javascripts/ace/mode-coffee.js +3 -3
- data/vendor/assets/javascripts/ace/mode-coldfusion.js +114 -63
- data/vendor/assets/javascripts/ace/mode-csharp.js +99 -55
- data/vendor/assets/javascripts/ace/mode-css.js +98 -53
- data/vendor/assets/javascripts/ace/mode-curly.js +114 -63
- data/vendor/assets/javascripts/ace/mode-d.js +47 -1
- data/vendor/assets/javascripts/ace/mode-dart.js +103 -58
- data/vendor/assets/javascripts/ace/mode-diff.js +85 -85
- data/vendor/assets/javascripts/ace/mode-django.js +114 -63
- data/vendor/assets/javascripts/ace/mode-dockerfile.js +97 -52
- data/vendor/assets/javascripts/ace/mode-dot.js +47 -1
- data/vendor/assets/javascripts/ace/mode-eiffel.js +30 -37
- data/vendor/assets/javascripts/ace/mode-ejs.js +117 -63
- data/vendor/assets/javascripts/ace/mode-elm.js +47 -1
- data/vendor/assets/javascripts/ace/mode-erlang.js +47 -1
- data/vendor/assets/javascripts/ace/mode-forth.js +47 -1
- data/vendor/assets/javascripts/ace/mode-ftl.js +10 -7
- data/vendor/assets/javascripts/ace/mode-glsl.js +101 -56
- data/vendor/assets/javascripts/ace/mode-golang.js +96 -51
- data/vendor/assets/javascripts/ace/mode-groovy.js +98 -53
- data/vendor/assets/javascripts/ace/mode-haml.js +3 -0
- data/vendor/assets/javascripts/ace/mode-handlebars.js +114 -63
- data/vendor/assets/javascripts/ace/mode-haskell.js +49 -3
- data/vendor/assets/javascripts/ace/mode-haxe.js +96 -51
- data/vendor/assets/javascripts/ace/mode-html.js +114 -63
- data/vendor/assets/javascripts/ace/mode-html_ruby.js +117 -63
- data/vendor/assets/javascripts/ace/mode-io.js +47 -1
- data/vendor/assets/javascripts/ace/mode-jack.js +96 -51
- data/vendor/assets/javascripts/ace/mode-jade.js +10 -7
- data/vendor/assets/javascripts/ace/mode-java.js +98 -53
- data/vendor/assets/javascripts/ace/mode-javascript.js +98 -53
- data/vendor/assets/javascripts/ace/mode-json.js +99 -54
- data/vendor/assets/javascripts/ace/mode-jsoniq.js +98 -51
- data/vendor/assets/javascripts/ace/mode-jsp.js +106 -58
- data/vendor/assets/javascripts/ace/mode-jsx.js +96 -51
- data/vendor/assets/javascripts/ace/mode-julia.js +47 -1
- data/vendor/assets/javascripts/ace/mode-latex.js +1 -1
- data/vendor/assets/javascripts/ace/mode-lean.js +281 -0
- data/vendor/assets/javascripts/ace/mode-less.js +96 -51
- data/vendor/assets/javascripts/ace/mode-liquid.js +10 -7
- data/vendor/assets/javascripts/ace/mode-live_script.js +481 -0
- data/vendor/assets/javascripts/ace/mode-livescript.js +5 -8
- data/vendor/assets/javascripts/ace/mode-logiql.js +49 -50
- data/vendor/assets/javascripts/ace/mode-lsl.js +96 -51
- data/vendor/assets/javascripts/ace/mode-lua.js +3 -3
- data/vendor/assets/javascripts/ace/mode-luapage.js +117 -66
- data/vendor/assets/javascripts/ace/mode-makefile.js +1 -1
- data/vendor/assets/javascripts/ace/mode-markdown.js +134 -67
- data/vendor/assets/javascripts/ace/mode-mask.js +1985 -0
- data/vendor/assets/javascripts/ace/mode-mel.js +96 -51
- data/vendor/assets/javascripts/ace/mode-mips_assembler.js +235 -0
- data/vendor/assets/javascripts/ace/mode-mipsassembler.js +196 -0
- data/vendor/assets/javascripts/ace/mode-nix.js +101 -56
- data/vendor/assets/javascripts/ace/mode-objectivec.js +52 -6
- data/vendor/assets/javascripts/ace/mode-perl.js +47 -1
- data/vendor/assets/javascripts/ace/mode-pgsql.js +1 -1
- data/vendor/assets/javascripts/ace/mode-php.js +139 -85
- data/vendor/assets/javascripts/ace/mode-powershell.js +96 -51
- data/vendor/assets/javascripts/ace/mode-praat.js +47 -1
- data/vendor/assets/javascripts/ace/mode-prolog.js +47 -1
- data/vendor/assets/javascripts/ace/mode-protobuf.js +101 -56
- data/vendor/assets/javascripts/ace/mode-rdoc.js +1 -1
- data/vendor/assets/javascripts/ace/mode-rhtml.js +114 -63
- data/vendor/assets/javascripts/ace/mode-ruby.js +52 -50
- data/vendor/assets/javascripts/ace/mode-rust.js +57 -18
- data/vendor/assets/javascripts/ace/mode-scad.js +96 -51
- data/vendor/assets/javascripts/ace/mode-scala.js +98 -53
- data/vendor/assets/javascripts/ace/mode-scss.js +96 -51
- data/vendor/assets/javascripts/ace/mode-sh.js +97 -52
- data/vendor/assets/javascripts/ace/mode-sjs.js +98 -53
- data/vendor/assets/javascripts/ace/mode-smarty.js +114 -63
- data/vendor/assets/javascripts/ace/mode-soy_template.js +114 -63
- data/vendor/assets/javascripts/ace/mode-stylus.js +1 -1
- data/vendor/assets/javascripts/ace/mode-svg.js +132 -65
- data/vendor/assets/javascripts/ace/mode-tcl.js +47 -1
- data/vendor/assets/javascripts/ace/mode-twig.js +114 -63
- data/vendor/assets/javascripts/ace/mode-typescript.js +98 -53
- data/vendor/assets/javascripts/ace/mode-vala.js +96 -51
- data/vendor/assets/javascripts/ace/mode-velocity.js +114 -63
- data/vendor/assets/javascripts/ace/mode-vhdl.js +21 -21
- data/vendor/assets/javascripts/ace/mode-xml.js +34 -12
- data/vendor/assets/javascripts/ace/mode-xquery.js +98 -51
- data/vendor/assets/javascripts/ace/snippets/abc.js +38 -0
- data/vendor/assets/javascripts/ace/snippets/elixir.js +7 -0
- data/vendor/assets/javascripts/ace/snippets/elm.js +7 -0
- data/vendor/assets/javascripts/ace/snippets/lean.js +7 -0
- data/vendor/assets/javascripts/ace/snippets/live_script.js +7 -0
- data/vendor/assets/javascripts/ace/snippets/mask.js +7 -0
- data/vendor/assets/javascripts/ace/snippets/mips_assembler.js +7 -0
- data/vendor/assets/javascripts/ace/snippets/mipsassembler.js +7 -0
- data/vendor/assets/javascripts/ace/snippets/r.js +1 -1
- data/vendor/assets/javascripts/ace/theme-clouds_midnight.js +1 -1
- data/vendor/assets/javascripts/ace/theme-github.js +7 -1
- data/vendor/assets/javascripts/ace/theme-katzenmilch.js +3 -0
- data/vendor/assets/javascripts/ace/theme-kuroir.js +3 -0
- data/vendor/assets/javascripts/ace/worker-coffee.js +6 -7
- data/vendor/assets/javascripts/ace/worker-css.js +5 -5
- data/vendor/assets/javascripts/ace/worker-html.js +4354 -4354
- data/vendor/assets/javascripts/ace/worker-javascript.js +2435 -1397
- data/vendor/assets/javascripts/ace/worker-json.js +6 -7
- data/vendor/assets/javascripts/ace/worker-lua.js +11 -11
- data/vendor/assets/javascripts/ace/worker-php.js +4 -8
- data/vendor/assets/javascripts/ace/worker-xml.js +3809 -0
- data/vendor/assets/javascripts/ace/worker-xquery.js +38 -47
- metadata +18 -9
- data/vendor/assets/javascripts/ace/ext-options.js +0 -252
- data/vendor/assets/javascripts/ace/mode-html_completions.js +0 -309
- data/vendor/assets/javascripts/ace/mode-luahtml.js +0 -2415
- data/vendor/assets/javascripts/ace/mode-mushcode_high_rules.js +0 -569
- data/vendor/assets/javascripts/ace/mode-tmsnippet.js +0 -200
- 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
|
-
|
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: '
|
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
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
398
|
-
|
399
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
371
|
-
|
372
|
-
|
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("
|
412
|
-
session.setAnnotations(
|
411
|
+
worker.on("annotate", function(e) {
|
412
|
+
session.setAnnotations(e.data);
|
413
413
|
});
|
414
414
|
|
415
|
-
worker.on("
|
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
|
-
|
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
|
-
|
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
|
-
|
679
|
-
|
680
|
-
|
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("
|
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("
|
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 : "(<\\?)(
|
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 : "(?:
|
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 : "(<\\!)(
|
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 : "(?:(<)|(</))((?:
|
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 : "(?:
|
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("
|
2799
|
-
session.setAnnotations(
|
2849
|
+
worker.on("annotate", function(e) {
|
2850
|
+
session.setAnnotations(e.data);
|
2800
2851
|
});
|
2801
2852
|
|
2802
|
-
worker.on("
|
2853
|
+
worker.on("terminate", function() {
|
2803
2854
|
session.clearAnnotations();
|
2804
2855
|
});
|
2805
2856
|
|