synch
This commit is contained in:
parent
044d455597
commit
e626847e93
@ -2,14 +2,14 @@
|
|||||||
// Distributed under an MIT license: http://codemirror.net/LICENSE
|
// Distributed under an MIT license: http://codemirror.net/LICENSE
|
||||||
|
|
||||||
(function(mod) {
|
(function(mod) {
|
||||||
if (typeof exports == "object" && typeof module == "object") // CommonJS
|
if (typeof exports == "object" && typeof module == "object") // CommonJS
|
||||||
mod(require("../../lib/codemirror"));
|
mod(require(["codemirror/lib/codemirror","codemirror/addon/lint/lint"]));
|
||||||
else if (typeof define == "function" && define.amd) // AMD
|
else if (typeof define == "function" && define.amd) // AMD
|
||||||
define(["../../lib/codemirror"], mod);
|
define([ "codemirror/lib/codemirror","codemirror/addon/lint/lint" ], mod);
|
||||||
else // Plain browser env
|
else // Plain browser env
|
||||||
mod(CodeMirror);
|
mod(CodeMirror);
|
||||||
})(function(CodeMirror) {
|
})(function(CodeMirror) {
|
||||||
"use strict";
|
"use strict";
|
||||||
|
|
||||||
CodeMirror.defineMode("prolog", function(conf, parserConfig) {
|
CodeMirror.defineMode("prolog", function(conf, parserConfig) {
|
||||||
function chain(stream, state, f) {
|
function chain(stream, state, f) {
|
||||||
@ -17,8 +17,7 @@ CodeMirror.defineMode("prolog", function(conf, parserConfig) {
|
|||||||
return f(stream, state);
|
return f(stream, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
var cm_ = null;
|
var cm_;
|
||||||
var document = CodeMirror.doc;
|
|
||||||
var curLine;
|
var curLine;
|
||||||
|
|
||||||
/*******************************
|
/*******************************
|
||||||
@ -35,25 +34,9 @@ var document = CodeMirror.doc;
|
|||||||
parserConfig.groupedIntegers || false; /* tag{k:v, ...} */
|
parserConfig.groupedIntegers || false; /* tag{k:v, ...} */
|
||||||
var unicodeEscape =
|
var unicodeEscape =
|
||||||
parserConfig.unicodeEscape || true; /* \uXXXX and \UXXXXXXXX */
|
parserConfig.unicodeEscape || true; /* \uXXXX and \UXXXXXXXX */
|
||||||
var multiLineQuoted = parserConfig.multiLineQuotedd || true;
|
var multiLineQuoted = parserConfig.multiLineQuoted || true; /* "...\n..." */
|
||||||
var singleQuoted = "atom";
|
var quoteType = parserConfig.quoteType ||
|
||||||
if (parserConfig.singleQuote === "string" ||
|
{'"' : "string", "'" : "qatom", "`" : "bqstring"};
|
||||||
parserConfig.singleQuote === "codes" ||
|
|
||||||
parserConfig.singleQuote === "chars")
|
|
||||||
singleQuoted = parserConfig.singleQuote;
|
|
||||||
var doubleQuoted = "string";
|
|
||||||
if (parserConfig.doubleQuote === "atom" ||
|
|
||||||
parserConfig.doubleQuote === "codes" ||
|
|
||||||
parserConfig.doubleQuote === "chars")
|
|
||||||
doubleQuoted = parserConfig.doubleQuote;
|
|
||||||
var backQuoted = "atom";
|
|
||||||
if (parserConfig.backQuote === "string" ||
|
|
||||||
parserConfig.backQuote === "codes" ||
|
|
||||||
parserConfig.backQuote === "chars")
|
|
||||||
backQuoted = parserConfig.backQuote;
|
|
||||||
|
|
||||||
var quoteType = {"\"" : doubleQuoted, "`" : backQuoted, "'" : singleQuoted};
|
|
||||||
|
|
||||||
var singletonVars = new Map();
|
var singletonVars = new Map();
|
||||||
|
|
||||||
var isSingleEscChar = /[abref\\'"nrtsv]/;
|
var isSingleEscChar = /[abref\\'"nrtsv]/;
|
||||||
@ -73,20 +56,21 @@ parserConfig.backQuote === "chars")
|
|||||||
var exportedMsgs = [];
|
var exportedMsgs = [];
|
||||||
|
|
||||||
function getLine(stream) {
|
function getLine(stream) {
|
||||||
if (stream)
|
|
||||||
return stream.lineOracle.line;
|
return stream.lineOracle.line;
|
||||||
if (document == null)
|
// return cm_.getDoc().getCursor().line;
|
||||||
return 0;
|
|
||||||
return document.getCursor().line;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// var ed =
|
// var ed =
|
||||||
// window.document.getElementsByClassName("CodeMirror")[0].CodeMirror.doc.getEditor();
|
// window.document.getElementsByClassName("CodeMirror")[0].CodeMirror.doc.getEditor();
|
||||||
|
|
||||||
function rmError(document,stream) {
|
function rmError(stream) {
|
||||||
|
if (cm_ == null)
|
||||||
|
return;
|
||||||
|
var doc = cm_.getDoc();
|
||||||
var l = getLine(stream);
|
var l = getLine(stream);
|
||||||
|
// stream.lineOracle.line;
|
||||||
for (var i = 0; i < errorFound.length; i++) {
|
for (var i = 0; i < errorFound.length; i++) {
|
||||||
var elLine = errorFound[i].document.getLineNumber(errorFound[i].line);
|
var elLine = doc.getLineNumber(errorFound[i].line);
|
||||||
if (elLine == null || l === elLine) {
|
if (elLine == null || l === elLine) {
|
||||||
errorFound.splice(i, 1);
|
errorFound.splice(i, 1);
|
||||||
i -= 1;
|
i -= 1;
|
||||||
@ -97,29 +81,30 @@ if (stream)
|
|||||||
function mkError(stream, severity, msg) {
|
function mkError(stream, severity, msg) {
|
||||||
if (stream.pos == 0)
|
if (stream.pos == 0)
|
||||||
return;
|
return;
|
||||||
var l = getLine(stream);
|
var l = cm_.getDoc().getLineHandle(getLine(stream));
|
||||||
var found = errorFound.find(function(
|
var found = errorFound.find(function(
|
||||||
element) { return element.line === l && element.to == stream.pos; });
|
element) { return element.line === l && element.to == stream.pos; });
|
||||||
if (!found) {
|
if (!found) {
|
||||||
//console.log(getLine(stream));
|
console.log( getLine(stream) );
|
||||||
errorFound.push({
|
errorFound.push({
|
||||||
"line" : l,
|
"line" : l,
|
||||||
"from" : stream.start,
|
"from" : stream.start,
|
||||||
"to" : stream.pos,
|
"to" : stream.pos,
|
||||||
severity : severity,
|
severity : severity,
|
||||||
message : msg,
|
message : msg
|
||||||
document: document
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function exportErrors(text) {
|
function exportErrors(text) {
|
||||||
if (document == null)
|
if (cm_ == null)
|
||||||
return;
|
return;
|
||||||
|
var doc = cm_.getDoc();
|
||||||
|
|
||||||
exportedMsgs.length = 0;
|
exportedMsgs.length = 0;
|
||||||
for (var i = 0; i < errorFound.length; i += 1) {
|
for (var i = 0; i < errorFound.length; i += 1) {
|
||||||
var e = errorFound[i];
|
var e = errorFound[i];
|
||||||
var l = document.getLineNumber(e.line);
|
var l = doc.getLineNumber(e.line);
|
||||||
if (l == null) {
|
if (l == null) {
|
||||||
errorFound.splice(i, 1);
|
errorFound.splice(i, 1);
|
||||||
i -= 1;
|
i -= 1;
|
||||||
@ -135,28 +120,29 @@ document: document
|
|||||||
return exportedMsgs;
|
return exportedMsgs;
|
||||||
}
|
}
|
||||||
|
|
||||||
function maybeSingleton(stream, key) {
|
function maybeSingleton( stream, key ) {
|
||||||
//console.log(key);
|
console.log(key);
|
||||||
var v = singletonVars.get(key);
|
var v = singletonVars.get(key);
|
||||||
if (v != undefined) {
|
if (v!= undefined) {
|
||||||
v.singleton = false;
|
v.singleton = false;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
singletonVars.set(
|
singletonVars.set(key, { 'singleton': true,
|
||||||
key, {'singleton' : true, 'from' : stream.start, to : stream.pos});
|
'from': stream.start, to: stream.pos } );
|
||||||
|
|
||||||
}
|
}
|
||||||
//console.log(singletonVars);
|
console.log(singletonVars);
|
||||||
}
|
}
|
||||||
|
|
||||||
function outputSingletonVars(stream) {
|
function outputSingletonVars(stream) {
|
||||||
var key, v;
|
var key,v;
|
||||||
for (var key in singletonVars.keys()) {
|
for ( [key,v] of singletonVars.entries()) {
|
||||||
var v = singletonVars[key];
|
if (v!=undefined && v.singleton) {
|
||||||
if (v != undefined && v.singleton) {
|
mkError(stream,"warning", key+" singleton variable");
|
||||||
mkError(stream, "warning", key + " singleton variable");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
singletonVars.clear();
|
singletonVars.clear();
|
||||||
// console.log("reset");
|
console.log("reset");
|
||||||
}
|
}
|
||||||
|
|
||||||
CodeMirror.registerHelper("lint", "prolog", exportErrors);
|
CodeMirror.registerHelper("lint", "prolog", exportErrors);
|
||||||
@ -323,7 +309,6 @@ document: document
|
|||||||
|
|
||||||
if (ch == "{" && state.lastType == "tag") {
|
if (ch == "{" && state.lastType == "tag") {
|
||||||
state.nesting.push({
|
state.nesting.push({
|
||||||
marker: ch,
|
|
||||||
tag : state.tagName,
|
tag : state.tagName,
|
||||||
column : stream.column(),
|
column : stream.column(),
|
||||||
leftCol : state.tagColumn,
|
leftCol : state.tagColumn,
|
||||||
@ -334,12 +319,8 @@ document: document
|
|||||||
return ret("dict_open", "bracket");
|
return ret("dict_open", "bracket");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ch == "/") {
|
if (ch == "/" && stream.eat("*"))
|
||||||
var next = stream.peek();
|
|
||||||
if (next == '*') {
|
|
||||||
return chain(stream, state, plTokenComment);
|
return chain(stream, state, plTokenComment);
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ch == "%") {
|
if (ch == "%") {
|
||||||
stream.skipToEnd();
|
stream.skipToEnd();
|
||||||
@ -351,28 +332,21 @@ if (next == '*') {
|
|||||||
if (isSoloChar.test(ch)) {
|
if (isSoloChar.test(ch)) {
|
||||||
switch (ch) {
|
switch (ch) {
|
||||||
case ")": {
|
case ")": {
|
||||||
if (state.nesting.marker != "(") {
|
|
||||||
mkError(stream, "error", state.nesting.marker + " closed by )");
|
|
||||||
}
|
|
||||||
state.nesting.pop();
|
state.nesting.pop();
|
||||||
} break;
|
} break;
|
||||||
case "]":
|
case "]":
|
||||||
if (state.nesting.marker != "[") {
|
|
||||||
mkError(stream, "error", state.nesting.marker + " closed by ]");
|
|
||||||
}
|
|
||||||
state.nesting.pop();
|
state.nesting.pop();
|
||||||
return ret("list_close", "bracket");
|
return ret("list_close", "bracket");
|
||||||
case "}": {
|
case "}": {
|
||||||
if (state.nesting.marker != "{") {
|
|
||||||
mkError(stream, "error", state.nesting.marker + " closed by }");
|
|
||||||
}
|
|
||||||
var nest = nesting(state);
|
var nest = nesting(state);
|
||||||
var type = (nest && nest.tag) ? "dict_close" : "brace_term_close";
|
var type = (nest && nest.tag) ? "dict_close" : "brace_term_close";
|
||||||
|
|
||||||
state.nesting.pop();
|
state.nesting.pop();
|
||||||
return ret(type, null);
|
return ret(type, null);
|
||||||
} break;
|
} break;
|
||||||
case ",": {
|
case ",":
|
||||||
|
{
|
||||||
if (stream.eol())
|
if (stream.eol())
|
||||||
state.commaAtEOL = true;
|
state.commaAtEOL = true;
|
||||||
nextArg(state);
|
nextArg(state);
|
||||||
@ -380,28 +354,28 @@ if (state.nesting.marker != "[") {
|
|||||||
if (!state.commaAtEOL)
|
if (!state.commaAtEOL)
|
||||||
stream.eatSpace();
|
stream.eatSpace();
|
||||||
var nch = stream.peek();
|
var nch = stream.peek();
|
||||||
if (nch == ';' || nch == ',') {
|
if ( nch == ';' || nch == ',') {
|
||||||
mkError(stream, "error", "\",\" followed by " + stream.peek());
|
mkError(stream, "error", "\",\" followed by "+stream.peek());
|
||||||
return ret("solo", "error", ",");
|
return ret("solo", "error", ",");
|
||||||
}
|
}
|
||||||
if (isControl(state)) {
|
if (isControl(state)) {
|
||||||
if ("[" != ch) {
|
if ("[" != ch ) {
|
||||||
if (state.inBody) {
|
if (state.inBody ) {
|
||||||
state.goalStart = true;
|
state.goalStart = true;
|
||||||
} else {
|
} else {
|
||||||
mkError(stream, "error", "\",\" followed by " + stream.peek());
|
mkError(stream, "error", "\",\" followed by "+stream.peek());
|
||||||
return ret("solo", "error", ",");
|
return ret("solo", "error", ",");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return ret('solo', 'tag', ",");
|
return ret('solo','tag', ",");
|
||||||
} break;
|
} break;
|
||||||
case ";":
|
case ";":
|
||||||
if (!state.commaAtEOL)
|
if (!state.commaAtEOL)
|
||||||
stream.eatSpace();
|
stream.eatSpace();
|
||||||
ch = stream.peek();
|
ch = stream.peek();
|
||||||
if (ch == ';' || ch == ',') {
|
if ( ch == ';' || ch == ',') {
|
||||||
mkError(stream, "error", "\",\" followed by " + stream.peek());
|
mkError(stream, "error", "\",\" followed by "+stream.peek());
|
||||||
return ret("solo", "error", ";");
|
return ret("solo", "error", ";");
|
||||||
}
|
}
|
||||||
if (isControl(state)) {
|
if (isControl(state)) {
|
||||||
@ -496,13 +470,11 @@ if (state.nesting.marker != "[") {
|
|||||||
state.nesting = [];
|
state.nesting = [];
|
||||||
}
|
}
|
||||||
// var start = cm_.getCursor("end");
|
// var start = cm_.getCursor("end");
|
||||||
// cm_.setBookmark(start, {"widget" :
|
//cm_.setBookmark(start, {"widget" : document.createTextNode("•")});
|
||||||
// document.createTextNode("•")});
|
|
||||||
state.inBody = false;
|
state.inBody = false;
|
||||||
state.goalStart = true;
|
state.goalStart = true;
|
||||||
outputSingletonVars(stream);
|
outputSingletonVars(stream);
|
||||||
stream.eat(ch);
|
stream.eat(ch);
|
||||||
state.headStart = true;
|
|
||||||
return ret("fullstop", "def", atom);
|
return ret("fullstop", "def", atom);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
@ -515,7 +487,7 @@ state.headStart = true;
|
|||||||
} else if (isNeck.test(atom)) {
|
} else if (isNeck.test(atom)) {
|
||||||
state.inBody = true;
|
state.inBody = true;
|
||||||
state.goalStart = true;
|
state.goalStart = true;
|
||||||
return ret("neck", "def", atom);
|
return ret("neck", "property", atom);
|
||||||
} else if (isControl(state) && isControlOp.test(atom)) {
|
} else if (isControl(state) && isControlOp.test(atom)) {
|
||||||
state.goalStart = true;
|
state.goalStart = true;
|
||||||
return ret("symbol", "meta", atom);
|
return ret("symbol", "meta", atom);
|
||||||
@ -523,7 +495,7 @@ state.headStart = true;
|
|||||||
return ret("symbol", "meta", atom);
|
return ret("symbol", "meta", atom);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stream.eatWhile(/\w/);
|
stream.eatWhile(/[\w_]/);
|
||||||
if (composeGoalWithDots) {
|
if (composeGoalWithDots) {
|
||||||
while (stream.peek() == ".") {
|
while (stream.peek() == ".") {
|
||||||
stream.eat('.');
|
stream.eat('.');
|
||||||
@ -532,8 +504,8 @@ state.headStart = true;
|
|||||||
stream.backUp(1);
|
stream.backUp(1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
} else if (/\w/.test(ch)) {
|
} else if (/[\w_]/.test(ch)) {
|
||||||
stream.eatWhile(/\w/);
|
stream.eatWhile(/[\w_]/);
|
||||||
} else if (ch == "'") {
|
} else if (ch == "'") {
|
||||||
|
|
||||||
stream.eat();
|
stream.eat();
|
||||||
@ -559,23 +531,20 @@ state.headStart = true;
|
|||||||
} else {
|
} else {
|
||||||
return ret("var", "variable-2", word);
|
return ret("var", "variable-2", word);
|
||||||
}
|
}
|
||||||
} else if (ch.match(/[A-Z]/)) {
|
} else if (ch.match(/[A-Z]/) ) {
|
||||||
maybeSingleton(stream, word);
|
maybeSingleton(stream,word);
|
||||||
return ret("var", "variable-1", word);
|
return ret("var", "variable-1", word);
|
||||||
}
|
}
|
||||||
if (state.headStart) {
|
|
||||||
state.headStart = false;
|
|
||||||
if (state.headFunctor !== word) {
|
|
||||||
state.headFunctor = word;
|
|
||||||
return ret("functor", "def", word);
|
|
||||||
}
|
|
||||||
return ret("functor", "atom", word);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if (stream.peek() == "(") {
|
if (stream.peek() == "(") {
|
||||||
state.functorName = word; /* tmp state extension */
|
state.functorName = word; /* tmp state extension */
|
||||||
state.functorColumn = stream.column();
|
state.functorColumn = stream.column();
|
||||||
|
if (state.headStart) {
|
||||||
|
state.headStart = false;
|
||||||
|
if (state.headFunctor != word) {
|
||||||
|
state.headFunctor = word;
|
||||||
|
return ret("functor", "def", word);
|
||||||
|
}
|
||||||
|
}
|
||||||
if (builtins[word] && isControl(state))
|
if (builtins[word] && isControl(state))
|
||||||
return ret("functor", "keyword", word);
|
return ret("functor", "keyword", word);
|
||||||
return ret("functor", "atom", word);
|
return ret("functor", "atom", word);
|
||||||
@ -604,6 +573,7 @@ return ret("functor", "atom", word);
|
|||||||
return ret("atom", "keyword", word);
|
return ret("atom", "keyword", word);
|
||||||
}
|
}
|
||||||
return ret("atom", "atom", word);
|
return ret("atom", "atom", word);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function plTokenString(quote) {
|
function plTokenString(quote) {
|
||||||
@ -748,7 +718,7 @@ IfTrue
|
|||||||
|
|
||||||
CodeMirror.defineOption(
|
CodeMirror.defineOption(
|
||||||
"prologKeys", true, function(cm, editor, prev) {
|
"prologKeys", true, function(cm, editor, prev) {
|
||||||
document = cm.getDoc();
|
cm_ = cm;
|
||||||
if (prev && prev != CodeMirror.Init)
|
if (prev && prev != CodeMirror.Init)
|
||||||
cm.removeKeyMap("prolog");
|
cm.removeKeyMap("prolog");
|
||||||
if (true) {
|
if (true) {
|
||||||
@ -1418,9 +1388,11 @@ IfTrue
|
|||||||
setArgAlignment(state);
|
setArgAlignment(state);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
if (state.curLine == null || state.pos == 0)
|
||||||
|
rmError(stream);
|
||||||
|
|
||||||
var style = state.tokenize(stream, state);
|
var style = state.tokenize(stream, state);
|
||||||
//console.log(state.curToken);
|
console.log(state.curToken);
|
||||||
|
|
||||||
if (stream.eol()) {
|
if (stream.eol()) {
|
||||||
if (stream.pos > 0)
|
if (stream.pos > 0)
|
||||||
@ -1467,7 +1439,7 @@ IfTrue
|
|||||||
blockCommentEnd : "*/",
|
blockCommentEnd : "*/",
|
||||||
blockCommentContinue : " * ",
|
blockCommentContinue : " * ",
|
||||||
comment : "%",
|
comment : "%",
|
||||||
matchBrackets : true
|
matchBrackets: true
|
||||||
};
|
};
|
||||||
return external;
|
return external;
|
||||||
});
|
});
|
||||||
|
Reference in New Issue
Block a user