aboutsummaryrefslogtreecommitdiff
path: root/.themes
diff options
context:
space:
mode:
authorBrandon Mathis <brandon@imathis.com>2011-07-17 17:25:27 -0400
committerBrandon Mathis <brandon@imathis.com>2011-07-17 17:25:27 -0400
commitfe8150d7880912ceafdc48393084a8021d002b35 (patch)
treefc36ef178894e816096e130de87594ce7ccdb0df /.themes
parente55f5f9ab99df2d34237308a94d6f0d0db29e74b (diff)
downloadmy_new_personal_website-fe8150d7880912ceafdc48393084a8021d002b35.tar.xz
my_new_personal_website-fe8150d7880912ceafdc48393084a8021d002b35.zip
Added plugin for simple code block authoring
Diffstat (limited to '.themes')
-rw-r--r--.themes/classic/plugins/code_block.rb81
1 files changed, 81 insertions, 0 deletions
diff --git a/.themes/classic/plugins/code_block.rb b/.themes/classic/plugins/code_block.rb
new file mode 100644
index 00000000..a2aab886
--- /dev/null
+++ b/.themes/classic/plugins/code_block.rb
@@ -0,0 +1,81 @@
+# Title: Simple Code Blocks for Jekyll
+# Author: Brandon Mathis http://brandonmathis.com
+# Description: Write codeblocks with semantic HTML5 <figure> and <figcaption> elements and optional syntax highlighting — all with a simple, intuitive interface.
+#
+# Syntax: {% codeblock [title] [url] [link text] %}
+#
+# For syntax highlighting, put a file extension somewhere in the title. examples:
+# {% codeblock file.sh %}
+# {% codeblock Time to be Awesome! (awesome.rb) %}
+#
+# Example:
+#
+# {% codeblock Got pain? painreleif.sh http://site.com/painreleief.sh Download it! %}
+# $ rm -rf ~/PAIN
+# {% endcodeblock %}
+#
+# Output:
+#
+# <figure role=code>
+# <figcaption><span>Got pain? painrelief.sh</span> <a href="http://site.com/painrelief.sh">Download it!</a>
+# <div class="highlight"><pre><code class="sh">
+# -- nicely escaped highlighted code --
+# </code></pre></div>
+# </figure>
+#
+# Example 2 (no syntax highlighting):
+#
+# {% codeblock %}
+# <sarcasm>Ooooh, sarcasm... How original!</sarcasm>
+# {% endcodeblock %}
+#
+# <figure role=code>
+# <pre><code>&lt;sarcasm> Ooooh, sarcasm... How original!&lt;/sarcasm>
+# </code></pre>
+# </figure>
+#
+module Jekyll
+
+ class CodeBlock < Liquid::Block
+ CaptionUrlTitle = /(\S[\S\s]*)\s+(https?:\/\/)(\S+)\s+(.+)/i
+ CaptionUrl = /(\S[\S\s]*)\s+(https?:\/\/)(\S+)/i
+ Caption = /(\S[\S\s]*)/
+ def initialize(tag_name, markup, tokens)
+ @title = nil
+ @caption = nil
+ @highlight = true
+ if markup =~ CaptionUrlTitle
+ @file = $1
+ @caption = "<figcaption><span>#{$1}</span><a href='#{$2 + $3}'>#{$4}</a</figcaption>"
+ elsif markup =~ CaptionUrl
+ @file = $1
+ @caption = "<figcaption><span>#{$1}</span><a href='#{$2 + $3}'>link</a</figcaption>"
+ elsif markup =~ Caption
+ @file = $1
+ @caption = "<figcaption><span>#{$1}</span></figcaption>\n"
+ end
+ if @file =~ /\S[\S\s]*\.(\w+)/
+ @filetype = $1
+ end
+ super
+ end
+
+ def render(context)
+ output = super
+ code = super.join
+ source = "<figure role=code>\n"
+ source += @caption if @caption
+ if @filetype
+ source += "{% highlight #{@filetype} %}\n" + code + "\n{% endhighlight %}\n</figure>"
+ else
+ source += "<pre><code>" + code.gsub!(/</,'&lt;') + "</code></pre>\n</figure>"
+ end
+ partial = Liquid::Template.parse(source)
+ context.stack do
+ partial.render(context)
+ end
+ end
+ end
+end
+
+Liquid::Template.register_tag('codeblock', Jekyll::CodeBlock)