* 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
This commit is contained in:
parent
64b7068846
commit
a915a09e4f
1339 changed files with 813 additions and 126 deletions
180
public/vendor/plugins/codemirror/mode/forth/forth.js
vendored
Normal file
180
public/vendor/plugins/codemirror/mode/forth/forth.js
vendored
Normal file
|
@ -0,0 +1,180 @@
|
|||
// CodeMirror, copyright (c) by Marijn Haverbeke and others
|
||||
// Distributed under an MIT license: http://codemirror.net/LICENSE
|
||||
|
||||
// Author: Aliaksei Chapyzhenka
|
||||
|
||||
(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";
|
||||
|
||||
function toWordList(words) {
|
||||
var ret = [];
|
||||
words.split(' ').forEach(function(e){
|
||||
ret.push({name: e});
|
||||
});
|
||||
return ret;
|
||||
}
|
||||
|
||||
var coreWordList = toWordList(
|
||||
'INVERT AND OR XOR\
|
||||
2* 2/ LSHIFT RSHIFT\
|
||||
0= = 0< < > U< MIN MAX\
|
||||
2DROP 2DUP 2OVER 2SWAP ?DUP DEPTH DROP DUP OVER ROT SWAP\
|
||||
>R R> R@\
|
||||
+ - 1+ 1- ABS NEGATE\
|
||||
S>D * M* UM*\
|
||||
FM/MOD SM/REM UM/MOD */ */MOD / /MOD MOD\
|
||||
HERE , @ ! CELL+ CELLS C, C@ C! CHARS 2@ 2!\
|
||||
ALIGN ALIGNED +! ALLOT\
|
||||
CHAR [CHAR] [ ] BL\
|
||||
FIND EXECUTE IMMEDIATE COUNT LITERAL STATE\
|
||||
; DOES> >BODY\
|
||||
EVALUATE\
|
||||
SOURCE >IN\
|
||||
<# # #S #> HOLD SIGN BASE >NUMBER HEX DECIMAL\
|
||||
FILL MOVE\
|
||||
. CR EMIT SPACE SPACES TYPE U. .R U.R\
|
||||
ACCEPT\
|
||||
TRUE FALSE\
|
||||
<> U> 0<> 0>\
|
||||
NIP TUCK ROLL PICK\
|
||||
2>R 2R@ 2R>\
|
||||
WITHIN UNUSED MARKER\
|
||||
I J\
|
||||
TO\
|
||||
COMPILE, [COMPILE]\
|
||||
SAVE-INPUT RESTORE-INPUT\
|
||||
PAD ERASE\
|
||||
2LITERAL DNEGATE\
|
||||
D- D+ D0< D0= D2* D2/ D< D= DMAX DMIN D>S DABS\
|
||||
M+ M*/ D. D.R 2ROT DU<\
|
||||
CATCH THROW\
|
||||
FREE RESIZE ALLOCATE\
|
||||
CS-PICK CS-ROLL\
|
||||
GET-CURRENT SET-CURRENT FORTH-WORDLIST GET-ORDER SET-ORDER\
|
||||
PREVIOUS SEARCH-WORDLIST WORDLIST FIND ALSO ONLY FORTH DEFINITIONS ORDER\
|
||||
-TRAILING /STRING SEARCH COMPARE CMOVE CMOVE> BLANK SLITERAL');
|
||||
|
||||
var immediateWordList = toWordList('IF ELSE THEN BEGIN WHILE REPEAT UNTIL RECURSE [IF] [ELSE] [THEN] ?DO DO LOOP +LOOP UNLOOP LEAVE EXIT AGAIN CASE OF ENDOF ENDCASE');
|
||||
|
||||
CodeMirror.defineMode('forth', function() {
|
||||
function searchWordList (wordList, word) {
|
||||
var i;
|
||||
for (i = wordList.length - 1; i >= 0; i--) {
|
||||
if (wordList[i].name === word.toUpperCase()) {
|
||||
return wordList[i];
|
||||
}
|
||||
}
|
||||
return undefined;
|
||||
}
|
||||
return {
|
||||
startState: function() {
|
||||
return {
|
||||
state: '',
|
||||
base: 10,
|
||||
coreWordList: coreWordList,
|
||||
immediateWordList: immediateWordList,
|
||||
wordList: []
|
||||
};
|
||||
},
|
||||
token: function (stream, stt) {
|
||||
var mat;
|
||||
if (stream.eatSpace()) {
|
||||
return null;
|
||||
}
|
||||
if (stt.state === '') { // interpretation
|
||||
if (stream.match(/^(\]|:NONAME)(\s|$)/i)) {
|
||||
stt.state = ' compilation';
|
||||
return 'builtin compilation';
|
||||
}
|
||||
mat = stream.match(/^(\:)\s+(\S+)(\s|$)+/);
|
||||
if (mat) {
|
||||
stt.wordList.push({name: mat[2].toUpperCase()});
|
||||
stt.state = ' compilation';
|
||||
return 'def' + stt.state;
|
||||
}
|
||||
mat = stream.match(/^(VARIABLE|2VARIABLE|CONSTANT|2CONSTANT|CREATE|POSTPONE|VALUE|WORD)\s+(\S+)(\s|$)+/i);
|
||||
if (mat) {
|
||||
stt.wordList.push({name: mat[2].toUpperCase()});
|
||||
return 'def' + stt.state;
|
||||
}
|
||||
mat = stream.match(/^(\'|\[\'\])\s+(\S+)(\s|$)+/);
|
||||
if (mat) {
|
||||
return 'builtin' + stt.state;
|
||||
}
|
||||
} else { // compilation
|
||||
// ; [
|
||||
if (stream.match(/^(\;|\[)(\s)/)) {
|
||||
stt.state = '';
|
||||
stream.backUp(1);
|
||||
return 'builtin compilation';
|
||||
}
|
||||
if (stream.match(/^(\;|\[)($)/)) {
|
||||
stt.state = '';
|
||||
return 'builtin compilation';
|
||||
}
|
||||
if (stream.match(/^(POSTPONE)\s+\S+(\s|$)+/)) {
|
||||
return 'builtin';
|
||||
}
|
||||
}
|
||||
|
||||
// dynamic wordlist
|
||||
mat = stream.match(/^(\S+)(\s+|$)/);
|
||||
if (mat) {
|
||||
if (searchWordList(stt.wordList, mat[1]) !== undefined) {
|
||||
return 'variable' + stt.state;
|
||||
}
|
||||
|
||||
// comments
|
||||
if (mat[1] === '\\') {
|
||||
stream.skipToEnd();
|
||||
return 'comment' + stt.state;
|
||||
}
|
||||
|
||||
// core words
|
||||
if (searchWordList(stt.coreWordList, mat[1]) !== undefined) {
|
||||
return 'builtin' + stt.state;
|
||||
}
|
||||
if (searchWordList(stt.immediateWordList, mat[1]) !== undefined) {
|
||||
return 'keyword' + stt.state;
|
||||
}
|
||||
|
||||
if (mat[1] === '(') {
|
||||
stream.eatWhile(function (s) { return s !== ')'; });
|
||||
stream.eat(')');
|
||||
return 'comment' + stt.state;
|
||||
}
|
||||
|
||||
// // strings
|
||||
if (mat[1] === '.(') {
|
||||
stream.eatWhile(function (s) { return s !== ')'; });
|
||||
stream.eat(')');
|
||||
return 'string' + stt.state;
|
||||
}
|
||||
if (mat[1] === 'S"' || mat[1] === '."' || mat[1] === 'C"') {
|
||||
stream.eatWhile(function (s) { return s !== '"'; });
|
||||
stream.eat('"');
|
||||
return 'string' + stt.state;
|
||||
}
|
||||
|
||||
// numbers
|
||||
if (mat[1] - 0xfffffffff) {
|
||||
return 'number' + stt.state;
|
||||
}
|
||||
// if (mat[1].match(/^[-+]?[0-9]+\.[0-9]*/)) {
|
||||
// return 'number' + stt.state;
|
||||
// }
|
||||
|
||||
return 'atom' + stt.state;
|
||||
}
|
||||
}
|
||||
};
|
||||
});
|
||||
CodeMirror.defineMIME("text/x-forth", "forth");
|
||||
});
|
75
public/vendor/plugins/codemirror/mode/forth/index.html
vendored
Normal file
75
public/vendor/plugins/codemirror/mode/forth/index.html
vendored
Normal file
|
@ -0,0 +1,75 @@
|
|||
<!doctype html>
|
||||
|
||||
<title>CodeMirror: Forth mode</title>
|
||||
<meta charset="utf-8"/>
|
||||
<link rel=stylesheet href="../../doc/docs.css">
|
||||
|
||||
<link href='http://fonts.googleapis.com/css?family=Droid+Sans+Mono' rel='stylesheet' type='text/css'>
|
||||
<link rel="stylesheet" href="../../lib/codemirror.css">
|
||||
<link rel=stylesheet href="../../theme/colorforth.css">
|
||||
<script src="../../lib/codemirror.js"></script>
|
||||
<script src="forth.js"></script>
|
||||
<style>
|
||||
.CodeMirror {
|
||||
font-family: 'Droid Sans Mono', monospace;
|
||||
font-size: 14px;
|
||||
}
|
||||
</style>
|
||||
<div id=nav>
|
||||
<a href="http://codemirror.net"><h1>CodeMirror</h1><img id=logo src="../../doc/logo.png"></a>
|
||||
|
||||
<ul>
|
||||
<li><a href="../../index.html">Home</a>
|
||||
<li><a href="../../doc/manual.html">Manual</a>
|
||||
<li><a href="https://github.com/codemirror/codemirror">Code</a>
|
||||
</ul>
|
||||
<ul>
|
||||
<li><a href="../index.html">Language modes</a>
|
||||
<li><a class=active href="#">Forth</a>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
<article>
|
||||
|
||||
<h2>Forth mode</h2>
|
||||
|
||||
<form><textarea id="code" name="code">
|
||||
\ Insertion sort
|
||||
|
||||
: cell- 1 cells - ;
|
||||
|
||||
: insert ( start end -- start )
|
||||
dup @ >r ( r: v )
|
||||
begin
|
||||
2dup <
|
||||
while
|
||||
r@ over cell- @ <
|
||||
while
|
||||
cell-
|
||||
dup @ over cell+ !
|
||||
repeat then
|
||||
r> swap ! ;
|
||||
|
||||
: sort ( array len -- )
|
||||
1 ?do
|
||||
dup i cells + insert
|
||||
loop drop ;</textarea>
|
||||
</form>
|
||||
|
||||
<script>
|
||||
var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
|
||||
lineNumbers: true,
|
||||
lineWrapping: true,
|
||||
indentUnit: 2,
|
||||
tabSize: 2,
|
||||
autofocus: true,
|
||||
theme: "colorforth",
|
||||
mode: "text/x-forth"
|
||||
});
|
||||
</script>
|
||||
|
||||
<p>Simple mode that handle Forth-Syntax (<a href="http://en.wikipedia.org/wiki/Forth_%28programming_language%29">Forth on WikiPedia</a>).</p>
|
||||
|
||||
<p><strong>MIME types defined:</strong> <code>text/x-forth</code>.</p>
|
||||
|
||||
</article>
|
Loading…
Add table
Add a link
Reference in a new issue