mirror of
https://github.com/erusev/parsedown.git
synced 2023-08-10 21:13:06 +03:00
Compare commits
2 Commits
Author | SHA1 | Date | |
---|---|---|---|
51a08fad85 | |||
7fb08f334a |
@ -629,9 +629,9 @@ class Parsedown
|
|||||||
|
|
||||||
$index = 0;
|
$index = 0;
|
||||||
|
|
||||||
# inline link or image (recursive)
|
# inline link / inline image (recursive)
|
||||||
|
|
||||||
if (strpos($text, '](') !== FALSE and preg_match_all('/(!?)(\[((?:[^\[\]]|(?2))*)\])\((.*?)\)/', $text, $matches, PREG_SET_ORDER)) # inline
|
if (strpos($text, '](') !== FALSE and preg_match_all('/(!?)(\[((?:[^\[\]]|(?2))*)\])\((.*?)\)/', $text, $matches, PREG_SET_ORDER))
|
||||||
{
|
{
|
||||||
foreach ($matches as $matches)
|
foreach ($matches as $matches)
|
||||||
{
|
{
|
||||||
@ -643,7 +643,7 @@ class Parsedown
|
|||||||
{
|
{
|
||||||
$element = '<img alt="'.$matches[3].'" src="'.$url.'">';
|
$element = '<img alt="'.$matches[3].'" src="'.$url.'">';
|
||||||
}
|
}
|
||||||
else
|
else # link
|
||||||
{
|
{
|
||||||
$element_text = $this->parse_span_elements($matches[3]);
|
$element_text = $this->parse_span_elements($matches[3]);
|
||||||
|
|
||||||
@ -662,7 +662,7 @@ class Parsedown
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# reference link or image (recursive)
|
# reference link / reference image (recursive)
|
||||||
|
|
||||||
if ($this->reference_map and strpos($text, '[') !== FALSE and preg_match_all('/(!?)\[(.+?)\](?:\n?[ ]?\[(.*?)\])?/ms', $text, $matches, PREG_SET_ORDER))
|
if ($this->reference_map and strpos($text, '[') !== FALSE and preg_match_all('/(!?)\[(.+?)\](?:\n?[ ]?\[(.*?)\])?/ms', $text, $matches, PREG_SET_ORDER))
|
||||||
{
|
{
|
||||||
@ -684,7 +684,7 @@ class Parsedown
|
|||||||
{
|
{
|
||||||
$element = '<img alt="'.$matches[2].'" src="'.$url.'">';
|
$element = '<img alt="'.$matches[2].'" src="'.$url.'">';
|
||||||
}
|
}
|
||||||
else # anchor
|
else # link
|
||||||
{
|
{
|
||||||
$element_text = $this->parse_span_elements($matches[2]);
|
$element_text = $this->parse_span_elements($matches[2]);
|
||||||
|
|
||||||
@ -784,18 +784,15 @@ class Parsedown
|
|||||||
if (strpos($text, '_') !== FALSE)
|
if (strpos($text, '_') !== FALSE)
|
||||||
{
|
{
|
||||||
$text = preg_replace('/__(?=\S)([^_]+?)(?<=\S)__/s', '<strong>$1</strong>', $text, -1, $count);
|
$text = preg_replace('/__(?=\S)([^_]+?)(?<=\S)__/s', '<strong>$1</strong>', $text, -1, $count);
|
||||||
$count or $text = preg_replace('/__(?=\S)(.+?)(?<=\S)__(?!_)/s', '<strong>$1</strong>', $text);
|
$text = preg_replace('/(\b|_)_(?=\S)([^_]+?)(?<=\S)_(\b|_)/s', '$1<em>$2</em>$3', $text);
|
||||||
|
$text = preg_replace('/__(?=\S)([^_]+?)(?<=\S)__/s', '<strong>$1</strong>', $text, -1, $count);
|
||||||
$text = preg_replace('/\b_(?=\S)(.+?)(?<=\S)_\b/s', '<em>$1</em>', $text);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strpos($text, '*') !== FALSE)
|
if (strpos($text, '*') !== FALSE)
|
||||||
{
|
{
|
||||||
$text = preg_replace('/\*\*(?=\S)([^*]+?)(?<=\S)\*\*/s', '<strong>$1</strong>', $text, -1, $count);
|
$text = preg_replace('/\*\*(?=\S)([^*]+?)(?<=\S)\*\*/s', '<strong>$1</strong>', $text);
|
||||||
$count or $text = preg_replace('/\*\*(?=\S)(.+?)(?<=\S)\*\*(?!\*)/s', '<strong>$1</strong>', $text);
|
$text = preg_replace('/\*(?=\S)([^*]+?)(?<=\S)\*/s', '<em>$1</em>', $text);
|
||||||
|
$text = preg_replace('/\*\*(?=\S)([^*]+?)(?<=\S)\*\*/s', '<strong>$1</strong>', $text);
|
||||||
$text = preg_replace('/\*(?=\S)([^*]+?)(?<=\S)\*/s', '<em>$1</em>', $text, -1, $count);
|
|
||||||
$count or $text = preg_replace('/\*(?=\S)(.+?)(?<=\S)\*(?!\*)/s', '<em>$1</em>', $text);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$text = strtr($text, $map);
|
$text = strtr($text, $map);
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
<p><strong><em>em strong</em> strong</strong></p>
|
<p><strong><em>em strong</em> strong</strong></p>
|
||||||
<p><strong>strong <em>em strong</em></strong></p>
|
<p><strong>strong <em>em strong</em></strong></p>
|
||||||
<p><strong>strong <em>em strong</em> strong</strong></p>
|
<p><strong>strong <em>em strong</em> strong</strong></p>
|
||||||
|
<p><strong><em>em strong</em> strong</strong></p>
|
||||||
<p><strong>strong <em>em strong</em></strong></p>
|
<p><strong>strong <em>em strong</em></strong></p>
|
||||||
|
<p><strong>strong <em>em strong</em> strong</strong></p>
|
@ -4,4 +4,8 @@ __strong _em strong___
|
|||||||
|
|
||||||
__strong _em strong_ strong__
|
__strong _em strong_ strong__
|
||||||
|
|
||||||
|
***em strong* strong**
|
||||||
|
|
||||||
**strong *em strong***
|
**strong *em strong***
|
||||||
|
|
||||||
|
**strong *em strong* strong**
|
@ -4,3 +4,4 @@ emphasis</em></p>
|
|||||||
<p>_ this _ is not an emphasis, neither is _ this_, _this _, or _this*</p>
|
<p>_ this _ is not an emphasis, neither is _ this_, _this _, or _this*</p>
|
||||||
<p>this_is_not_an_emphasis</p>
|
<p>this_is_not_an_emphasis</p>
|
||||||
<p>an empty emphasis __ ** is not an emphasis</p>
|
<p>an empty emphasis __ ** is not an emphasis</p>
|
||||||
|
<p>*mixed *<em>double and</em> single asterisk** spans</p>
|
@ -8,3 +8,5 @@ _ this _ is not an emphasis, neither is _ this_, _this _, or _this*
|
|||||||
this_is_not_an_emphasis
|
this_is_not_an_emphasis
|
||||||
|
|
||||||
an empty emphasis __ ** is not an emphasis
|
an empty emphasis __ ** is not an emphasis
|
||||||
|
|
||||||
|
*mixed **double and* single asterisk** spans
|
Reference in New Issue
Block a user