forked from forgejo/forgejo
* 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
64
public/vendor/plugins/codemirror/mode/rust/index.html
vendored
Normal file
64
public/vendor/plugins/codemirror/mode/rust/index.html
vendored
Normal file
|
@ -0,0 +1,64 @@
|
|||
<!doctype html>
|
||||
|
||||
<title>CodeMirror: Rust mode</title>
|
||||
<meta charset="utf-8"/>
|
||||
<link rel=stylesheet href="../../doc/docs.css">
|
||||
|
||||
<link rel="stylesheet" href="../../lib/codemirror.css">
|
||||
<script src="../../lib/codemirror.js"></script>
|
||||
<script src="../../addon/mode/simple.js"></script>
|
||||
<script src="rust.js"></script>
|
||||
<style type="text/css">.CodeMirror {border-top: 1px solid black; border-bottom: 1px solid black;}</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="#">Rust</a>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
<article>
|
||||
<h2>Rust mode</h2>
|
||||
|
||||
|
||||
<div><textarea id="code" name="code">
|
||||
// Demo code.
|
||||
|
||||
type foo<T> = int;
|
||||
enum bar {
|
||||
some(int, foo<float>),
|
||||
none
|
||||
}
|
||||
|
||||
fn check_crate(x: int) {
|
||||
let v = 10;
|
||||
match foo {
|
||||
1 ... 3 {
|
||||
print_foo();
|
||||
if x {
|
||||
blah().to_string();
|
||||
}
|
||||
}
|
||||
(x, y) { "bye" }
|
||||
_ { "hi" }
|
||||
}
|
||||
}
|
||||
</textarea></div>
|
||||
|
||||
<script>
|
||||
var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
|
||||
lineNumbers: true,
|
||||
lineWrapping: true,
|
||||
indentUnit: 4,
|
||||
mode: "rust"
|
||||
});
|
||||
</script>
|
||||
|
||||
<p><strong>MIME types defined:</strong> <code>text/x-rustsrc</code>.</p>
|
||||
</article>
|
71
public/vendor/plugins/codemirror/mode/rust/rust.js
vendored
Normal file
71
public/vendor/plugins/codemirror/mode/rust/rust.js
vendored
Normal file
|
@ -0,0 +1,71 @@
|
|||
// 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"), require("../../addon/mode/simple"));
|
||||
else if (typeof define == "function" && define.amd) // AMD
|
||||
define(["../../lib/codemirror", "../../addon/mode/simple"], mod);
|
||||
else // Plain browser env
|
||||
mod(CodeMirror);
|
||||
})(function(CodeMirror) {
|
||||
"use strict";
|
||||
|
||||
CodeMirror.defineSimpleMode("rust",{
|
||||
start: [
|
||||
// string and byte string
|
||||
{regex: /b?"/, token: "string", next: "string"},
|
||||
// raw string and raw byte string
|
||||
{regex: /b?r"/, token: "string", next: "string_raw"},
|
||||
{regex: /b?r#+"/, token: "string", next: "string_raw_hash"},
|
||||
// character
|
||||
{regex: /'(?:[^'\\]|\\(?:[nrt0'"]|x[\da-fA-F]{2}|u\{[\da-fA-F]{6}\}))'/, token: "string-2"},
|
||||
// byte
|
||||
{regex: /b'(?:[^']|\\(?:['\\nrt0]|x[\da-fA-F]{2}))'/, token: "string-2"},
|
||||
|
||||
{regex: /(?:(?:[0-9][0-9_]*)(?:(?:[Ee][+-]?[0-9_]+)|\.[0-9_]+(?:[Ee][+-]?[0-9_]+)?)(?:f32|f64)?)|(?:0(?:b[01_]+|(?:o[0-7_]+)|(?:x[0-9a-fA-F_]+))|(?:[0-9][0-9_]*))(?:u8|u16|u32|u64|i8|i16|i32|i64|isize|usize)?/,
|
||||
token: "number"},
|
||||
{regex: /(let(?:\s+mut)?|fn|enum|mod|struct|type)(\s+)([a-zA-Z_][a-zA-Z0-9_]*)/, token: ["keyword", null, "def"]},
|
||||
{regex: /(?:abstract|alignof|as|box|break|continue|const|crate|do|else|enum|extern|fn|for|final|if|impl|in|loop|macro|match|mod|move|offsetof|override|priv|proc|pub|pure|ref|return|self|sizeof|static|struct|super|trait|type|typeof|unsafe|unsized|use|virtual|where|while|yield)\b/, token: "keyword"},
|
||||
{regex: /\b(?:Self|isize|usize|char|bool|u8|u16|u32|u64|f16|f32|f64|i8|i16|i32|i64|str|Option)\b/, token: "atom"},
|
||||
{regex: /\b(?:true|false|Some|None|Ok|Err)\b/, token: "builtin"},
|
||||
{regex: /\b(fn)(\s+)([a-zA-Z_][a-zA-Z0-9_]*)/,
|
||||
token: ["keyword", null ,"def"]},
|
||||
{regex: /#!?\[.*\]/, token: "meta"},
|
||||
{regex: /\/\/.*/, token: "comment"},
|
||||
{regex: /\/\*/, token: "comment", next: "comment"},
|
||||
{regex: /[-+\/*=<>!]+/, token: "operator"},
|
||||
{regex: /[a-zA-Z_]\w*!/,token: "variable-3"},
|
||||
{regex: /[a-zA-Z_]\w*/, token: "variable"},
|
||||
{regex: /[\{\[\(]/, indent: true},
|
||||
{regex: /[\}\]\)]/, dedent: true}
|
||||
],
|
||||
string: [
|
||||
{regex: /"/, token: "string", next: "start"},
|
||||
{regex: /(?:[^\\"]|\\(?:.|$))*/, token: "string"}
|
||||
],
|
||||
string_raw: [
|
||||
{regex: /"/, token: "string", next: "start"},
|
||||
{regex: /[^"]*/, token: "string"}
|
||||
],
|
||||
string_raw_hash: [
|
||||
{regex: /"#+/, token: "string", next: "start"},
|
||||
{regex: /(?:[^"]|"(?!#))*/, token: "string"}
|
||||
],
|
||||
comment: [
|
||||
{regex: /.*?\*\//, token: "comment", next: "start"},
|
||||
{regex: /.*/, token: "comment"}
|
||||
],
|
||||
meta: {
|
||||
dontIndentStates: ["comment"],
|
||||
electricInput: /^\s*\}$/,
|
||||
blockCommentStart: "/*",
|
||||
blockCommentEnd: "*/",
|
||||
lineComment: "//",
|
||||
fold: "brace"
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
CodeMirror.defineMIME("text/x-rustsrc", "rust");
|
||||
});
|
39
public/vendor/plugins/codemirror/mode/rust/test.js
vendored
Normal file
39
public/vendor/plugins/codemirror/mode/rust/test.js
vendored
Normal file
|
@ -0,0 +1,39 @@
|
|||
// CodeMirror, copyright (c) by Marijn Haverbeke and others
|
||||
// Distributed under an MIT license: http://codemirror.net/LICENSE
|
||||
|
||||
(function() {
|
||||
var mode = CodeMirror.getMode({indentUnit: 4}, "rust");
|
||||
function MT(name) {test.mode(name, mode, Array.prototype.slice.call(arguments, 1));}
|
||||
|
||||
MT('integer_test',
|
||||
'[number 123i32]',
|
||||
'[number 123u32]',
|
||||
'[number 123_u32]',
|
||||
'[number 0xff_u8]',
|
||||
'[number 0o70_i16]',
|
||||
'[number 0b1111_1111_1001_0000_i32]',
|
||||
'[number 0usize]');
|
||||
|
||||
MT('float_test',
|
||||
'[number 123.0f64]',
|
||||
'[number 0.1f64]',
|
||||
'[number 0.1f32]',
|
||||
'[number 12E+99_f64]');
|
||||
|
||||
MT('string-literals-test',
|
||||
'[string "foo"]',
|
||||
'[string r"foo"]',
|
||||
'[string "\\"foo\\""]',
|
||||
'[string r#""foo""#]',
|
||||
'[string "foo #\\"# bar"]',
|
||||
|
||||
'[string b"foo"]',
|
||||
'[string br"foo"]',
|
||||
'[string b"\\"foo\\""]',
|
||||
'[string br#""foo""#]',
|
||||
'[string br##"foo #" bar"##]',
|
||||
|
||||
"[string-2 'h']",
|
||||
"[string-2 b'h']");
|
||||
|
||||
})();
|
Loading…
Add table
Add a link
Reference in a new issue