fix: Greatly improve latex markdown
This commit is contained in:
parent
66e590073e
commit
ad0192e8e1
|
@ -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)])
|
||||||
]);
|
]);
|
||||||
|
|
|
@ -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>');
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue