annotate .cms/lib/codemirror/mode/javascript/index.html @ 1:1d486627aa1e draft default tip

24.10
author Coffee CMS <info@coffee-cms.ru>
date Sat, 12 Oct 2024 02:51:39 +0000
parents 78edf6b517a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
1 <!doctype html>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
2
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
3 <title>CodeMirror: JavaScript mode</title>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
4 <meta charset="utf-8"/>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
5 <link rel=stylesheet href="../../doc/docs.css">
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
6
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
7 <link rel="stylesheet" href="../../lib/codemirror.css">
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
8 <script src="../../lib/codemirror.js"></script>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
9 <script src="../../addon/edit/matchbrackets.js"></script>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
10 <script src="../../addon/comment/continuecomment.js"></script>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
11 <script src="../../addon/comment/comment.js"></script>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
12 <script src="javascript.js"></script>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
13 <style>.CodeMirror {border-top: 1px solid black; border-bottom: 1px solid black;}</style>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
14 <div id=nav>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
15 <a href="https://codemirror.net/5"><h1>CodeMirror</h1><img id=logo src="../../doc/logo.png" alt=""></a>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
16
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
17 <ul>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
18 <li><a href="../../index.html">Home</a>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
19 <li><a href="../../doc/manual.html">Manual</a>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
20 <li><a href="https://github.com/codemirror/codemirror5">Code</a>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
21 </ul>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
22 <ul>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
23 <li><a href="../index.html">Language modes</a>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
24 <li><a class=active href="#">JavaScript</a>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
25 </ul>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
26 </div>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
27
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
28 <article>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
29 <h2>JavaScript mode</h2>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
30
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
31
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
32 <div><textarea id="code" name="code">
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
33 // Demo code (the actual new parser character stream implementation)
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
34
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
35 function StringStream(string) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
36 this.pos = 0;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
37 this.string = string;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
38 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
39
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
40 StringStream.prototype = {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
41 done: function() {return this.pos >= this.string.length;},
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
42 peek: function() {return this.string.charAt(this.pos);},
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
43 next: function() {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
44 if (this.pos &lt; this.string.length)
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
45 return this.string.charAt(this.pos++);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
46 },
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
47 eat: function(match) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
48 var ch = this.string.charAt(this.pos);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
49 if (typeof match == "string") var ok = ch == match;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
50 else var ok = ch &amp;&amp; match.test ? match.test(ch) : match(ch);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
51 if (ok) {this.pos++; return ch;}
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
52 },
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
53 eatWhile: function(match) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
54 var start = this.pos;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
55 while (this.eat(match));
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
56 if (this.pos > start) return this.string.slice(start, this.pos);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
57 },
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
58 backUp: function(n) {this.pos -= n;},
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
59 column: function() {return this.pos;},
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
60 eatSpace: function() {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
61 var start = this.pos;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
62 while (/\s/.test(this.string.charAt(this.pos))) this.pos++;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
63 return this.pos - start;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
64 },
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
65 match: function(pattern, consume, caseInsensitive) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
66 if (typeof pattern == "string") {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
67 function cased(str) {return caseInsensitive ? str.toLowerCase() : str;}
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
68 if (cased(this.string).indexOf(cased(pattern), this.pos) == this.pos) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
69 if (consume !== false) this.pos += str.length;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
70 return true;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
71 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
72 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
73 else {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
74 var match = this.string.slice(this.pos).match(pattern);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
75 if (match &amp;&amp; consume !== false) this.pos += match[0].length;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
76 return match;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
77 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
78 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
79 };
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
80 </textarea></div>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
81
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
82 <script>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
83 var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
84 lineNumbers: true,
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
85 matchBrackets: true,
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
86 continueComments: "Enter",
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
87 extraKeys: {"Ctrl-Q": "toggleComment"}
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
88 });
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
89 </script>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
90
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
91 <p>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
92 JavaScript mode supports several configuration options:
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
93 <ul>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
94 <li><code>json</code> which will set the mode to expect JSON
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
95 data rather than a JavaScript program.</li>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
96 <li><code>jsonld</code> which will set the mode to expect
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
97 <a href="http://json-ld.org">JSON-LD</a> linked data rather
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
98 than a JavaScript program (<a href="json-ld.html">demo</a>).</li>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
99 <li><code>typescript</code> which will activate additional
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
100 syntax highlighting and some other things for TypeScript code
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
101 (<a href="typescript.html">demo</a>).</li>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
102 <li><code>trackScope</code> can be set to false to turn off
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
103 tracking of local variables. This will prevent locals from
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
104 getting the <code>"variable-2"</code> token type, and will
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
105 break completion of locals with javascript-hint.</li>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
106 <li><code>statementIndent</code> which (given a number) will
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
107 determine the amount of indentation to use for statements
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
108 continued on a new line.</li>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
109 <li><code>wordCharacters</code>, a regexp that indicates which
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
110 characters should be considered part of an identifier.
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
111 Defaults to <code>/[\w$]/</code>, which does not handle
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
112 non-ASCII identifiers. Can be set to something more elaborate
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
113 to improve Unicode support.</li>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
114 </ul>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
115 </p>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
116
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
117 <p><strong>MIME types defined:</strong> <code>text/javascript</code>, <code>application/javascript</code>, <code>application/x-javascript</code>, <code>text/ecmascript</code>, <code>application/ecmascript</code>, <code>application/json</code>, <code>application/x-json</code>, <code>application/manifest+json</code>, <code>application/ld+json</code>, <code>text/typescript</code>, <code>application/typescript</code>.</p>
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
118 </article>