mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
189 lines
5.9 KiB
JavaScript
189 lines
5.9 KiB
JavaScript
|
/*
|
||
|
* r_highlight_rules.js
|
||
|
*
|
||
|
* Copyright (C) 2009-11 by RStudio, Inc.
|
||
|
*
|
||
|
* The Initial Developer of the Original Code is
|
||
|
* Ajax.org B.V.
|
||
|
* Portions created by the Initial Developer are Copyright (C) 2010
|
||
|
* the Initial Developer. All Rights Reserved.
|
||
|
*
|
||
|
* This program is licensed to you under the terms of version 3 of the
|
||
|
* GNU Affero General Public License. This program is distributed WITHOUT
|
||
|
* ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,
|
||
|
* MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the
|
||
|
* AGPL (http://www.gnu.org/licenses/agpl-3.0.txt) for more details.
|
||
|
*
|
||
|
*/
|
||
|
define(function(require, exports, module)
|
||
|
{
|
||
|
|
||
|
var oop = require("../lib/oop");
|
||
|
var lang = require("../lib/lang");
|
||
|
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
|
||
|
var TexHighlightRules = require("./tex_highlight_rules").TexHighlightRules;
|
||
|
|
||
|
var RHighlightRules = function()
|
||
|
{
|
||
|
|
||
|
var keywords = lang.arrayToMap(
|
||
|
("function|if|in|break|next|repeat|else|for|return|switch|while|try|tryCatch|stop|warning|require|library|attach|detach|source|setMethod|setGeneric|setGroupGeneric|setClass")
|
||
|
.split("|")
|
||
|
);
|
||
|
|
||
|
var buildinConstants = lang.arrayToMap(
|
||
|
("NULL|NA|TRUE|FALSE|T|F|Inf|NaN|NA_integer_|NA_real_|NA_character_|" +
|
||
|
"NA_complex_").split("|")
|
||
|
);
|
||
|
|
||
|
// regexp must not have capturing parentheses. Use (?:) instead.
|
||
|
// regexps are ordered -> the first match is used
|
||
|
|
||
|
this.$rules = {
|
||
|
"start" : [
|
||
|
{
|
||
|
// Roxygen
|
||
|
token : "comment.sectionhead",
|
||
|
regex : "#+(?!').*(?:----|====|####)\\s*$"
|
||
|
},
|
||
|
{
|
||
|
// Roxygen
|
||
|
token : "comment",
|
||
|
regex : "#+'",
|
||
|
next : "rd-start"
|
||
|
},
|
||
|
{
|
||
|
token : "comment",
|
||
|
regex : "#.*$"
|
||
|
},
|
||
|
{
|
||
|
token : "string", // multi line string start
|
||
|
regex : '["]',
|
||
|
next : "qqstring"
|
||
|
},
|
||
|
{
|
||
|
token : "string", // multi line string start
|
||
|
regex : "[']",
|
||
|
next : "qstring"
|
||
|
},
|
||
|
{
|
||
|
token : "constant.numeric", // hex
|
||
|
regex : "0[xX][0-9a-fA-F]+[Li]?\\b"
|
||
|
},
|
||
|
{
|
||
|
token : "constant.numeric", // explicit integer
|
||
|
regex : "\\d+L\\b"
|
||
|
},
|
||
|
{
|
||
|
token : "constant.numeric", // number
|
||
|
regex : "\\d+(?:\\.\\d*)?(?:[eE][+\\-]?\\d*)?i?\\b"
|
||
|
},
|
||
|
{
|
||
|
token : "constant.numeric", // number with leading decimal
|
||
|
regex : "\\.\\d+(?:[eE][+\\-]?\\d*)?i?\\b"
|
||
|
},
|
||
|
{
|
||
|
token : "constant.language.boolean",
|
||
|
regex : "(?:TRUE|FALSE|T|F)\\b"
|
||
|
},
|
||
|
{
|
||
|
token : "identifier",
|
||
|
regex : "`.*?`"
|
||
|
},
|
||
|
{
|
||
|
onMatch : function(value) {
|
||
|
if (keywords[value])
|
||
|
return "keyword";
|
||
|
else if (buildinConstants[value])
|
||
|
return "constant.language";
|
||
|
else if (value == '...' || value.match(/^\.\.\d+$/))
|
||
|
return "variable.language";
|
||
|
else
|
||
|
return "identifier";
|
||
|
},
|
||
|
regex : "[a-zA-Z.][a-zA-Z0-9._]*\\b"
|
||
|
},
|
||
|
{
|
||
|
token : "keyword.operator",
|
||
|
regex : "%%|>=|<=|==|!=|\\->|<\\-|\\|\\||&&|=|\\+|\\-|\\*|/|\\^|>|<|!|&|\\||~|\\$|:"
|
||
|
},
|
||
|
{
|
||
|
token : "keyword.operator", // infix operators
|
||
|
regex : "%.*?%"
|
||
|
},
|
||
|
{
|
||
|
// Obviously these are neither keywords nor operators, but
|
||
|
// labelling them as such was the easiest way to get them
|
||
|
// to be colored distinctly from regular text
|
||
|
token : "paren.keyword.operator",
|
||
|
regex : "[[({]"
|
||
|
},
|
||
|
{
|
||
|
// Obviously these are neither keywords nor operators, but
|
||
|
// labelling them as such was the easiest way to get them
|
||
|
// to be colored distinctly from regular text
|
||
|
token : "paren.keyword.operator",
|
||
|
regex : "[\\])}]"
|
||
|
},
|
||
|
{
|
||
|
token : "text",
|
||
|
regex : "\\s+"
|
||
|
}
|
||
|
],
|
||
|
"qqstring" : [
|
||
|
{
|
||
|
token : "string",
|
||
|
regex : '(?:(?:\\\\.)|(?:[^"\\\\]))*?"',
|
||
|
next : "start"
|
||
|
},
|
||
|
{
|
||
|
token : "string",
|
||
|
regex : '.+'
|
||
|
}
|
||
|
],
|
||
|
"qstring" : [
|
||
|
{
|
||
|
token : "string",
|
||
|
regex : "(?:(?:\\\\.)|(?:[^'\\\\]))*?'",
|
||
|
next : "start"
|
||
|
},
|
||
|
{
|
||
|
token : "string",
|
||
|
regex : '.+'
|
||
|
}
|
||
|
]
|
||
|
};
|
||
|
|
||
|
var rdRules = new TexHighlightRules("comment").getRules();
|
||
|
|
||
|
// Make all embedded TeX virtual-comment so they don't interfere with
|
||
|
// auto-indent.
|
||
|
for (var i = 0; i < rdRules["start"].length; i++) {
|
||
|
rdRules["start"][i].token += ".virtual-comment";
|
||
|
}
|
||
|
|
||
|
this.addRules(rdRules, "rd-");
|
||
|
this.$rules["rd-start"].unshift({
|
||
|
token: "text",
|
||
|
regex: "^",
|
||
|
next: "start"
|
||
|
});
|
||
|
this.$rules["rd-start"].unshift({
|
||
|
token : "keyword",
|
||
|
regex : "@(?!@)[^ ]*"
|
||
|
});
|
||
|
this.$rules["rd-start"].unshift({
|
||
|
token : "comment",
|
||
|
regex : "@@"
|
||
|
});
|
||
|
this.$rules["rd-start"].push({
|
||
|
token : "comment",
|
||
|
regex : "[^%\\\\[({\\])}]+"
|
||
|
});
|
||
|
};
|
||
|
|
||
|
oop.inherits(RHighlightRules, TextHighlightRules);
|
||
|
|
||
|
exports.RHighlightRules = RHighlightRules;
|
||
|
});
|