diff options
author | Artem Yunusov <nedrlab@gmail.com> | 2008-08-04 05:17:55 +0500 |
---|---|---|
committer | Artem Yunusov <nedrlab@gmail.com> | 2008-08-04 05:17:55 +0500 |
commit | 3f9ea693d71d24ad272000dfaaea5b886b18f68f (patch) | |
tree | a112c231593f1b2869f7fa59f9d6d011e6b42c12 /markdown.py | |
parent | 495578c86f58b9a84d8583825768a84eebdd8a9f (diff) | |
download | markdown-3f9ea693d71d24ad272000dfaaea5b886b18f68f.tar.gz markdown-3f9ea693d71d24ad272000dfaaea5b886b18f68f.tar.bz2 markdown-3f9ea693d71d24ad272000dfaaea5b886b18f68f.zip |
Bugfix for inline patterns. Tables extension ported to ElementTree.
Diffstat (limited to 'markdown.py')
-rwxr-xr-x | markdown.py | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/markdown.py b/markdown.py index 059ac87..7c78b18 100755 --- a/markdown.py +++ b/markdown.py @@ -649,10 +649,12 @@ class HtmlPattern (Pattern): class LinkPattern (Pattern): """ Return a link element from the given match. """ def handleMatch(self, m): + el = etree.Element("a") el.text = m.group(2) title = m.group(11) href = m.group(9) + if href: if href[0] == "<": href = href[1:-1] @@ -1640,8 +1642,10 @@ class Markdown: data, matched, startIndex = self._applyInline( self.inlinePatterns[patternIndex], data, patternIndex, startIndex) + if not matched: patternIndex += 1 + return data def _applyInline(self, pattern, data, patternIndex, startIndex=0): @@ -1735,6 +1739,7 @@ class Markdown: result = [] prefix = self.inlineStash.prefix strartIndex = 0 + while data: index = data.find(prefix, strartIndex) @@ -1751,15 +1756,17 @@ class Markdown: linkText(text) if not isstr(node): # it's Element - + for child in [node] + node.getchildren(): if child.tail: - self._processElementText(node, child, False) + if child.tail.strip(): + self._processElementText(node, child, False) if child.text: - self._processElementText(child, child) - + if child.text.strip(): + self._processElementText(child, child) + else: # it's just a string linkText(node) @@ -1793,16 +1800,18 @@ class Markdown: """ stack = [el] + while stack: currElement = stack.pop() insertQueue = [] for child in currElement.getchildren(): if child.tag == "inline": - + lst = self._processPlaceholders(self._handleInline( child.text), currElement) - + stack += lst + pos = currElement.getchildren().index(child) insertQueue.append((child, pos, lst)) |