#!/usr/bin/env ruby # A few helpful tips about the Rules file: # # * The string given to #compile and #route are matching patterns for # identifiers--not for paths. Therefore, you can’t match on extension. # # * The order of rules is important: for each item, only the first matching # rule is applied. # # * Item identifiers start and end with a slash (e.g. “/about/” for the file # “content/about.html”). To select all children, grandchildren, … of an # item, use the pattern “/about/*/”; “/about/*” will also select the parent, # because “*” matches zero or more characters. compile '/stylesheet/' do # don’t filter or layout end compile '/googleb33734e827953d88/' do end compile '*' do if item.binary? # don’t filter binary items filter :svg2png if item[:extension] == 'svg' else filter :erb layout 'default' end end route '/stylesheet/' do '/style.css' end route '/googleb33734e827953d88/' do '/googleb33734e827953d88.html' end route '*' do if item.binary? # Write item with identifier /foo/ to /foo.ext if item[:extension] == 'svg' # SVGs are transcoded by :svg2png filter item.identifier.chop + '.png' else item.identifier.chop + '.' + item[:extension] end else # Write item with identifier /foo/ to /foo/index.html item.identifier + 'index.html' end end layout '*', :erb