mirror of
https://github.com/go-gitea/gitea
synced 2025-01-23 18:57:51 +01:00
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
85 lines
2.3 KiB
JavaScript
85 lines
2.3 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")
|
|
mod(require("../../lib/codemirror"));
|
|
else if (typeof define == "function" && define.amd)
|
|
define(["../../lib/codemirror"], mod);
|
|
else
|
|
mod(CodeMirror);
|
|
})(function(CodeMirror) {
|
|
"use strict";
|
|
|
|
CodeMirror.defineMode('troff', function() {
|
|
|
|
var words = {};
|
|
|
|
function tokenBase(stream) {
|
|
if (stream.eatSpace()) return null;
|
|
|
|
var sol = stream.sol();
|
|
var ch = stream.next();
|
|
|
|
if (ch === '\\') {
|
|
if (stream.match('fB') || stream.match('fR') || stream.match('fI') ||
|
|
stream.match('u') || stream.match('d') ||
|
|
stream.match('%') || stream.match('&')) {
|
|
return 'string';
|
|
}
|
|
if (stream.match('m[')) {
|
|
stream.skipTo(']');
|
|
stream.next();
|
|
return 'string';
|
|
}
|
|
if (stream.match('s+') || stream.match('s-')) {
|
|
stream.eatWhile(/[\d-]/);
|
|
return 'string';
|
|
}
|
|
if (stream.match('\(') || stream.match('*\(')) {
|
|
stream.eatWhile(/[\w-]/);
|
|
return 'string';
|
|
}
|
|
return 'string';
|
|
}
|
|
if (sol && (ch === '.' || ch === '\'')) {
|
|
if (stream.eat('\\') && stream.eat('\"')) {
|
|
stream.skipToEnd();
|
|
return 'comment';
|
|
}
|
|
}
|
|
if (sol && ch === '.') {
|
|
if (stream.match('B ') || stream.match('I ') || stream.match('R ')) {
|
|
return 'attribute';
|
|
}
|
|
if (stream.match('TH ') || stream.match('SH ') || stream.match('SS ') || stream.match('HP ')) {
|
|
stream.skipToEnd();
|
|
return 'quote';
|
|
}
|
|
if ((stream.match(/[A-Z]/) && stream.match(/[A-Z]/)) || (stream.match(/[a-z]/) && stream.match(/[a-z]/))) {
|
|
return 'attribute';
|
|
}
|
|
}
|
|
stream.eatWhile(/[\w-]/);
|
|
var cur = stream.current();
|
|
return words.hasOwnProperty(cur) ? words[cur] : null;
|
|
}
|
|
|
|
function tokenize(stream, state) {
|
|
return (state.tokens[0] || tokenBase) (stream, state);
|
|
};
|
|
|
|
return {
|
|
startState: function() {return {tokens:[]};},
|
|
token: function(stream, state) {
|
|
return tokenize(stream, state);
|
|
}
|
|
};
|
|
});
|
|
|
|
CodeMirror.defineMIME('text/troff', 'troff');
|
|
CodeMirror.defineMIME('text/x-troff', 'troff');
|
|
CodeMirror.defineMIME('application/x-troff', 'troff');
|
|
|
|
});
|