ace.define("ace/mode/bibtex_highlight_rules",["require","exports","module","ace/lib/oop","ace/mode/text_highlight_rules"], function(require, exports, module){"use strict"; var oop = require("../lib/oop"); var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules; var BibTeXHighlightRules = function () { this.$rules = { start: [ { token: "comment", regex: /@Comment\{/, stateName: "bibtexComment", push: [ { token: "comment", regex: /}/, next: "pop" }, { token: "comment", regex: /\{/, push: "bibtexComment" }, { defaultToken: "comment" } ] }, { token: [ "keyword", "text", "paren.lparen", "text", "variable", "text", "keyword.operator" ], regex: /(@String)(\s*)(\{)(\s*)([a-zA-Z]*)(\s*)(=)/, push: [ { token: "paren.rparen", regex: /\}/, next: "pop" }, { include: "#misc" }, { defaultToken: "text" } ] }, { token: [ "keyword", "text", "paren.lparen", "text", "variable", "text", "keyword.operator" ], regex: /(@String)(\s*)(\()(\s*)([a-zA-Z]*)(\s*)(=)/, push: [ { token: "paren.rparen", regex: /\)/, next: "pop" }, { include: "#misc" }, { defaultToken: "text" } ] }, { token: [ "keyword", "text", "paren.lparen" ], regex: /(@preamble)(\s*)(\()/, push: [ { token: "paren.rparen", regex: /\)/, next: "pop" }, { include: "#misc" }, { defaultToken: "text" } ] }, { token: [ "keyword", "text", "paren.lparen" ], regex: /(@preamble)(\s*)(\{)/, push: [ { token: "paren.rparen", regex: /\}/, next: "pop" }, { include: "#misc" }, { defaultToken: "text" } ] }, { token: [ "keyword", "text", "paren.lparen", "text", "support.class" ], regex: /(@[a-zA-Z]+)(\s*)(\{)(\s*)([\w-]+)/, push: [ { token: "paren.rparen", regex: /\}/, next: "pop" }, { token: [ "variable", "text", "keyword.operator" ], regex: /([a-zA-Z0-9\!\$\&\*\+\-\.\/\:\;\<\>\?\[\]\^\_\`\|]+)(\s*)(=)/, push: [ { token: "text", regex: /(?=[,}])/, next: "pop" }, { include: "#misc" }, { include: "#integer" }, { defaultToken: "text" } ] }, { token: "punctuation", regex: /,/ }, { defaultToken: "text" } ] }, { defaultToken: "comment" } ], "#integer": [ { token: "constant.numeric.bibtex", regex: /\d+/ } ], "#misc": [ { token: "string", regex: /"/, push: "#string_quotes" }, { token: "paren.lparen", regex: /\{/, push: "#string_braces" }, { token: "keyword.operator", regex: /#/ } ], "#string_braces": [ { token: "paren.rparen", regex: /\}/, next: "pop" }, { token: "invalid.illegal", regex: /@/ }, { include: "#misc" }, { defaultToken: "string" } ], "#string_quotes": [ { token: "string", regex: /"/, next: "pop" }, { include: "#misc" }, { defaultToken: "string" } ] }; this.normalizeRules(); }; oop.inherits(BibTeXHighlightRules, TextHighlightRules); exports.BibTeXHighlightRules = BibTeXHighlightRules; }); ace.define("ace/mode/folding/cstyle",["require","exports","module","ace/lib/oop","ace/range","ace/mode/folding/fold_mode"], function(require, exports, module){"use strict"; var oop = require("../../lib/oop"); var Range = require("../../range").Range; var BaseFoldMode = require("./fold_mode").FoldMode; var FoldMode = exports.FoldMode = function (commentRegex) { if (commentRegex) { this.foldingStartMarker = new RegExp(this.foldingStartMarker.source.replace(/\|[^|]*?$/, "|" + commentRegex.start)); this.foldingStopMarker = new RegExp(this.foldingStopMarker.source.replace(/\|[^|]*?$/, "|" + commentRegex.end)); } }; oop.inherits(FoldMode, BaseFoldMode); (function () { this.foldingStartMarker = /([\{\[\(])[^\}\]\)]*$|^\s*(\/\*)/; this.foldingStopMarker = /^[^\[\{\(]*([\}\]\)])|^[\s\*]*(\*\/)/; this.singleLineBlockCommentRe = /^\s*(\/\*).*\*\/\s*$/; this.tripleStarBlockCommentRe = /^\s*(\/\*\*\*).*\*\/\s*$/; this.startRegionRe = /^\s*(\/\*|\/\/)#?region\b/; this._getFoldWidgetBase = this.getFoldWidget; this.getFoldWidget = function (session, foldStyle, row) { var line = session.getLine(row); if (this.singleLineBlockCommentRe.test(line)) { if (!this.startRegionRe.test(line) && !this.tripleStarBlockCommentRe.test(line)) return ""; } var fw = this._getFoldWidgetBase(session, foldStyle, row); if (!fw && this.startRegionRe.test(line)) return "start"; // lineCommentRegionStart return fw; }; this.getFoldWidgetRange = function (session, foldStyle, row, forceMultiline) { var line = session.getLine(row); if (this.startRegionRe.test(line)) return this.getCommentRegionBlock(session, line, row); var match = line.match(this.foldingStartMarker); if (match) { var i = match.index; if (match[1]) return this.openingBracketBlock(session, match[1], row, i); var range = session.getCommentFoldRange(row, i + match[0].length, 1); if (range && !range.isMultiLine()) { if (forceMultiline) { range = this.getSectionRange(session, row); } else if (foldStyle != "all") range = null; } return range; } if (foldStyle === "markbegin") return; var match = line.match(this.foldingStopMarker); if (match) { var i = match.index + match[0].length; if (match[1]) return this.closingBracketBlock(session, match[1], row, i); return session.getCommentFoldRange(row, i, -1); } }; this.getSectionRange = function (session, row) { var line = session.getLine(row); var startIndent = line.search(/\S/); var startRow = row; var startColumn = line.length; row = row + 1; var endRow = row; var maxRow = session.getLength(); while (++row < maxRow) { line = session.getLine(row); var indent = line.search(/\S/); if (indent === -1) continue; if (startIndent > indent) break; var subRange = this.getFoldWidgetRange(session, "all", row); if (subRange) { if (subRange.start.row <= startRow) { break; } else if (subRange.isMultiLine()) { row = subRange.end.row; } else if (startIndent == indent) { break; } } endRow = row; } return new Range(startRow, startColumn, endRow, session.getLine(endRow).length); }; this.getCommentRegionBlock = function (session, line, row) { var startColumn = line.search(/\s*$/); var maxRow = session.getLength(); var startRow = row; var re = /^\s*(?:\/\*|\/\/|--)#?(end)?region\b/; var depth = 1; while (++row < maxRow) { line = session.getLine(row); var m = re.exec(line); if (!m) continue; if (m[1]) depth--; else depth++; if (!depth) break; } var endRow = row; if (endRow > startRow) { return new Range(startRow, startColumn, endRow, line.length); } }; }).call(FoldMode.prototype); }); ace.define("ace/mode/bibtex",["require","exports","module","ace/lib/oop","ace/mode/text","ace/mode/bibtex_highlight_rules","ace/mode/folding/cstyle"], function(require, exports, module){"use strict"; var oop = require("../lib/oop"); var TextMode = require("./text").Mode; var BibTeXHighlightRules = require("./bibtex_highlight_rules").BibTeXHighlightRules; var FoldMode = require("./folding/cstyle").FoldMode; var Mode = function () { this.HighlightRules = BibTeXHighlightRules; this.foldingRules = new FoldMode(); }; oop.inherits(Mode, TextMode); (function () { this.$id = "ace/mode/bibtex"; }).call(Mode.prototype); exports.Mode = Mode; }); (function() { ace.require(["ace/mode/bibtex"], function(m) { if (typeof module == "object" && typeof exports == "object" && module) { module.exports = m; } }); })();