From 273b78c0802ed63f4f0129731aae244b4b618103 Mon Sep 17 00:00:00 2001 From: ibrokemypie Date: Sun, 20 Jan 2019 19:44:52 +1100 Subject: [PATCH] Change italic syntax to fit with other markdown implementations (#3916) currently italics require an html syntax, unlike every other formatter. this is very confusing, especially as there doesnt seem to be any documentation. this change makes both _text_ and *text* work, both things that users would expect from other implementations of markdown such as pleroma, discord and github. Add test --- src/mfm/parser.ts | 2 +- test/mfm.ts | 43 +++++++++++++++++++++++++++++++++++++------ 2 files changed, 38 insertions(+), 7 deletions(-) diff --git a/src/mfm/parser.ts b/src/mfm/parser.ts index 7dc97aa9f..f377d1861 100644 --- a/src/mfm/parser.ts +++ b/src/mfm/parser.ts @@ -224,7 +224,7 @@ const mfm = P.createLanguage({ //#region Italic italic: r => - P.regexp(/([\s\S]+?)<\/i>/, 1) + P.regexp(/(\*|_)([a-zA-Z0-9]+?[\s\S]*?)\1/, 2) .map(x => createTree('italic', P.alt( r.bold, r.strike, diff --git a/test/mfm.ts b/test/mfm.ts index 4e922cab2..44e7d6904 100644 --- a/test/mfm.ts +++ b/test/mfm.ts @@ -32,8 +32,8 @@ describe('createTree', () => { leaf('left', { a: 2 }), leaf('right', { b: 'hi' }) ], { - c: 4 - }); + c: 4 + }); assert.deepStrictEqual(t, { node: { type: 'tree', @@ -288,7 +288,7 @@ describe('MFM', () => { leaf('mention', { acct: '@a', canonical: '@a', username: 'a', host: null }) ]); - const tokens4 = analyze('@\n@v\n@veryverylongusername' /* \n@toolongtobeasamention */ ); + const tokens4 = analyze('@\n@v\n@veryverylongusername' /* \n@toolongtobeasamention */); assert.deepStrictEqual(tokens4, [ text('@\n'), leaf('mention', { acct: '@v', canonical: '@v', username: 'v', host: null }), @@ -883,15 +883,46 @@ describe('MFM', () => { }); describe('italic', () => { - it('simple', () => { - const tokens = analyze('foo'); + it('underscore', () => { + const tokens = analyze('_foo_'); assert.deepStrictEqual(tokens, [ tree('italic', [ text('foo') ], {}), ]); }); - }); + + it('simple with asterix', () => { + const tokens = analyze('*foo*'); + assert.deepStrictEqual(tokens, [ + tree('italic', [ + text('foo') + ], {}), + ]); + }); + + it('exlude emotes', () => { + const tokens = analyze('*.*'); + assert.deepStrictEqual(tokens, [ + text("*.*"), + ]); + }); + + it('mixed', () => { + const tokens = analyze('_foo*'); + assert.deepStrictEqual(tokens, [ + text('_foo*'), + ]); + }); + + it('mixed', () => { + const tokens = analyze('*foo_'); + assert.deepStrictEqual(tokens, [ + text('*foo_'), + ]); + }); + }, + ); }); describe('toHtml', () => {