# Title: Simple Code Blocks for Jekyll # Author: Brandon Mathis http://brandonmathis.com # Description: Write codeblocks with semantic HTML5
and
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: # #
#
Got pain? painrelief.sh Download it! #

# -- nicely escaped highlighted code --
# 
#
# # Example 2 (no syntax highlighting): # # {% codeblock %} # Ooooh, sarcasm... How original! # {% endcodeblock %} # #
#
<sarcasm> Ooooh, sarcasm... How original!</sarcasm>
#
# 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 = "
#{$1}#{$4}" elsif markup =~ CaptionUrl @file = $1 @caption = "
#{$1}link" elsif markup =~ Caption @file = $1 @caption = "
#{$1}
\n" end if @file =~ /\S[\S\s]*\.(\w+)/ @filetype = $1 end super end def render(context) output = super code = super.join source = "
\n" source += @caption if @caption if @filetype source += "{% highlight #{@filetype} %}\n" + code + "\n{% endhighlight %}\n
" else source += "
" + code.gsub!(/
\n
" end partial = Liquid::Template.parse(source) context.stack do partial.render(context) end end end end Liquid::Template.register_tag('codeblock', Jekyll::CodeBlock)