diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2019-01-31 12:23:45 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2019-01-31 12:23:45 +0900 |
| commit | b515cc90e9070465d9ba1f2e40d7af184fff5491 (patch) | |
| tree | 62fe52284a87479560c97f0b242d89bf91f74236 /src | |
| parent | [MFM] Make some syntax block (diff) | |
| download | sharkey-b515cc90e9070465d9ba1f2e40d7af184fff5491.tar.gz sharkey-b515cc90e9070465d9ba1f2e40d7af184fff5491.tar.bz2 sharkey-b515cc90e9070465d9ba1f2e40d7af184fff5491.zip | |
[MFM] Better syntax parsing
Allow nesting by same tag
Diffstat (limited to 'src')
| -rw-r--r-- | src/mfm/language.ts | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/mfm/language.ts b/src/mfm/language.ts index 8f35d443dc..75451f3bd4 100644 --- a/src/mfm/language.ts +++ b/src/mfm/language.ts @@ -108,20 +108,20 @@ export const mfmLanguage = P.createLanguage({ strike: r => P.regexp(/~~(.+?)~~/, 1).map(x => createTree('strike', r.inline.atLeast(1).tryParse(x), {})), motion: r => { const paren = P.regexp(/\(\(\(([\s\S]+?)\)\)\)/, 1); - const xml = P.regexp(/<motion>(.+?)<\/motion>/, 1); + const xml = P.regexp(/<motion>(.+)<\/motion>/, 1); return P.alt(paren, xml).map(x => createTree('motion', r.inline.atLeast(1).tryParse(x), {})); }, spin: r => { return P((input, i) => { const text = input.substr(i); - const match = text.match(/^<spin(\s[a-z]+?)?>(.+?)<\/spin>/i); + const match = text.match(/^<spin(\s[a-z]+?)?>(.+)<\/spin>/i); if (!match) return P.makeFailure(i, 'not a spin'); return P.makeSuccess(i + match[0].length, { content: match[2], attr: match[1] ? match[1].trim() : null }); }).map(x => createTree('spin', r.inline.atLeast(1).tryParse(x.content), { attr: x.attr })); }, - jump: r => P.regexp(/<jump>(.+?)<\/jump>/, 1).map(x => createTree('jump', r.inline.atLeast(1).tryParse(x), {})), + jump: r => P.regexp(/<jump>(.+)<\/jump>/, 1).map(x => createTree('jump', r.inline.atLeast(1).tryParse(x), {})), flip: r => P.regexp(/<flip>(.+?)<\/flip>/, 1).map(x => createTree('flip', r.inline.atLeast(1).tryParse(x), {})), center: r => r.startOfLine.then(P.regexp(/<center>([\s\S]+?)<\/center>/, 1).map(x => createTree('center', r.inline.atLeast(1).tryParse(x), {}))), inlineCode: () => P.regexp(/`([^ยด\n]+?)`/, 1).map(x => createLeaf('inlineCode', { code: x })), |