wikiparser-node 1.3.2 → 1.3.3-b

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.
Files changed (154) hide show
  1. package/bundle/bundle.min.js +36 -0
  2. package/config/llwiki.json +1 -35
  3. package/config/moegirl.json +1 -44
  4. package/config/zhwiki.json +1 -466
  5. package/extensions/dist/base.js +68 -0
  6. package/extensions/dist/editor.js +159 -0
  7. package/extensions/dist/highlight.js +30 -0
  8. package/extensions/dist/lint.js +48 -0
  9. package/extensions/editor.css +63 -0
  10. package/extensions/ui.css +114 -0
  11. package/package.json +32 -12
  12. package/config/.schema.json +0 -172
  13. package/dist/addon/table.d.ts +0 -6
  14. package/dist/addon/table.js +0 -564
  15. package/dist/base.d.ts +0 -45
  16. package/dist/bin/toc.js +0 -18
  17. package/dist/index.d.ts +0 -31
  18. package/dist/index.js +0 -209
  19. package/dist/internal.d.ts +0 -44
  20. package/dist/lib/element.d.ts +0 -155
  21. package/dist/lib/element.js +0 -634
  22. package/dist/lib/node.d.ts +0 -146
  23. package/dist/lib/node.js +0 -419
  24. package/dist/lib/range.d.ts +0 -104
  25. package/dist/lib/range.js +0 -385
  26. package/dist/lib/ranges.d.ts +0 -26
  27. package/dist/lib/ranges.js +0 -117
  28. package/dist/lib/text.d.ts +0 -62
  29. package/dist/lib/text.js +0 -248
  30. package/dist/lib/title.d.ts +0 -38
  31. package/dist/lib/title.js +0 -162
  32. package/dist/mixin/attributesParent.js +0 -94
  33. package/dist/mixin/fixed.js +0 -32
  34. package/dist/mixin/flagsParent.js +0 -70
  35. package/dist/mixin/hidden.js +0 -26
  36. package/dist/mixin/magicLinkParent.js +0 -41
  37. package/dist/mixin/singleLine.js +0 -25
  38. package/dist/mixin/sol.js +0 -43
  39. package/dist/mixin/syntax.js +0 -56
  40. package/dist/parser/braces.js +0 -121
  41. package/dist/parser/commentAndExt.js +0 -69
  42. package/dist/parser/converter.js +0 -40
  43. package/dist/parser/externalLinks.js +0 -28
  44. package/dist/parser/hrAndDoubleUnderscore.js +0 -38
  45. package/dist/parser/html.js +0 -36
  46. package/dist/parser/links.js +0 -94
  47. package/dist/parser/list.js +0 -59
  48. package/dist/parser/magicLinks.js +0 -40
  49. package/dist/parser/quotes.js +0 -67
  50. package/dist/parser/selector.js +0 -162
  51. package/dist/parser/table.js +0 -112
  52. package/dist/src/arg.d.ts +0 -58
  53. package/dist/src/arg.js +0 -189
  54. package/dist/src/atom.d.ts +0 -12
  55. package/dist/src/atom.js +0 -27
  56. package/dist/src/attribute.d.ts +0 -87
  57. package/dist/src/attribute.js +0 -392
  58. package/dist/src/attributes.d.ts +0 -107
  59. package/dist/src/attributes.js +0 -341
  60. package/dist/src/converter.d.ts +0 -52
  61. package/dist/src/converter.js +0 -79
  62. package/dist/src/converterFlags.d.ts +0 -87
  63. package/dist/src/converterFlags.js +0 -224
  64. package/dist/src/converterRule.d.ts +0 -81
  65. package/dist/src/converterRule.js +0 -212
  66. package/dist/src/extLink.d.ts +0 -54
  67. package/dist/src/extLink.js +0 -122
  68. package/dist/src/gallery.d.ts +0 -55
  69. package/dist/src/gallery.js +0 -122
  70. package/dist/src/heading.d.ts +0 -74
  71. package/dist/src/heading.js +0 -127
  72. package/dist/src/hidden.d.ts +0 -22
  73. package/dist/src/hidden.js +0 -23
  74. package/dist/src/html.d.ts +0 -101
  75. package/dist/src/html.js +0 -222
  76. package/dist/src/imageParameter.d.ts +0 -66
  77. package/dist/src/imageParameter.js +0 -247
  78. package/dist/src/imagemap.d.ts +0 -57
  79. package/dist/src/imagemap.js +0 -148
  80. package/dist/src/imagemapLink.d.ts +0 -59
  81. package/dist/src/imagemapLink.js +0 -40
  82. package/dist/src/index.d.ts +0 -146
  83. package/dist/src/index.js +0 -777
  84. package/dist/src/link/base.d.ts +0 -52
  85. package/dist/src/link/base.js +0 -209
  86. package/dist/src/link/category.d.ts +0 -13
  87. package/dist/src/link/category.js +0 -29
  88. package/dist/src/link/file.d.ts +0 -96
  89. package/dist/src/link/file.js +0 -255
  90. package/dist/src/link/galleryImage.d.ts +0 -44
  91. package/dist/src/link/galleryImage.js +0 -106
  92. package/dist/src/link/index.d.ts +0 -53
  93. package/dist/src/link/index.js +0 -123
  94. package/dist/src/magicLink.d.ts +0 -70
  95. package/dist/src/magicLink.js +0 -147
  96. package/dist/src/nested.d.ts +0 -44
  97. package/dist/src/nested.js +0 -87
  98. package/dist/src/nowiki/base.d.ts +0 -47
  99. package/dist/src/nowiki/base.js +0 -42
  100. package/dist/src/nowiki/comment.d.ts +0 -40
  101. package/dist/src/nowiki/comment.js +0 -67
  102. package/dist/src/nowiki/dd.d.ts +0 -8
  103. package/dist/src/nowiki/dd.js +0 -25
  104. package/dist/src/nowiki/doubleUnderscore.d.ts +0 -45
  105. package/dist/src/nowiki/doubleUnderscore.js +0 -50
  106. package/dist/src/nowiki/hr.d.ts +0 -31
  107. package/dist/src/nowiki/hr.js +0 -14
  108. package/dist/src/nowiki/index.d.ts +0 -16
  109. package/dist/src/nowiki/index.js +0 -21
  110. package/dist/src/nowiki/list.d.ts +0 -30
  111. package/dist/src/nowiki/list.js +0 -48
  112. package/dist/src/nowiki/listBase.d.ts +0 -19
  113. package/dist/src/nowiki/listBase.js +0 -12
  114. package/dist/src/nowiki/noinclude.d.ts +0 -26
  115. package/dist/src/nowiki/noinclude.js +0 -25
  116. package/dist/src/nowiki/quote.d.ts +0 -23
  117. package/dist/src/nowiki/quote.js +0 -45
  118. package/dist/src/onlyinclude.d.ts +0 -16
  119. package/dist/src/onlyinclude.js +0 -57
  120. package/dist/src/paramTag/index.d.ts +0 -37
  121. package/dist/src/paramTag/index.js +0 -68
  122. package/dist/src/paramTag/inputbox.d.ts +0 -8
  123. package/dist/src/paramTag/inputbox.js +0 -23
  124. package/dist/src/parameter.d.ts +0 -85
  125. package/dist/src/parameter.js +0 -205
  126. package/dist/src/pre.d.ts +0 -28
  127. package/dist/src/pre.js +0 -51
  128. package/dist/src/syntax.d.ts +0 -28
  129. package/dist/src/syntax.js +0 -34
  130. package/dist/src/table/base.d.ts +0 -53
  131. package/dist/src/table/base.js +0 -78
  132. package/dist/src/table/index.d.ts +0 -229
  133. package/dist/src/table/index.js +0 -379
  134. package/dist/src/table/td.d.ts +0 -104
  135. package/dist/src/table/td.js +0 -261
  136. package/dist/src/table/tr.d.ts +0 -32
  137. package/dist/src/table/tr.js +0 -56
  138. package/dist/src/table/trBase.d.ts +0 -54
  139. package/dist/src/table/trBase.js +0 -159
  140. package/dist/src/tagPair/ext.d.ts +0 -56
  141. package/dist/src/tagPair/ext.js +0 -142
  142. package/dist/src/tagPair/include.d.ts +0 -53
  143. package/dist/src/tagPair/include.js +0 -63
  144. package/dist/src/tagPair/index.d.ts +0 -48
  145. package/dist/src/tagPair/index.js +0 -93
  146. package/dist/src/transclude.d.ts +0 -167
  147. package/dist/src/transclude.js +0 -689
  148. package/dist/util/constants.js +0 -108
  149. package/dist/util/debug.js +0 -64
  150. package/dist/util/diff.js +0 -72
  151. package/dist/util/lint.js +0 -46
  152. package/dist/util/string.js +0 -61
  153. package/errors/README +0 -1
  154. package/printed/README +0 -1
package/dist/lib/range.js DELETED
@@ -1,385 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.AstRange = void 0;
4
- const constants_1 = require("../util/constants");
5
- /**
6
- * 计算绝对位置
7
- * @param referenceNode 容器
8
- * @param offset 相对位置
9
- */
10
- const getIndex = (referenceNode, offset) => referenceNode.getAbsoluteIndex() + referenceNode.getRelativeIndex(offset);
11
- /** 模拟Range对象 */
12
- class AstRange {
13
- #startContainer;
14
- #startOffset;
15
- #endContainer;
16
- #endOffset;
17
- /**
18
- * 未初始化时抛出错误
19
- * @param start 是否未初始化起点
20
- * @throws `Error` 未初始化
21
- */
22
- #notInit(start) {
23
- throw new Error(`请先指定${start ? '起始' : '终止'}位置!`);
24
- }
25
- /** 起点容器 */
26
- get startContainer() {
27
- return this.#startContainer ?? this.#notInit(true);
28
- }
29
- /** 起点位置 */
30
- get startOffset() {
31
- return this.#startOffset ?? this.#notInit(true);
32
- }
33
- /** 起点绝对位置 */
34
- get startIndex() {
35
- return getIndex(this.startContainer, this.startOffset);
36
- }
37
- /** 起点行列位置 */
38
- get startPos() {
39
- return this.startContainer.getRootNode().posFromIndex(this.startIndex);
40
- }
41
- /** 终点容器 */
42
- get endContainer() {
43
- return this.#endContainer ?? this.#notInit(false);
44
- }
45
- /** 终点位置 */
46
- get endOffset() {
47
- return this.#endOffset ?? this.#notInit(false);
48
- }
49
- /** 终点绝对位置 */
50
- get endIndex() {
51
- return getIndex(this.endContainer, this.endOffset);
52
- }
53
- /** 终点行列位置 */
54
- get endPos() {
55
- return this.endContainer.getRootNode().posFromIndex(this.endIndex);
56
- }
57
- /** 起始和终止位置是否重合 */
58
- get collapsed() {
59
- return this.startContainer === this.endContainer && this.startOffset === this.endOffset;
60
- }
61
- /** 最近的公共祖先 */
62
- get commonAncestorContainer() {
63
- const { startContainer, endContainer } = this;
64
- return startContainer.contains(endContainer) ? startContainer : startContainer.parentNode;
65
- }
66
- /**
67
- * 检查起点和终点的设置是否有效
68
- * @throws `RangeError` 起点和终点不是兄弟节点
69
- * @throws `RangeError` 起点位于终点之后
70
- */
71
- #check() {
72
- const { startContainer, startOffset, endContainer, endOffset } = this;
73
- if (startContainer === endContainer) {
74
- if (startOffset > endOffset) {
75
- throw new RangeError('起点不能位于终点之后!');
76
- }
77
- return;
78
- }
79
- const { type: startType, parentNode: startParent } = startContainer, { type: endType, parentNode: endParent } = endContainer;
80
- if (startType !== 'text') {
81
- if (endType !== 'text' || startContainer !== endParent) {
82
- throw new RangeError('起点和终点不是兄弟节点!');
83
- }
84
- else if (startOffset > endParent.childNodes.indexOf(endContainer)) {
85
- throw new RangeError('起点不能位于终点之后!');
86
- }
87
- }
88
- else if (endType === 'text') {
89
- if (!startParent || startParent !== endParent) {
90
- throw new RangeError('起点和终点不是兄弟节点!');
91
- }
92
- const { childNodes } = startParent;
93
- if (childNodes.indexOf(startContainer) > childNodes.indexOf(endContainer)) {
94
- throw new RangeError('起点不能位于终点之后!');
95
- }
96
- }
97
- else if (startParent !== endContainer) {
98
- throw new RangeError('起点和终点不是兄弟节点!');
99
- }
100
- else if (endOffset <= startParent.childNodes.indexOf(startContainer)) {
101
- throw new RangeError('起点不能位于终点之后!');
102
- }
103
- }
104
- /**
105
- * 设置起点
106
- * @param startNode 起点容器
107
- * @param startOffset 起点位置
108
- * @throws `RangeError` offset取值超出范围
109
- */
110
- setStart(startNode, startOffset) {
111
- const { length } = startNode;
112
- if (startOffset < 0 || startOffset > length) {
113
- throw new RangeError(`offset取值范围应为 0 ~ ${length}`);
114
- }
115
- this.#startContainer = startNode;
116
- this.#startOffset = startOffset;
117
- if (this.#endContainer) {
118
- try {
119
- this.#check();
120
- }
121
- catch (e) {
122
- this.#startContainer = undefined;
123
- this.#startOffset = undefined;
124
- throw e;
125
- }
126
- }
127
- }
128
- /**
129
- * 设置终点
130
- * @param endNode 终点容器
131
- * @param endOffset 终点位置
132
- * @throws `RangeError` offset取值超出范围
133
- */
134
- setEnd(endNode, endOffset) {
135
- const { length } = endNode;
136
- if (endOffset < 0 || endOffset > length) {
137
- throw new RangeError(`offset取值范围应为 0 ~ ${length}`);
138
- }
139
- this.#endContainer = endNode;
140
- this.#endOffset = endOffset;
141
- if (this.#startContainer) {
142
- try {
143
- this.#check();
144
- }
145
- catch (e) {
146
- this.#endContainer = undefined;
147
- this.#endOffset = undefined;
148
- throw e;
149
- }
150
- }
151
- }
152
- /**
153
- * 在节点后设置
154
- * @param method 方法名
155
- * @param referenceNode 节点
156
- * @throws `RangeError` 参考节点没有父节点
157
- */
158
- #setAfter(method, referenceNode) {
159
- const { parentNode } = referenceNode;
160
- if (!parentNode) {
161
- throw new RangeError('参考节点没有父节点!');
162
- }
163
- this[method](parentNode, parentNode.childNodes.indexOf(referenceNode) + 1);
164
- }
165
- /**
166
- * 在节点后设置起点
167
- * @param referenceNode 节点
168
- */
169
- setStartAfter(referenceNode) {
170
- this.#setAfter('setStart', referenceNode);
171
- }
172
- /**
173
- * 在节点后设置终点
174
- * @param referenceNode 节点
175
- */
176
- setEndAfter(referenceNode) {
177
- this.#setAfter('setEnd', referenceNode);
178
- }
179
- /**
180
- * 在节点前设置
181
- * @param method 方法名
182
- * @param referenceNode 节点
183
- * @throws `RangeError` 参考节点没有父节点
184
- */
185
- #setBefore(method, referenceNode) {
186
- const { parentNode } = referenceNode;
187
- if (!parentNode) {
188
- throw new RangeError('参考节点没有父节点!');
189
- }
190
- this[method](parentNode, parentNode.childNodes.indexOf(referenceNode));
191
- }
192
- /**
193
- * 在节点前设置起点
194
- * @param referenceNode 节点
195
- */
196
- setStartBefore(referenceNode) {
197
- this.#setBefore('setStart', referenceNode);
198
- }
199
- /**
200
- * 在节点前设置终点
201
- * @param referenceNode 节点
202
- */
203
- setEndBefore(referenceNode) {
204
- this.#setBefore('setEnd', referenceNode);
205
- }
206
- /**
207
- * 设置Range包含整个节点的内容
208
- * @param referenceNode 节点
209
- */
210
- selectNodeContents(referenceNode) {
211
- this.#startContainer = referenceNode;
212
- this.#startOffset = 0;
213
- this.#endContainer = referenceNode;
214
- this.#endOffset = referenceNode.length;
215
- }
216
- /**
217
- * 设置Range包含整个节点
218
- * @param referenceNode 节点
219
- * @throws `RangeError` 参考节点没有父节点
220
- */
221
- selectNode(referenceNode) {
222
- const { parentNode } = referenceNode;
223
- if (!parentNode) {
224
- throw new RangeError('参考节点没有父节点!');
225
- }
226
- const i = parentNode.childNodes.indexOf(referenceNode);
227
- this.#startContainer = parentNode;
228
- this.#startOffset = i;
229
- this.#endContainer = parentNode;
230
- this.#endOffset = i + 1;
231
- }
232
- /**
233
- * 使起始和终止位置重合
234
- * @param toStart 重合至起始位置
235
- */
236
- collapse(toStart = false) {
237
- if (toStart) {
238
- this.#endContainer = this.startContainer;
239
- this.#endOffset = this.startOffset;
240
- }
241
- else {
242
- this.#startContainer = this.endContainer;
243
- this.#startOffset = this.endOffset;
244
- }
245
- }
246
- /**
247
- * 比较端点和Range的位置
248
- * @param referenceNode 端点容器
249
- * @param offset 端点位置
250
- * @throws `RangeError` 不在同一个文档
251
- */
252
- comparePoint(referenceNode, offset) {
253
- const { startContainer, startIndex, endContainer, endIndex } = this;
254
- if (startContainer.getRootNode() !== referenceNode.getRootNode()) {
255
- throw new RangeError('待比较的端点不在同一个文档中!');
256
- }
257
- const index = getIndex(referenceNode, offset);
258
- if (index < startIndex || index === startIndex && !startContainer.contains(referenceNode)) {
259
- return -1;
260
- }
261
- return index < endIndex || index === endIndex && endContainer.contains(referenceNode) ? 0 : 1;
262
- }
263
- /**
264
- * 端点是否在Range中
265
- * @param referenceNode 端点容器
266
- * @param offset 端点位置
267
- */
268
- isPointInRange(referenceNode, offset) {
269
- return this.comparePoint(referenceNode, offset) === 0;
270
- }
271
- /** 复制AstRange对象 */
272
- cloneRange() {
273
- const range = new AstRange();
274
- range.setStart(this.startContainer, this.startOffset);
275
- range.setEnd(this.endContainer, this.endOffset);
276
- return range;
277
- }
278
- /** 删除Range中的内容 */
279
- deleteContents() {
280
- const { startContainer, endContainer, commonAncestorContainer } = this, { childNodes } = commonAncestorContainer;
281
- let { startOffset, endOffset } = this;
282
- if (commonAncestorContainer.type === 'text') {
283
- commonAncestorContainer.deleteData(startOffset, endOffset);
284
- return;
285
- }
286
- else if (startContainer.type === 'text') {
287
- startContainer.deleteData(startOffset, Infinity);
288
- startOffset = childNodes.indexOf(startContainer) + 1;
289
- }
290
- if (endContainer.type === 'text') {
291
- endContainer.deleteData(0, endOffset);
292
- endOffset = childNodes.indexOf(endContainer);
293
- }
294
- for (let i = endOffset - 1; i >= startOffset; i--) {
295
- commonAncestorContainer.removeAt(i);
296
- }
297
- this.#startContainer = commonAncestorContainer;
298
- this.#startOffset = startOffset;
299
- this.#endContainer = commonAncestorContainer;
300
- this.#endOffset = startOffset;
301
- }
302
- /** 获取行列位置和大小 */
303
- getBoundingClientRect() {
304
- const { startPos: { top, left }, endPos: { top: bottom, left: right } } = this;
305
- return { top, left, height: bottom - top + 1, width: bottom === top ? right - left : right };
306
- }
307
- /**
308
- * 在起始位置插入节点
309
- * @param newNode 插入的节点
310
- */
311
- insertNode(newNode) {
312
- const { startContainer, startOffset } = this, endContainer = this.#endContainer;
313
- if (startContainer.type === 'text') {
314
- if (startOffset) {
315
- startContainer.splitText(startOffset);
316
- this.#startContainer = startContainer.nextSibling;
317
- this.#startOffset = 0;
318
- startContainer.after(newNode);
319
- if (endContainer === startContainer) {
320
- this.#endContainer = this.#startContainer;
321
- this.#endOffset -= startOffset;
322
- }
323
- else if (endContainer && endContainer.type !== 'text') {
324
- this.#endOffset += 2;
325
- }
326
- }
327
- else {
328
- startContainer.before(newNode);
329
- if (endContainer && endContainer.type !== 'text') {
330
- this.#endOffset++;
331
- }
332
- }
333
- }
334
- else {
335
- startContainer.insertAt(newNode, startOffset);
336
- this.#startOffset++;
337
- if (endContainer === startContainer) {
338
- this.#endOffset++;
339
- }
340
- }
341
- }
342
- /** @private */
343
- toString() {
344
- const { startContainer, startIndex, endIndex } = this;
345
- return String(startContainer.getRootNode()).slice(startIndex, endIndex);
346
- }
347
- /** 获取范围内的全部节点 */
348
- extractContents() {
349
- const { startContainer, startOffset, endContainer, endOffset, commonAncestorContainer } = this, { childNodes } = commonAncestorContainer;
350
- if (commonAncestorContainer.type === 'text') {
351
- if (startOffset === endOffset) {
352
- return [];
353
- }
354
- commonAncestorContainer.splitText(endOffset);
355
- const nextSibling = commonAncestorContainer.splitText(startOffset);
356
- this.#startContainer = nextSibling;
357
- this.#startOffset = 0;
358
- this.#endContainer = nextSibling;
359
- this.#endOffset -= startOffset;
360
- return [nextSibling];
361
- }
362
- else if (endContainer.type === 'text') {
363
- if (endOffset && endOffset < endContainer.length) {
364
- endContainer.splitText(endOffset);
365
- }
366
- this.#endContainer = commonAncestorContainer;
367
- this.#endOffset = childNodes.indexOf(endContainer) + (endOffset && 1);
368
- }
369
- if (startContainer.type === 'text') {
370
- if (startOffset && startOffset < startContainer.length) {
371
- startContainer.splitText(startOffset);
372
- this.#endOffset++;
373
- }
374
- this.#startContainer = commonAncestorContainer;
375
- this.#startOffset = childNodes.indexOf(startContainer) + (startOffset && 1);
376
- }
377
- return commonAncestorContainer.childNodes.slice(this.#startOffset, this.#endOffset);
378
- }
379
- /** 在满足条件时拷贝范围内的全部节点 */
380
- cloneContents() {
381
- return this.extractContents().map(node => node.cloneNode());
382
- }
383
- }
384
- exports.AstRange = AstRange;
385
- constants_1.classes['AstRange'] = __filename;
@@ -1,26 +0,0 @@
1
- /** 模拟Python的Range对象。除`step`至少为`1`外,允许负数、小数或`end < start`的情形。 */
2
- export declare class Range {
3
- #private;
4
- /**
5
- * @param s 表达式
6
- * @throws `RangeError` 起点、终点和步长均应为整数
7
- * @throws `RangeError` n的系数不能为0
8
- * @throws `RangeError` 应使用CSS选择器或Python切片的格式
9
- */
10
- constructor(str: string);
11
- /**
12
- * 将Range转换为针对特定数组的下标集
13
- * @param arr 参考数组`[0, 1, 2, ...]`
14
- */
15
- applyTo(arr: readonly number[]): readonly number[];
16
- }
17
- /** @extends {Array<number|Range>} */
18
- export declare class Ranges extends Array<number | Range> {
19
- /** @param a 表达式数组 */
20
- constructor(a?: number | string | Range | readonly (number | string | Range)[]);
21
- /**
22
- * 将Ranges转换为针对特定Array的下标集
23
- * @param arr 参考数组
24
- */
25
- applyTo(arr: number | readonly unknown[]): readonly number[];
26
- }
@@ -1,117 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Ranges = exports.Range = void 0;
4
- const constants_1 = require("../util/constants");
5
- /** 模拟Python的Range对象。除`step`至少为`1`外,允许负数、小数或`end < start`的情形。 */
6
- class Range {
7
- #start;
8
- #end;
9
- #step;
10
- /**
11
- * @param s 表达式
12
- * @throws `RangeError` 起点、终点和步长均应为整数
13
- * @throws `RangeError` n的系数不能为0
14
- * @throws `RangeError` 应使用CSS选择器或Python切片的格式
15
- */
16
- constructor(str) {
17
- str = str.trim();
18
- if (str === 'odd') {
19
- Object.assign(this, { start: 1, end: Infinity, step: 2 });
20
- }
21
- else if (str === 'even') {
22
- Object.assign(this, { start: 0, end: Infinity, step: 2 });
23
- }
24
- else if (str.includes(':')) {
25
- const [start, end, step = '1'] = str.split(':', 3);
26
- this.#start = Number(start);
27
- this.#end = Number(end || Infinity);
28
- this.#step = Math.max(Number(step), 1);
29
- if (!Number.isInteger(this.#start)) {
30
- throw new RangeError(`起点 ${this.#start} 应为整数!`);
31
- }
32
- else if (this.#end !== Infinity && !Number.isInteger(this.#end)) {
33
- throw new RangeError(`终点 ${this.#end} 应为整数!`);
34
- }
35
- else if (!Number.isInteger(this.#step)) {
36
- throw new RangeError(`步长 ${this.#step} 应为整数!`);
37
- }
38
- }
39
- else {
40
- const mt = /^([+-])?(\d+)?n(?:([+-])(\d+))?$/u
41
- .exec(str);
42
- if (mt) {
43
- const [, sgnA = '+', a = 1, sgnB = '+'] = mt, b = Number(mt[4] ?? 0);
44
- this.#step = Number(a);
45
- if (this.#step === 0) {
46
- throw new RangeError(`参数 ${str} 中 "n" 的系数不允许为 0!`);
47
- }
48
- else if (sgnA === '+') {
49
- this.#start = sgnB === '+' || b === 0 ? b : this.#step - 1 - (b - 1) % this.#step;
50
- this.#end = Infinity;
51
- }
52
- else if (sgnB === '-') {
53
- this.#start = 0;
54
- this.#end = b > 0 ? 0 : this.#step;
55
- }
56
- else {
57
- this.#start = b % this.#step;
58
- this.#end = this.#step + b;
59
- }
60
- }
61
- else {
62
- throw new RangeError(`参数 ${str} 应写作CSS选择器的 "an+b" 形式或Python切片!`);
63
- }
64
- }
65
- }
66
- /**
67
- * 将Range转换为针对特定数组的下标集
68
- * @param arr 参考数组`[0, 1, 2, ...]`
69
- */
70
- applyTo(arr) {
71
- return arr.slice(this.#start, this.#end).filter((_, j) => j % this.#step === 0);
72
- }
73
- }
74
- exports.Range = Range;
75
- /** @extends {Array<number|Range>} */
76
- class Ranges extends Array {
77
- /** @param a 表达式数组 */
78
- constructor(a) {
79
- super();
80
- if (a === undefined) {
81
- return;
82
- }
83
- for (const ele of Array.isArray(a) ? a : [a]) {
84
- if (ele instanceof Range) {
85
- this.push(ele);
86
- continue;
87
- }
88
- const number = Number(ele);
89
- if (Number.isInteger(number)) {
90
- this.push(number);
91
- }
92
- else if (typeof ele === 'string' && Number.isNaN(number)) {
93
- try {
94
- this.push(new Range(ele));
95
- }
96
- catch { }
97
- }
98
- }
99
- }
100
- /**
101
- * 将Ranges转换为针对特定Array的下标集
102
- * @param arr 参考数组
103
- */
104
- applyTo(arr) {
105
- const length = typeof arr === 'number' ? arr : arr.length, a = new Array(length).fill(undefined).map((_, i) => i);
106
- return [
107
- ...new Set([...this].flatMap(ele => {
108
- if (typeof ele === 'number') {
109
- return ele < 0 ? ele + length : ele;
110
- }
111
- return ele.applyTo(a);
112
- })),
113
- ].filter(i => i >= 0 && i < length).sort();
114
- }
115
- }
116
- exports.Ranges = Ranges;
117
- constants_1.classes['Ranges'] = __filename;
@@ -1,62 +0,0 @@
1
- import { AstNode } from './node';
2
- import type { LintError } from '../base';
3
- /** 文本节点 */
4
- export declare class AstText extends AstNode {
5
- #private;
6
- readonly type = "text";
7
- readonly name: undefined;
8
- readonly data: string;
9
- /** 文本长度 */
10
- get length(): number;
11
- /** @param text 包含文本 */
12
- constructor(text: string);
13
- /** 可见部分 */
14
- text(): string;
15
- /**
16
- * @override
17
- * @param start
18
- * @throws `Error` 孤立文本节点
19
- */
20
- lint(start?: number): LintError[];
21
- /**
22
- * 替换字符串
23
- * @param text 替换的字符串
24
- */
25
- replaceData(text: string): void;
26
- /** @override */
27
- print(): string;
28
- /** 复制 */
29
- cloneNode(): AstText;
30
- /**
31
- * 在后方添加字符串
32
- * @param text 添加的字符串
33
- */
34
- appendData(text: string): void;
35
- /**
36
- * 删减字符串
37
- * @param offset 起始位置
38
- * @param count 删减字符数
39
- */
40
- deleteData(offset: number, count: number): void;
41
- /**
42
- * 插入字符串
43
- * @param offset 插入位置
44
- * @param text 待插入的字符串
45
- */
46
- insertData(offset: number, text: string): void;
47
- /**
48
- * 提取子串
49
- * @param offset 起始位置
50
- * @param count 字符数
51
- */
52
- substringData(offset: number, count: number): string;
53
- /**
54
- * 将文本子节点分裂为两部分
55
- * @param offset 分裂位置
56
- * @throws `RangeError` 错误的断开位置
57
- * @throws `Error` 没有父节点
58
- */
59
- splitText(offset: number): AstText;
60
- /** 转义 `=` */
61
- escape(): void;
62
- }