diff options
author | Brandon Mathis <brandon@imathis.com> | 2011-07-17 17:25:27 -0400 |
---|---|---|
committer | Brandon Mathis <brandon@imathis.com> | 2011-07-17 17:25:27 -0400 |
commit | fe8150d7880912ceafdc48393084a8021d002b35 (patch) | |
tree | fc36ef178894e816096e130de87594ce7ccdb0df /.themes | |
parent | e55f5f9ab99df2d34237308a94d6f0d0db29e74b (diff) | |
download | my_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.rb | 81 |
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><sarcasm> Ooooh, sarcasm... How original!</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!(/</,'<') + "</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) |