mirror of
https://github.com/go-gitea/gitea
synced 2025-01-15 20:24:27 +00:00
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
115 lines
4.1 KiB
HTML
115 lines
4.1 KiB
HTML
<!doctype html>
|
|
|
|
<title>CodeMirror: JavaScript 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/edit/matchbrackets.js"></script>
|
|
<script src="../../addon/comment/continuecomment.js"></script>
|
|
<script src="../../addon/comment/comment.js"></script>
|
|
<script src="javascript.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="#">JavaScript</a>
|
|
</ul>
|
|
</div>
|
|
|
|
<article>
|
|
<h2>JavaScript mode</h2>
|
|
|
|
|
|
<div><textarea id="code" name="code">
|
|
// Demo code (the actual new parser character stream implementation)
|
|
|
|
function StringStream(string) {
|
|
this.pos = 0;
|
|
this.string = string;
|
|
}
|
|
|
|
StringStream.prototype = {
|
|
done: function() {return this.pos >= this.string.length;},
|
|
peek: function() {return this.string.charAt(this.pos);},
|
|
next: function() {
|
|
if (this.pos < this.string.length)
|
|
return this.string.charAt(this.pos++);
|
|
},
|
|
eat: function(match) {
|
|
var ch = this.string.charAt(this.pos);
|
|
if (typeof match == "string") var ok = ch == match;
|
|
else var ok = ch && match.test ? match.test(ch) : match(ch);
|
|
if (ok) {this.pos++; return ch;}
|
|
},
|
|
eatWhile: function(match) {
|
|
var start = this.pos;
|
|
while (this.eat(match));
|
|
if (this.pos > start) return this.string.slice(start, this.pos);
|
|
},
|
|
backUp: function(n) {this.pos -= n;},
|
|
column: function() {return this.pos;},
|
|
eatSpace: function() {
|
|
var start = this.pos;
|
|
while (/\s/.test(this.string.charAt(this.pos))) this.pos++;
|
|
return this.pos - start;
|
|
},
|
|
match: function(pattern, consume, caseInsensitive) {
|
|
if (typeof pattern == "string") {
|
|
function cased(str) {return caseInsensitive ? str.toLowerCase() : str;}
|
|
if (cased(this.string).indexOf(cased(pattern), this.pos) == this.pos) {
|
|
if (consume !== false) this.pos += str.length;
|
|
return true;
|
|
}
|
|
}
|
|
else {
|
|
var match = this.string.slice(this.pos).match(pattern);
|
|
if (match && consume !== false) this.pos += match[0].length;
|
|
return match;
|
|
}
|
|
}
|
|
};
|
|
</textarea></div>
|
|
|
|
<script>
|
|
var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
|
|
lineNumbers: true,
|
|
matchBrackets: true,
|
|
continueComments: "Enter",
|
|
extraKeys: {"Ctrl-Q": "toggleComment"}
|
|
});
|
|
</script>
|
|
|
|
<p>
|
|
JavaScript mode supports several configuration options:
|
|
<ul>
|
|
<li><code>json</code> which will set the mode to expect JSON
|
|
data rather than a JavaScript program.</li>
|
|
<li><code>jsonld</code> which will set the mode to expect
|
|
<a href="http://json-ld.org">JSON-LD</a> linked data rather
|
|
than a JavaScript program (<a href="json-ld.html">demo</a>).</li>
|
|
<li><code>typescript</code> which will activate additional
|
|
syntax highlighting and some other things for TypeScript code
|
|
(<a href="typescript.html">demo</a>).</li>
|
|
<li><code>statementIndent</code> which (given a number) will
|
|
determine the amount of indentation to use for statements
|
|
continued on a new line.</li>
|
|
<li><code>wordCharacters</code>, a regexp that indicates which
|
|
characters should be considered part of an identifier.
|
|
Defaults to <code>/[\w$]/</code>, which does not handle
|
|
non-ASCII identifiers. Can be set to something more elaborate
|
|
to improve Unicode support.</li>
|
|
</ul>
|
|
</p>
|
|
|
|
<p><strong>MIME types defined:</strong> <code>text/javascript</code>, <code>application/json</code>, <code>application/ld+json</code>, <code>text/typescript</code>, <code>application/typescript</code>.</p>
|
|
</article>
|