changeset 356:f54bf3b3bece

Fix 180; Add strikethrough capability to markdown via an extension. Also control in SVN the extensions we are using.
author Brian Neal <bgneal@gmail.com>
date Fri, 04 Mar 2011 02:10:37 +0000 (2011-03-04)
parents a1e3724f0799
children 8e3f252e4fbb
files gpp/core/markup.py gpp/templates/core/markdown_help.html static/js/markitup/sets/markdown/images/strike.png static/js/markitup/sets/markdown/set.js static/js/markitup/sets/markdown/style.css tools/mdx_del.py tools/mdx_nl2br.py tools/mdx_urlize.py
diffstat 8 files changed, 138 insertions(+), 7 deletions(-) [+]
line wrap: on
line diff
--- a/gpp/core/markup.py	Fri Mar 04 01:34:43 2011 +0000
+++ b/gpp/core/markup.py	Fri Mar 04 02:10:37 2011 +0000
@@ -19,7 +19,7 @@
         # exists only in markdown v1.6.2rc-2 or above.
         self.unicode_support = getattr(_markdown, "version_info", None) >= (1, 7)
         self.md = _markdown.Markdown(safe_mode=safe_mode,
-                                extensions=['urlize', 'nl2br'])
+                                extensions=['urlize', 'nl2br', 'del'])
 
     def convert(self, s):
         if self.unicode_support:
--- a/gpp/templates/core/markdown_help.html	Fri Mar 04 01:34:43 2011 +0000
+++ b/gpp/templates/core/markdown_help.html	Fri Mar 04 02:10:37 2011 +0000
@@ -157,6 +157,11 @@
       <td><pre>###### Header 6</pre></td>
       <td><h6>Header 6</h6></td>
    </tr>
+   <tr>
+      <th>Strikethrough</th>
+      <td><pre>--This text is deleted--</pre></td>
+      <td><del>This text is deleted</del></td>
+   </tr>
 </table>
 <p>
 More help:
Binary file static/js/markitup/sets/markdown/images/strike.png has changed
--- a/static/js/markitup/sets/markdown/set.js	Fri Mar 04 01:34:43 2011 +0000
+++ b/static/js/markitup/sets/markdown/set.js	Fri Mar 04 02:10:37 2011 +0000
@@ -20,6 +20,7 @@
 	markupSet: [
 		{name:'Bold', key:'B', openWith:'**', closeWith:'**'},
 		{name:'Italic', key:'I', openWith:'_', closeWith:'_'},
+		{name:'Strike', key:'S', openWith:'--', closeWith:'--'},
 		{separator:'---------------' },
 		{name:'Bulleted List', openWith:'- ' },
 		{name:'Numeric List', openWith:function(markItUp) {
--- a/static/js/markitup/sets/markdown/style.css	Fri Mar 04 01:34:43 2011 +0000
+++ b/static/js/markitup/sets/markdown/style.css	Fri Mar 04 02:10:37 2011 +0000
@@ -8,25 +8,28 @@
 .markItUp .markItUpButton2 a {
 	background-image:url(images/italic.png);
 }
+.markItUp .markItUpButton3 a {
+	background-image:url(images/strike.png);
+}
 
-.markItUp .markItUpButton3 a {
+.markItUp .markItUpButton4 a {
 	background-image:url(images/list-bullet.png);
 }
-.markItUp .markItUpButton4 a {
+.markItUp .markItUpButton5 a {
 	background-image:url(images/list-numeric.png);
 }
 
-.markItUp .markItUpButton5 a {
+.markItUp .markItUpButton6 a {
 	background-image:url(images/picture.png); 
 }
-.markItUp .markItUpButton6 a {
+.markItUp .markItUpButton7 a {
 	background-image:url(images/link.png);
 }
 
-.markItUp .markItUpButton7 a	{
+.markItUp .markItUpButton8 a	{
 	background-image:url(images/quotes.png);
 }
-.markItUp .markItUpButton8 a	{
+.markItUp .markItUpButton9 a	{
 	background-image:url(images/code.png);
 }
 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tools/mdx_del.py	Fri Mar 04 02:10:37 2011 +0000
@@ -0,0 +1,19 @@
+"""
+A python-markdown extension to add support for <del>.
+The Markdown syntax is --this is deleted text--.
+
+"""
+import markdown
+
+
+DEL_RE = r'(--)(.*?)--'
+
+class DelExtension(markdown.Extension):
+
+    def extendMarkdown(self, md, md_globals):
+        del_tag = markdown.inlinepatterns.SimpleTagPattern(DEL_RE, 'del')
+        md.inlinePatterns.add('del', del_tag, '>not_strong')
+
+
+def makeExtension(configs=None):
+    return DelExtension(configs)
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tools/mdx_nl2br.py	Fri Mar 04 02:10:37 2011 +0000
@@ -0,0 +1,19 @@
+"""
+A python-markdown extension to treat newlines as hard breaks; like
+StackOverflow and GitHub flavored Markdown do.
+
+"""
+import markdown
+
+
+BR_RE = r'\n'
+
+class Nl2BrExtension(markdown.Extension):
+
+    def extendMarkdown(self, md, md_globals):
+        br_tag = markdown.inlinepatterns.SubstituteTagPattern(BR_RE, 'br')
+        md.inlinePatterns.add('nl', br_tag, '_end')
+
+
+def makeExtension(configs=None):
+    return Nl2BrExtension(configs)
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tools/mdx_urlize.py	Fri Mar 04 02:10:37 2011 +0000
@@ -0,0 +1,84 @@
+"""
+Taken from: https://github.com/r0wb0t/markdown-urlize
+
+A more liberal autolinker
+
+Inspired by Django's urlize function.
+
+Positive examples:
+
+>>> import markdown
+>>> md = markdown.Markdown(extensions=['urlize'])
+
+>>> md.convert('http://example.com/')
+u'<p><a href="http://example.com/">http://example.com/</a></p>'
+
+>>> md.convert('go to http://example.com')
+u'<p>go to <a href="http://example.com">http://example.com</a></p>'
+
+>>> md.convert('example.com')
+u'<p><a href="http://example.com">example.com</a></p>'
+
+>>> md.convert('example.net')
+u'<p><a href="http://example.net">example.net</a></p>'
+
+>>> md.convert('www.example.us')
+u'<p><a href="http://www.example.us">www.example.us</a></p>'
+
+>>> md.convert('(www.example.us/path/?name=val)')
+u'<p>(<a href="http://www.example.us/path/?name=val">www.example.us/path/?name=val</a>)</p>'
+
+>>> md.convert('go to <http://example.com> now!')
+u'<p>go to <a href="http://example.com">http://example.com</a> now!</p>'
+
+Negative examples:
+
+>>> md.convert('del.icio.us')
+u'<p>del.icio.us</p>'
+
+"""
+
+import markdown
+
+# Global Vars
+URLIZE_RE = '(%s)' % '|'.join([
+    r'<(?:f|ht)tps?://[^>]*>',
+    r'\b(?:f|ht)tps?://[^)<>\s]+[^.,)<>\s]',
+    r'\bwww\.[^)<>\s]+[^.,)<>\s]',
+    r'[^(<\s]+\.(?:com|net|org)\b',
+])
+
+class UrlizePattern(markdown.inlinepatterns.Pattern):
+    """ Return a link Element given an autolink (`http://example/com`). """
+    def handleMatch(self, m):
+        url = m.group(2)
+        
+        if url.startswith('<'):
+            url = url[1:-1]
+            
+        text = url
+        
+        if not url.split('://')[0] in ('http','https','ftp'):
+            if '@' in url and not '/' in url:
+                url = 'mailto:' + url
+            else:
+                url = 'http://' + url
+    
+        el = markdown.etree.Element("a")
+        el.set('href', url)
+        el.text = markdown.AtomicString(text)
+        return el
+
+class UrlizeExtension(markdown.Extension):
+    """ Urlize Extension for Python-Markdown. """
+
+    def extendMarkdown(self, md, md_globals):
+        """ Replace autolink with UrlizePattern """
+        md.inlinePatterns['autolink'] = UrlizePattern(URLIZE_RE, md)
+
+def makeExtension(configs=None):
+    return UrlizeExtension(configs=configs)
+
+if __name__ == "__main__":
+    import doctest
+    doctest.testmod()