mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-31 03:18:24 +00:00 
			
		
		
		
	* 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");
 | |
| 
 | |
| });
 |