Skip to content

Commit

Permalink
Merge branch 'mini' into browser
Browse files Browse the repository at this point in the history
  • Loading branch information
bhsd-harry committed Nov 1, 2024
2 parents ca50c38 + dd05aab commit 8188258
Show file tree
Hide file tree
Showing 10 changed files with 103 additions and 74 deletions.
50 changes: 25 additions & 25 deletions bundle/bundle.min.js

Large diffs are not rendered by default.

10 changes: 1 addition & 9 deletions config/default.json
Original file line number Diff line number Diff line change
Expand Up @@ -140,10 +140,6 @@
"711": "TimedText talk",
"828": "Module",
"829": "Module talk",
"2300": "Gadget",
"2301": "Gadget talk",
"2302": "Gadget definition",
"2303": "Gadget definition talk",
"2600": "Topic"
},
"nsid": {
Expand Down Expand Up @@ -300,11 +296,7 @@
"模組討論": 829,
"模组对话": 829,
"模组讨论": 829,
"モジュール・トーク": 829,
"gadget": 2300,
"gadget talk": 2301,
"gadget definition": 2302,
"gadget definition talk": 2303
"モジュール・トーク": 829
},
"parserFunction": [
{
Expand Down
12 changes: 2 additions & 10 deletions config/enwiki.json
Original file line number Diff line number Diff line change
Expand Up @@ -125,11 +125,7 @@
"710": "TimedText",
"711": "TimedText talk",
"828": "Module",
"829": "Module talk",
"2300": "Gadget",
"2301": "Gadget talk",
"2302": "Gadget definition",
"2303": "Gadget definition talk"
"829": "Module talk"
},
"nsid": {
"": 0,
Expand Down Expand Up @@ -165,11 +161,7 @@
"timedtext": 710,
"timedtext talk": 711,
"module": 828,
"module talk": 829,
"gadget": 2300,
"gadget talk": 2301,
"gadget definition": 2302,
"gadget definition talk": 2303
"module talk": 829
},
"parserFunction": [
{
Expand Down
1 change: 1 addition & 0 deletions i18n/zh-hans.json
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@
"unexpected template argument": "未预期的模板参数",
"unmatched closing tag": "未匹配的闭合标签",
"unnecessary URL encoding in an internal link": "内链中不必要的URL编码",
"useless attribute": "无用的属性",
"useless fragment": "无用的fragment",
"useless link text": "无用的链接文字",
"variable anchor in a section header": "段落标题中可变的锚点",
Expand Down
1 change: 1 addition & 0 deletions i18n/zh-hant.json
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@
"unexpected template argument": "未預期的模板參數",
"unmatched closing tag": "未匹配的閉合標籤",
"unnecessary URL encoding in an internal link": "內部連結中不必要的URL編碼",
"useless attribute": "無用的屬性",
"useless fragment": "無用的fragment",
"useless link text": "無用的連結文字",
"variable anchor in a section header": "段落標題中可變的錨點",
Expand Down
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -52,8 +52,8 @@
"test:real": "node --enable-source-maps dist/test/real.js"
},
"devDependencies": {
"@bhsd/codemirror-mediawiki": "^2.17.4",
"@bhsd/common": "^0.2.0",
"@bhsd/codemirror-mediawiki": "^2.18.3",
"@bhsd/common": "^0.3.0",
"@codemirror/lint": "^6.8.0",
"@types/node": "^20.11.6",
"@types/prismjs": "^1.26.3",
Expand Down
4 changes: 2 additions & 2 deletions src/paramTag/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -56,9 +56,9 @@ export abstract class ParamTagToken extends Token {
override lint(start = this.getAbsoluteIndex()): LintError[] {
const rect = new BoundingRect(this, start);
return this.childNodes.filter(child => {
const {childNodes} = child,
const childNodes = child.childNodes.filter(({type}) => type !== 'comment'),
i = childNodes.findIndex(({type}) => type !== 'text'),
str = (i >= 0 ? childNodes.slice(0, i).map(String).join('') : child.toString()).trim();
str = childNodes.slice(0, i >= 0 ? i : undefined).map(String).join('');
return str && !(i >= 0 ? /^[a-z]+(?:\[\])?\s*(?:=|$)/iu : /^[a-z]+(?:\[\])?\s*=/iu).test(str);
}).map(child => {
const e = generateForChild(child, rect, 'no-ignored', Parser.msg('invalid parameter of <$1>', this.name));
Expand Down
20 changes: 20 additions & 0 deletions src/paramTag/inputbox.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,32 @@
import {parseBraces} from '../../parser/braces';
import Parser from '../../index';
import {ParamTagToken} from './index';
import {CommentToken} from '../nowiki/comment';
import type {Config} from '../../base';
import type {Token} from '../index';

/**
* 解析注释
* @param wikitext 维基文本
* @param config
* @param accum
*/
const parseComment = (wikitext: string, config: Config, accum: Token[]): string => wikitext.replace(
/<!--.*?(?:-->|$)/gsu,
comment => {
const str = `\0${accum.length + 1}c\x7F`,
closed = comment.endsWith('-->');
// @ts-expect-error abstract class
new CommentToken(comment.slice(4, closed ? -3 : undefined), closed, config, accum);
return str;
},
);

/** `<inputbox>` */
export abstract class InputboxToken extends ParamTagToken {
/** @class */
constructor(wikitext?: string, config = Parser.getConfig(), accum: Token[] = []) {
wikitext &&= parseComment(wikitext, config, accum);
const placeholder = Symbol('InputboxToken'),
{length} = accum;
accum.push(placeholder as unknown as Token);
Expand Down
36 changes: 22 additions & 14 deletions src/pre.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,25 +28,33 @@ export abstract class PreToken extends Token {
/** @class */
constructor(wikitext?: string, config = Parser.getConfig(), accum: Token[] = []) {
if (wikitext) {
const opening = '<nowiki>',
closing = '</nowiki>',
{length} = opening;
let i = wikitext.indexOf(opening),
j = wikitext.indexOf(closing, i + length),
const opening = /<nowiki>/giu,
closing = /<\/nowiki>/giu,
{length} = opening.source;
let i = opening.exec(wikitext);
if (i) {
closing.lastIndex = i.index + length;
}
let j = closing.exec(wikitext),
lastIndex = 0,
str = '';
while (i !== -1 && j !== -1) {
while (i && j) {
// @ts-expect-error abstract class
new NoincludeToken(opening, config, accum);
new NoincludeToken(i[0], config, accum);
// @ts-expect-error abstract class
new NoincludeToken(closing, config, accum);
str += `${wikitext.slice(0, i)}\0${accum.length - 1}n\x7F${
wikitext.slice(i + length, j)
new NoincludeToken(j[0], config, accum);
str += `${wikitext.slice(lastIndex, i.index)}\0${accum.length - 1}n\x7F${
wikitext.slice(i.index + length, j.index)
}\0${accum.length}n\x7F`;
wikitext = wikitext.slice(j + length + 1);
i = wikitext.indexOf(opening);
j = wikitext.indexOf(closing, i + length);
lastIndex = j.index + length + 1;
opening.lastIndex = lastIndex;
i = opening.exec(wikitext);
if (i) {
closing.lastIndex = i.index + length;
}
j = closing.exec(wikitext);
}
wikitext = str + wikitext;
wikitext = str + wikitext.slice(lastIndex);
}
super(wikitext, config, accum, {
});
Expand Down
39 changes: 27 additions & 12 deletions src/tagPair/include.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import {generateForSelf} from '../../util/lint';
import {generateForSelf, generateForChild} from '../../util/lint';
import {BoundingRect} from '../../lib/rect';
import {hiddenToken} from '../../mixin/hidden';
import Parser from '../../index';
import {TagPairToken} from './index';
Expand Down Expand Up @@ -36,17 +37,31 @@ export abstract class IncludeToken extends TagPairToken {

/** @private */
override lint(start = this.getAbsoluteIndex()): LintError[] {
if (this.closed) {
return [];
const errors: LintError[] = [],
{firstChild, closed, name} = this,
rect = new BoundingRect(this, start);
if (firstChild.data.trim()) {
const e = generateForChild(firstChild, rect, 'no-ignored', 'useless attribute', 'warning');
e.suggestions = [
{
desc: 'remove',
range: [e.startIndex, e.endIndex],
text: '',
},
];
errors.push(e);
}
const e = generateForSelf(this, {start}, 'unclosed-comment', Parser.msg('unclosed $1', `<${this.name}>`));
e.suggestions = [
{
desc: 'close',
range: [e.endIndex, e.endIndex],
text: `</${this.name}>`,
},
];
return [e];
if (!closed) {
const e = generateForSelf(this, rect, 'unclosed-comment', Parser.msg('unclosed $1', `<${name}>`));
e.suggestions = [
{
desc: 'close',
range: [e.endIndex, e.endIndex],
text: `</${name}>`,
},
];
errors.push(e);
}
return errors;
}
}

0 comments on commit 8188258

Please sign in to comment.