4
* Copyright (C) 2009-11 by RStudio, Inc.
6
* The Initial Developer of the Original Code is
8
* Portions created by the Initial Developer are Copyright (C) 2010
9
* the Initial Developer. All Rights Reserved.
11
* This program is licensed to you under the terms of version 3 of the
12
* GNU Affero General Public License. This program is distributed WITHOUT
13
* ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,
14
* MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the
15
* AGPL (http://www.gnu.org/licenses/agpl-3.0.txt) for more details.
19
define('ace/mode/rhtml', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/html', 'ace/tokenizer', 'ace/mode/rhtml_highlight_rules'], function(require, exports, module) {
22
var oop = require("../lib/oop");
23
var HtmlMode = require("./html").Mode;
24
var Tokenizer = require("../tokenizer").Tokenizer;
26
var RHtmlHighlightRules = require("./rhtml_highlight_rules").RHtmlHighlightRules;
28
var Mode = function(doc, session) {
29
this.$session = session;
30
this.$tokenizer = new Tokenizer(new RHtmlHighlightRules().getRules());
32
oop.inherits(Mode, HtmlMode);
35
this.insertChunkInfo = {
36
value: "<!--begin.rcode\n\nend.rcode-->\n",
37
position: {row: 0, column: 15}
40
this.getLanguageMode = function(position)
42
return this.$session.getState(position.row).match(/^r-/) ? 'R' : 'HTML';
45
this.getNextLineIndent = function(state, line, tab, tabSize, row)
47
return this.codeModel.getNextLineIndent(row, line, state, tab, tabSize);
50
}).call(Mode.prototype);
55
define('ace/mode/html', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/text', 'ace/mode/javascript', 'ace/mode/css', 'ace/tokenizer', 'ace/mode/html_highlight_rules', 'ace/mode/behaviour/html', 'ace/mode/folding/html'], function(require, exports, module) {
58
var oop = require("../lib/oop");
59
var TextMode = require("./text").Mode;
60
var JavaScriptMode = require("./javascript").Mode;
61
var CssMode = require("./css").Mode;
62
var Tokenizer = require("../tokenizer").Tokenizer;
63
var HtmlHighlightRules = require("./html_highlight_rules").HtmlHighlightRules;
64
var HtmlBehaviour = require("./behaviour/html").HtmlBehaviour;
65
var HtmlFoldMode = require("./folding/html").FoldMode;
67
var Mode = function() {
68
var highlighter = new HtmlHighlightRules();
69
this.$tokenizer = new Tokenizer(highlighter.getRules());
70
this.$behaviour = new HtmlBehaviour();
72
this.$embeds = highlighter.getEmbeds();
73
this.createModeDelegates({
74
"js-": JavaScriptMode,
78
this.foldingRules = new HtmlFoldMode();
80
oop.inherits(Mode, TextMode);
84
this.blockComment = {start: "<!--", end: "-->"};
86
this.getNextLineIndent = function(state, line, tab) {
87
return this.$getIndent(line);
90
this.checkOutdent = function(state, line, input) {
94
}).call(Mode.prototype);
99
define('ace/mode/javascript', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/text', 'ace/tokenizer', 'ace/mode/javascript_highlight_rules', 'ace/mode/matching_brace_outdent', 'ace/range', 'ace/worker/worker_client', 'ace/mode/behaviour/cstyle', 'ace/mode/folding/cstyle'], function(require, exports, module) {
102
var oop = require("../lib/oop");
103
var TextMode = require("./text").Mode;
104
var Tokenizer = require("../tokenizer").Tokenizer;
105
var JavaScriptHighlightRules = require("./javascript_highlight_rules").JavaScriptHighlightRules;
106
var MatchingBraceOutdent = require("./matching_brace_outdent").MatchingBraceOutdent;
107
var Range = require("../range").Range;
108
var WorkerClient = require("../worker/worker_client").WorkerClient;
109
var CstyleBehaviour = require("./behaviour/cstyle").CstyleBehaviour;
110
var CStyleFoldMode = require("./folding/cstyle").FoldMode;
112
var Mode = function() {
113
this.$tokenizer = new Tokenizer(new JavaScriptHighlightRules().getRules());
114
this.$outdent = new MatchingBraceOutdent();
115
this.$behaviour = new CstyleBehaviour();
116
this.foldingRules = new CStyleFoldMode();
118
oop.inherits(Mode, TextMode);
122
this.lineCommentStart = "//";
123
this.blockComment = {start: "/*", end: "*/"};
125
this.getNextLineIndent = function(state, line, tab) {
126
var indent = this.$getIndent(line);
128
var tokenizedLine = this.$tokenizer.getLineTokens(line, state);
129
var tokens = tokenizedLine.tokens;
130
var endState = tokenizedLine.state;
132
if (tokens.length && tokens[tokens.length-1].type == "comment") {
136
if (state == "start" || state == "no_regex") {
137
var match = line.match(/^.*(?:\bcase\b.*\:|[\{\(\[])\s*$/);
141
} else if (state == "doc-start") {
142
if (endState == "start" || endState == "no_regex") {
145
var match = line.match(/^\s*(\/?)\*/);
157
this.checkOutdent = function(state, line, input) {
158
return this.$outdent.checkOutdent(line, input);
161
this.autoOutdent = function(state, doc, row) {
162
this.$outdent.autoOutdent(doc, row);
165
this.createWorker = function(session) {
166
var worker = new WorkerClient(["ace"], "ace/mode/javascript_worker", "JavaScriptWorker");
167
worker.attachToDocument(session.getDocument());
169
worker.on("jslint", function(results) {
170
session.setAnnotations(results.data);
173
worker.on("terminate", function() {
174
session.clearAnnotations();
180
}).call(Mode.prototype);
185
define('ace/mode/javascript_highlight_rules', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/doc_comment_highlight_rules', 'ace/mode/text_highlight_rules'], function(require, exports, module) {
188
var oop = require("../lib/oop");
189
var DocCommentHighlightRules = require("./doc_comment_highlight_rules").DocCommentHighlightRules;
190
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
192
var JavaScriptHighlightRules = function() {
193
var keywordMapper = this.createKeywordMapper({
195
"Array|Boolean|Date|Function|Iterator|Number|Object|RegExp|String|Proxy|" + // Constructors
196
"Namespace|QName|XML|XMLList|" + // E4X
197
"ArrayBuffer|Float32Array|Float64Array|Int16Array|Int32Array|Int8Array|" +
198
"Uint16Array|Uint32Array|Uint8Array|Uint8ClampedArray|" +
199
"Error|EvalError|InternalError|RangeError|ReferenceError|StopIteration|" + // Errors
200
"SyntaxError|TypeError|URIError|" +
201
"decodeURI|decodeURIComponent|encodeURI|encodeURIComponent|eval|isFinite|" + // Non-constructor functions
202
"isNaN|parseFloat|parseInt|" +
203
"JSON|Math|" + // Other
204
"this|arguments|prototype|window|document" , // Pseudo
206
"const|yield|import|get|set|" +
207
"break|case|catch|continue|default|delete|do|else|finally|for|function|" +
208
"if|in|instanceof|new|return|switch|throw|try|typeof|let|var|while|with|debugger|" +
209
"__parent__|__count__|escape|unescape|with|__proto__|" +
210
"class|enum|extends|super|export|implements|private|public|interface|package|protected|static",
212
"const|let|var|function",
214
"null|Infinity|NaN|undefined",
217
"constant.language.boolean": "true|false"
219
var kwBeforeRe = "case|do|else|finally|in|instanceof|return|throw|try|typeof|yield|void";
220
var identifierRe = "[a-zA-Z\\$_\u00a1-\uffff][a-zA-Z\\d\\$_\u00a1-\uffff]*\\b";
222
var escapedRe = "\\\\(?:x[0-9a-fA-F]{2}|" + // hex
223
"u[0-9a-fA-F]{4}|" + // unicode
224
"[0-2][0-7]{0,2}|" + // oct
225
"3[0-6][0-7]?|" + // oct
227
"[4-7][0-7]?|" + //oct
236
DocCommentHighlightRules.getStartRule("doc-start"),
238
token : "comment", // multi line comment
250
token : "constant.numeric", // hex
251
regex : /0[xX][0-9a-fA-F]+\b/
253
token : "constant.numeric", // float
254
regex : /[+-]?\d+(?:(?:\.\d*)?(?:[eE][+-]?\d+)?)?\b/
257
"storage.type", "punctuation.operator", "support.function",
258
"punctuation.operator", "entity.name.function", "text","keyword.operator"
260
regex : "(" + identifierRe + ")(\\.)(prototype)(\\.)(" + identifierRe +")(\\s*)(=)",
261
next: "function_arguments"
264
"storage.type", "punctuation.operator", "entity.name.function", "text",
265
"keyword.operator", "text", "storage.type", "text", "paren.lparen"
267
regex : "(" + identifierRe + ")(\\.)(" + identifierRe +")(\\s*)(=)(\\s*)(function)(\\s*)(\\()",
268
next: "function_arguments"
271
"entity.name.function", "text", "keyword.operator", "text", "storage.type",
272
"text", "paren.lparen"
274
regex : "(" + identifierRe +")(\\s*)(=)(\\s*)(function)(\\s*)(\\()",
275
next: "function_arguments"
278
"storage.type", "punctuation.operator", "entity.name.function", "text",
279
"keyword.operator", "text",
280
"storage.type", "text", "entity.name.function", "text", "paren.lparen"
282
regex : "(" + identifierRe + ")(\\.)(" + identifierRe +")(\\s*)(=)(\\s*)(function)(\\s+)(\\w+)(\\s*)(\\()",
283
next: "function_arguments"
286
"storage.type", "text", "entity.name.function", "text", "paren.lparen"
288
regex : "(function)(\\s+)(" + identifierRe + ")(\\s*)(\\()",
289
next: "function_arguments"
292
"entity.name.function", "text", "punctuation.operator",
293
"text", "storage.type", "text", "paren.lparen"
295
regex : "(" + identifierRe + ")(\\s*)(:)(\\s*)(function)(\\s*)(\\()",
296
next: "function_arguments"
299
"text", "text", "storage.type", "text", "paren.lparen"
301
regex : "(:)(\\s*)(function)(\\s*)(\\()",
302
next: "function_arguments"
305
regex : "(?:" + kwBeforeRe + ")\\b",
308
token : ["punctuation.operator", "support.function"],
309
regex : /(\.)(s(?:h(?:ift|ow(?:Mod(?:elessDialog|alDialog)|Help))|croll(?:X|By(?:Pages|Lines)?|Y|To)?|t(?:opzzzz|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(?=\()/
311
token : ["punctuation.operator", "support.function.dom"],
312
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(?=\()/
314
token : ["punctuation.operator", "support.constant"],
315
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/
317
token : ["storage.type", "punctuation.operator", "support.function.firebug"],
318
regex : /(console)(\.)(warn|info|log|error|time|timeEnd|assert)\b/
320
token : keywordMapper,
323
token : "keyword.operator",
324
regex : /--|\+\+|[!$%&*+\-~]|===|==|=|!=|!==|<=|>=|<<=|>>=|>>>=|<>|<|>|!|&&|\|\||\?\:|\*=|%=|\+=|\-=|&=|\^=/,
327
token : "punctuation.operator",
328
regex : /\?|\:|\,|\;|\./,
331
token : "paren.lparen",
335
token : "paren.rparen",
338
token : "keyword.operator",
347
DocCommentHighlightRules.getStartRule("doc-start"),
349
token : "comment", // multi line comment
351
next : "comment_regex_allowed"
357
token: "string.regexp",
372
token: "regexp.keyword.operator",
373
regex: "\\\\(?:u[\\da-fA-F]{4}|x[\\da-fA-F]{2}|.)"
375
token: "string.regexp",
380
regex: /\{\d+\b,?\d*\}[+*]|[+*$^?][+*]|[$^][?]|\?{3,}/
382
token : "constant.language.escape",
383
regex: /\(\?[:=!]|\)|\{\d+\b,?\d*\}|[+*]\?|[()$^+*?]/
385
token : "constant.language.delimiter",
388
token: "constant.language.escape",
390
next: "regex_character_class",
396
defaultToken: "string.regexp"
399
"regex_character_class": [
401
token: "regexp.keyword.operator",
402
regex: "\\\\(?:u[\\da-fA-F]{4}|x[\\da-fA-F]{2}|.)"
404
token: "constant.language.escape",
408
token: "constant.language.escape",
415
defaultToken: "string.regexp.charachterclass"
418
"function_arguments": [
420
token: "variable.parameter",
423
token: "punctuation.operator",
426
token: "punctuation.operator",
434
"comment_regex_allowed" : [
435
{token : "comment", regex : "\\*\\/", next : "start"},
436
{defaultToken : "comment"}
439
{token : "comment", regex : "\\*\\/", next : "no_regex"},
440
{defaultToken : "comment"}
444
token : "constant.language.escape",
455
defaultToken: "string"
460
token : "constant.language.escape",
471
defaultToken: "string"
476
this.embedRules(DocCommentHighlightRules, "doc-",
477
[ DocCommentHighlightRules.getEndRule("no_regex") ]);
480
oop.inherits(JavaScriptHighlightRules, TextHighlightRules);
482
exports.JavaScriptHighlightRules = JavaScriptHighlightRules;
485
define('ace/mode/doc_comment_highlight_rules', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/text_highlight_rules'], function(require, exports, module) {
488
var oop = require("../lib/oop");
489
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
491
var DocCommentHighlightRules = function() {
495
token : "comment.doc.tag",
496
regex : "@[\\w\\d_]+" // TODO: fix email addresses
498
token : "comment.doc.tag",
501
defaultToken : "comment.doc"
506
oop.inherits(DocCommentHighlightRules, TextHighlightRules);
508
DocCommentHighlightRules.getStartRule = function(start) {
510
token : "comment.doc", // doc comment
511
regex : "\\/\\*(?=\\*)",
516
DocCommentHighlightRules.getEndRule = function (start) {
518
token : "comment.doc", // closing comment
525
exports.DocCommentHighlightRules = DocCommentHighlightRules;
529
define('ace/mode/matching_brace_outdent', ['require', 'exports', 'module' , 'ace/range'], function(require, exports, module) {
532
var Range = require("../range").Range;
534
var MatchingBraceOutdent = function() {};
538
this.checkOutdent = function(line, input) {
539
if (! /^\s+$/.test(line))
542
return /^\s*\}/.test(input);
545
this.autoOutdent = function(doc, row) {
546
var line = doc.getLine(row);
547
var match = line.match(/^(\s*\})/);
549
if (!match) return 0;
551
var column = match[1].length;
552
var openBracePos = doc.findMatchingBracket({row: row, column: column});
554
if (!openBracePos || openBracePos.row == row) return 0;
556
var indent = this.$getIndent(doc.getLine(openBracePos.row));
557
doc.replace(new Range(row, 0, row, column-1), indent);
560
this.$getIndent = function(line) {
561
return line.match(/^\s*/)[0];
564
}).call(MatchingBraceOutdent.prototype);
566
exports.MatchingBraceOutdent = MatchingBraceOutdent;
569
define('ace/mode/behaviour/cstyle', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/behaviour', 'ace/token_iterator', 'ace/lib/lang'], function(require, exports, module) {
572
var oop = require("../../lib/oop");
573
var Behaviour = require("../behaviour").Behaviour;
574
var TokenIterator = require("../../token_iterator").TokenIterator;
575
var lang = require("../../lib/lang");
577
var SAFE_INSERT_IN_TOKENS =
578
["text", "paren.rparen", "punctuation.operator"];
579
var SAFE_INSERT_BEFORE_TOKENS =
580
["text", "paren.rparen", "punctuation.operator", "comment"];
583
var autoInsertedBrackets = 0;
584
var autoInsertedRow = -1;
585
var autoInsertedLineEnd = "";
586
var maybeInsertedBrackets = 0;
587
var maybeInsertedRow = -1;
588
var maybeInsertedLineStart = "";
589
var maybeInsertedLineEnd = "";
591
var CstyleBehaviour = function () {
593
CstyleBehaviour.isSaneInsertion = function(editor, session) {
594
var cursor = editor.getCursorPosition();
595
var iterator = new TokenIterator(session, cursor.row, cursor.column);
596
if (!this.$matchTokenType(iterator.getCurrentToken() || "text", SAFE_INSERT_IN_TOKENS)) {
597
var iterator2 = new TokenIterator(session, cursor.row, cursor.column + 1);
598
if (!this.$matchTokenType(iterator2.getCurrentToken() || "text", SAFE_INSERT_IN_TOKENS))
601
iterator.stepForward();
602
return iterator.getCurrentTokenRow() !== cursor.row ||
603
this.$matchTokenType(iterator.getCurrentToken() || "text", SAFE_INSERT_BEFORE_TOKENS);
606
CstyleBehaviour.$matchTokenType = function(token, types) {
607
return types.indexOf(token.type || token) > -1;
610
CstyleBehaviour.recordAutoInsert = function(editor, session, bracket) {
611
var cursor = editor.getCursorPosition();
612
var line = session.doc.getLine(cursor.row);
613
if (!this.isAutoInsertedClosing(cursor, line, autoInsertedLineEnd[0]))
614
autoInsertedBrackets = 0;
615
autoInsertedRow = cursor.row;
616
autoInsertedLineEnd = bracket + line.substr(cursor.column);
617
autoInsertedBrackets++;
620
CstyleBehaviour.recordMaybeInsert = function(editor, session, bracket) {
621
var cursor = editor.getCursorPosition();
622
var line = session.doc.getLine(cursor.row);
623
if (!this.isMaybeInsertedClosing(cursor, line))
624
maybeInsertedBrackets = 0;
625
maybeInsertedRow = cursor.row;
626
maybeInsertedLineStart = line.substr(0, cursor.column) + bracket;
627
maybeInsertedLineEnd = line.substr(cursor.column);
628
maybeInsertedBrackets++;
631
CstyleBehaviour.isAutoInsertedClosing = function(cursor, line, bracket) {
632
return autoInsertedBrackets > 0 &&
633
cursor.row === autoInsertedRow &&
634
bracket === autoInsertedLineEnd[0] &&
635
line.substr(cursor.column) === autoInsertedLineEnd;
638
CstyleBehaviour.isMaybeInsertedClosing = function(cursor, line) {
639
return maybeInsertedBrackets > 0 &&
640
cursor.row === maybeInsertedRow &&
641
line.substr(cursor.column) === maybeInsertedLineEnd &&
642
line.substr(0, cursor.column) == maybeInsertedLineStart;
645
CstyleBehaviour.popAutoInsertedClosing = function() {
646
autoInsertedLineEnd = autoInsertedLineEnd.substr(1);
647
autoInsertedBrackets--;
650
CstyleBehaviour.clearMaybeInsertedClosing = function() {
651
maybeInsertedBrackets = 0;
652
maybeInsertedRow = -1;
655
this.add("braces", "insertion", function (state, action, editor, session, text) {
656
var cursor = editor.getCursorPosition();
657
var line = session.doc.getLine(cursor.row);
659
var selection = editor.getSelectionRange();
660
var selected = session.doc.getTextRange(selection);
661
if (selected !== "" && selected !== "{" && editor.getWrapBehavioursEnabled()) {
663
text: '{' + selected + '}',
666
} else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
667
if (/[\]\}\)]/.test(line[cursor.column])) {
668
CstyleBehaviour.recordAutoInsert(editor, session, "}");
674
CstyleBehaviour.recordMaybeInsert(editor, session, "{");
681
} else if (text == '}') {
682
var rightChar = line.substring(cursor.column, cursor.column + 1);
683
if (rightChar == '}') {
684
var matching = session.$findOpeningBracket('}', {column: cursor.column + 1, row: cursor.row});
685
if (matching !== null && CstyleBehaviour.isAutoInsertedClosing(cursor, line, text)) {
686
CstyleBehaviour.popAutoInsertedClosing();
693
} else if (text == "\n" || text == "\r\n") {
695
if (CstyleBehaviour.isMaybeInsertedClosing(cursor, line)) {
696
closing = lang.stringRepeat("}", maybeInsertedBrackets);
697
CstyleBehaviour.clearMaybeInsertedClosing();
699
var rightChar = line.substring(cursor.column, cursor.column + 1);
700
if (rightChar == '}' || closing !== "") {
701
var openBracePos = session.findMatchingBracket({row: cursor.row, column: cursor.column}, '}');
705
var indent = this.getNextLineIndent(state, line.substring(0, cursor.column), session.getTabString());
706
var next_indent = this.$getIndent(line);
709
text: '\n' + indent + '\n' + next_indent + closing,
710
selection: [1, indent.length, 1, indent.length]
716
this.add("braces", "deletion", function (state, action, editor, session, range) {
717
var selected = session.doc.getTextRange(range);
718
if (!range.isMultiLine() && selected == '{') {
719
var line = session.doc.getLine(range.start.row);
720
var rightChar = line.substring(range.end.column, range.end.column + 1);
721
if (rightChar == '}') {
725
maybeInsertedBrackets--;
730
this.add("parens", "insertion", function (state, action, editor, session, text) {
732
var selection = editor.getSelectionRange();
733
var selected = session.doc.getTextRange(selection);
734
if (selected !== "" && editor.getWrapBehavioursEnabled()) {
736
text: '(' + selected + ')',
739
} else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
740
CstyleBehaviour.recordAutoInsert(editor, session, ")");
746
} else if (text == ')') {
747
var cursor = editor.getCursorPosition();
748
var line = session.doc.getLine(cursor.row);
749
var rightChar = line.substring(cursor.column, cursor.column + 1);
750
if (rightChar == ')') {
751
var matching = session.$findOpeningBracket(')', {column: cursor.column + 1, row: cursor.row});
752
if (matching !== null && CstyleBehaviour.isAutoInsertedClosing(cursor, line, text)) {
753
CstyleBehaviour.popAutoInsertedClosing();
763
this.add("parens", "deletion", function (state, action, editor, session, range) {
764
var selected = session.doc.getTextRange(range);
765
if (!range.isMultiLine() && selected == '(') {
766
var line = session.doc.getLine(range.start.row);
767
var rightChar = line.substring(range.start.column + 1, range.start.column + 2);
768
if (rightChar == ')') {
775
this.add("brackets", "insertion", function (state, action, editor, session, text) {
777
var selection = editor.getSelectionRange();
778
var selected = session.doc.getTextRange(selection);
779
if (selected !== "" && editor.getWrapBehavioursEnabled()) {
781
text: '[' + selected + ']',
784
} else if (CstyleBehaviour.isSaneInsertion(editor, session)) {
785
CstyleBehaviour.recordAutoInsert(editor, session, "]");
791
} else if (text == ']') {
792
var cursor = editor.getCursorPosition();
793
var line = session.doc.getLine(cursor.row);
794
var rightChar = line.substring(cursor.column, cursor.column + 1);
795
if (rightChar == ']') {
796
var matching = session.$findOpeningBracket(']', {column: cursor.column + 1, row: cursor.row});
797
if (matching !== null && CstyleBehaviour.isAutoInsertedClosing(cursor, line, text)) {
798
CstyleBehaviour.popAutoInsertedClosing();
808
this.add("brackets", "deletion", function (state, action, editor, session, range) {
809
var selected = session.doc.getTextRange(range);
810
if (!range.isMultiLine() && selected == '[') {
811
var line = session.doc.getLine(range.start.row);
812
var rightChar = line.substring(range.start.column + 1, range.start.column + 2);
813
if (rightChar == ']') {
820
this.add("string_dquotes", "insertion", function (state, action, editor, session, text) {
821
if (text == '"' || text == "'") {
823
var selection = editor.getSelectionRange();
824
var selected = session.doc.getTextRange(selection);
825
if (selected !== "" && selected !== "'" && selected != '"' && editor.getWrapBehavioursEnabled()) {
827
text: quote + selected + quote,
831
var cursor = editor.getCursorPosition();
832
var line = session.doc.getLine(cursor.row);
833
var leftChar = line.substring(cursor.column-1, cursor.column);
834
if (leftChar == '\\') {
837
var tokens = session.getTokens(selection.start.row);
839
var quotepos = -1; // Track whether we're inside an open quote.
841
for (var x = 0; x < tokens.length; x++) {
843
if (token.type == "string") {
845
} else if (quotepos < 0) {
846
quotepos = token.value.indexOf(quote);
848
if ((token.value.length + col) > selection.start.column) {
851
col += tokens[x].value.length;
853
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)))) {
854
if (!CstyleBehaviour.isSaneInsertion(editor, session))
860
} else if (token && token.type === "string") {
861
var rightChar = line.substring(cursor.column, cursor.column + 1);
862
if (rightChar == quote) {
873
this.add("string_dquotes", "deletion", function (state, action, editor, session, range) {
874
var selected = session.doc.getTextRange(range);
875
if (!range.isMultiLine() && (selected == '"' || selected == "'")) {
876
var line = session.doc.getLine(range.start.row);
877
var rightChar = line.substring(range.start.column + 1, range.start.column + 2);
878
if (rightChar == selected) {
887
oop.inherits(CstyleBehaviour, Behaviour);
889
exports.CstyleBehaviour = CstyleBehaviour;
892
define('ace/mode/folding/cstyle', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/range', 'ace/mode/folding/fold_mode'], function(require, exports, module) {
895
var oop = require("../../lib/oop");
896
var Range = require("../../range").Range;
897
var BaseFoldMode = require("./fold_mode").FoldMode;
899
var FoldMode = exports.FoldMode = function(commentRegex) {
901
this.foldingStartMarker = new RegExp(
902
this.foldingStartMarker.source.replace(/\|[^|]*?$/, "|" + commentRegex.start)
904
this.foldingStopMarker = new RegExp(
905
this.foldingStopMarker.source.replace(/\|[^|]*?$/, "|" + commentRegex.end)
909
oop.inherits(FoldMode, BaseFoldMode);
913
this.foldingStartMarker = /(\{|\[)[^\}\]]*$|^\s*(\/\*)/;
914
this.foldingStopMarker = /^[^\[\{]*(\}|\])|^[\s\*]*(\*\/)/;
916
this.getFoldWidgetRange = function(session, foldStyle, row) {
917
var line = session.getLine(row);
918
var match = line.match(this.foldingStartMarker);
923
return this.openingBracketBlock(session, match[1], row, i);
925
return session.getCommentFoldRange(row, i + match[0].length, 1);
928
if (foldStyle !== "markbeginend")
931
var match = line.match(this.foldingStopMarker);
933
var i = match.index + match[0].length;
936
return this.closingBracketBlock(session, match[1], row, i);
938
return session.getCommentFoldRange(row, i, -1);
942
}).call(FoldMode.prototype);
946
define('ace/mode/css', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/text', 'ace/tokenizer', 'ace/mode/css_highlight_rules', 'ace/mode/matching_brace_outdent', 'ace/worker/worker_client', 'ace/mode/behaviour/css', 'ace/mode/folding/cstyle'], function(require, exports, module) {
949
var oop = require("../lib/oop");
950
var TextMode = require("./text").Mode;
951
var Tokenizer = require("../tokenizer").Tokenizer;
952
var CssHighlightRules = require("./css_highlight_rules").CssHighlightRules;
953
var MatchingBraceOutdent = require("./matching_brace_outdent").MatchingBraceOutdent;
954
var WorkerClient = require("../worker/worker_client").WorkerClient;
955
var CssBehaviour = require("./behaviour/css").CssBehaviour;
956
var CStyleFoldMode = require("./folding/cstyle").FoldMode;
958
var Mode = function() {
959
this.$tokenizer = new Tokenizer(new CssHighlightRules().getRules());
960
this.$outdent = new MatchingBraceOutdent();
961
this.$behaviour = new CssBehaviour();
962
this.foldingRules = new CStyleFoldMode();
964
oop.inherits(Mode, TextMode);
968
this.foldingRules = "cStyle";
969
this.blockComment = {start: "/*", end: "*/"};
971
this.getNextLineIndent = function(state, line, tab) {
972
var indent = this.$getIndent(line);
973
var tokens = this.$tokenizer.getLineTokens(line, state).tokens;
974
if (tokens.length && tokens[tokens.length-1].type == "comment") {
978
var match = line.match(/^.*\{\s*$/);
986
this.checkOutdent = function(state, line, input) {
987
return this.$outdent.checkOutdent(line, input);
990
this.autoOutdent = function(state, doc, row) {
991
this.$outdent.autoOutdent(doc, row);
994
this.createWorker = function(session) {
995
var worker = new WorkerClient(["ace"], "ace/mode/css_worker", "Worker");
996
worker.attachToDocument(session.getDocument());
998
worker.on("csslint", function(e) {
999
session.setAnnotations(e.data);
1002
worker.on("terminate", function() {
1003
session.clearAnnotations();
1009
}).call(Mode.prototype);
1011
exports.Mode = Mode;
1015
define('ace/mode/css_highlight_rules', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/lib/lang', 'ace/mode/text_highlight_rules'], function(require, exports, module) {
1018
var oop = require("../lib/oop");
1019
var lang = require("../lib/lang");
1020
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
1021
var supportType = exports.supportType = "animation-fill-mode|alignment-adjust|alignment-baseline|animation-delay|animation-direction|animation-duration|animation-iteration-count|animation-name|animation-play-state|animation-timing-function|animation|appearance|azimuth|backface-visibility|background-attachment|background-break|background-clip|background-color|background-image|background-origin|background-position|background-repeat|background-size|background|baseline-shift|binding|bleed|bookmark-label|bookmark-level|bookmark-state|bookmark-target|border-bottom|border-bottom-color|border-bottom-left-radius|border-bottom-right-radius|border-bottom-style|border-bottom-width|border-collapse|border-color|border-image|border-image-outset|border-image-repeat|border-image-slice|border-image-source|border-image-width|border-left|border-left-color|border-left-style|border-left-width|border-radius|border-right|border-right-color|border-right-style|border-right-width|border-spacing|border-style|border-top|border-top-color|border-top-left-radius|border-top-right-radius|border-top-style|border-top-width|border-width|border|bottom|box-align|box-decoration-break|box-direction|box-flex-group|box-flex|box-lines|box-ordinal-group|box-orient|box-pack|box-shadow|box-sizing|break-after|break-before|break-inside|caption-side|clear|clip|color-profile|color|column-count|column-fill|column-gap|column-rule|column-rule-color|column-rule-style|column-rule-width|column-span|column-width|columns|content|counter-increment|counter-reset|crop|cue-after|cue-before|cue|cursor|direction|display|dominant-baseline|drop-initial-after-adjust|drop-initial-after-align|drop-initial-before-adjust|drop-initial-before-align|drop-initial-size|drop-initial-value|elevation|empty-cells|fit|fit-position|float-offset|float|font-family|font-size|font-size-adjust|font-stretch|font-style|font-variant|font-weight|font|grid-columns|grid-rows|hanging-punctuation|height|hyphenate-after|hyphenate-before|hyphenate-character|hyphenate-lines|hyphenate-resource|hyphens|icon|image-orientation|image-rendering|image-resolution|inline-box-align|left|letter-spacing|line-height|line-stacking-ruby|line-stacking-shift|line-stacking-strategy|line-stacking|list-style-image|list-style-position|list-style-type|list-style|margin-bottom|margin-left|margin-right|margin-top|margin|mark-after|mark-before|mark|marks|marquee-direction|marquee-play-count|marquee-speed|marquee-style|max-height|max-width|min-height|min-width|move-to|nav-down|nav-index|nav-left|nav-right|nav-up|opacity|orphans|outline-color|outline-offset|outline-style|outline-width|outline|overflow-style|overflow-x|overflow-y|overflow|padding-bottom|padding-left|padding-right|padding-top|padding|page-break-after|page-break-before|page-break-inside|page-policy|page|pause-after|pause-before|pause|perspective-origin|perspective|phonemes|pitch-range|pitch|play-during|position|presentation-level|punctuation-trim|quotes|rendering-intent|resize|rest-after|rest-before|rest|richness|right|rotation-point|rotation|ruby-align|ruby-overhang|ruby-position|ruby-span|size|speak-header|speak-numeral|speak-punctuation|speak|speech-rate|stress|string-set|table-layout|target-name|target-new|target-position|target|text-align-last|text-align|text-decoration|text-emphasis|text-height|text-indent|text-justify|text-outline|text-shadow|text-transform|text-wrap|top|transform-origin|transform-style|transform|transition-delay|transition-duration|transition-property|transition-timing-function|transition|unicode-bidi|vertical-align|visibility|voice-balance|voice-duration|voice-family|voice-pitch-range|voice-pitch|voice-rate|voice-stress|voice-volume|volume|white-space-collapse|white-space|widows|width|word-break|word-spacing|word-wrap|z-index";
1022
var supportFunction = exports.supportFunction = "rgb|rgba|url|attr|counter|counters";
1023
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";
1024
var supportConstantColor = exports.supportConstantColor = "aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|orange|purple|red|silver|teal|white|yellow";
1025
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";
1027
var numRe = exports.numRe = "\\-?(?:(?:[0-9]+)|(?:[0-9]*\\.[0-9]+))";
1028
var pseudoElements = exports.pseudoElements = "(\\:+)\\b(after|before|first-letter|first-line|moz-selection|selection)\\b";
1029
var pseudoClasses = exports.pseudoClasses = "(:)\\b(active|checked|disabled|empty|enabled|first-child|first-of-type|focus|hover|indeterminate|invalid|last-child|last-of-type|link|not|nth-child|nth-last-child|nth-last-of-type|nth-of-type|only-child|only-of-type|required|root|target|valid|visited)\\b";
1031
var CssHighlightRules = function() {
1033
var keywordMapper = this.createKeywordMapper({
1034
"support.function": supportFunction,
1035
"support.constant": supportConstant,
1036
"support.type": supportType,
1037
"support.constant.color": supportConstantColor,
1038
"support.constant.fonts": supportConstantFonts
1041
var base_ruleset = [
1043
token : "comment", // multi line comment
1045
next : "ruleset_comment"
1047
token : "string", // single line
1048
regex : '["](?:(?:\\\\.)|(?:[^"\\\\]))*?["]'
1050
token : "string", // single line
1051
regex : "['](?:(?:\\\\.)|(?:[^'\\\\]))*?[']"
1053
token : ["constant.numeric", "keyword"],
1054
regex : "(" + numRe + ")(ch|cm|deg|em|ex|fr|gd|grad|Hz|in|kHz|mm|ms|pc|pt|px|rad|rem|s|turn|vh|vm|vw|%)"
1056
token : "constant.numeric",
1059
token : "constant.numeric", // hex6 color
1060
regex : "#[a-f0-9]{6}"
1062
token : "constant.numeric", // hex3 color
1063
regex : "#[a-f0-9]{3}"
1065
token : ["punctuation", "entity.other.attribute-name.pseudo-element.css"],
1066
regex : pseudoElements
1068
token : ["punctuation", "entity.other.attribute-name.pseudo-class.css"],
1069
regex : pseudoClasses
1071
token : ["support.function", "string", "support.function"],
1072
regex : "(url\\()(.*)(\\))"
1074
token : keywordMapper,
1075
regex : "\\-?[a-zA-Z_][a-zA-Z0-9_\\-]*"
1077
caseInsensitive: true
1081
var ruleset = lang.copyArray(base_ruleset);
1083
token : "paren.rparen",
1088
var media_ruleset = lang.copyArray( base_ruleset );
1089
media_ruleset.unshift({
1090
token : "paren.rparen",
1095
var base_comment = [{
1096
token : "comment", // comment spanning whole line
1100
var comment = lang.copyArray(base_comment);
1102
token : "comment", // closing comment
1103
regex : ".*?\\*\\/",
1107
var media_comment = lang.copyArray(base_comment);
1108
media_comment.unshift({
1109
token : "comment", // closing comment
1110
regex : ".*?\\*\\/",
1114
var ruleset_comment = lang.copyArray(base_comment);
1115
ruleset_comment.unshift({
1116
token : "comment", // closing comment
1117
regex : ".*?\\*\\/",
1123
token : "comment", // multi line comment
1127
token: "paren.lparen",
1136
regex: "#[a-z0-9-_]+"
1139
regex: "\\.[a-z0-9-_]+"
1142
regex: ":[a-z0-9-_]+"
1145
regex: "[a-z0-9-_]+"
1147
caseInsensitive: true
1151
token : "comment", // multi line comment
1153
next : "media_comment"
1155
token: "paren.lparen",
1157
next: "media_ruleset"
1164
regex: "#[a-z0-9-_]+"
1167
regex: "\\.[a-z0-9-_]+"
1170
regex: ":[a-z0-9-_]+"
1173
regex: "[a-z0-9-_]+"
1175
caseInsensitive: true
1178
"comment" : comment,
1180
"ruleset" : ruleset,
1181
"ruleset_comment" : ruleset_comment,
1183
"media_ruleset" : media_ruleset,
1184
"media_comment" : media_comment
1188
oop.inherits(CssHighlightRules, TextHighlightRules);
1190
exports.CssHighlightRules = CssHighlightRules;
1194
define('ace/mode/behaviour/css', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/behaviour', 'ace/mode/behaviour/cstyle', 'ace/token_iterator'], function(require, exports, module) {
1197
var oop = require("../../lib/oop");
1198
var Behaviour = require("../behaviour").Behaviour;
1199
var CstyleBehaviour = require("./cstyle").CstyleBehaviour;
1200
var TokenIterator = require("../../token_iterator").TokenIterator;
1202
var CssBehaviour = function () {
1204
this.inherit(CstyleBehaviour);
1206
this.add("colon", "insertion", function (state, action, editor, session, text) {
1208
var cursor = editor.getCursorPosition();
1209
var iterator = new TokenIterator(session, cursor.row, cursor.column);
1210
var token = iterator.getCurrentToken();
1211
if (token && token.value.match(/\s+/)) {
1212
token = iterator.stepBackward();
1214
if (token && token.type === 'support.type') {
1215
var line = session.doc.getLine(cursor.row);
1216
var rightChar = line.substring(cursor.column, cursor.column + 1);
1217
if (rightChar === ':') {
1223
if (!line.substring(cursor.column).match(/^\s*;/)) {
1233
this.add("colon", "deletion", function (state, action, editor, session, range) {
1234
var selected = session.doc.getTextRange(range);
1235
if (!range.isMultiLine() && selected === ':') {
1236
var cursor = editor.getCursorPosition();
1237
var iterator = new TokenIterator(session, cursor.row, cursor.column);
1238
var token = iterator.getCurrentToken();
1239
if (token && token.value.match(/\s+/)) {
1240
token = iterator.stepBackward();
1242
if (token && token.type === 'support.type') {
1243
var line = session.doc.getLine(range.start.row);
1244
var rightChar = line.substring(range.end.column, range.end.column + 1);
1245
if (rightChar === ';') {
1246
range.end.column ++;
1253
this.add("semicolon", "insertion", function (state, action, editor, session, text) {
1255
var cursor = editor.getCursorPosition();
1256
var line = session.doc.getLine(cursor.row);
1257
var rightChar = line.substring(cursor.column, cursor.column + 1);
1258
if (rightChar === ';') {
1268
oop.inherits(CssBehaviour, CstyleBehaviour);
1270
exports.CssBehaviour = CssBehaviour;
1273
define('ace/mode/html_highlight_rules', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/lib/lang', 'ace/mode/css_highlight_rules', 'ace/mode/javascript_highlight_rules', 'ace/mode/xml_util', 'ace/mode/text_highlight_rules'], function(require, exports, module) {
1276
var oop = require("../lib/oop");
1277
var lang = require("../lib/lang");
1278
var CssHighlightRules = require("./css_highlight_rules").CssHighlightRules;
1279
var JavaScriptHighlightRules = require("./javascript_highlight_rules").JavaScriptHighlightRules;
1280
var xmlUtil = require("./xml_util");
1281
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
1283
var tagMap = lang.createMap({
1302
var HtmlHighlightRules = function() {
1306
regex : "<\\!\\[CDATA\\[",
1310
regex : "<\\?.*?\\?>"
1320
regex : "<(?=script\\b)",
1324
regex : "<(?=style\\b)",
1327
token : "meta.tag", // opening tag
1334
token : "constant.character.entity",
1335
regex : "(?:&#[0-9]+;)|(?:&#x[0-9a-fA-F]+;)|(?:&[a-zA-Z0-9_:\\.-]+;)"
1349
defaultToken : "comment"
1353
xmlUtil.tag(this.$rules, "tag", "start", tagMap);
1354
xmlUtil.tag(this.$rules, "style", "css-start", tagMap);
1355
xmlUtil.tag(this.$rules, "script", "js-start", tagMap);
1357
this.embedRules(JavaScriptHighlightRules, "js-", [{
1359
regex: "\\/\\/.*(?=<\\/script>)",
1363
regex: "<\\/(?=script)",
1367
this.embedRules(CssHighlightRules, "css-", [{
1369
regex: "<\\/(?=style)",
1374
oop.inherits(HtmlHighlightRules, TextHighlightRules);
1376
exports.HtmlHighlightRules = HtmlHighlightRules;
1379
define('ace/mode/xml_util', ['require', 'exports', 'module' ], function(require, exports, module) {
1382
function string(state) {
1386
next : state + "_qqstring"
1390
next : state + "_qstring"
1394
function multiLineString(quote, state) {
1396
{token : "string", regex : quote, next : state},
1398
token : "constant.language.escape",
1399
regex : "(?:&#[0-9]+;)|(?:&#x[0-9a-fA-F]+;)|(?:&[a-zA-Z0-9_:\\.-]+;)"
1401
{defaultToken : "string"}
1405
exports.tag = function(states, name, nextState, tagMap) {
1411
token : !tagMap ? "meta.tag.tag-name" : function(value) {
1413
return "meta.tag.tag-name." + tagMap[value];
1415
return "meta.tag.tag-name";
1417
regex : "[-_a-zA-Z0-9:]+",
1418
next : name + "_embed_attribute_list"
1422
next : name + "_embed_attribute_list"
1425
states[name + "_qstring"] = multiLineString("'", name + "_embed_attribute_list");
1426
states[name + "_qqstring"] = multiLineString("\"", name + "_embed_attribute_list");
1428
states[name + "_embed_attribute_list"] = [{
1429
token : "meta.tag.r",
1433
token : "keyword.operator",
1436
token : "entity.other.attribute-name",
1437
regex : "[-_a-zA-Z0-9:]+"
1439
token : "constant.numeric", // float
1440
regex : "[+-]?\\d+(?:(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)?\\b"
1444
}].concat(string(name));
1449
define('ace/mode/behaviour/html', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/behaviour/xml', 'ace/mode/behaviour/cstyle', 'ace/token_iterator'], function(require, exports, module) {
1452
var oop = require("../../lib/oop");
1453
var XmlBehaviour = require("../behaviour/xml").XmlBehaviour;
1454
var CstyleBehaviour = require("./cstyle").CstyleBehaviour;
1455
var TokenIterator = require("../../token_iterator").TokenIterator;
1456
var voidElements = ['area', 'base', 'br', 'col', 'command', 'embed', 'hr', 'img', 'input', 'keygen', 'link', 'meta', 'param', 'source', 'track', 'wbr'];
1458
function hasType(token, type) {
1460
var typeList = token.type.split('.');
1461
var needleList = type.split('.');
1462
needleList.forEach(function(needle){
1463
if (typeList.indexOf(needle) == -1) {
1471
var HtmlBehaviour = function () {
1473
this.inherit(XmlBehaviour); // Get xml behaviour
1475
this.add("autoclosing", "insertion", function (state, action, editor, session, text) {
1477
var position = editor.getCursorPosition();
1478
var iterator = new TokenIterator(session, position.row, position.column);
1479
var token = iterator.getCurrentToken();
1480
var atCursor = false;
1481
if (!token || !hasType(token, 'meta.tag') && !(hasType(token, 'text') && token.value.match('/'))){
1483
token = iterator.stepBackward();
1484
} while (token && (hasType(token, 'string') || hasType(token, 'keyword.operator') || hasType(token, 'entity.attribute-name') || hasType(token, 'text')));
1488
if (!token || !hasType(token, 'meta.tag-name') || iterator.stepBackward().value.match('/')) {
1491
var element = token.value;
1493
var element = element.substring(0, position.column - token.start);
1495
if (voidElements.indexOf(element) !== -1){
1499
text: '>' + '</' + element + '>',
1505
oop.inherits(HtmlBehaviour, XmlBehaviour);
1507
exports.HtmlBehaviour = HtmlBehaviour;
1510
define('ace/mode/behaviour/xml', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/behaviour', 'ace/mode/behaviour/cstyle', 'ace/token_iterator'], function(require, exports, module) {
1513
var oop = require("../../lib/oop");
1514
var Behaviour = require("../behaviour").Behaviour;
1515
var CstyleBehaviour = require("./cstyle").CstyleBehaviour;
1516
var TokenIterator = require("../../token_iterator").TokenIterator;
1518
function hasType(token, type) {
1520
var typeList = token.type.split('.');
1521
var needleList = type.split('.');
1522
needleList.forEach(function(needle){
1523
if (typeList.indexOf(needle) == -1) {
1531
var XmlBehaviour = function () {
1533
this.inherit(CstyleBehaviour, ["string_dquotes"]); // Get string behaviour
1535
this.add("autoclosing", "insertion", function (state, action, editor, session, text) {
1537
var position = editor.getCursorPosition();
1538
var iterator = new TokenIterator(session, position.row, position.column);
1539
var token = iterator.getCurrentToken();
1540
var atCursor = false;
1541
if (!token || !hasType(token, 'meta.tag') && !(hasType(token, 'text') && token.value.match('/'))){
1543
token = iterator.stepBackward();
1544
} while (token && (hasType(token, 'string') || hasType(token, 'keyword.operator') || hasType(token, 'entity.attribute-name') || hasType(token, 'text')));
1548
if (!token || !hasType(token, 'meta.tag-name') || iterator.stepBackward().value.match('/')) {
1551
var tag = token.value;
1553
var tag = tag.substring(0, position.column - token.start);
1557
text: '>' + '</' + tag + '>',
1563
this.add('autoindent', 'insertion', function (state, action, editor, session, text) {
1565
var cursor = editor.getCursorPosition();
1566
var line = session.doc.getLine(cursor.row);
1567
var rightChars = line.substring(cursor.column, cursor.column + 2);
1568
if (rightChars == '</') {
1569
var indent = this.$getIndent(session.doc.getLine(cursor.row)) + session.getTabString();
1570
var next_indent = this.$getIndent(session.doc.getLine(cursor.row));
1573
text: '\n' + indent + '\n' + next_indent,
1574
selection: [1, indent.length, 1, indent.length]
1581
oop.inherits(XmlBehaviour, Behaviour);
1583
exports.XmlBehaviour = XmlBehaviour;
1586
define('ace/mode/folding/html', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/folding/mixed', 'ace/mode/folding/xml', 'ace/mode/folding/cstyle'], function(require, exports, module) {
1589
var oop = require("../../lib/oop");
1590
var MixedFoldMode = require("./mixed").FoldMode;
1591
var XmlFoldMode = require("./xml").FoldMode;
1592
var CStyleFoldMode = require("./cstyle").FoldMode;
1594
var FoldMode = exports.FoldMode = function() {
1595
MixedFoldMode.call(this, new XmlFoldMode({
1624
"js-": new CStyleFoldMode(),
1625
"css-": new CStyleFoldMode()
1629
oop.inherits(FoldMode, MixedFoldMode);
1633
define('ace/mode/folding/mixed', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/folding/fold_mode'], function(require, exports, module) {
1636
var oop = require("../../lib/oop");
1637
var BaseFoldMode = require("./fold_mode").FoldMode;
1639
var FoldMode = exports.FoldMode = function(defaultMode, subModes) {
1640
this.defaultMode = defaultMode;
1641
this.subModes = subModes;
1643
oop.inherits(FoldMode, BaseFoldMode);
1648
this.$getMode = function(state) {
1649
for (var key in this.subModes) {
1650
if (state.indexOf(key) === 0)
1651
return this.subModes[key];
1656
this.$tryMode = function(state, session, foldStyle, row) {
1657
var mode = this.$getMode(state);
1658
return (mode ? mode.getFoldWidget(session, foldStyle, row) : "");
1661
this.getFoldWidget = function(session, foldStyle, row) {
1663
this.$tryMode(session.getState(row-1), session, foldStyle, row) ||
1664
this.$tryMode(session.getState(row), session, foldStyle, row) ||
1665
this.defaultMode.getFoldWidget(session, foldStyle, row)
1669
this.getFoldWidgetRange = function(session, foldStyle, row) {
1670
var mode = this.$getMode(session.getState(row-1));
1672
if (!mode || !mode.getFoldWidget(session, foldStyle, row))
1673
mode = this.$getMode(session.getState(row));
1675
if (!mode || !mode.getFoldWidget(session, foldStyle, row))
1676
mode = this.defaultMode;
1678
return mode.getFoldWidgetRange(session, foldStyle, row);
1681
}).call(FoldMode.prototype);
1685
define('ace/mode/folding/xml', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/lib/lang', 'ace/range', 'ace/mode/folding/fold_mode', 'ace/token_iterator'], function(require, exports, module) {
1688
var oop = require("../../lib/oop");
1689
var lang = require("../../lib/lang");
1690
var Range = require("../../range").Range;
1691
var BaseFoldMode = require("./fold_mode").FoldMode;
1692
var TokenIterator = require("../../token_iterator").TokenIterator;
1694
var FoldMode = exports.FoldMode = function(voidElements) {
1695
BaseFoldMode.call(this);
1696
this.voidElements = voidElements || {};
1698
oop.inherits(FoldMode, BaseFoldMode);
1702
this.getFoldWidget = function(session, foldStyle, row) {
1703
var tag = this._getFirstTagInLine(session, row);
1706
return foldStyle == "markbeginend" ? "end" : "";
1708
if (!tag.tagName || this.voidElements[tag.tagName.toLowerCase()])
1711
if (tag.selfClosing)
1714
if (tag.value.indexOf("/" + tag.tagName) !== -1)
1720
this._getFirstTagInLine = function(session, row) {
1721
var tokens = session.getTokens(row);
1723
for (var i = 0; i < tokens.length; i++) {
1724
var token = tokens[i];
1725
if (token.type.indexOf("meta.tag") === 0)
1726
value += token.value;
1728
value += lang.stringRepeat(" ", token.value.length);
1731
return this._parseTag(value);
1734
this.tagRe = /^(\s*)(<?(\/?)([-_a-zA-Z0-9:!]*)\s*(\/?)>?)/;
1735
this._parseTag = function(tag) {
1737
var match = this.tagRe.exec(tag);
1738
var column = this.tagRe.lastIndex || 0;
1739
this.tagRe.lastIndex = 0;
1743
match: match ? match[2] : "",
1744
closing: match ? !!match[3] : false,
1745
selfClosing: match ? !!match[5] || match[2] == "/>" : false,
1746
tagName: match ? match[4] : "",
1747
column: match[1] ? column + match[1].length : column
1750
this._readTagForward = function(iterator) {
1751
var token = iterator.getCurrentToken();
1759
if (token.type.indexOf("meta.tag") === 0) {
1762
row: iterator.getCurrentTokenRow(),
1763
column: iterator.getCurrentTokenColumn()
1766
value += token.value;
1767
if (value.indexOf(">") !== -1) {
1768
var tag = this._parseTag(value);
1771
row: iterator.getCurrentTokenRow(),
1772
column: iterator.getCurrentTokenColumn() + token.value.length
1774
iterator.stepForward();
1778
} while(token = iterator.stepForward());
1783
this._readTagBackward = function(iterator) {
1784
var token = iterator.getCurrentToken();
1792
if (token.type.indexOf("meta.tag") === 0) {
1795
row: iterator.getCurrentTokenRow(),
1796
column: iterator.getCurrentTokenColumn() + token.value.length
1799
value = token.value + value;
1800
if (value.indexOf("<") !== -1) {
1801
var tag = this._parseTag(value);
1804
row: iterator.getCurrentTokenRow(),
1805
column: iterator.getCurrentTokenColumn()
1807
iterator.stepBackward();
1811
} while(token = iterator.stepBackward());
1816
this._pop = function(stack, tag) {
1817
while (stack.length) {
1819
var top = stack[stack.length-1];
1820
if (!tag || top.tagName == tag.tagName) {
1823
else if (this.voidElements[tag.tagName]) {
1826
else if (this.voidElements[top.tagName]) {
1835
this.getFoldWidgetRange = function(session, foldStyle, row) {
1836
var firstTag = this._getFirstTagInLine(session, row);
1838
if (!firstTag.match)
1841
var isBackward = firstTag.closing || firstTag.selfClosing;
1846
var iterator = new TokenIterator(session, row, firstTag.column);
1849
column: firstTag.column + firstTag.tagName.length + 2
1851
while (tag = this._readTagForward(iterator)) {
1852
if (tag.selfClosing) {
1853
if (!stack.length) {
1854
tag.start.column += tag.tagName.length + 2;
1855
tag.end.column -= 2;
1856
return Range.fromPoints(tag.start, tag.end);
1862
this._pop(stack, tag);
1863
if (stack.length == 0)
1864
return Range.fromPoints(start, tag.start);
1872
var iterator = new TokenIterator(session, row, firstTag.column + firstTag.match.length);
1875
column: firstTag.column
1878
while (tag = this._readTagBackward(iterator)) {
1879
if (tag.selfClosing) {
1880
if (!stack.length) {
1881
tag.start.column += tag.tagName.length + 2;
1882
tag.end.column -= 2;
1883
return Range.fromPoints(tag.start, tag.end);
1889
this._pop(stack, tag);
1890
if (stack.length == 0) {
1891
tag.start.column += tag.tagName.length + 2;
1892
return Range.fromPoints(tag.start, end);
1903
}).call(FoldMode.prototype);
1906
define('ace/mode/rhtml_highlight_rules', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/r_highlight_rules', 'ace/mode/html_highlight_rules', 'ace/mode/text_highlight_rules'], function(require, exports, module) {
1909
var oop = require("../lib/oop");
1910
var RHighlightRules = require("./r_highlight_rules").RHighlightRules;
1911
var HtmlHighlightRules = require("./html_highlight_rules").HtmlHighlightRules;
1912
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
1914
var RHtmlHighlightRules = function() {
1916
this.$rules = new HtmlHighlightRules().getRules();
1917
this.$rules["start"].unshift({
1918
token: "support.function.codebegin",
1919
regex: "^<" + "!--\\s*begin.rcode\\s*(?:.*)",
1923
var rRules = new RHighlightRules().getRules();
1924
this.addRules(rRules, "r-");
1925
this.$rules["r-start"].unshift({
1926
token: "support.function.codeend",
1927
regex: "^\\s*end.rcode\\s*-->",
1931
oop.inherits(RHtmlHighlightRules, TextHighlightRules);
1933
exports.RHtmlHighlightRules = RHtmlHighlightRules;
1935
define('ace/mode/r_highlight_rules', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/lib/lang', 'ace/mode/text_highlight_rules', 'ace/mode/tex_highlight_rules'], function(require, exports, module) {
1937
var oop = require("../lib/oop");
1938
var lang = require("../lib/lang");
1939
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
1940
var TexHighlightRules = require("./tex_highlight_rules").TexHighlightRules;
1942
var RHighlightRules = function()
1945
var keywords = lang.arrayToMap(
1946
("function|if|in|break|next|repeat|else|for|return|switch|while|try|tryCatch|stop|warning|require|library|attach|detach|source|setMethod|setGeneric|setGroupGeneric|setClass")
1950
var buildinConstants = lang.arrayToMap(
1951
("NULL|NA|TRUE|FALSE|T|F|Inf|NaN|NA_integer_|NA_real_|NA_character_|" +
1952
"NA_complex_").split("|")
1958
token : "comment.sectionhead",
1959
regex : "#+(?!').*(?:----|====|####)\\s*$"
1971
token : "string", // multi line string start
1976
token : "string", // multi line string start
1981
token : "constant.numeric", // hex
1982
regex : "0[xX][0-9a-fA-F]+[Li]?\\b"
1985
token : "constant.numeric", // explicit integer
1989
token : "constant.numeric", // number
1990
regex : "\\d+(?:\\.\\d*)?(?:[eE][+\\-]?\\d*)?i?\\b"
1993
token : "constant.numeric", // number with leading decimal
1994
regex : "\\.\\d+(?:[eE][+\\-]?\\d*)?i?\\b"
1997
token : "constant.language.boolean",
1998
regex : "(?:TRUE|FALSE|T|F)\\b"
2001
token : "identifier",
2005
onMatch : function(value) {
2006
if (keywords[value])
2008
else if (buildinConstants[value])
2009
return "constant.language";
2010
else if (value == '...' || value.match(/^\.\.\d+$/))
2011
return "variable.language";
2013
return "identifier";
2015
regex : "[a-zA-Z.][a-zA-Z0-9._]*\\b"
2018
token : "keyword.operator",
2019
regex : "%%|>=|<=|==|!=|\\->|<\\-|\\|\\||&&|=|\\+|\\-|\\*|/|\\^|>|<|!|&|\\||~|\\$|:"
2022
token : "keyword.operator", // infix operators
2026
token : "paren.keyword.operator",
2030
token : "paren.keyword.operator",
2041
regex : '(?:(?:\\\\.)|(?:[^"\\\\]))*?"',
2052
regex : "(?:(?:\\\\.)|(?:[^'\\\\]))*?'",
2062
var rdRules = new TexHighlightRules("comment").getRules();
2063
for (var i = 0; i < rdRules["start"].length; i++) {
2064
rdRules["start"][i].token += ".virtual-comment";
2067
this.addRules(rdRules, "rd-");
2068
this.$rules["rd-start"].unshift({
2073
this.$rules["rd-start"].unshift({
2075
regex : "@(?!@)[^ ]*"
2077
this.$rules["rd-start"].unshift({
2081
this.$rules["rd-start"].push({
2083
regex : "[^%\\\\[({\\])}]+"
2087
oop.inherits(RHighlightRules, TextHighlightRules);
2089
exports.RHighlightRules = RHighlightRules;
2091
define('ace/mode/tex_highlight_rules', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/lib/lang', 'ace/mode/text_highlight_rules'], function(require, exports, module) {
2094
var oop = require("../lib/oop");
2095
var lang = require("../lib/lang");
2096
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
2098
var TexHighlightRules = function(textClass) {
2109
token : textClass, // non-command
2110
regex : "\\\\[$&%#\\{\\}]"
2112
token : "keyword", // command
2113
regex : "\\\\(?:documentclass|usepackage|newcounter|setcounter|addtocounter|value|arabic|stepcounter|newenvironment|renewenvironment|ref|vref|eqref|pageref|label|cite[a-zA-Z]*|tag|begin|end|bibitem)\\b",
2116
token : "keyword", // command
2117
regex : "\\\\(?:[a-zA-z0-9]+|[^a-zA-z0-9])"
2119
token : "paren.keyword.operator",
2122
token : "paren.keyword.operator",
2135
token : "nospell." + textClass, // non-command
2136
regex : "\\\\[$&%#\\{\\}]"
2138
token : "keyword", // command
2139
regex : "\\\\(?:documentclass|usepackage|newcounter|setcounter|addtocounter|value|arabic|stepcounter|newenvironment|renewenvironment|ref|vref|eqref|pageref|label|cite[a-zA-Z]*|tag|begin|end|bibitem)\\b"
2141
token : "keyword", // command
2142
regex : "\\\\(?:[a-zA-z0-9]+|[^a-zA-z0-9])",
2145
token : "paren.keyword.operator",
2148
token : "paren.keyword.operator",
2151
token : "paren.keyword.operator",
2155
token : "nospell." + textClass,
2158
token : "nospell." + textClass,
2165
oop.inherits(TexHighlightRules, TextHighlightRules);
2167
exports.TexHighlightRules = TexHighlightRules;