fix: Greatly improve latex markdown

This commit is contained in:
Sorunome 2020-10-24 11:50:16 +02:00
parent 66e590073e
commit ad0192e8e1
No known key found for this signature in database
GPG key ID: B19471D07FC9BE9C
2 changed files with 27 additions and 8 deletions

View file

@ -76,12 +76,13 @@ class EmoteSyntax extends InlineSyntax {
} }
} }
class InlineLatexSyntax extends InlineSyntax { class InlineLatexSyntax extends TagSyntax {
InlineLatexSyntax() : super(r'(?<=\s|^)\$(?=\S)([^\n$]+)(?<=\S)\$(?=\s|$)'); InlineLatexSyntax() : super(r'\$', requiresDelimiterRun: true);
@override @override
bool onMatch(InlineParser parser, Match match) { bool onMatchEnd(InlineParser parser, Match match, TagState state) {
final latex = htmlEscape.convert(match[1]); final latex =
htmlEscape.convert(parser.source.substring(state.endPos, match.start));
final element = Element('span', [Element.text('code', latex)]); final element = Element('span', [Element.text('code', latex)]);
element.attributes['data-mx-maths'] = latex; element.attributes['data-mx-maths'] = latex;
parser.addNode(element); parser.addNode(element);
@ -89,22 +90,28 @@ class InlineLatexSyntax extends InlineSyntax {
} }
} }
// We also want to allow single-lines of like "$$latex$$"
class BlockLatexSyntax extends BlockSyntax { class BlockLatexSyntax extends BlockSyntax {
@override @override
RegExp get pattern => RegExp(r'^[ ]{0,3}\${2}\s*$'); RegExp get pattern => RegExp(r'^[ ]{0,3}\$\$(.*)$');
final endPattern = RegExp(r'^(.*)\$\$\s*$');
@override @override
List<String> parseChildLines(BlockParser parser) { List<String> parseChildLines(BlockParser parser) {
var childLines = <String>[]; var childLines = <String>[];
parser.advance(); var first = true;
while (!parser.isDone) { while (!parser.isDone) {
if (!pattern.hasMatch(parser.current)) { final match = endPattern.firstMatch(parser.current);
if (match == null || (first && match.group(1).trim().isEmpty)) {
childLines.add(parser.current); childLines.add(parser.current);
parser.advance(); parser.advance();
} else { } else {
childLines.add(match.group(1));
parser.advance(); parser.advance();
break; break;
} }
first = false;
} }
return childLines; return childLines;
} }
@ -112,7 +119,9 @@ class BlockLatexSyntax extends BlockSyntax {
@override @override
Node parse(BlockParser parser) { Node parse(BlockParser parser) {
final childLines = parseChildLines(parser); final childLines = parseChildLines(parser);
final latex = htmlEscape.convert(childLines.join('\n')); // we use .substring(2) as childLines will *always* contain the first two '$$'
final latex =
htmlEscape.convert(childLines.join('\n').trim().substring(2).trim());
final element = Element('div', [ final element = Element('div', [
Element('pre', [Element.text('code', latex)]) Element('pre', [Element.text('code', latex)])
]); ]);

View file

@ -73,6 +73,16 @@ void main() {
test('latex', () { test('latex', () {
expect(markdown('meep \$\\frac{2}{3}\$'), expect(markdown('meep \$\\frac{2}{3}\$'),
'meep <span data-mx-maths="\\frac{2}{3}"><code>\\frac{2}{3}</code></span>'); 'meep <span data-mx-maths="\\frac{2}{3}"><code>\\frac{2}{3}</code></span>');
expect(markdown('meep \$hmm *yay*\$'),
'meep <span data-mx-maths="hmm *yay*"><code>hmm *yay*</code></span>');
expect(markdown('you have \$somevar and \$someothervar'),
'you have \$somevar and \$someothervar');
expect(markdown('meep ||\$\\frac{2}{3}\$||'),
'meep <span data-mx-spoiler=""><span data-mx-maths="\\frac{2}{3}"><code>\\frac{2}{3}</code></span></span>');
expect(markdown('meep `\$\\frac{2}{3}\$`'),
'meep <code>\$\\frac{2}{3}\$</code>');
expect(markdown('hey\n\$\$beep\$\$\nmeow'),
'<p>hey</p>\n<div data-mx-maths="beep">\n<pre><code>beep</code></pre>\n</div>\n<p>meow</p>');
expect(markdown('hey\n\$\$\nbeep\nboop\n\$\$\nmeow'), expect(markdown('hey\n\$\$\nbeep\nboop\n\$\$\nmeow'),
'<p>hey</p>\n<div data-mx-maths="beep\nboop">\n<pre><code>beep\nboop</code></pre>\n</div>\n<p>meow</p>'); '<p>hey</p>\n<div data-mx-maths="beep\nboop">\n<pre><code>beep\nboop</code></pre>\n</div>\n<p>meow</p>');
}); });