@zjlab-frontier/markdown 1.0.4
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 +148 -0
- package/dist/Tableau10-D7jGxypv.mjs +8 -0
- package/dist/arc-BkFOiLi7.mjs +84 -0
- package/dist/array-CqVTtuYm.mjs +6 -0
- package/dist/blockDiagram-c4efeb88-CngVNufX.mjs +1221 -0
- package/dist/c4Diagram-c83219d4-CvSWXhSV.mjs +1579 -0
- package/dist/channel-BCTzeqLo.mjs +5 -0
- package/dist/classDiagram-beda092f-8UkpWDgI.mjs +218 -0
- package/dist/classDiagram-v2-2358418a-D3LsBhTm.mjs +200 -0
- package/dist/clone-DZgGXtyK.mjs +8 -0
- package/dist/createText-1719965b-DMv-Bu7A.mjs +155 -0
- package/dist/edges-96097737-BeVwLt3S.mjs +1088 -0
- package/dist/erDiagram-0228fc6a-GXXkRZ8r.mjs +929 -0
- package/dist/flowDb-c6c81e3f-CrOg5i55.mjs +1126 -0
- package/dist/flowDiagram-50d868cf-sXe_oFAW.mjs +788 -0
- package/dist/flowDiagram-v2-4f6560a1-CoKYvZkH.mjs +17 -0
- package/dist/flowchart-elk-definition-6af322e1-SuvGsuBl.mjs +48146 -0
- package/dist/ganttDiagram-a2739b55-BbWq9bqY.mjs +2477 -0
- package/dist/gitGraphDiagram-82fe8481-C6-e4UmK.mjs +1264 -0
- package/dist/graph-CoIGCRFf.mjs +847 -0
- package/dist/index-5325376f-BENBY8aO.mjs +373 -0
- package/dist/index-5_ujiRGo.mjs +46276 -0
- package/dist/index.css +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.mjs +8 -0
- package/dist/index.umd.js +2421 -0
- package/dist/infoDiagram-8eee0895-BEAb2pCD.mjs +319 -0
- package/dist/init-DjUOC4st.mjs +16 -0
- package/dist/journeyDiagram-c64418c1-CERjyYnA.mjs +801 -0
- package/dist/layout-aCAVHR2T.mjs +1472 -0
- package/dist/line-BGunMwE-.mjs +33 -0
- package/dist/linear-DciWi0hE.mjs +423 -0
- package/dist/markdown.d.ts +25 -0
- package/dist/mindmap-definition-8da855dc-Cc8_U7zD.mjs +21936 -0
- package/dist/ordinal-C0oynhte.mjs +61 -0
- package/dist/path-DLwuMfdd.mjs +84 -0
- package/dist/pieDiagram-a8764435-B00hy7Ez.mjs +500 -0
- package/dist/quadrantDiagram-1e28029f-DR7IGAoM.mjs +903 -0
- package/dist/requirementDiagram-08caed73-o6N3X3-m.mjs +767 -0
- package/dist/sankeyDiagram-a04cb91d-CYF9Ro1W.mjs +802 -0
- package/dist/sequenceDiagram-c5b8d532-vz_R7xBU.mjs +2234 -0
- package/dist/stateDiagram-1ecb1508-B0YUHnuE.mjs +266 -0
- package/dist/stateDiagram-v2-c2b004d7-CDTm1Jfb.mjs +184 -0
- package/dist/styles/highlight.scss +115 -0
- package/dist/styles/markdown.scss +1163 -0
- package/dist/styles-b4e223ce-C_-huVuQ.mjs +1089 -0
- package/dist/styles-ca3715f6-soe07Bnw.mjs +960 -0
- package/dist/styles-d45a18b0-0ZXwJp5P.mjs +436 -0
- package/dist/svgDrawCommon-b86b1483-UCLksviB.mjs +64 -0
- package/dist/timeline-definition-faaaa080-Dt5unv7p.mjs +792 -0
- package/dist/vite.config.d.ts +2 -0
- package/dist/xychartDiagram-f5964ef8-BZWS0E_9.mjs +1282 -0
- package/package.json +66 -0
|
@@ -0,0 +1,319 @@
|
|
|
1
|
+
import { l as Y, T as D, e as M } from "./index-5_ujiRGo.mjs";
|
|
2
|
+
var O = (function() {
|
|
3
|
+
var a = function(u, t, e, n) {
|
|
4
|
+
for (e = e || {}, n = u.length; n--; e[u[n]] = t)
|
|
5
|
+
;
|
|
6
|
+
return e;
|
|
7
|
+
}, f = [6, 9, 10], m = {
|
|
8
|
+
trace: function() {
|
|
9
|
+
},
|
|
10
|
+
yy: {},
|
|
11
|
+
symbols_: { error: 2, start: 3, info: 4, document: 5, EOF: 6, line: 7, statement: 8, NL: 9, showInfo: 10, $accept: 0, $end: 1 },
|
|
12
|
+
terminals_: { 2: "error", 4: "info", 6: "EOF", 9: "NL", 10: "showInfo" },
|
|
13
|
+
productions_: [0, [3, 3], [5, 0], [5, 2], [7, 1], [7, 1], [8, 1]],
|
|
14
|
+
performAction: function(t, e, n, s, r, i, d) {
|
|
15
|
+
switch (i.length - 1, r) {
|
|
16
|
+
case 1:
|
|
17
|
+
return s;
|
|
18
|
+
case 4:
|
|
19
|
+
break;
|
|
20
|
+
case 6:
|
|
21
|
+
s.setInfo(!0);
|
|
22
|
+
break;
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
table: [{ 3: 1, 4: [1, 2] }, { 1: [3] }, a(f, [2, 2], { 5: 3 }), { 6: [1, 4], 7: 5, 8: 6, 9: [1, 7], 10: [1, 8] }, { 1: [2, 1] }, a(f, [2, 3]), a(f, [2, 4]), a(f, [2, 5]), a(f, [2, 6])],
|
|
26
|
+
defaultActions: { 4: [2, 1] },
|
|
27
|
+
parseError: function(t, e) {
|
|
28
|
+
if (e.recoverable)
|
|
29
|
+
this.trace(t);
|
|
30
|
+
else {
|
|
31
|
+
var n = new Error(t);
|
|
32
|
+
throw n.hash = e, n;
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
parse: function(t) {
|
|
36
|
+
var e = this, n = [0], s = [], r = [null], i = [], d = this.table, P = "", v = 0, T = 0, N = 2, L = 1, R = i.slice.call(arguments, 1), o = Object.create(this.lexer), p = { yy: {} };
|
|
37
|
+
for (var E in this.yy)
|
|
38
|
+
Object.prototype.hasOwnProperty.call(this.yy, E) && (p.yy[E] = this.yy[E]);
|
|
39
|
+
o.setInput(t, p.yy), p.yy.lexer = o, p.yy.parser = this, typeof o.yylloc > "u" && (o.yylloc = {});
|
|
40
|
+
var I = o.yylloc;
|
|
41
|
+
i.push(I);
|
|
42
|
+
var z = o.options && o.options.ranges;
|
|
43
|
+
typeof p.yy.parseError == "function" ? this.parseError = p.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError;
|
|
44
|
+
function U() {
|
|
45
|
+
var y;
|
|
46
|
+
return y = s.pop() || o.lex() || L, typeof y != "number" && (y instanceof Array && (s = y, y = s.pop()), y = e.symbols_[y] || y), y;
|
|
47
|
+
}
|
|
48
|
+
for (var l, g, h, w, _ = {}, b, c, F, S; ; ) {
|
|
49
|
+
if (g = n[n.length - 1], this.defaultActions[g] ? h = this.defaultActions[g] : ((l === null || typeof l > "u") && (l = U()), h = d[g] && d[g][l]), typeof h > "u" || !h.length || !h[0]) {
|
|
50
|
+
var A = "";
|
|
51
|
+
S = [];
|
|
52
|
+
for (b in d[g])
|
|
53
|
+
this.terminals_[b] && b > N && S.push("'" + this.terminals_[b] + "'");
|
|
54
|
+
o.showPosition ? A = "Parse error on line " + (v + 1) + `:
|
|
55
|
+
` + o.showPosition() + `
|
|
56
|
+
Expecting ` + S.join(", ") + ", got '" + (this.terminals_[l] || l) + "'" : A = "Parse error on line " + (v + 1) + ": Unexpected " + (l == L ? "end of input" : "'" + (this.terminals_[l] || l) + "'"), this.parseError(A, {
|
|
57
|
+
text: o.match,
|
|
58
|
+
token: this.terminals_[l] || l,
|
|
59
|
+
line: o.yylineno,
|
|
60
|
+
loc: I,
|
|
61
|
+
expected: S
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
if (h[0] instanceof Array && h.length > 1)
|
|
65
|
+
throw new Error("Parse Error: multiple actions possible at state: " + g + ", token: " + l);
|
|
66
|
+
switch (h[0]) {
|
|
67
|
+
case 1:
|
|
68
|
+
n.push(l), r.push(o.yytext), i.push(o.yylloc), n.push(h[1]), l = null, T = o.yyleng, P = o.yytext, v = o.yylineno, I = o.yylloc;
|
|
69
|
+
break;
|
|
70
|
+
case 2:
|
|
71
|
+
if (c = this.productions_[h[1]][1], _.$ = r[r.length - c], _._$ = {
|
|
72
|
+
first_line: i[i.length - (c || 1)].first_line,
|
|
73
|
+
last_line: i[i.length - 1].last_line,
|
|
74
|
+
first_column: i[i.length - (c || 1)].first_column,
|
|
75
|
+
last_column: i[i.length - 1].last_column
|
|
76
|
+
}, z && (_._$.range = [
|
|
77
|
+
i[i.length - (c || 1)].range[0],
|
|
78
|
+
i[i.length - 1].range[1]
|
|
79
|
+
]), w = this.performAction.apply(_, [
|
|
80
|
+
P,
|
|
81
|
+
T,
|
|
82
|
+
v,
|
|
83
|
+
p.yy,
|
|
84
|
+
h[1],
|
|
85
|
+
r,
|
|
86
|
+
i
|
|
87
|
+
].concat(R)), typeof w < "u")
|
|
88
|
+
return w;
|
|
89
|
+
c && (n = n.slice(0, -1 * c * 2), r = r.slice(0, -1 * c), i = i.slice(0, -1 * c)), n.push(this.productions_[h[1]][0]), r.push(_.$), i.push(_._$), F = d[n[n.length - 2]][n[n.length - 1]], n.push(F);
|
|
90
|
+
break;
|
|
91
|
+
case 3:
|
|
92
|
+
return !0;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
return !0;
|
|
96
|
+
}
|
|
97
|
+
}, k = /* @__PURE__ */ (function() {
|
|
98
|
+
var u = {
|
|
99
|
+
EOF: 1,
|
|
100
|
+
parseError: function(e, n) {
|
|
101
|
+
if (this.yy.parser)
|
|
102
|
+
this.yy.parser.parseError(e, n);
|
|
103
|
+
else
|
|
104
|
+
throw new Error(e);
|
|
105
|
+
},
|
|
106
|
+
// resets the lexer, sets new input
|
|
107
|
+
setInput: function(t, e) {
|
|
108
|
+
return this.yy = e || this.yy || {}, this._input = t, this._more = this._backtrack = this.done = !1, this.yylineno = this.yyleng = 0, this.yytext = this.matched = this.match = "", this.conditionStack = ["INITIAL"], this.yylloc = {
|
|
109
|
+
first_line: 1,
|
|
110
|
+
first_column: 0,
|
|
111
|
+
last_line: 1,
|
|
112
|
+
last_column: 0
|
|
113
|
+
}, this.options.ranges && (this.yylloc.range = [0, 0]), this.offset = 0, this;
|
|
114
|
+
},
|
|
115
|
+
// consumes and returns one char from the input
|
|
116
|
+
input: function() {
|
|
117
|
+
var t = this._input[0];
|
|
118
|
+
this.yytext += t, this.yyleng++, this.offset++, this.match += t, this.matched += t;
|
|
119
|
+
var e = t.match(/(?:\r\n?|\n).*/g);
|
|
120
|
+
return e ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), t;
|
|
121
|
+
},
|
|
122
|
+
// unshifts one char (or a string) into the input
|
|
123
|
+
unput: function(t) {
|
|
124
|
+
var e = t.length, n = t.split(/(?:\r\n?|\n)/g);
|
|
125
|
+
this._input = t + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - e), this.offset -= e;
|
|
126
|
+
var s = this.match.split(/(?:\r\n?|\n)/g);
|
|
127
|
+
this.match = this.match.substr(0, this.match.length - 1), this.matched = this.matched.substr(0, this.matched.length - 1), n.length - 1 && (this.yylineno -= n.length - 1);
|
|
128
|
+
var r = this.yylloc.range;
|
|
129
|
+
return this.yylloc = {
|
|
130
|
+
first_line: this.yylloc.first_line,
|
|
131
|
+
last_line: this.yylineno + 1,
|
|
132
|
+
first_column: this.yylloc.first_column,
|
|
133
|
+
last_column: n ? (n.length === s.length ? this.yylloc.first_column : 0) + s[s.length - n.length].length - n[0].length : this.yylloc.first_column - e
|
|
134
|
+
}, this.options.ranges && (this.yylloc.range = [r[0], r[0] + this.yyleng - e]), this.yyleng = this.yytext.length, this;
|
|
135
|
+
},
|
|
136
|
+
// When called from action, caches matched text and appends it on next action
|
|
137
|
+
more: function() {
|
|
138
|
+
return this._more = !0, this;
|
|
139
|
+
},
|
|
140
|
+
// When called from action, signals the lexer that this rule fails to match the input, so the next matching rule (regex) should be tested instead.
|
|
141
|
+
reject: function() {
|
|
142
|
+
if (this.options.backtrack_lexer)
|
|
143
|
+
this._backtrack = !0;
|
|
144
|
+
else
|
|
145
|
+
return this.parseError("Lexical error on line " + (this.yylineno + 1) + `. You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).
|
|
146
|
+
` + this.showPosition(), {
|
|
147
|
+
text: "",
|
|
148
|
+
token: null,
|
|
149
|
+
line: this.yylineno
|
|
150
|
+
});
|
|
151
|
+
return this;
|
|
152
|
+
},
|
|
153
|
+
// retain first n characters of the match
|
|
154
|
+
less: function(t) {
|
|
155
|
+
this.unput(this.match.slice(t));
|
|
156
|
+
},
|
|
157
|
+
// displays already matched input, i.e. for error messages
|
|
158
|
+
pastInput: function() {
|
|
159
|
+
var t = this.matched.substr(0, this.matched.length - this.match.length);
|
|
160
|
+
return (t.length > 20 ? "..." : "") + t.substr(-20).replace(/\n/g, "");
|
|
161
|
+
},
|
|
162
|
+
// displays upcoming input, i.e. for error messages
|
|
163
|
+
upcomingInput: function() {
|
|
164
|
+
var t = this.match;
|
|
165
|
+
return t.length < 20 && (t += this._input.substr(0, 20 - t.length)), (t.substr(0, 20) + (t.length > 20 ? "..." : "")).replace(/\n/g, "");
|
|
166
|
+
},
|
|
167
|
+
// displays the character position where the lexing error occurred, i.e. for error messages
|
|
168
|
+
showPosition: function() {
|
|
169
|
+
var t = this.pastInput(), e = new Array(t.length + 1).join("-");
|
|
170
|
+
return t + this.upcomingInput() + `
|
|
171
|
+
` + e + "^";
|
|
172
|
+
},
|
|
173
|
+
// test the lexed token: return FALSE when not a match, otherwise return token
|
|
174
|
+
test_match: function(t, e) {
|
|
175
|
+
var n, s, r;
|
|
176
|
+
if (this.options.backtrack_lexer && (r = {
|
|
177
|
+
yylineno: this.yylineno,
|
|
178
|
+
yylloc: {
|
|
179
|
+
first_line: this.yylloc.first_line,
|
|
180
|
+
last_line: this.last_line,
|
|
181
|
+
first_column: this.yylloc.first_column,
|
|
182
|
+
last_column: this.yylloc.last_column
|
|
183
|
+
},
|
|
184
|
+
yytext: this.yytext,
|
|
185
|
+
match: this.match,
|
|
186
|
+
matches: this.matches,
|
|
187
|
+
matched: this.matched,
|
|
188
|
+
yyleng: this.yyleng,
|
|
189
|
+
offset: this.offset,
|
|
190
|
+
_more: this._more,
|
|
191
|
+
_input: this._input,
|
|
192
|
+
yy: this.yy,
|
|
193
|
+
conditionStack: this.conditionStack.slice(0),
|
|
194
|
+
done: this.done
|
|
195
|
+
}, this.options.ranges && (r.yylloc.range = this.yylloc.range.slice(0))), s = t[0].match(/(?:\r\n?|\n).*/g), s && (this.yylineno += s.length), this.yylloc = {
|
|
196
|
+
first_line: this.yylloc.last_line,
|
|
197
|
+
last_line: this.yylineno + 1,
|
|
198
|
+
first_column: this.yylloc.last_column,
|
|
199
|
+
last_column: s ? s[s.length - 1].length - s[s.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + t[0].length
|
|
200
|
+
}, this.yytext += t[0], this.match += t[0], this.matches = t, this.yyleng = this.yytext.length, this.options.ranges && (this.yylloc.range = [this.offset, this.offset += this.yyleng]), this._more = !1, this._backtrack = !1, this._input = this._input.slice(t[0].length), this.matched += t[0], n = this.performAction.call(this, this.yy, this, e, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), n)
|
|
201
|
+
return n;
|
|
202
|
+
if (this._backtrack) {
|
|
203
|
+
for (var i in r)
|
|
204
|
+
this[i] = r[i];
|
|
205
|
+
return !1;
|
|
206
|
+
}
|
|
207
|
+
return !1;
|
|
208
|
+
},
|
|
209
|
+
// return next match in input
|
|
210
|
+
next: function() {
|
|
211
|
+
if (this.done)
|
|
212
|
+
return this.EOF;
|
|
213
|
+
this._input || (this.done = !0);
|
|
214
|
+
var t, e, n, s;
|
|
215
|
+
this._more || (this.yytext = "", this.match = "");
|
|
216
|
+
for (var r = this._currentRules(), i = 0; i < r.length; i++)
|
|
217
|
+
if (n = this._input.match(this.rules[r[i]]), n && (!e || n[0].length > e[0].length)) {
|
|
218
|
+
if (e = n, s = i, this.options.backtrack_lexer) {
|
|
219
|
+
if (t = this.test_match(n, r[i]), t !== !1)
|
|
220
|
+
return t;
|
|
221
|
+
if (this._backtrack) {
|
|
222
|
+
e = !1;
|
|
223
|
+
continue;
|
|
224
|
+
} else
|
|
225
|
+
return !1;
|
|
226
|
+
} else if (!this.options.flex)
|
|
227
|
+
break;
|
|
228
|
+
}
|
|
229
|
+
return e ? (t = this.test_match(e, r[s]), t !== !1 ? t : !1) : this._input === "" ? this.EOF : this.parseError("Lexical error on line " + (this.yylineno + 1) + `. Unrecognized text.
|
|
230
|
+
` + this.showPosition(), {
|
|
231
|
+
text: "",
|
|
232
|
+
token: null,
|
|
233
|
+
line: this.yylineno
|
|
234
|
+
});
|
|
235
|
+
},
|
|
236
|
+
// return next match that has a token
|
|
237
|
+
lex: function() {
|
|
238
|
+
var e = this.next();
|
|
239
|
+
return e || this.lex();
|
|
240
|
+
},
|
|
241
|
+
// activates a new lexer condition state (pushes the new lexer condition state onto the condition stack)
|
|
242
|
+
begin: function(e) {
|
|
243
|
+
this.conditionStack.push(e);
|
|
244
|
+
},
|
|
245
|
+
// pop the previously active lexer condition state off the condition stack
|
|
246
|
+
popState: function() {
|
|
247
|
+
var e = this.conditionStack.length - 1;
|
|
248
|
+
return e > 0 ? this.conditionStack.pop() : this.conditionStack[0];
|
|
249
|
+
},
|
|
250
|
+
// produce the lexer rule set which is active for the currently active lexer condition state
|
|
251
|
+
_currentRules: function() {
|
|
252
|
+
return this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1] ? this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules : this.conditions.INITIAL.rules;
|
|
253
|
+
},
|
|
254
|
+
// return the currently active lexer condition state; when an index argument is provided it produces the N-th previous condition state, if available
|
|
255
|
+
topState: function(e) {
|
|
256
|
+
return e = this.conditionStack.length - 1 - Math.abs(e || 0), e >= 0 ? this.conditionStack[e] : "INITIAL";
|
|
257
|
+
},
|
|
258
|
+
// alias for begin(condition)
|
|
259
|
+
pushState: function(e) {
|
|
260
|
+
this.begin(e);
|
|
261
|
+
},
|
|
262
|
+
// return the number of states currently on the stack
|
|
263
|
+
stateStackSize: function() {
|
|
264
|
+
return this.conditionStack.length;
|
|
265
|
+
},
|
|
266
|
+
options: { "case-insensitive": !0 },
|
|
267
|
+
performAction: function(e, n, s, r) {
|
|
268
|
+
switch (s) {
|
|
269
|
+
case 0:
|
|
270
|
+
return 4;
|
|
271
|
+
case 1:
|
|
272
|
+
return 9;
|
|
273
|
+
case 2:
|
|
274
|
+
return "space";
|
|
275
|
+
case 3:
|
|
276
|
+
return 10;
|
|
277
|
+
case 4:
|
|
278
|
+
return 6;
|
|
279
|
+
case 5:
|
|
280
|
+
return "TXT";
|
|
281
|
+
}
|
|
282
|
+
},
|
|
283
|
+
rules: [/^(?:info\b)/i, /^(?:[\s\n\r]+)/i, /^(?:[\s]+)/i, /^(?:showInfo\b)/i, /^(?:$)/i, /^(?:.)/i],
|
|
284
|
+
conditions: { INITIAL: { rules: [0, 1, 2, 3, 4, 5], inclusive: !0 } }
|
|
285
|
+
};
|
|
286
|
+
return u;
|
|
287
|
+
})();
|
|
288
|
+
m.lexer = k;
|
|
289
|
+
function x() {
|
|
290
|
+
this.yy = {};
|
|
291
|
+
}
|
|
292
|
+
return x.prototype = m, m.Parser = x, new x();
|
|
293
|
+
})();
|
|
294
|
+
O.parser = O;
|
|
295
|
+
const B = O, j = {
|
|
296
|
+
info: !1
|
|
297
|
+
};
|
|
298
|
+
let $ = j.info;
|
|
299
|
+
const V = (a) => {
|
|
300
|
+
$ = a;
|
|
301
|
+
}, X = () => $, q = () => {
|
|
302
|
+
$ = j.info;
|
|
303
|
+
}, C = {
|
|
304
|
+
clear: q,
|
|
305
|
+
setInfo: V,
|
|
306
|
+
getInfo: X
|
|
307
|
+
}, G = (a, f, m) => {
|
|
308
|
+
Y.debug(`rendering info diagram
|
|
309
|
+
` + a);
|
|
310
|
+
const k = D(f);
|
|
311
|
+
M(k, 100, 400, !0), k.append("g").append("text").attr("x", 100).attr("y", 40).attr("class", "version").attr("font-size", 32).style("text-anchor", "middle").text(`v${m}`);
|
|
312
|
+
}, H = { draw: G }, K = {
|
|
313
|
+
parser: B,
|
|
314
|
+
db: C,
|
|
315
|
+
renderer: H
|
|
316
|
+
};
|
|
317
|
+
export {
|
|
318
|
+
K as diagram
|
|
319
|
+
};
|