Fix an issue with links not being reversed in code blocks

Fixes #672

+ Markdown to HTML unit test
This commit is contained in:
ArthurHoaro 2016-10-21 12:38:38 +02:00
parent e680cfea08
commit c5941f316a
4 changed files with 67 additions and 5 deletions

View file

@ -155,8 +155,9 @@ function reverse_text2clickable($description)
$lineCount = 0; $lineCount = 0;
foreach ($descriptionLines as $descriptionLine) { foreach ($descriptionLines as $descriptionLine) {
// Detect line of code // Detect line of code: starting with 4 spaces,
$codeLineOn = preg_match('/^ /', $descriptionLine) > 0; // except lists which can start with +/*/- or `2.` after spaces.
$codeLineOn = preg_match('/^ +(?=[^\+\*\-])(?=(?!\d\.).)/', $descriptionLine) > 0;
// Detect and toggle block of code // Detect and toggle block of code
if (!$codeBlockOn) { if (!$codeBlockOn) {
$codeBlockOn = preg_match('/^```/', $descriptionLine) > 0; $codeBlockOn = preg_match('/^```/', $descriptionLine) > 0;
@ -173,10 +174,10 @@ function reverse_text2clickable($description)
$descriptionLine $descriptionLine
); );
// Reverse hashtag links if we're in a code block. // Reverse all links in code blocks, only non hashtag elsewhere.
$hashtagFilter = ($codeBlockOn || $codeLineOn) ? $hashtagTitle : ''; $hashtagFilter = (!$codeBlockOn && !$codeLineOn) ? '(?!'. $hashtagTitle .')': '(?:'. $hashtagTitle .')?';
$descriptionLine = preg_replace( $descriptionLine = preg_replace(
'!<a href="[^ ]*"'. $hashtagFilter .'>([^<]+)</a>!m', '#<a href="[^ ]*"'. $hashtagFilter .'>([^<]+)</a>#m',
'$1', '$1',
$descriptionLine $descriptionLine
); );

View file

@ -151,4 +151,17 @@ function testNoMarkdownTag()
$data = hook_markdown_render_daily($data); $data = hook_markdown_render_daily($data);
$this->assertEquals($str, $data['cols'][0][0]['formatedDescription']); $this->assertEquals($str, $data['cols'][0][0]['formatedDescription']);
} }
/**
* Test hashtag links processed with markdown.
*/
function testMarkdownHashtagLinks()
{
$md = file_get_contents('tests/plugins/resources/markdown.md');
$md = format_description($md);
$html = file_get_contents('tests/plugins/resources/markdown.html');
$data = process_markdown($md);
$this->assertEquals($html, $data);
}
} }

View file

@ -0,0 +1,24 @@
<div class="markdown"><ul>
<li>test:
<ul>
<li><a href="http://link.tld">zero</a></li>
<li><a href="http://link.tld">two</a></li>
<li><a href="http://link.tld">three</a></li>
</ul></li>
</ul>
<ol>
<li><a href="http://link.tld">zero</a>
<ol>
<li><a href="http://link.tld">two</a></li>
<li><a href="http://link.tld">three</a></li>
<li><a href="http://link.tld">four</a></li>
<li>foo <a href="?addtag=foobar" title="Hashtag foobar">#foobar</a></li>
</ol></li>
</ol>
<p><a href="?addtag=foobar" title="Hashtag foobar">#foobar</a> foo <code>lol #foo</code> <a href="?addtag=bar" title="Hashtag bar">#bar</a></p>
<p>fsdfs <a href="http://link.tld">http://link.tld</a> <a href="?addtag=foobar" title="Hashtag foobar">#foobar</a> <code>http://link.tld</code></p>
<pre><code>http://link.tld #foobar
next #foo</code></pre>
<p>Block:</p>
<pre><code>lorem ipsum #foobar http://link.tld
#foobar http://link.tld</code></pre></div>

View file

@ -0,0 +1,24 @@
* test:
* [zero](http://link.tld)
+ [two](http://link.tld)
- [three](http://link.tld)
1. [zero](http://link.tld)
2. [two](http://link.tld)
3. [three](http://link.tld)
4. [four](http://link.tld)
5. foo #foobar
#foobar foo `lol #foo` #bar
fsdfs http://link.tld #foobar `http://link.tld`
http://link.tld #foobar
next #foo
Block:
```
lorem ipsum #foobar http://link.tld
#foobar http://link.tld
```