2013-11-12 18:10:47 +00:00
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Distributed under the BSD license:
|
|
|
|
*
|
|
|
|
* Copyright (c) 2012, Ajax.org B.V.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions are met:
|
|
|
|
* * Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* * Neither the name of Ajax.org B.V. nor the
|
|
|
|
* names of its contributors may be used to endorse or promote products
|
|
|
|
* derived from this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
* DISCLAIMED. IN NO EVENT SHALL AJAX.ORG B.V. BE LIABLE FOR ANY
|
|
|
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
|
|
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
|
|
ace.define('ace/mode/prolog', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/text', 'ace/tokenizer', 'ace/mode/prolog_highlight_rules', 'ace/mode/folding/cstyle'], function(require, exports, module) {
|
|
|
|
|
|
|
|
|
|
|
|
var oop = require("../lib/oop");
|
|
|
|
var TextMode = require("./text").Mode;
|
|
|
|
var Tokenizer = require("../tokenizer").Tokenizer;
|
|
|
|
var PrologHighlightRules = require("./prolog_highlight_rules").PrologHighlightRules;
|
|
|
|
var FoldMode = require("./folding/cstyle").FoldMode;
|
|
|
|
|
|
|
|
var Mode = function() {
|
|
|
|
this.HighlightRules = PrologHighlightRules;
|
|
|
|
this.foldingRules = new FoldMode();
|
|
|
|
};
|
|
|
|
oop.inherits(Mode, TextMode);
|
|
|
|
|
|
|
|
(function() {
|
|
|
|
this.lineCommentStart = "/\\*";
|
|
|
|
this.blockComment = {start: "/*", end: "*/"};
|
|
|
|
}).call(Mode.prototype);
|
|
|
|
|
|
|
|
exports.Mode = Mode;
|
|
|
|
});
|
|
|
|
|
|
|
|
ace.define('ace/mode/prolog_highlight_rules', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/text_highlight_rules'], function(require, exports, module) {
|
|
|
|
|
|
|
|
|
|
|
|
var oop = require("../lib/oop");
|
|
|
|
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
|
|
|
|
|
|
|
|
var PrologHighlightRules = function() {
|
|
|
|
|
|
|
|
this.$rules = { start:
|
|
|
|
[ { include: '#comment' },
|
|
|
|
{ include: '#basic_fact' },
|
|
|
|
{ include: '#rule' },
|
|
|
|
{ include: '#directive' },
|
|
|
|
{ include: '#fact' } ],
|
|
|
|
'#atom':
|
|
|
|
[ { token: 'constant.other.atom.prolog',
|
|
|
|
regex: '\\b[a-z][a-zA-Z0-9_]*\\b' },
|
|
|
|
{ token: 'constant.numeric.prolog',
|
|
|
|
regex: '-?\\d+(?:\\.\\d+)?' },
|
|
|
|
{ include: '#string' } ],
|
|
|
|
'#basic_elem':
|
|
|
|
[ { include: '#comment' },
|
|
|
|
{ include: '#statement' },
|
|
|
|
{ include: '#constants' },
|
|
|
|
{ include: '#operators' },
|
|
|
|
{ include: '#builtins' },
|
|
|
|
{ include: '#list' },
|
|
|
|
{ include: '#atom' },
|
|
|
|
{ include: '#variable' } ],
|
|
|
|
'#basic_fact':
|
|
|
|
[ { token:
|
|
|
|
[ 'entity.name.function.fact.basic.prolog',
|
|
|
|
'punctuation.end.fact.basic.prolog' ],
|
|
|
|
regex: '([a-z]\\w*)(\\.)' } ],
|
|
|
|
'#builtins':
|
|
|
|
[ { token: 'support.function.builtin.prolog',
|
|
|
|
regex: '\\b(?:\n\t\t\t\t\t\tabolish|abort|ancestors|arg|ascii|assert[az]|\n\t\t\t\t\t\tatom(?:ic)?|body|char|close|conc|concat|consult|\n\t\t\t\t\t\tdefine|definition|dynamic|dump|fail|file|free|\n\t\t\t\t\t\tfree_proc|functor|getc|goal|halt|head|head|integer|\n\t\t\t\t\t\tlength|listing|match_args|member|next_clause|nl|\n\t\t\t\t\t\tnonvar|nth|number|cvars|nvars|offset|op|\n\t\t\t\t\t\tprint?|prompt|putc|quoted|ratom|read|redefine|\n\t\t\t\t\t\trename|retract(?:all)?|see|seeing|seen|skip|spy|\n\t\t\t\t\t\tstatistics|system|tab|tell|telling|term|\n\t\t\t\t\t\ttime|told|univ|unlink_clause|unspy_predicate|\n\t\t\t\t\t\tvar|write\n\t\t\t\t\t)\\b' } ],
|
|
|
|
'#comment':
|
|
|
|
[ { token:
|
|
|
|
[ 'punctuation.definition.comment.prolog',
|
|
|
|
'comment.line.percentage.prolog' ],
|
|
|
|
regex: '(%)(.*$)' },
|
|
|
|
{ token: 'punctuation.definition.comment.prolog',
|
|
|
|
regex: '/\\*',
|
|
|
|
push:
|
|
|
|
[ { token: 'punctuation.definition.comment.prolog',
|
|
|
|
regex: '\\*/',
|
|
|
|
next: 'pop' },
|
|
|
|
{ defaultToken: 'comment.block.prolog' } ] } ],
|
|
|
|
'#constants':
|
|
|
|
[ { token: 'constant.language.prolog',
|
|
|
|
regex: '\\b(?:true|false|yes|no)\\b' } ],
|
|
|
|
'#directive':
|
|
|
|
[ { token: 'keyword.operator.directive.prolog',
|
|
|
|
regex: ':-',
|
|
|
|
push:
|
|
|
|
[ { token: 'meta.directive.prolog', regex: '\\.', next: 'pop' },
|
|
|
|
{ include: '#comment' },
|
|
|
|
{ include: '#statement' },
|
|
|
|
{ defaultToken: 'meta.directive.prolog' } ] } ],
|
|
|
|
'#expr':
|
|
|
|
[ { include: '#comments' },
|
|
|
|
{ token: 'meta.expression.prolog',
|
|
|
|
regex: '\\(',
|
|
|
|
push:
|
|
|
|
[ { token: 'meta.expression.prolog', regex: '\\)', next: 'pop' },
|
|
|
|
{ include: '#expr' },
|
|
|
|
{ defaultToken: 'meta.expression.prolog' } ] },
|
|
|
|
{ token: 'keyword.control.cutoff.prolog', regex: '!' },
|
|
|
|
{ token: 'punctuation.control.and.prolog', regex: ',' },
|
|
|
|
{ token: 'punctuation.control.or.prolog', regex: ';' },
|
|
|
|
{ include: '#basic_elem' } ],
|
|
|
|
'#fact':
|
|
|
|
[ { token:
|
|
|
|
[ 'entity.name.function.fact.prolog',
|
|
|
|
'punctuation.begin.fact.parameters.prolog' ],
|
|
|
|
regex: '([a-z]\\w*)(\\()(?!.*:-)',
|
|
|
|
push:
|
|
|
|
[ { token:
|
|
|
|
[ 'punctuation.end.fact.parameters.prolog',
|
|
|
|
'punctuation.end.fact.prolog' ],
|
|
|
|
regex: '(\\))(\\.)',
|
|
|
|
next: 'pop' },
|
|
|
|
{ include: '#parameter' },
|
|
|
|
{ defaultToken: 'meta.fact.prolog' } ] } ],
|
|
|
|
'#list':
|
|
|
|
[ { token: 'punctuation.begin.list.prolog',
|
|
|
|
regex: '\\[(?=.*\\])',
|
|
|
|
push:
|
|
|
|
[ { token: 'punctuation.end.list.prolog',
|
|
|
|
regex: '\\]',
|
|
|
|
next: 'pop' },
|
|
|
|
{ include: '#comment' },
|
|
|
|
{ token: 'punctuation.separator.list.prolog', regex: ',' },
|
|
|
|
{ token: 'punctuation.concat.list.prolog',
|
|
|
|
regex: '\\|',
|
|
|
|
push:
|
|
|
|
[ { token: 'meta.list.concat.prolog',
|
|
|
|
regex: '(?=\\s*\\])',
|
|
|
|
next: 'pop' },
|
|
|
|
{ include: '#basic_elem' },
|
|
|
|
{ defaultToken: 'meta.list.concat.prolog' } ] },
|
|
|
|
{ include: '#basic_elem' },
|
|
|
|
{ defaultToken: 'meta.list.prolog' } ] } ],
|
|
|
|
'#operators':
|
|
|
|
[ { token: 'keyword.operator.prolog',
|
|
|
|
regex: '\\\\\\+|\\bnot\\b|\\bis\\b|->|[><]|[><\\\\:=]?=|(?:=\\\\|\\\\=)=' } ],
|
|
|
|
'#parameter':
|
|
|
|
[ { token: 'variable.language.anonymous.prolog',
|
|
|
|
regex: '\\b_\\b' },
|
|
|
|
{ token: 'variable.parameter.prolog',
|
|
|
|
regex: '\\b[A-Z_]\\w*\\b' },
|
|
|
|
{ token: 'punctuation.separator.parameters.prolog', regex: ',' },
|
|
|
|
{ include: '#basic_elem' },
|
|
|
|
{ token: 'invalid.illegal.invalidchar.prolog', regex: '[^\\s]' } ],
|
|
|
|
'#rule':
|
|
|
|
[ { token: 'meta.rule.prolog',
|
|
|
|
regex: '(?=[a-z]\\w*.*:-)',
|
|
|
|
push:
|
|
|
|
[ { token: 'punctuation.rule.end.prolog',
|
|
|
|
regex: '\\.',
|
|
|
|
next: 'pop' },
|
|
|
|
{ token: 'meta.rule.signature.prolog',
|
|
|
|
regex: '(?=[a-z]\\w*.*:-)',
|
|
|
|
push:
|
|
|
|
[ { token: 'meta.rule.signature.prolog',
|
|
|
|
regex: '(?=:-)',
|
|
|
|
next: 'pop' },
|
|
|
|
{ token: 'entity.name.function.rule.prolog',
|
|
|
|
regex: '[a-z]\\w*(?=\\(|\\s*:-)' },
|
|
|
|
{ token: 'punctuation.rule.parameters.begin.prolog',
|
|
|
|
regex: '\\(',
|
|
|
|
push:
|
|
|
|
[ { token: 'punctuation.rule.parameters.end.prolog',
|
|
|
|
regex: '\\)',
|
|
|
|
next: 'pop' },
|
|
|
|
{ include: '#parameter' },
|
|
|
|
{ defaultToken: 'meta.rule.parameters.prolog' } ] },
|
|
|
|
{ defaultToken: 'meta.rule.signature.prolog' } ] },
|
|
|
|
{ token: 'keyword.operator.definition.prolog',
|
|
|
|
regex: ':-',
|
|
|
|
push:
|
|
|
|
[ { token: 'meta.rule.definition.prolog',
|
|
|
|
regex: '(?=\\.)',
|
|
|
|
next: 'pop' },
|
|
|
|
{ include: '#comment' },
|
|
|
|
{ include: '#expr' },
|
|
|
|
{ defaultToken: 'meta.rule.definition.prolog' } ] },
|
|
|
|
{ defaultToken: 'meta.rule.prolog' } ] } ],
|
|
|
|
'#statement':
|
|
|
|
[ { token: 'meta.statement.prolog',
|
|
|
|
regex: '(?=[a-z]\\w*\\()',
|
|
|
|
push:
|
|
|
|
[ { token: 'punctuation.end.statement.parameters.prolog',
|
|
|
|
regex: '\\)',
|
|
|
|
next: 'pop' },
|
|
|
|
{ include: '#builtins' },
|
|
|
|
{ include: '#atom' },
|
|
|
|
{ token: 'punctuation.begin.statement.parameters.prolog',
|
|
|
|
regex: '\\(',
|
|
|
|
push:
|
|
|
|
[ { token: 'meta.statement.parameters.prolog',
|
|
|
|
regex: '(?=\\))',
|
|
|
|
next: 'pop' },
|
|
|
|
{ token: 'punctuation.separator.statement.prolog', regex: ',' },
|
|
|
|
{ include: '#basic_elem' },
|
|
|
|
{ defaultToken: 'meta.statement.parameters.prolog' } ] },
|
|
|
|
{ defaultToken: 'meta.statement.prolog' } ] } ],
|
|
|
|
'#string':
|
|
|
|
[ { token: 'punctuation.definition.string.begin.prolog',
|
|
|
|
regex: '\'',
|
|
|
|
push:
|
|
|
|
[ { token: 'punctuation.definition.string.end.prolog',
|
|
|
|
regex: '\'',
|
|
|
|
next: 'pop' },
|
|
|
|
{ token: 'constant.character.escape.prolog', regex: '\\\\.' },
|
|
|
|
{ token: 'constant.character.escape.quote.prolog',
|
|
|
|
regex: '\'\'' },
|
|
|
|
{ defaultToken: 'string.quoted.single.prolog' } ] } ],
|
|
|
|
'#variable':
|
|
|
|
[ { token: 'variable.language.anonymous.prolog',
|
|
|
|
regex: '\\b_\\b' },
|
|
|
|
{ token: 'variable.other.prolog',
|
|
|
|
regex: '\\b[A-Z_][a-zA-Z0-9_]*\\b' } ] }
|
|
|
|
|
|
|
|
this.normalizeRules();
|
|
|
|
};
|
|
|
|
|
|
|
|
PrologHighlightRules.metaData = { fileTypes: [ 'plg', 'prolog' ],
|
|
|
|
foldingStartMarker: '(%\\s*region \\w*)|([a-z]\\w*.*:- ?)',
|
|
|
|
foldingStopMarker: '(%\\s*end(\\s*region)?)|(?=\\.)',
|
|
|
|
keyEquivalent: '^~P',
|
|
|
|
name: 'Prolog',
|
|
|
|
scopeName: 'source.prolog' }
|
|
|
|
|
|
|
|
|
|
|
|
oop.inherits(PrologHighlightRules, TextHighlightRules);
|
|
|
|
|
|
|
|
exports.PrologHighlightRules = PrologHighlightRules;
|
|
|
|
});
|
|
|
|
|
|
|
|
ace.define('ace/mode/folding/cstyle', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/range', 'ace/mode/folding/fold_mode'], function(require, exports, module) {
|
|
|
|
|
|
|
|
|
|
|
|
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.getFoldWidgetRange = function(session, foldStyle, row) {
|
|
|
|
var line = session.getLine(row);
|
|
|
|
var match = line.match(this.foldingStartMarker);
|
|
|
|
if (match) {
|
|
|
|
var i = match.index;
|
|
|
|
|
|
|
|
if (match[1])
|
|
|
|
return this.openingBracketBlock(session, match[1], row, i);
|
|
|
|
|
|
|
|
return session.getCommentFoldRange(row, i + match[0].length, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (foldStyle !== "markbeginend")
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
}).call(FoldMode.prototype);
|
|
|
|
|
|
|
|
});
|