a915a09e4f
* Cleaning up public/ and documenting js/css libs. This commit mostly addresses #1484 by moving vendor'ed plugins into a vendor/ directory and documenting their upstream source and license in vendor/librejs.html. This also proves gitea is using only open source js/css libraries which helps toward reaching #1524. * Removing unused css file. The version of this file in use is located at: vendor/plugins/highlight/github.css * Cleaned up librejs.html and added javascript header A SafeJS function was added to templates/helper.go to allow keeping comments inside of javascript. A javascript comment was added in the header of templates/base/head.tmpl to mark all non-inline source as free. The librejs.html file was updated to meet the current librejs spec. I have now verified that the librejs plugin detects most of the scripts included in gitea and suspect the non-free detections are the result of a bug in the plugin. I believe this commit is enough to meet the C0.0 requirement of #1534. * Updating SafeJS function per lint suggestion * Added VERSIONS file, per request
112 lines
3.1 KiB
JavaScript
112 lines
3.1 KiB
JavaScript
// CodeMirror, copyright (c) by Marijn Haverbeke and others
|
|
// Distributed under an MIT license: http://codemirror.net/LICENSE
|
|
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") // CommonJS
|
|
mod(require("../../lib/codemirror"));
|
|
else if (typeof define == "function" && define.amd) // AMD
|
|
define(["../../lib/codemirror"], mod);
|
|
else // Plain browser env
|
|
mod(CodeMirror);
|
|
})(function(CodeMirror) {
|
|
"use strict";
|
|
|
|
CodeMirror.defineMode("spreadsheet", function () {
|
|
return {
|
|
startState: function () {
|
|
return {
|
|
stringType: null,
|
|
stack: []
|
|
};
|
|
},
|
|
token: function (stream, state) {
|
|
if (!stream) return;
|
|
|
|
//check for state changes
|
|
if (state.stack.length === 0) {
|
|
//strings
|
|
if ((stream.peek() == '"') || (stream.peek() == "'")) {
|
|
state.stringType = stream.peek();
|
|
stream.next(); // Skip quote
|
|
state.stack.unshift("string");
|
|
}
|
|
}
|
|
|
|
//return state
|
|
//stack has
|
|
switch (state.stack[0]) {
|
|
case "string":
|
|
while (state.stack[0] === "string" && !stream.eol()) {
|
|
if (stream.peek() === state.stringType) {
|
|
stream.next(); // Skip quote
|
|
state.stack.shift(); // Clear flag
|
|
} else if (stream.peek() === "\\") {
|
|
stream.next();
|
|
stream.next();
|
|
} else {
|
|
stream.match(/^.[^\\\"\']*/);
|
|
}
|
|
}
|
|
return "string";
|
|
|
|
case "characterClass":
|
|
while (state.stack[0] === "characterClass" && !stream.eol()) {
|
|
if (!(stream.match(/^[^\]\\]+/) || stream.match(/^\\./)))
|
|
state.stack.shift();
|
|
}
|
|
return "operator";
|
|
}
|
|
|
|
var peek = stream.peek();
|
|
|
|
//no stack
|
|
switch (peek) {
|
|
case "[":
|
|
stream.next();
|
|
state.stack.unshift("characterClass");
|
|
return "bracket";
|
|
case ":":
|
|
stream.next();
|
|
return "operator";
|
|
case "\\":
|
|
if (stream.match(/\\[a-z]+/)) return "string-2";
|
|
else {
|
|
stream.next();
|
|
return "atom";
|
|
}
|
|
case ".":
|
|
case ",":
|
|
case ";":
|
|
case "*":
|
|
case "-":
|
|
case "+":
|
|
case "^":
|
|
case "<":
|
|
case "/":
|
|
case "=":
|
|
stream.next();
|
|
return "atom";
|
|
case "$":
|
|
stream.next();
|
|
return "builtin";
|
|
}
|
|
|
|
if (stream.match(/\d+/)) {
|
|
if (stream.match(/^\w+/)) return "error";
|
|
return "number";
|
|
} else if (stream.match(/^[a-zA-Z_]\w*/)) {
|
|
if (stream.match(/(?=[\(.])/, false)) return "keyword";
|
|
return "variable-2";
|
|
} else if (["[", "]", "(", ")", "{", "}"].indexOf(peek) != -1) {
|
|
stream.next();
|
|
return "bracket";
|
|
} else if (!stream.eatSpace()) {
|
|
stream.next();
|
|
}
|
|
return null;
|
|
}
|
|
};
|
|
});
|
|
|
|
CodeMirror.defineMIME("text/x-spreadsheet", "spreadsheet");
|
|
});
|