1
0
mirror of https://github.com/erusev/parsedown.git synced 2023-08-10 21:13:06 +03:00

Compare commits

...

7 Commits
0.4.1 ... 0.4.5

9 changed files with 52 additions and 42 deletions

View File

@ -78,7 +78,7 @@ class Parsedown
# ~ # ~
$text = preg_replace('/\n\s*\n/', "\n\n", $text); $text = preg_replace('/\n\s*\n/', "\n\n", $text);
$text = trim($text, "\n"); $text = trim($text, "\n ");
$lines = explode("\n", $text); $lines = explode("\n", $text);
@ -205,7 +205,7 @@ class Parsedown
# Quick Paragraph # Quick Paragraph
if ($line[0] >= 'A' and $line[0] !== '_' and $line[0] !== '[') if ($line[0] >= 'a' or $line[0] >= 'A' and $line[0] <= 'Z')
{ {
goto paragraph; # trust me goto paragraph; # trust me
} }
@ -216,7 +216,12 @@ class Parsedown
{ {
if ($element['type'] === 'code') if ($element['type'] === 'code')
{ {
isset($element['interrupted']) and $element['text'] .= "\n"; if (isset($element['interrupted']))
{
$element['text'] .= "\n";
unset ($element['interrupted']);
}
$element['text'] .= "\n".$matches[1]; $element['text'] .= "\n".$matches[1];
} }
@ -272,13 +277,13 @@ class Parsedown
# ~ # ~
$pure_line = ltrim($line); $pure_line = $line[0] !== ' ' ? $line : ltrim($line);
# Link Reference # Link Reference
if ($pure_line[0] === '[' and preg_match('/^\[(.+?)\]:[ ]*([^ ]+)/', $pure_line, $matches)) if ($pure_line[0] === '[' and preg_match('/^\[(.+?)\]:[ ]*([^ ]+)/', $pure_line, $matches))
{ {
$label = $matches[1]; $label = strtolower($matches[1]);
$url = trim($matches[2], '<>'); $url = trim($matches[2], '<>');
$this->reference_map[$label] = $url; $this->reference_map[$label] = $url;
@ -555,11 +560,13 @@ class Parsedown
# Inline Link / Image # Inline Link / Image
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)) # inline
{ {
foreach ($matches as $matches) foreach ($matches as $matches)
{ {
$url = $this->escape_special_characters($matches[4]); $url = $matches[4];
strpos($url, '&') !== FALSE and $url = preg_replace('/&(?!#?\w+;)/', '&amp;', $url);
if ($matches[1]) # image if ($matches[1]) # image
{ {
@ -599,7 +606,8 @@ class Parsedown
if (isset($this->reference_map[$link_definition])) if (isset($this->reference_map[$link_definition]))
{ {
$url = $this->reference_map[$link_definition]; $url = $this->reference_map[$link_definition];
$url = $this->escape_special_characters($url);
strpos($url, '&') !== FALSE and $url = preg_replace('/&(?!#?\w+;)/', '&amp;', $url);
if ($matches[1]) # image if ($matches[1]) # image
{ {
@ -631,7 +639,9 @@ class Parsedown
{ {
foreach ($matches as $matches) foreach ($matches as $matches)
{ {
$url = $this->escape_special_characters($matches[1]); $url = $matches[1];
strpos($url, '&') !== FALSE and $url = preg_replace('/&(?!#?\w+;)/', '&amp;', $url);
$element = '<a href=":href">:text</a>'; $element = '<a href=":href">:text</a>';
$element = str_replace(':text', $url, $element); $element = str_replace(':text', $url, $element);
@ -651,8 +661,9 @@ class Parsedown
# ~ # ~
$text = $this->escape_special_characters($text); strpos($text, '&') !== FALSE and $text = preg_replace('/&(?!#?\w+;)/', '&amp;', $text);
strpos($text, '<') !== FALSE and $text = preg_replace('/<(?!\/?\w.*?>)/', '&lt;', $text);
# ~ # ~
if (strpos($text, '_') !== FALSE) if (strpos($text, '_') !== FALSE)
@ -671,13 +682,4 @@ class Parsedown
return $text; return $text;
} }
private function escape_special_characters($text)
{
strpos($text, '&') !== FALSE and $text = preg_replace('/&(?!#?\w+;)/', '&amp;', $text);
$text = str_replace('<', '&lt;', $text);
return $text;
}
} }

View File

@ -1,9 +1,8 @@
<p>Here's a regular code block:</p> <p>Here's a code block:</p>
<pre><code>&lt;?php <pre><code>&lt;?php
echo 'Hello World!'; $message = 'Hello World!';
echo $message;</code></pre>
?&gt;</code></pre> <p>Here's one that holds a list:</p>
<p>Here's one that holds a list:</p> <pre><code>- list item
<pre><code>- list item
- another list item</code></pre> - another list item</code></pre>

View File

@ -1,13 +1,12 @@
Here's a regular code block: Here's a code block:
<?php <?php
echo 'Hello World!'; $message = 'Hello World!';
echo $message;
?>
Here's one that holds a list:
Here's one that holds a list:
- list item
- list item - another list item
- another list item

View File

@ -2,6 +2,7 @@
<p>Here's <a href="http://parsedown.org">one</a> on the next line.</p> <p>Here's <a href="http://parsedown.org">one</a> on the next line.</p>
<p>Here's <a href="http://parsedown.org/tests/">one</a> with a different URL.</p> <p>Here's <a href="http://parsedown.org/tests/">one</a> with a different URL.</p>
<p>Here's <a href="http://parsedown.org">one</a> with a semantic name.</p> <p>Here's <a href="http://parsedown.org">one</a> with a semantic name.</p>
<p>Here's <a href="http://parsedown.org">one</a> with an upper case label definition.</p>
<p>Here's <a href="http://parsedown.org">one</a> with definition name on the next line.</p> <p>Here's <a href="http://parsedown.org">one</a> with definition name on the next line.</p>
<p>Here's [one][404] with no definition.</p> <p>Here's [one][404] with no definition.</p>
<p>Here's an image: <img alt="Markdown Logo" src="/md.png"></p> <p>Here's an image: <img alt="Markdown Logo" src="/md.png"></p>

View File

@ -13,6 +13,10 @@ Here's [one][website] with a semantic name.
[website]: http://parsedown.org [website]: http://parsedown.org
Here's [one][case] with an upper case label definition.
[CASE]: http://parsedown.org
Here's [one] Here's [one]
[website] with definition name on the next line. [website] with definition name on the next line.

View File

@ -0,0 +1 @@
<p>Here's an <b>important</b> <a href=''>link</a>.</p>

View File

@ -0,0 +1 @@
Here's an <b>important</b> <a href=''>link</a>.

View File

@ -4,5 +4,6 @@
<p>4 &lt; 5 and 6 > 5.</p> <p>4 &lt; 5 and 6 > 5.</p>
<p>Here's a <a href="http://example.com/?foo=1&amp;bar=2">link</a> with an ampersand in the URL.</p> <p>Here's a <a href="http://example.com/?foo=1&amp;bar=2">link</a> with an ampersand in the URL.</p>
<p>Here's an inline <a href="/script?foo=1&amp;bar=2">link</a>.</p> <p>Here's an inline <a href="/script?foo=1&amp;bar=2">link</a>.</p>
<p><a href="http://example.com/autolink?a=1&amp;b=2">http://example.com/autolink?a=1&amp;b=2</a></p>
<hr /> <hr />
<p>Based on <a href="http://daringfireball.net/projects/downloads/MarkdownTest_1.0.zip">the original</a> test suite.</p> <p>Based on <a href="http://daringfireball.net/projects/downloads/MarkdownTest_1.0.zip">the original</a> test suite.</p>

View File

@ -1,6 +1,6 @@
AT&T has an ampersand in their name. AT&T has an ampersand in their name.
AT&amp;T is another way to write it. AT&T is another way to write it.
This & that. This & that.
@ -12,6 +12,8 @@ Here's an inline [link](/script?foo=1&bar=2).
[1]: http://example.com/?foo=1&bar=2 [1]: http://example.com/?foo=1&bar=2
<http://example.com/autolink?a=1&b=2>
--- ---
Based on [the original](http://daringfireball.net/projects/downloads/MarkdownTest_1.0.zip) test suite. Based on [the original](http://daringfireball.net/projects/downloads/MarkdownTest_1.0.zip) test suite.