* 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
		
			
				
	
	
		
			113 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			113 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");
 | |
| });
 |