Skip to content

Commit

Permalink
fix: usr: fixed working with Markdown 3.3 (fixes #39)
Browse files Browse the repository at this point in the history
  • Loading branch information
Michele Tessaro committed Dec 12, 2020
1 parent 980cbd9 commit 0128009
Show file tree
Hide file tree
Showing 5 changed files with 17 additions and 7 deletions.
2 changes: 2 additions & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,12 @@ python:
- 3.6
- 3.7
- 3.8
- 3.9

env:
- MARKDOWN_VER=2.6.8
- MARKDOWN_VER=3.0.1
- MARKDOWN_VER=3.3.3

install:
- sudo apt-get install graphviz
Expand Down
5 changes: 3 additions & 2 deletions plantuml_markdown.py
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,8 @@
from plantuml import PlantUML
import logging
import markdown
from markdown.util import etree, AtomicString
from markdown.util import AtomicString #, etree
from xml.etree import ElementTree as etree


logger = logging.getLogger('MARKDOWN')
Expand Down Expand Up @@ -305,7 +306,7 @@ def extendMarkdown(self, md, md_globals=None):
blockprocessor.config = self.getConfigs()
# need to go before both fenced_code_block and things like retext's PosMapMarkPreprocessor.
# Need to go after mdx_include.
if markdown.version_info[0] < 3:
if markdown.__version_info__[0] < 3:
md.preprocessors.add('plantuml', blockprocessor, '_begin')
else:
md.preprocessors.register(blockprocessor, 'plantuml', int(blockprocessor.config['priority']))
Expand Down
2 changes: 1 addition & 1 deletion test/data/svg_object_diag.html
Original file line number Diff line number Diff line change
@@ -1 +1 @@
<p><object alt="uml diagram" class="uml" data="" title="" /></p>
<object alt="uml diagram" class="uml" data="" title="" />
12 changes: 8 additions & 4 deletions test/test_plantuml.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,13 @@ def setUpClass(cls):
def setUp(self):
self.md = markdown.Markdown(extensions=['markdown.extensions.fenced_code',
'admonition', 'pymdownx.snippets',
'plantuml_markdown'])
'plantuml_markdown'],
extension_configs={
# fix for fences in Markdown 3.3
'markdown.extensions.fenced_code': {
'lang_prefix': ''
}
})
self.text_builder = None

def _load_file(self, filename):
Expand Down Expand Up @@ -52,7 +58,7 @@ def sort_attributes(groups):
html = "<img{}{}{}{}{}/>".format(alt, title, classes, style, src)
return cls.BASE64_REGEX.sub(r'\1%s' % cls.FAKE_IMAGE, html)

return cls.IMAGE_REGEX.sub(lambda x: sort_attributes(x.groups()), html)
return cls.IMAGE_REGEX.sub(lambda x: sort_attributes(x.groups()), html.replace('\n\n', '\n'))

FAKE_SVG = '...svg-body...'
SVG_REGEX = re.compile(r'<(?:\w+:)?svg(?:( alt=".*?")|( class=".*?")|( title=".*?")|( style=".*?")|(?:.*?))+>.*</(?:\w+:)?svg>')
Expand Down Expand Up @@ -411,13 +417,11 @@ def test_multiple_fences(self):
A --&gt; B
```
</code></pre>
<p><img alt="uml diagram" title="" class="uml" src="data:image/png;base64,%s"/></p>
<pre><code class="markdown"> ```uml
A &lt;-- B
```
</code></pre>
<p><img alt="uml diagram" title="" class="uml" src="data:image/png;base64,%s"/></p>''' %
(self.FAKE_IMAGE, self.FAKE_IMAGE), self._stripImageData(self.md.convert(text)))

Expand Down
3 changes: 3 additions & 0 deletions test/test_plantuml_legacy.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,9 @@ def setUp(self):
# Setup testing with old block delimiter (I don't remember where I've seen this syntax)
self.text_builder = MarkdownBuilder('::uml::')

def test_multiple_fences(self):
pass # this test has non sense with legacy diagram delimiter


if __name__ == '__main__':
unittest.main()

0 comments on commit 0128009

Please sign in to comment.