mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-09 08:45:55 +02:00
854 lines
25 KiB
HTML
854 lines
25 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<title>turndown test runner</title>
|
|
<link rel="stylesheet" href="../node_modules/turndown-attendant/dist/styles.css">
|
|
</head>
|
|
<body>
|
|
|
|
<!-- TEST CASES -->
|
|
|
|
<div class="case" data-name="p">
|
|
<div class="input"><p>Lorem ipsum</p></div>
|
|
<pre class="expected">Lorem ipsum</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="multiple ps">
|
|
<div class="input">
|
|
<p>Lorem</p>
|
|
<p>ipsum</p>
|
|
<p>sit</p>
|
|
</div>
|
|
<pre class="expected">Lorem
|
|
|
|
ipsum
|
|
|
|
sit</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="em">
|
|
<div class="input"><em>em element</em></div>
|
|
<pre class="expected">_em element_</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="i">
|
|
<div class="input"><i>i element</i></div>
|
|
<pre class="expected">_i element_</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="strong">
|
|
<div class="input"><strong>strong element</strong></div>
|
|
<pre class="expected">**strong element**</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="b">
|
|
<div class="input"><b>b element</b></div>
|
|
<pre class="expected">**b element**</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="code">
|
|
<div class="input"><code>code element</code></div>
|
|
<pre class="expected">`code element`</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="code containing a backtick">
|
|
<div class="input"><code>There is a literal backtick (`) here</code></div>
|
|
<pre class="expected">``There is a literal backtick (`) here``</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="code containing three or more backticks">
|
|
<div class="input"><code>here are three ``` here are four ```` that's it</code></div>
|
|
<pre class="expected">`here are three ``` here are four ```` that's it`</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="code containing one or more backticks">
|
|
<div class="input"><code>here are three ``` here are four ```` here is one ` that's it</code></div>
|
|
<pre class="expected">``here are three ``` here are four ```` here is one ` that's it``</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="code starting with a backtick">
|
|
<div class="input"><code>`starting with a backtick</code></div>
|
|
<pre class="expected">`` `starting with a backtick``</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="code containing markdown syntax">
|
|
<div class="input"><code>_emphasis_</code></div>
|
|
<pre class="expected">`_emphasis_`</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="code containing markdown syntax in a span">
|
|
<div class="input"><code><span>_emphasis_</span></code></div>
|
|
<pre class="expected">`_emphasis_`</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="h1">
|
|
<div class="input"><h1>Level One Heading</h1></div>
|
|
<pre class="expected">Level One Heading
|
|
=================</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="h1 as atx" data-options='{"headingStyle":"atx"}'>
|
|
<div class="input"><h1>Level One Heading with ATX</h1></div>
|
|
<pre class="expected"># Level One Heading with ATX</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="h2">
|
|
<div class="input"><h2>Level Two Heading</h2></div>
|
|
<pre class="expected">Level Two Heading
|
|
-----------------</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="h2 as atx" data-options='{"headingStyle":"atx"}'>
|
|
<div class="input"><h2>Level Two Heading with ATX</h2></div>
|
|
<pre class="expected">## Level Two Heading with ATX</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="h3">
|
|
<div class="input"><h3>Level Three Heading</h3></div>
|
|
<pre class="expected">### Level Three Heading</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="heading with child">
|
|
<div class="input"><h4>Level Four Heading with <code>child</code></h4></div>
|
|
<pre class="expected">#### Level Four Heading with `child`</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="invalid heading">
|
|
<div class="input"><h7>Level Seven Heading?</h7></div>
|
|
<pre class="expected">Level Seven Heading?</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="hr">
|
|
<div class="input"><hr></div>
|
|
<pre class="expected">* * *</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="hr with closing tag">
|
|
<div class="input"><hr></hr></div>
|
|
<pre class="expected">* * *</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="hr with option" data-options='{"hr": "- - -"}'>
|
|
<div class="input"><hr></div>
|
|
<pre class="expected">- - -</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="br">
|
|
<div class="input">More<br>after the break</div>
|
|
<pre class="expected">More
|
|
after the break</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="br with visible line-ending" data-options='{"br": "\\"}'>
|
|
<div class="input">More<br>after the break</div>
|
|
<pre class="expected">More\
|
|
after the break</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="img with no alt">
|
|
<div class="input"><img src="http://example.com/logo.png" /></div>
|
|
<pre class="expected">![](http://example.com/logo.png)</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="img with relative src">
|
|
<div class="input"><img src="logo.png"></div>
|
|
<pre class="expected">![](logo.png)</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="img with alt">
|
|
<div class="input"><img src="logo.png" alt="img with alt"></div>
|
|
<pre class="expected">![img with alt](logo.png)</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="img with no src">
|
|
<div class="input"><img></div>
|
|
<pre class="expected"></pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="a">
|
|
<div class="input"><a href="http://example.com">An anchor</a></div>
|
|
<pre class="expected">[An anchor](http://example.com)</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="a with title">
|
|
<div class="input"><a href="http://example.com" title="Title for link">An anchor</a></div>
|
|
<pre class="expected">[An anchor](http://example.com "Title for link")</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="a without a src">
|
|
<div class="input"><a id="about-anchor">Anchor without a title</a></div>
|
|
<pre class="expected">Anchor without a title</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="a with a child">
|
|
<div class="input"><a href="http://example.com/code">Some <code>code</code></a></div>
|
|
<pre class="expected">[Some `code`](http://example.com/code)</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="a reference" data-options='{"linkStyle": "referenced"}'>
|
|
<div class="input"><a href="http://example.com">Reference link</a></div>
|
|
<pre class="expected">[Reference link][1]
|
|
|
|
[1]: http://example.com</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="a reference with collapsed style" data-options='{"linkStyle": "referenced", "linkReferenceStyle": "collapsed"}'>
|
|
<div class="input"><a href="http://example.com">Reference link with collapsed style</a></div>
|
|
<pre class="expected">[Reference link with collapsed style][]
|
|
|
|
[Reference link with collapsed style]: http://example.com</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="a reference with shortcut style" data-options='{"linkStyle": "referenced", "linkReferenceStyle": "shortcut"}'>
|
|
<div class="input"><a href="http://example.com">Reference link with shortcut style</a></div>
|
|
<pre class="expected">[Reference link with shortcut style]
|
|
|
|
[Reference link with shortcut style]: http://example.com</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="pre/code block">
|
|
<div class="input"><pre><code>def code_block
|
|
# 42 < 9001
|
|
"Hello world!"
|
|
end</code></pre></div>
|
|
|
|
<pre class="expected"> def code_block
|
|
# 42 < 9001
|
|
"Hello world!"
|
|
end</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="multiple pre/code blocks">
|
|
<div class="input"><pre><code>def first_code_block
|
|
# 42 < 9001
|
|
"Hello world!"
|
|
end</code></pre>
|
|
|
|
<p>next:</p>
|
|
|
|
<pre><code>def second_code_block
|
|
# 42 < 9001
|
|
"Hello world!"
|
|
end</code></pre></div>
|
|
|
|
<pre class="expected"> def first_code_block
|
|
# 42 < 9001
|
|
"Hello world!"
|
|
end
|
|
|
|
next:
|
|
|
|
def second_code_block
|
|
# 42 < 9001
|
|
"Hello world!"
|
|
end</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="pre/code block with multiple new lines">
|
|
<div class="input"><div><pre><code>Multiple new lines
|
|
|
|
|
|
should not be
|
|
|
|
|
|
removed</code></pre></div></div>
|
|
|
|
<pre class="expected"> Multiple new lines
|
|
|
|
|
|
should not be
|
|
|
|
|
|
removed</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="fenced pre/code block" data-options='{"codeBlockStyle": "fenced"}'>
|
|
<div class="input">
|
|
<pre><code>def a_fenced_code block; end</code></pre>
|
|
</div>
|
|
<pre class="expected">```
|
|
def a_fenced_code block; end
|
|
```</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="pre/code block fenced with ~" data-options='{"codeBlockStyle": "fenced", "fence": "~~~"}'>
|
|
<div class="input">
|
|
<pre><code>def a_fenced_code block; end</code></pre>
|
|
</div>
|
|
<pre class="expected">~~~
|
|
def a_fenced_code block; end
|
|
~~~</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="fenced pre/code block with language" data-options='{"codeBlockStyle": "fenced"}'>
|
|
<div class="input">
|
|
<pre><code class="language-ruby">def a_fenced_code block; end</code></pre>
|
|
</div>
|
|
<pre class="expected">```ruby
|
|
def a_fenced_code block; end
|
|
```</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="empty pre does not throw error">
|
|
<div class="input">
|
|
<pre></pre>
|
|
</div>
|
|
<pre class="expected"></pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="ol">
|
|
<div class="input">
|
|
<ol>
|
|
<li>Ordered list item 1</li>
|
|
<li>Ordered list item 2</li>
|
|
<li>Ordered list item 3</li>
|
|
</ol>
|
|
</div>
|
|
<pre class="expected">1. Ordered list item 1
|
|
2. Ordered list item 2
|
|
3. Ordered list item 3</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="ol with start">
|
|
<div class="input">
|
|
<ol start="42">
|
|
<li>Ordered list item 42</li>
|
|
<li>Ordered list item 43</li>
|
|
<li>Ordered list item 44</li>
|
|
</ol>
|
|
</div>
|
|
<pre class="expected">42. Ordered list item 42
|
|
43. Ordered list item 43
|
|
44. Ordered list item 44</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="list spacing">
|
|
<div class="input">
|
|
<p>A paragraph.</p>
|
|
<ol>
|
|
<li>Ordered list item 1</li>
|
|
<li>Ordered list item 2</li>
|
|
<li>Ordered list item 3</li>
|
|
</ol>
|
|
<p>Another paragraph.</p>
|
|
<ul>
|
|
<li>Unordered list item 1</li>
|
|
<li>Unordered list item 2</li>
|
|
<li>Unordered list item 3</li>
|
|
</ul>
|
|
</div>
|
|
<pre class="expected">A paragraph.
|
|
|
|
1. Ordered list item 1
|
|
2. Ordered list item 2
|
|
3. Ordered list item 3
|
|
|
|
Another paragraph.
|
|
|
|
* Unordered list item 1
|
|
* Unordered list item 2
|
|
* Unordered list item 3</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="ul">
|
|
<div class="input">
|
|
<ul>
|
|
<li>Unordered list item 1</li>
|
|
<li>Unordered list item 2</li>
|
|
<li>Unordered list item 3</li>
|
|
</ul>
|
|
</div>
|
|
<pre class="expected">* Unordered list item 1
|
|
* Unordered list item 2
|
|
* Unordered list item 3</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="ul with custom bullet" data-options='{"bulletListMarker": "-"}'>
|
|
<div class="input">
|
|
<ul>
|
|
<li>Unordered list item 1</li>
|
|
<li>Unordered list item 2</li>
|
|
<li>Unordered list item 3</li>
|
|
</ul>
|
|
</div>
|
|
<pre class="expected">- Unordered list item 1
|
|
- Unordered list item 2
|
|
- Unordered list item 3</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="ul with paragraph">
|
|
<div class="input">
|
|
<ul>
|
|
<li><p>List item with paragraph</p></li>
|
|
<li>List item without paragraph</li>
|
|
</ul>
|
|
</div>
|
|
<pre class="expected">* List item with paragraph
|
|
|
|
* List item without paragraph</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="ol with paragraphs">
|
|
<div class="input">
|
|
<ol>
|
|
<li>
|
|
<p>This is a paragraph in a list item.</p>
|
|
<p>This is a paragraph in the same list item as above.</p>
|
|
</li>
|
|
<li>
|
|
<p>A paragraph in a second list item.</p>
|
|
</li>
|
|
</ol>
|
|
</div>
|
|
<pre class="expected">1. This is a paragraph in a list item.
|
|
|
|
This is a paragraph in the same list item as above.
|
|
|
|
2. A paragraph in a second list item.</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="nested uls">
|
|
<div class="input">
|
|
<ul>
|
|
<li>This is a list item at root level</li>
|
|
<li>This is another item at root level</li>
|
|
<li>
|
|
<ul>
|
|
<li>This is a nested list item</li>
|
|
<li>This is another nested list item</li>
|
|
<li>
|
|
<ul>
|
|
<li>This is a deeply nested list item</li>
|
|
<li>This is another deeply nested list item</li>
|
|
<li>This is a third deeply nested list item</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
<li>This is a third item at root level</li>
|
|
</ul>
|
|
</div>
|
|
<pre class="expected">* This is a list item at root level
|
|
* This is another item at root level
|
|
* * This is a nested list item
|
|
* This is another nested list item
|
|
* * This is a deeply nested list item
|
|
* This is another deeply nested list item
|
|
* This is a third deeply nested list item
|
|
* This is a third item at root level</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="nested ols and uls">
|
|
<div class="input">
|
|
<ul>
|
|
<li>This is a list item at root level</li>
|
|
<li>This is another item at root level</li>
|
|
<li>
|
|
<ol>
|
|
<li>This is a nested list item</li>
|
|
<li>This is another nested list item</li>
|
|
<li>
|
|
<ul>
|
|
<li>This is a deeply nested list item</li>
|
|
<li>This is another deeply nested list item</li>
|
|
<li>This is a third deeply nested list item</li>
|
|
</ul>
|
|
</li>
|
|
</ol>
|
|
</li>
|
|
<li>This is a third item at root level</li>
|
|
</ul>
|
|
</div>
|
|
<pre class="expected">* This is a list item at root level
|
|
* This is another item at root level
|
|
* 1. This is a nested list item
|
|
2. This is another nested list item
|
|
3. * This is a deeply nested list item
|
|
* This is another deeply nested list item
|
|
* This is a third deeply nested list item
|
|
* This is a third item at root level</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="ul with blockquote">
|
|
<div class="input">
|
|
<ul>
|
|
<li>
|
|
<p>A list item with a blockquote:</p>
|
|
<blockquote>
|
|
<p>This is a blockquote inside a list item.</p>
|
|
</blockquote>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
<pre class="expected">* A list item with a blockquote:
|
|
|
|
> This is a blockquote inside a list item.</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="blockquote">
|
|
<div class="input">
|
|
<blockquote>
|
|
<p>This is a paragraph within a blockquote.</p>
|
|
<p>This is another paragraph within a blockquote.</p>
|
|
</blockquote>
|
|
</div>
|
|
<pre class="expected">> This is a paragraph within a blockquote.
|
|
>
|
|
> This is another paragraph within a blockquote.</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="nested blockquotes">
|
|
<div class="input">
|
|
<blockquote>
|
|
<p>This is the first level of quoting.</p>
|
|
<blockquote>
|
|
<p>This is a paragraph in a nested blockquote.</p>
|
|
</blockquote>
|
|
<p>Back to the first level.</p>
|
|
</blockquote>
|
|
</div>
|
|
<pre class="expected">> This is the first level of quoting.
|
|
>
|
|
> > This is a paragraph in a nested blockquote.
|
|
>
|
|
> Back to the first level.</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="html in blockquote">
|
|
<div class="input">
|
|
<blockquote>
|
|
<h2>This is a header.</h2>
|
|
<ol>
|
|
<li>This is the first list item.</li>
|
|
<li>This is the second list item.</li>
|
|
</ol>
|
|
<p>A code block:</p>
|
|
<pre><code>return 1 < 2 ? shell_exec('echo $input | $markdown_script') : 0;</code></pre>
|
|
</blockquote>
|
|
</div>
|
|
<pre class="expected">> This is a header.
|
|
> -----------------
|
|
>
|
|
> 1. This is the first list item.
|
|
> 2. This is the second list item.
|
|
>
|
|
> A code block:
|
|
>
|
|
> return 1 < 2 ? shell_exec('echo $input | $markdown_script') : 0;</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="multiple divs">
|
|
<div class="input">
|
|
<div>A div</div>
|
|
<div>Another div</div>
|
|
</div>
|
|
<pre class="expected">A div
|
|
|
|
Another div</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="multiple divs">
|
|
<div class="input">
|
|
<div>A div</div>
|
|
<div>Another div</div>
|
|
</div>
|
|
<pre class="expected">A div
|
|
|
|
Another div</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="comment">
|
|
<div class="input"><!-- comment --></div>
|
|
<pre class="expected"></pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="pre/code with comment">
|
|
<div class="input">
|
|
<pre ><code>Hello<!-- comment --> world</code></pre>
|
|
</div>
|
|
<pre class="expected"> Hello world</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="leading whitespace in heading">
|
|
<div class="input"><h3>
|
|
h3 with leading whitespace</h3></div>
|
|
<pre class="expected">### h3 with leading whitespace</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="trailing whitespace in li">
|
|
<div class="input">
|
|
<ol>
|
|
<li>Chapter One
|
|
<ol>
|
|
<li>Section One</li>
|
|
<li>Section Two with trailing whitespace </li>
|
|
<li>Section Three with trailing whitespace </li>
|
|
</ol>
|
|
</li>
|
|
<li>Chapter Two</li>
|
|
<li>Chapter Three with trailing whitespace </li>
|
|
</ol>
|
|
</div>
|
|
<pre class="expected">1. Chapter One
|
|
1. Section One
|
|
2. Section Two with trailing whitespace
|
|
3. Section Three with trailing whitespace
|
|
2. Chapter Two
|
|
3. Chapter Three with trailing whitespace</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="multilined and bizarre formatting">
|
|
<div class="input">
|
|
<ul>
|
|
<li>
|
|
Indented li with leading/trailing newlines
|
|
</li>
|
|
<li>
|
|
<strong>Strong with trailing space inside li with leading/trailing whitespace </strong> </li>
|
|
<li>li without whitespace</li>
|
|
<li> Leading space, text, lots of whitespace …
|
|
text
|
|
</li>
|
|
</ol>
|
|
</div>
|
|
<pre class="expected">* Indented li with leading/trailing newlines
|
|
* **Strong with trailing space inside li with leading/trailing whitespace**
|
|
* li without whitespace
|
|
* Leading space, text, lots of whitespace … text</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="whitespace between inline elements">
|
|
<div class="input">
|
|
<p>I <a href="http://example.com/need">need</a> <a href="http://www.example.com/more">more</a> spaces!</p>
|
|
</div>
|
|
<pre class="expected">I [need](http://example.com/need) [more](http://www.example.com/more) spaces!</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="whitespace in inline elements">
|
|
<div class="input">Text with no space after the period.<em> Text in em with leading/trailing spaces </em><strong>text in strong with trailing space </strong></div>
|
|
<pre class="expected">Text with no space after the period. _Text in em with leading/trailing spaces_ **text in strong with trailing space**</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="whitespace in nested inline elements">
|
|
<div class="input">Text at root <strong><a href="http://www.example.com">link text with trailing space in strong </a></strong>more text at root</div>
|
|
<pre class="expected">Text at root **[link text with trailing space in strong](http://www.example.com)** more text at root</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="blank inline elements">
|
|
<div class="input">
|
|
Text before blank em … <em></em> text after blank em
|
|
</div>
|
|
<pre class="expected">Text before blank em … text after blank em</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="blank block elements">
|
|
<div class="input">
|
|
Text before blank div … <div></div> text after blank div
|
|
</div>
|
|
<pre class="expected">Text before blank div …
|
|
|
|
text after blank div</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="blank inline element with br">
|
|
<div class="input"><strong><br></strong></div>
|
|
<pre class="expected"></pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="whitespace between blocks">
|
|
<div class="input"><div><div>Content in a nested div</div></div>
|
|
<div>Content in another div</div></div>
|
|
<pre class="expected">Content in a nested div
|
|
|
|
Content in another div</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping backslashes">
|
|
<div class="input">*\*</div>
|
|
<pre class="expected">*\\*</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping headings with #">
|
|
<div class="input">### This is not a heading</div>
|
|
<pre class="expected">\### This is not a heading</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping em markdown with *">
|
|
<div class="input">To add emphasis, surround text with *. For example: *this is emphasis*</div>
|
|
<pre class="expected">To add emphasis, surround text with *. For example: \*this is emphasis\*</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping em markdown with _">
|
|
<div class="input">To add emphasis, surround text with _. For example: _this is emphasis_</div>
|
|
<pre class="expected">To add emphasis, surround text with _. For example: \_this is emphasis\_</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="not escaping underscores surrounded by words">
|
|
<div class="input"><pre><code>def this_is_a_method; end;</code></pre></div>
|
|
<pre class="expected"> def this_is_a_method; end;</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping strong markdown with *">
|
|
<div class="input">To add strong emphasis, surround text with **. For example: **this is strong**</div>
|
|
<pre class="expected">To add strong emphasis, surround text with **. For example: \*\*this is strong\*\*</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping strong markdown with _">
|
|
<div class="input">To add strong emphasis, surround text with __. For example: __this is strong__</div>
|
|
<pre class="expected">To add strong emphasis, surround text with __. For example: \_\_this is strong\_\_</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping hr markdown with *">
|
|
<div class="input">* * *</div>
|
|
<pre class="expected">\* \* \*</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping hr markdown with -">
|
|
<div class="input">- - -</div>
|
|
<pre class="expected">\- \- \-</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping hr markdown with _">
|
|
<div class="input">_ _ _</div>
|
|
<pre class="expected">\_ \_ \_</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping hr markdown without spaces">
|
|
<div class="input">***</div>
|
|
<pre class="expected">\*\*\*</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping hr markdown with more than 3 characters">
|
|
<div class="input">* * * * *</div>
|
|
<pre class="expected">\* \* \* \* \*</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping ol markdown">
|
|
<div class="input">1984. by George Orwell</div>
|
|
<pre class="expected">1984\. by George Orwell</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="not escaping numbers in a sentence">
|
|
<div class="input">George Orwell wrote 1984.</div>
|
|
<pre class="expected">George Orwell wrote 1984.</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping ul markdown *">
|
|
<div class="input">* An unordered list item</div>
|
|
<pre class="expected">\* An unordered list item</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping ul markdown -">
|
|
<div class="input">- An unordered list item</div>
|
|
<pre class="expected">\- An unordered list item</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping ul markdown +">
|
|
<div class="input">+ An unordered list item</div>
|
|
<pre class="expected">\+ An unordered list item</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="not escaping *">
|
|
<div class="input">You can use * for multiplication: 1.5 * 3 = 4.5</div>
|
|
<pre class="expected">You can use * for multiplication: 1.5 * 3 = 4.5</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="not escaping -">
|
|
<div class="input">45.5 - 3.5 = 42</div>
|
|
<pre class="expected">45.5 - 3.5 = 42</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="not escaping +">
|
|
<div class="input">+1</div>
|
|
<pre class="expected">+1</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping >">
|
|
<div class="input">> Blockquote in markdown</div>
|
|
<pre class="expected">\> Blockquote in markdown</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="not escaping >">
|
|
<div class="input">42 > 1</div>
|
|
<pre class="expected">42 > 1</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping code">
|
|
<div class="input">`not code`</div>
|
|
<pre class="expected">\`not code\`</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping []">
|
|
<div class="input">[This] is a sentence with brackets</div>
|
|
<pre class="expected">\[This\] is a sentence with brackets</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping [">
|
|
<div class="input"><a href="http://www.example.com">c[iao</a></div>
|
|
<pre class="expected">[c\[iao](http://www.example.com)</pre>
|
|
</div>
|
|
|
|
<!-- https://github.com/domchristie/to-markdown/issues/188#issuecomment-332216019 -->
|
|
<div class="case" data-name="escaping * performance">
|
|
<div class="input">fasdf *883 asdf wer qweasd fsd asdf asdfaqwe rqwefrsdf</div>
|
|
<pre class="expected">fasdf *883 asdf wer qweasd fsd asdf asdfaqwe rqwefrsdf</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping multiple asterisks">
|
|
<div class="input"><p>* * ** It aims to be*</p></div>
|
|
<pre class="expected">\* \* \*\* It aims to be*</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="escaping delimiters around short words and numbers">
|
|
<div class="input"><p>_Really_? Is that what it _is_? A **2000** year-old computer?</p></div>
|
|
<pre class="expected">\_Really\_? Is that what it \_is\_? A \*\*2000\*\* year-old computer?</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="non-markdown block elements">
|
|
<div class="input">
|
|
Foo
|
|
<div>Bar</div>
|
|
Baz
|
|
</div>
|
|
<pre class="expected">Foo
|
|
|
|
Bar
|
|
|
|
Baz</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="non-markdown inline elements">
|
|
<div class="input">
|
|
Foo <span>Bar</span>
|
|
</div>
|
|
<pre class="expected">Foo Bar</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="blank inline elements">
|
|
<div class="input">
|
|
Hello <em></em>world
|
|
</div>
|
|
<pre class="expected">Hello world</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="elements with a single void element">
|
|
<div class="input">
|
|
<p><img src="http://example.com/logo.png" /></p>
|
|
</div>
|
|
<pre class="expected">![](http://example.com/logo.png)</pre>
|
|
</div>
|
|
|
|
<div class="case" data-name="elements with a nested void element">
|
|
<div class="input">
|
|
<p><span><img src="http://example.com/logo.png" /></span></p>
|
|
</div>
|
|
<pre class="expected">![](http://example.com/logo.png)</pre>
|
|
</div>
|
|
|
|
<!-- /TEST CASES -->
|
|
|
|
<script src="turndown-test.browser.js"></script>
|
|
</body>
|
|
</html>
|