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
114 lines
2.7 KiB
JavaScript
114 lines
2.7 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("http", function() {
|
|
function failFirstLine(stream, state) {
|
|
stream.skipToEnd();
|
|
state.cur = header;
|
|
return "error";
|
|
}
|
|
|
|
function start(stream, state) {
|
|
if (stream.match(/^HTTP\/\d\.\d/)) {
|
|
state.cur = responseStatusCode;
|
|
return "keyword";
|
|
} else if (stream.match(/^[A-Z]+/) && /[ \t]/.test(stream.peek())) {
|
|
state.cur = requestPath;
|
|
return "keyword";
|
|
} else {
|
|
return failFirstLine(stream, state);
|
|
}
|
|
}
|
|
|
|
function responseStatusCode(stream, state) {
|
|
var code = stream.match(/^\d+/);
|
|
if (!code) return failFirstLine(stream, state);
|
|
|
|
state.cur = responseStatusText;
|
|
var status = Number(code[0]);
|
|
if (status >= 100 && status < 200) {
|
|
return "positive informational";
|
|
} else if (status >= 200 && status < 300) {
|
|
return "positive success";
|
|
} else if (status >= 300 && status < 400) {
|
|
return "positive redirect";
|
|
} else if (status >= 400 && status < 500) {
|
|
return "negative client-error";
|
|
} else if (status >= 500 && status < 600) {
|
|
return "negative server-error";
|
|
} else {
|
|
return "error";
|
|
}
|
|
}
|
|
|
|
function responseStatusText(stream, state) {
|
|
stream.skipToEnd();
|
|
state.cur = header;
|
|
return null;
|
|
}
|
|
|
|
function requestPath(stream, state) {
|
|
stream.eatWhile(/\S/);
|
|
state.cur = requestProtocol;
|
|
return "string-2";
|
|
}
|
|
|
|
function requestProtocol(stream, state) {
|
|
if (stream.match(/^HTTP\/\d\.\d$/)) {
|
|
state.cur = header;
|
|
return "keyword";
|
|
} else {
|
|
return failFirstLine(stream, state);
|
|
}
|
|
}
|
|
|
|
function header(stream) {
|
|
if (stream.sol() && !stream.eat(/[ \t]/)) {
|
|
if (stream.match(/^.*?:/)) {
|
|
return "atom";
|
|
} else {
|
|
stream.skipToEnd();
|
|
return "error";
|
|
}
|
|
} else {
|
|
stream.skipToEnd();
|
|
return "string";
|
|
}
|
|
}
|
|
|
|
function body(stream) {
|
|
stream.skipToEnd();
|
|
return null;
|
|
}
|
|
|
|
return {
|
|
token: function(stream, state) {
|
|
var cur = state.cur;
|
|
if (cur != header && cur != body && stream.eatSpace()) return null;
|
|
return cur(stream, state);
|
|
},
|
|
|
|
blankLine: function(state) {
|
|
state.cur = body;
|
|
},
|
|
|
|
startState: function() {
|
|
return {cur: start};
|
|
}
|
|
};
|
|
});
|
|
|
|
CodeMirror.defineMIME("message/http", "http");
|
|
|
|
});
|