claude-maestro 0.1.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +130 -0
- package/bin/maestro.mjs +45 -0
- package/out/main/index.js +5293 -0
- package/out/preload/index.js +130 -0
- package/out/renderer/assets/apl-fqmucPXA.js +140 -0
- package/out/renderer/assets/asciiarmor-DucZyvP0.js +56 -0
- package/out/renderer/assets/asn1-BnOEsgAm.js +144 -0
- package/out/renderer/assets/asterisk-QAlztEwS.js +345 -0
- package/out/renderer/assets/brainfuck-DZVCuF_t.js +53 -0
- package/out/renderer/assets/clike-xqXYL6ge.js +805 -0
- package/out/renderer/assets/clojure-BhXMqnxz.js +849 -0
- package/out/renderer/assets/cmake-BGaNd9E7.js +71 -0
- package/out/renderer/assets/cobol-4yqQntpt.js +120 -0
- package/out/renderer/assets/coffeescript-D2dXvhEc.js +308 -0
- package/out/renderer/assets/commonlisp-CF_VNHQR.js +130 -0
- package/out/renderer/assets/crystal-DyuLTqLs.js +398 -0
- package/out/renderer/assets/css-c-jst79C.js +1783 -0
- package/out/renderer/assets/cypher-Dlu_3r4V.js +121 -0
- package/out/renderer/assets/d-UURgV0Ux.js +179 -0
- package/out/renderer/assets/diff-B_Bi2Crb.js +25 -0
- package/out/renderer/assets/dockerfile-Bvk733Ga.js +201 -0
- package/out/renderer/assets/dtd-Dy74G54E.js +114 -0
- package/out/renderer/assets/dylan-TSb-Nfix.js +314 -0
- package/out/renderer/assets/ebnf-4fKAGW3a.js +140 -0
- package/out/renderer/assets/ecl-B59qGGVg.js +178 -0
- package/out/renderer/assets/eiffel-Dze7nlu3.js +134 -0
- package/out/renderer/assets/elm-DG7jkhNZ.js +176 -0
- package/out/renderer/assets/erlang-BO6gOnGA.js +674 -0
- package/out/renderer/assets/factor-CMxFHDqz.js +65 -0
- package/out/renderer/assets/fcl-CDDUNjTj.js +141 -0
- package/out/renderer/assets/forth-B9D2JCeE.js +116 -0
- package/out/renderer/assets/fortran-CAG2BFbe.js +467 -0
- package/out/renderer/assets/gas-d3KEcW3x.js +294 -0
- package/out/renderer/assets/gherkin-DhZlEZiy.js +115 -0
- package/out/renderer/assets/groovy-CpwJiBl7.js +223 -0
- package/out/renderer/assets/haskell-ySd-OUo8.js +459 -0
- package/out/renderer/assets/haxe-7MlzfeYV.js +514 -0
- package/out/renderer/assets/http-BqypyemW.js +79 -0
- package/out/renderer/assets/idl-4HIGJlDI.js +985 -0
- package/out/renderer/assets/index-2SQReYbL.js +117 -0
- package/out/renderer/assets/index-B4G_DF7l.js +178 -0
- package/out/renderer/assets/index-BJ7HHtlW.css +4015 -0
- package/out/renderer/assets/index-BLk1t3tc.js +151 -0
- package/out/renderer/assets/index-BLtm0KYA.js +157 -0
- package/out/renderer/assets/index-BPgGZ4iY.js +82 -0
- package/out/renderer/assets/index-BQE9vCdv.js +332 -0
- package/out/renderer/assets/index-BYr39Do3.js +61 -0
- package/out/renderer/assets/index-Ba0sUbhl.js +47177 -0
- package/out/renderer/assets/index-BewSkGJT.js +1041 -0
- package/out/renderer/assets/index-BnId7J8H.js +1021 -0
- package/out/renderer/assets/index-Btn996gP.js +406 -0
- package/out/renderer/assets/index-C7i4WyfA.js +311 -0
- package/out/renderer/assets/index-CW9SAu99.js +385 -0
- package/out/renderer/assets/index-CXmk7jHk.js +291 -0
- package/out/renderer/assets/index-CyQp9UDR.js +82 -0
- package/out/renderer/assets/index-Da2gJ_Wd.js +704 -0
- package/out/renderer/assets/index-DkFO-IXC.js +2488 -0
- package/out/renderer/assets/index-DqrDpNqn.js +689 -0
- package/out/renderer/assets/index-Dw7p19YD.js +327 -0
- package/out/renderer/assets/index-QPm3UFYR.js +97 -0
- package/out/renderer/assets/index-RGiHNShF.js +1768 -0
- package/out/renderer/assets/index-RgZE5T_I.js +642 -0
- package/out/renderer/assets/index-t8kJBumF.js +312 -0
- package/out/renderer/assets/javascript-C_OHM9hj.js +994 -0
- package/out/renderer/assets/julia-Bs6JJhYG.js +407 -0
- package/out/renderer/assets/livescript-DmzgM3Yt.js +296 -0
- package/out/renderer/assets/lua-Cvg8VrAA.js +256 -0
- package/out/renderer/assets/mathematica-DNLOL9PQ.js +110 -0
- package/out/renderer/assets/mbox-Ga7d4MMN.js +117 -0
- package/out/renderer/assets/mirc-Dma3B8rS.js +107 -0
- package/out/renderer/assets/mllike-DHn7xckP.js +334 -0
- package/out/renderer/assets/modelica-0d55jYY0.js +147 -0
- package/out/renderer/assets/mscgen-DdqZYINH.js +135 -0
- package/out/renderer/assets/mumps-Btr8VblO.js +93 -0
- package/out/renderer/assets/nginx-DTDtBDVN.js +141 -0
- package/out/renderer/assets/nsis-3zG7tgur.js +62 -0
- package/out/renderer/assets/ntriples-CvgOYMpL.js +153 -0
- package/out/renderer/assets/octave-DYBj3-tl.js +200 -0
- package/out/renderer/assets/oz-R_e8WMIi.js +231 -0
- package/out/renderer/assets/pascal-GD8iposT.js +105 -0
- package/out/renderer/assets/perl-DL9mHpoi.js +1105 -0
- package/out/renderer/assets/pig-C_4T4YIV.js +101 -0
- package/out/renderer/assets/powershell-B0suO7Vd.js +328 -0
- package/out/renderer/assets/properties-BR-vP1aU.js +58 -0
- package/out/renderer/assets/protobuf-BxgpyhoW.js +77 -0
- package/out/renderer/assets/pug-CTXt1f8z.js +405 -0
- package/out/renderer/assets/puppet-Bdao66PW.js +137 -0
- package/out/renderer/assets/python-CvWbmiX4.js +427 -0
- package/out/renderer/assets/q-CrbCVq4a.js +131 -0
- package/out/renderer/assets/r-V7nswm59.js +170 -0
- package/out/renderer/assets/rpm-C-DLY-If.js +109 -0
- package/out/renderer/assets/ruby-JDKLJNK0.js +330 -0
- package/out/renderer/assets/sas-D2UG-yhZ.js +207 -0
- package/out/renderer/assets/scheme-BKzrkGJD.js +222 -0
- package/out/renderer/assets/shell-BlsXDxCn.js +222 -0
- package/out/renderer/assets/sieve-CjwBwOY5.js +135 -0
- package/out/renderer/assets/simple-mode-DMneyfDu.js +130 -0
- package/out/renderer/assets/smalltalk-BOIGQuhN.js +121 -0
- package/out/renderer/assets/solr-CwD7U71z.js +69 -0
- package/out/renderer/assets/sparql-DYskk2vE.js +249 -0
- package/out/renderer/assets/spreadsheet-Bgtt3oLP.js +87 -0
- package/out/renderer/assets/sql-BSrOzCRI.js +354 -0
- package/out/renderer/assets/stex-B6LNC55o.js +231 -0
- package/out/renderer/assets/stylus-BkS-boTH.js +565 -0
- package/out/renderer/assets/swift-FRZi1uvB.js +291 -0
- package/out/renderer/assets/tcl-CUcaCdmq.js +114 -0
- package/out/renderer/assets/textile-BnFpjsrl.js +414 -0
- package/out/renderer/assets/tiddlywiki-CjprD-Qp.js +218 -0
- package/out/renderer/assets/tiki-DK9DOeWn.js +268 -0
- package/out/renderer/assets/toml-BOuWGMcf.js +76 -0
- package/out/renderer/assets/troff-E1bJ0PPL.js +61 -0
- package/out/renderer/assets/ttcn-cfg-Dc39-fIP.js +133 -0
- package/out/renderer/assets/ttcn-tKd4HLu4.js +192 -0
- package/out/renderer/assets/turtle-Dq7-1WAf.js +124 -0
- package/out/renderer/assets/vb-Dp90gtsv.js +196 -0
- package/out/renderer/assets/vbscript-CI6_mxxU.js +479 -0
- package/out/renderer/assets/velocity-BwIZK1TH.js +149 -0
- package/out/renderer/assets/verilog-DDCYnHN8.js +430 -0
- package/out/renderer/assets/vhdl-DCkMIyT9.js +158 -0
- package/out/renderer/assets/webidl-BTLTThCm.js +204 -0
- package/out/renderer/assets/xquery-BrBUuxMR.js +525 -0
- package/out/renderer/assets/yacas-b5lAVEIl.js +130 -0
- package/out/renderer/assets/z80-BZV19vqv.js +93 -0
- package/out/renderer/index.html +16 -0
- package/package.json +109 -0
|
@@ -0,0 +1,414 @@
|
|
|
1
|
+
var TOKEN_STYLES = {
|
|
2
|
+
addition: "inserted",
|
|
3
|
+
attributes: "propertyName",
|
|
4
|
+
bold: "strong",
|
|
5
|
+
cite: "keyword",
|
|
6
|
+
code: "monospace",
|
|
7
|
+
definitionList: "list",
|
|
8
|
+
deletion: "deleted",
|
|
9
|
+
div: "punctuation",
|
|
10
|
+
em: "emphasis",
|
|
11
|
+
footnote: "variable",
|
|
12
|
+
footCite: "qualifier",
|
|
13
|
+
header: "heading",
|
|
14
|
+
html: "comment",
|
|
15
|
+
image: "atom",
|
|
16
|
+
italic: "emphasis",
|
|
17
|
+
link: "link",
|
|
18
|
+
linkDefinition: "link",
|
|
19
|
+
list1: "list",
|
|
20
|
+
list2: "list.special",
|
|
21
|
+
list3: "list",
|
|
22
|
+
notextile: "string.special",
|
|
23
|
+
pre: "operator",
|
|
24
|
+
p: "content",
|
|
25
|
+
quote: "bracket",
|
|
26
|
+
span: "quote",
|
|
27
|
+
specialChar: "character",
|
|
28
|
+
strong: "strong",
|
|
29
|
+
sub: "content.special",
|
|
30
|
+
sup: "content.special",
|
|
31
|
+
table: "variableName.special",
|
|
32
|
+
tableHeading: "operator"
|
|
33
|
+
};
|
|
34
|
+
function startNewLine(stream, state) {
|
|
35
|
+
state.mode = Modes.newLayout;
|
|
36
|
+
state.tableHeading = false;
|
|
37
|
+
if (state.layoutType === "definitionList" && state.spanningLayout && stream.match(RE("definitionListEnd"), false))
|
|
38
|
+
state.spanningLayout = false;
|
|
39
|
+
}
|
|
40
|
+
function handlePhraseModifier(stream, state, ch) {
|
|
41
|
+
if (ch === "_") {
|
|
42
|
+
if (stream.eat("_"))
|
|
43
|
+
return togglePhraseModifier(stream, state, "italic", /__/, 2);
|
|
44
|
+
else
|
|
45
|
+
return togglePhraseModifier(stream, state, "em", /_/, 1);
|
|
46
|
+
}
|
|
47
|
+
if (ch === "*") {
|
|
48
|
+
if (stream.eat("*")) {
|
|
49
|
+
return togglePhraseModifier(stream, state, "bold", /\*\*/, 2);
|
|
50
|
+
}
|
|
51
|
+
return togglePhraseModifier(stream, state, "strong", /\*/, 1);
|
|
52
|
+
}
|
|
53
|
+
if (ch === "[") {
|
|
54
|
+
if (stream.match(/\d+\]/)) state.footCite = true;
|
|
55
|
+
return tokenStyles(state);
|
|
56
|
+
}
|
|
57
|
+
if (ch === "(") {
|
|
58
|
+
var spec = stream.match(/^(r|tm|c)\)/);
|
|
59
|
+
if (spec)
|
|
60
|
+
return TOKEN_STYLES.specialChar;
|
|
61
|
+
}
|
|
62
|
+
if (ch === "<" && stream.match(/(\w+)[^>]+>[^<]+<\/\1>/))
|
|
63
|
+
return TOKEN_STYLES.html;
|
|
64
|
+
if (ch === "?" && stream.eat("?"))
|
|
65
|
+
return togglePhraseModifier(stream, state, "cite", /\?\?/, 2);
|
|
66
|
+
if (ch === "=" && stream.eat("="))
|
|
67
|
+
return togglePhraseModifier(stream, state, "notextile", /==/, 2);
|
|
68
|
+
if (ch === "-" && !stream.eat("-"))
|
|
69
|
+
return togglePhraseModifier(stream, state, "deletion", /-/, 1);
|
|
70
|
+
if (ch === "+")
|
|
71
|
+
return togglePhraseModifier(stream, state, "addition", /\+/, 1);
|
|
72
|
+
if (ch === "~")
|
|
73
|
+
return togglePhraseModifier(stream, state, "sub", /~/, 1);
|
|
74
|
+
if (ch === "^")
|
|
75
|
+
return togglePhraseModifier(stream, state, "sup", /\^/, 1);
|
|
76
|
+
if (ch === "%")
|
|
77
|
+
return togglePhraseModifier(stream, state, "span", /%/, 1);
|
|
78
|
+
if (ch === "@")
|
|
79
|
+
return togglePhraseModifier(stream, state, "code", /@/, 1);
|
|
80
|
+
if (ch === "!") {
|
|
81
|
+
var type = togglePhraseModifier(stream, state, "image", /(?:\([^\)]+\))?!/, 1);
|
|
82
|
+
stream.match(/^:\S+/);
|
|
83
|
+
return type;
|
|
84
|
+
}
|
|
85
|
+
return tokenStyles(state);
|
|
86
|
+
}
|
|
87
|
+
function togglePhraseModifier(stream, state, phraseModifier, closeRE, openSize) {
|
|
88
|
+
var charBefore = stream.pos > openSize ? stream.string.charAt(stream.pos - openSize - 1) : null;
|
|
89
|
+
var charAfter = stream.peek();
|
|
90
|
+
if (state[phraseModifier]) {
|
|
91
|
+
if ((!charAfter || /\W/.test(charAfter)) && charBefore && /\S/.test(charBefore)) {
|
|
92
|
+
var type = tokenStyles(state);
|
|
93
|
+
state[phraseModifier] = false;
|
|
94
|
+
return type;
|
|
95
|
+
}
|
|
96
|
+
} else if ((!charBefore || /\W/.test(charBefore)) && charAfter && /\S/.test(charAfter) && stream.match(new RegExp("^.*\\S" + closeRE.source + "(?:\\W|$)"), false)) {
|
|
97
|
+
state[phraseModifier] = true;
|
|
98
|
+
state.mode = Modes.attributes;
|
|
99
|
+
}
|
|
100
|
+
return tokenStyles(state);
|
|
101
|
+
}
|
|
102
|
+
function tokenStyles(state) {
|
|
103
|
+
var disabled = textileDisabled(state);
|
|
104
|
+
if (disabled) return disabled;
|
|
105
|
+
var styles = [];
|
|
106
|
+
if (state.layoutType) styles.push(TOKEN_STYLES[state.layoutType]);
|
|
107
|
+
styles = styles.concat(activeStyles(
|
|
108
|
+
state,
|
|
109
|
+
"addition",
|
|
110
|
+
"bold",
|
|
111
|
+
"cite",
|
|
112
|
+
"code",
|
|
113
|
+
"deletion",
|
|
114
|
+
"em",
|
|
115
|
+
"footCite",
|
|
116
|
+
"image",
|
|
117
|
+
"italic",
|
|
118
|
+
"link",
|
|
119
|
+
"span",
|
|
120
|
+
"strong",
|
|
121
|
+
"sub",
|
|
122
|
+
"sup",
|
|
123
|
+
"table",
|
|
124
|
+
"tableHeading"
|
|
125
|
+
));
|
|
126
|
+
if (state.layoutType === "header")
|
|
127
|
+
styles.push(TOKEN_STYLES.header + "-" + state.header);
|
|
128
|
+
return styles.length ? styles.join(" ") : null;
|
|
129
|
+
}
|
|
130
|
+
function textileDisabled(state) {
|
|
131
|
+
var type = state.layoutType;
|
|
132
|
+
switch (type) {
|
|
133
|
+
case "notextile":
|
|
134
|
+
case "code":
|
|
135
|
+
case "pre":
|
|
136
|
+
return TOKEN_STYLES[type];
|
|
137
|
+
default:
|
|
138
|
+
if (state.notextile)
|
|
139
|
+
return TOKEN_STYLES.notextile + (type ? " " + TOKEN_STYLES[type] : "");
|
|
140
|
+
return null;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
function activeStyles(state) {
|
|
144
|
+
var styles = [];
|
|
145
|
+
for (var i = 1; i < arguments.length; ++i) {
|
|
146
|
+
if (state[arguments[i]])
|
|
147
|
+
styles.push(TOKEN_STYLES[arguments[i]]);
|
|
148
|
+
}
|
|
149
|
+
return styles;
|
|
150
|
+
}
|
|
151
|
+
function blankLine(state) {
|
|
152
|
+
var spanningLayout = state.spanningLayout, type = state.layoutType;
|
|
153
|
+
for (var key in state) if (state.hasOwnProperty(key))
|
|
154
|
+
delete state[key];
|
|
155
|
+
state.mode = Modes.newLayout;
|
|
156
|
+
if (spanningLayout) {
|
|
157
|
+
state.layoutType = type;
|
|
158
|
+
state.spanningLayout = true;
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
var REs = {
|
|
162
|
+
cache: {},
|
|
163
|
+
single: {
|
|
164
|
+
bc: "bc",
|
|
165
|
+
bq: "bq",
|
|
166
|
+
definitionList: /- .*?:=+/,
|
|
167
|
+
definitionListEnd: /.*=:\s*$/,
|
|
168
|
+
div: "div",
|
|
169
|
+
drawTable: /\|.*\|/,
|
|
170
|
+
foot: /fn\d+/,
|
|
171
|
+
header: /h[1-6]/,
|
|
172
|
+
html: /\s*<(?:\/)?(\w+)(?:[^>]+)?>(?:[^<]+<\/\1>)?/,
|
|
173
|
+
link: /[^"]+":\S/,
|
|
174
|
+
linkDefinition: /\[[^\s\]]+\]\S+/,
|
|
175
|
+
list: /(?:#+|\*+)/,
|
|
176
|
+
notextile: "notextile",
|
|
177
|
+
para: "p",
|
|
178
|
+
pre: "pre",
|
|
179
|
+
table: "table",
|
|
180
|
+
tableCellAttributes: /[\/\\]\d+/,
|
|
181
|
+
tableHeading: /\|_\./,
|
|
182
|
+
tableText: /[^"_\*\[\(\?\+~\^%@|-]+/,
|
|
183
|
+
text: /[^!"_=\*\[\(<\?\+~\^%@-]+/
|
|
184
|
+
},
|
|
185
|
+
attributes: {
|
|
186
|
+
align: /(?:<>|<|>|=)/,
|
|
187
|
+
selector: /\([^\(][^\)]+\)/,
|
|
188
|
+
lang: /\[[^\[\]]+\]/,
|
|
189
|
+
pad: /(?:\(+|\)+){1,2}/,
|
|
190
|
+
css: /\{[^\}]+\}/
|
|
191
|
+
},
|
|
192
|
+
createRe: function(name) {
|
|
193
|
+
switch (name) {
|
|
194
|
+
case "drawTable":
|
|
195
|
+
return REs.makeRe("^", REs.single.drawTable, "$");
|
|
196
|
+
case "html":
|
|
197
|
+
return REs.makeRe("^", REs.single.html, "(?:", REs.single.html, ")*", "$");
|
|
198
|
+
case "linkDefinition":
|
|
199
|
+
return REs.makeRe("^", REs.single.linkDefinition, "$");
|
|
200
|
+
case "listLayout":
|
|
201
|
+
return REs.makeRe("^", REs.single.list, RE("allAttributes"), "*\\s+");
|
|
202
|
+
case "tableCellAttributes":
|
|
203
|
+
return REs.makeRe("^", REs.choiceRe(
|
|
204
|
+
REs.single.tableCellAttributes,
|
|
205
|
+
RE("allAttributes")
|
|
206
|
+
), "+\\.");
|
|
207
|
+
case "type":
|
|
208
|
+
return REs.makeRe("^", RE("allTypes"));
|
|
209
|
+
case "typeLayout":
|
|
210
|
+
return REs.makeRe(
|
|
211
|
+
"^",
|
|
212
|
+
RE("allTypes"),
|
|
213
|
+
RE("allAttributes"),
|
|
214
|
+
"*\\.\\.?",
|
|
215
|
+
"(\\s+|$)"
|
|
216
|
+
);
|
|
217
|
+
case "attributes":
|
|
218
|
+
return REs.makeRe("^", RE("allAttributes"), "+");
|
|
219
|
+
case "allTypes":
|
|
220
|
+
return REs.choiceRe(
|
|
221
|
+
REs.single.div,
|
|
222
|
+
REs.single.foot,
|
|
223
|
+
REs.single.header,
|
|
224
|
+
REs.single.bc,
|
|
225
|
+
REs.single.bq,
|
|
226
|
+
REs.single.notextile,
|
|
227
|
+
REs.single.pre,
|
|
228
|
+
REs.single.table,
|
|
229
|
+
REs.single.para
|
|
230
|
+
);
|
|
231
|
+
case "allAttributes":
|
|
232
|
+
return REs.choiceRe(
|
|
233
|
+
REs.attributes.selector,
|
|
234
|
+
REs.attributes.css,
|
|
235
|
+
REs.attributes.lang,
|
|
236
|
+
REs.attributes.align,
|
|
237
|
+
REs.attributes.pad
|
|
238
|
+
);
|
|
239
|
+
default:
|
|
240
|
+
return REs.makeRe("^", REs.single[name]);
|
|
241
|
+
}
|
|
242
|
+
},
|
|
243
|
+
makeRe: function() {
|
|
244
|
+
var pattern = "";
|
|
245
|
+
for (var i = 0; i < arguments.length; ++i) {
|
|
246
|
+
var arg = arguments[i];
|
|
247
|
+
pattern += typeof arg === "string" ? arg : arg.source;
|
|
248
|
+
}
|
|
249
|
+
return new RegExp(pattern);
|
|
250
|
+
},
|
|
251
|
+
choiceRe: function() {
|
|
252
|
+
var parts = [arguments[0]];
|
|
253
|
+
for (var i = 1; i < arguments.length; ++i) {
|
|
254
|
+
parts[i * 2 - 1] = "|";
|
|
255
|
+
parts[i * 2] = arguments[i];
|
|
256
|
+
}
|
|
257
|
+
parts.unshift("(?:");
|
|
258
|
+
parts.push(")");
|
|
259
|
+
return REs.makeRe.apply(null, parts);
|
|
260
|
+
}
|
|
261
|
+
};
|
|
262
|
+
function RE(name) {
|
|
263
|
+
return REs.cache[name] || (REs.cache[name] = REs.createRe(name));
|
|
264
|
+
}
|
|
265
|
+
var Modes = {
|
|
266
|
+
newLayout: function(stream, state) {
|
|
267
|
+
if (stream.match(RE("typeLayout"), false)) {
|
|
268
|
+
state.spanningLayout = false;
|
|
269
|
+
return (state.mode = Modes.blockType)(stream, state);
|
|
270
|
+
}
|
|
271
|
+
var newMode;
|
|
272
|
+
if (!textileDisabled(state)) {
|
|
273
|
+
if (stream.match(RE("listLayout"), false))
|
|
274
|
+
newMode = Modes.list;
|
|
275
|
+
else if (stream.match(RE("drawTable"), false))
|
|
276
|
+
newMode = Modes.table;
|
|
277
|
+
else if (stream.match(RE("linkDefinition"), false))
|
|
278
|
+
newMode = Modes.linkDefinition;
|
|
279
|
+
else if (stream.match(RE("definitionList")))
|
|
280
|
+
newMode = Modes.definitionList;
|
|
281
|
+
else if (stream.match(RE("html"), false))
|
|
282
|
+
newMode = Modes.html;
|
|
283
|
+
}
|
|
284
|
+
return (state.mode = newMode || Modes.text)(stream, state);
|
|
285
|
+
},
|
|
286
|
+
blockType: function(stream, state) {
|
|
287
|
+
var match, type;
|
|
288
|
+
state.layoutType = null;
|
|
289
|
+
if (match = stream.match(RE("type")))
|
|
290
|
+
type = match[0];
|
|
291
|
+
else
|
|
292
|
+
return (state.mode = Modes.text)(stream, state);
|
|
293
|
+
if (match = type.match(RE("header"))) {
|
|
294
|
+
state.layoutType = "header";
|
|
295
|
+
state.header = parseInt(match[0][1]);
|
|
296
|
+
} else if (type.match(RE("bq"))) {
|
|
297
|
+
state.layoutType = "quote";
|
|
298
|
+
} else if (type.match(RE("bc"))) {
|
|
299
|
+
state.layoutType = "code";
|
|
300
|
+
} else if (type.match(RE("foot"))) {
|
|
301
|
+
state.layoutType = "footnote";
|
|
302
|
+
} else if (type.match(RE("notextile"))) {
|
|
303
|
+
state.layoutType = "notextile";
|
|
304
|
+
} else if (type.match(RE("pre"))) {
|
|
305
|
+
state.layoutType = "pre";
|
|
306
|
+
} else if (type.match(RE("div"))) {
|
|
307
|
+
state.layoutType = "div";
|
|
308
|
+
} else if (type.match(RE("table"))) {
|
|
309
|
+
state.layoutType = "table";
|
|
310
|
+
}
|
|
311
|
+
state.mode = Modes.attributes;
|
|
312
|
+
return tokenStyles(state);
|
|
313
|
+
},
|
|
314
|
+
text: function(stream, state) {
|
|
315
|
+
if (stream.match(RE("text"))) return tokenStyles(state);
|
|
316
|
+
var ch = stream.next();
|
|
317
|
+
if (ch === '"')
|
|
318
|
+
return (state.mode = Modes.link)(stream, state);
|
|
319
|
+
return handlePhraseModifier(stream, state, ch);
|
|
320
|
+
},
|
|
321
|
+
attributes: function(stream, state) {
|
|
322
|
+
state.mode = Modes.layoutLength;
|
|
323
|
+
if (stream.match(RE("attributes")))
|
|
324
|
+
return TOKEN_STYLES.attributes;
|
|
325
|
+
else
|
|
326
|
+
return tokenStyles(state);
|
|
327
|
+
},
|
|
328
|
+
layoutLength: function(stream, state) {
|
|
329
|
+
if (stream.eat(".") && stream.eat("."))
|
|
330
|
+
state.spanningLayout = true;
|
|
331
|
+
state.mode = Modes.text;
|
|
332
|
+
return tokenStyles(state);
|
|
333
|
+
},
|
|
334
|
+
list: function(stream, state) {
|
|
335
|
+
var match = stream.match(RE("list"));
|
|
336
|
+
state.listDepth = match[0].length;
|
|
337
|
+
var listMod = (state.listDepth - 1) % 3;
|
|
338
|
+
if (!listMod)
|
|
339
|
+
state.layoutType = "list1";
|
|
340
|
+
else if (listMod === 1)
|
|
341
|
+
state.layoutType = "list2";
|
|
342
|
+
else
|
|
343
|
+
state.layoutType = "list3";
|
|
344
|
+
state.mode = Modes.attributes;
|
|
345
|
+
return tokenStyles(state);
|
|
346
|
+
},
|
|
347
|
+
link: function(stream, state) {
|
|
348
|
+
state.mode = Modes.text;
|
|
349
|
+
if (stream.match(RE("link"))) {
|
|
350
|
+
stream.match(/\S+/);
|
|
351
|
+
return TOKEN_STYLES.link;
|
|
352
|
+
}
|
|
353
|
+
return tokenStyles(state);
|
|
354
|
+
},
|
|
355
|
+
linkDefinition: function(stream) {
|
|
356
|
+
stream.skipToEnd();
|
|
357
|
+
return TOKEN_STYLES.linkDefinition;
|
|
358
|
+
},
|
|
359
|
+
definitionList: function(stream, state) {
|
|
360
|
+
stream.match(RE("definitionList"));
|
|
361
|
+
state.layoutType = "definitionList";
|
|
362
|
+
if (stream.match(/\s*$/))
|
|
363
|
+
state.spanningLayout = true;
|
|
364
|
+
else
|
|
365
|
+
state.mode = Modes.attributes;
|
|
366
|
+
return tokenStyles(state);
|
|
367
|
+
},
|
|
368
|
+
html: function(stream) {
|
|
369
|
+
stream.skipToEnd();
|
|
370
|
+
return TOKEN_STYLES.html;
|
|
371
|
+
},
|
|
372
|
+
table: function(stream, state) {
|
|
373
|
+
state.layoutType = "table";
|
|
374
|
+
return (state.mode = Modes.tableCell)(stream, state);
|
|
375
|
+
},
|
|
376
|
+
tableCell: function(stream, state) {
|
|
377
|
+
if (stream.match(RE("tableHeading")))
|
|
378
|
+
state.tableHeading = true;
|
|
379
|
+
else
|
|
380
|
+
stream.eat("|");
|
|
381
|
+
state.mode = Modes.tableCellAttributes;
|
|
382
|
+
return tokenStyles(state);
|
|
383
|
+
},
|
|
384
|
+
tableCellAttributes: function(stream, state) {
|
|
385
|
+
state.mode = Modes.tableText;
|
|
386
|
+
if (stream.match(RE("tableCellAttributes")))
|
|
387
|
+
return TOKEN_STYLES.attributes;
|
|
388
|
+
else
|
|
389
|
+
return tokenStyles(state);
|
|
390
|
+
},
|
|
391
|
+
tableText: function(stream, state) {
|
|
392
|
+
if (stream.match(RE("tableText")))
|
|
393
|
+
return tokenStyles(state);
|
|
394
|
+
if (stream.peek() === "|") {
|
|
395
|
+
state.mode = Modes.tableCell;
|
|
396
|
+
return tokenStyles(state);
|
|
397
|
+
}
|
|
398
|
+
return handlePhraseModifier(stream, state, stream.next());
|
|
399
|
+
}
|
|
400
|
+
};
|
|
401
|
+
const textile = {
|
|
402
|
+
name: "textile",
|
|
403
|
+
startState: function() {
|
|
404
|
+
return { mode: Modes.newLayout };
|
|
405
|
+
},
|
|
406
|
+
token: function(stream, state) {
|
|
407
|
+
if (stream.sol()) startNewLine(stream, state);
|
|
408
|
+
return state.mode(stream, state);
|
|
409
|
+
},
|
|
410
|
+
blankLine
|
|
411
|
+
};
|
|
412
|
+
export {
|
|
413
|
+
textile
|
|
414
|
+
};
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
var textwords = {};
|
|
2
|
+
var keywords = {
|
|
3
|
+
"allTags": true,
|
|
4
|
+
"closeAll": true,
|
|
5
|
+
"list": true,
|
|
6
|
+
"newJournal": true,
|
|
7
|
+
"newTiddler": true,
|
|
8
|
+
"permaview": true,
|
|
9
|
+
"saveChanges": true,
|
|
10
|
+
"search": true,
|
|
11
|
+
"slider": true,
|
|
12
|
+
"tabs": true,
|
|
13
|
+
"tag": true,
|
|
14
|
+
"tagging": true,
|
|
15
|
+
"tags": true,
|
|
16
|
+
"tiddler": true,
|
|
17
|
+
"timeline": true,
|
|
18
|
+
"today": true,
|
|
19
|
+
"version": true,
|
|
20
|
+
"option": true,
|
|
21
|
+
"with": true,
|
|
22
|
+
"filter": true
|
|
23
|
+
};
|
|
24
|
+
var isSpaceName = /[\w_\-]/i, reHR = /^\-\-\-\-+$/, reWikiCommentStart = /^\/\*\*\*$/, reWikiCommentStop = /^\*\*\*\/$/, reBlockQuote = /^<<<$/, reJsCodeStart = /^\/\/\{\{\{$/, reJsCodeStop = /^\/\/\}\}\}$/, reXmlCodeStart = /^<!--\{\{\{-->$/, reXmlCodeStop = /^<!--\}\}\}-->$/, reCodeBlockStart = /^\{\{\{$/, reCodeBlockStop = /^\}\}\}$/, reUntilCodeStop = /.*?\}\}\}/;
|
|
25
|
+
function chain(stream, state, f) {
|
|
26
|
+
state.tokenize = f;
|
|
27
|
+
return f(stream, state);
|
|
28
|
+
}
|
|
29
|
+
function tokenBase(stream, state) {
|
|
30
|
+
var sol = stream.sol(), ch = stream.peek();
|
|
31
|
+
state.block = false;
|
|
32
|
+
if (sol && /[<\/\*{}\-]/.test(ch)) {
|
|
33
|
+
if (stream.match(reCodeBlockStart)) {
|
|
34
|
+
state.block = true;
|
|
35
|
+
return chain(stream, state, twTokenCode);
|
|
36
|
+
}
|
|
37
|
+
if (stream.match(reBlockQuote))
|
|
38
|
+
return "quote";
|
|
39
|
+
if (stream.match(reWikiCommentStart) || stream.match(reWikiCommentStop))
|
|
40
|
+
return "comment";
|
|
41
|
+
if (stream.match(reJsCodeStart) || stream.match(reJsCodeStop) || stream.match(reXmlCodeStart) || stream.match(reXmlCodeStop))
|
|
42
|
+
return "comment";
|
|
43
|
+
if (stream.match(reHR))
|
|
44
|
+
return "contentSeparator";
|
|
45
|
+
}
|
|
46
|
+
stream.next();
|
|
47
|
+
if (sol && /[\/\*!#;:>|]/.test(ch)) {
|
|
48
|
+
if (ch == "!") {
|
|
49
|
+
stream.skipToEnd();
|
|
50
|
+
return "header";
|
|
51
|
+
}
|
|
52
|
+
if (ch == "*") {
|
|
53
|
+
stream.eatWhile("*");
|
|
54
|
+
return "comment";
|
|
55
|
+
}
|
|
56
|
+
if (ch == "#") {
|
|
57
|
+
stream.eatWhile("#");
|
|
58
|
+
return "comment";
|
|
59
|
+
}
|
|
60
|
+
if (ch == ";") {
|
|
61
|
+
stream.eatWhile(";");
|
|
62
|
+
return "comment";
|
|
63
|
+
}
|
|
64
|
+
if (ch == ":") {
|
|
65
|
+
stream.eatWhile(":");
|
|
66
|
+
return "comment";
|
|
67
|
+
}
|
|
68
|
+
if (ch == ">") {
|
|
69
|
+
stream.eatWhile(">");
|
|
70
|
+
return "quote";
|
|
71
|
+
}
|
|
72
|
+
if (ch == "|")
|
|
73
|
+
return "header";
|
|
74
|
+
}
|
|
75
|
+
if (ch == "{" && stream.match("{{"))
|
|
76
|
+
return chain(stream, state, twTokenCode);
|
|
77
|
+
if (/[hf]/i.test(ch) && /[ti]/i.test(stream.peek()) && stream.match(/\b(ttps?|tp|ile):\/\/[\-A-Z0-9+&@#\/%?=~_|$!:,.;]*[A-Z0-9+&@#\/%=~_|$]/i))
|
|
78
|
+
return "link";
|
|
79
|
+
if (ch == '"')
|
|
80
|
+
return "string";
|
|
81
|
+
if (ch == "~")
|
|
82
|
+
return "brace";
|
|
83
|
+
if (/[\[\]]/.test(ch) && stream.match(ch))
|
|
84
|
+
return "brace";
|
|
85
|
+
if (ch == "@") {
|
|
86
|
+
stream.eatWhile(isSpaceName);
|
|
87
|
+
return "link";
|
|
88
|
+
}
|
|
89
|
+
if (/\d/.test(ch)) {
|
|
90
|
+
stream.eatWhile(/\d/);
|
|
91
|
+
return "number";
|
|
92
|
+
}
|
|
93
|
+
if (ch == "/") {
|
|
94
|
+
if (stream.eat("%")) {
|
|
95
|
+
return chain(stream, state, twTokenComment);
|
|
96
|
+
} else if (stream.eat("/")) {
|
|
97
|
+
return chain(stream, state, twTokenEm);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
if (ch == "_" && stream.eat("_"))
|
|
101
|
+
return chain(stream, state, twTokenUnderline);
|
|
102
|
+
if (ch == "-" && stream.eat("-")) {
|
|
103
|
+
if (stream.peek() != " ")
|
|
104
|
+
return chain(stream, state, twTokenStrike);
|
|
105
|
+
if (stream.peek() == " ")
|
|
106
|
+
return "brace";
|
|
107
|
+
}
|
|
108
|
+
if (ch == "'" && stream.eat("'"))
|
|
109
|
+
return chain(stream, state, twTokenStrong);
|
|
110
|
+
if (ch == "<" && stream.eat("<"))
|
|
111
|
+
return chain(stream, state, twTokenMacro);
|
|
112
|
+
stream.eatWhile(/[\w\$_]/);
|
|
113
|
+
return textwords.propertyIsEnumerable(stream.current()) ? "keyword" : null;
|
|
114
|
+
}
|
|
115
|
+
function twTokenComment(stream, state) {
|
|
116
|
+
var maybeEnd = false, ch;
|
|
117
|
+
while (ch = stream.next()) {
|
|
118
|
+
if (ch == "/" && maybeEnd) {
|
|
119
|
+
state.tokenize = tokenBase;
|
|
120
|
+
break;
|
|
121
|
+
}
|
|
122
|
+
maybeEnd = ch == "%";
|
|
123
|
+
}
|
|
124
|
+
return "comment";
|
|
125
|
+
}
|
|
126
|
+
function twTokenStrong(stream, state) {
|
|
127
|
+
var maybeEnd = false, ch;
|
|
128
|
+
while (ch = stream.next()) {
|
|
129
|
+
if (ch == "'" && maybeEnd) {
|
|
130
|
+
state.tokenize = tokenBase;
|
|
131
|
+
break;
|
|
132
|
+
}
|
|
133
|
+
maybeEnd = ch == "'";
|
|
134
|
+
}
|
|
135
|
+
return "strong";
|
|
136
|
+
}
|
|
137
|
+
function twTokenCode(stream, state) {
|
|
138
|
+
var sb = state.block;
|
|
139
|
+
if (sb && stream.current()) {
|
|
140
|
+
return "comment";
|
|
141
|
+
}
|
|
142
|
+
if (!sb && stream.match(reUntilCodeStop)) {
|
|
143
|
+
state.tokenize = tokenBase;
|
|
144
|
+
return "comment";
|
|
145
|
+
}
|
|
146
|
+
if (sb && stream.sol() && stream.match(reCodeBlockStop)) {
|
|
147
|
+
state.tokenize = tokenBase;
|
|
148
|
+
return "comment";
|
|
149
|
+
}
|
|
150
|
+
stream.next();
|
|
151
|
+
return "comment";
|
|
152
|
+
}
|
|
153
|
+
function twTokenEm(stream, state) {
|
|
154
|
+
var maybeEnd = false, ch;
|
|
155
|
+
while (ch = stream.next()) {
|
|
156
|
+
if (ch == "/" && maybeEnd) {
|
|
157
|
+
state.tokenize = tokenBase;
|
|
158
|
+
break;
|
|
159
|
+
}
|
|
160
|
+
maybeEnd = ch == "/";
|
|
161
|
+
}
|
|
162
|
+
return "emphasis";
|
|
163
|
+
}
|
|
164
|
+
function twTokenUnderline(stream, state) {
|
|
165
|
+
var maybeEnd = false, ch;
|
|
166
|
+
while (ch = stream.next()) {
|
|
167
|
+
if (ch == "_" && maybeEnd) {
|
|
168
|
+
state.tokenize = tokenBase;
|
|
169
|
+
break;
|
|
170
|
+
}
|
|
171
|
+
maybeEnd = ch == "_";
|
|
172
|
+
}
|
|
173
|
+
return "link";
|
|
174
|
+
}
|
|
175
|
+
function twTokenStrike(stream, state) {
|
|
176
|
+
var maybeEnd = false, ch;
|
|
177
|
+
while (ch = stream.next()) {
|
|
178
|
+
if (ch == "-" && maybeEnd) {
|
|
179
|
+
state.tokenize = tokenBase;
|
|
180
|
+
break;
|
|
181
|
+
}
|
|
182
|
+
maybeEnd = ch == "-";
|
|
183
|
+
}
|
|
184
|
+
return "deleted";
|
|
185
|
+
}
|
|
186
|
+
function twTokenMacro(stream, state) {
|
|
187
|
+
if (stream.current() == "<<") {
|
|
188
|
+
return "meta";
|
|
189
|
+
}
|
|
190
|
+
var ch = stream.next();
|
|
191
|
+
if (!ch) {
|
|
192
|
+
state.tokenize = tokenBase;
|
|
193
|
+
return null;
|
|
194
|
+
}
|
|
195
|
+
if (ch == ">") {
|
|
196
|
+
if (stream.peek() == ">") {
|
|
197
|
+
stream.next();
|
|
198
|
+
state.tokenize = tokenBase;
|
|
199
|
+
return "meta";
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
stream.eatWhile(/[\w\$_]/);
|
|
203
|
+
return keywords.propertyIsEnumerable(stream.current()) ? "keyword" : null;
|
|
204
|
+
}
|
|
205
|
+
const tiddlyWiki = {
|
|
206
|
+
name: "tiddlywiki",
|
|
207
|
+
startState: function() {
|
|
208
|
+
return { tokenize: tokenBase };
|
|
209
|
+
},
|
|
210
|
+
token: function(stream, state) {
|
|
211
|
+
if (stream.eatSpace()) return null;
|
|
212
|
+
var style = state.tokenize(stream, state);
|
|
213
|
+
return style;
|
|
214
|
+
}
|
|
215
|
+
};
|
|
216
|
+
export {
|
|
217
|
+
tiddlyWiki
|
|
218
|
+
};
|