X-Git-Url: http://git.draconx.ca/gitweb/homepage.git/blobdiff_plain/b585d7ee7724970904ba0bd77d84c2337159b4b3..d07907f27644b18d6d552907d31ae98f8585ef38:/Rules diff --git a/Rules b/Rules index d9130f0..e00c5f3 100644 --- a/Rules +++ b/Rules @@ -16,6 +16,13 @@ # along with this program. If not, see . preprocess do + # Remove dead annex keys from processing + @items.delete_if do |item| + l = File.readlink(item.raw_filename) + true if !File.exists?(item.raw_filename) and l =~ %r{/annex/objects/} + rescue Errno::EINVAL + end + commit = nil Open3.popen2("git", "rev-parse", "HEAD") do |stdin, stdout, result| stdin.close @@ -29,6 +36,17 @@ preprocess do item[:gitrev] = commit if item_source(item) end end + + @items.find_all('/weblog/*.md').each do |item| + item[:kind] ||= 'article' + end + + @items.each do |item| + item[:created_at] ||= + item[:published] || File.stat(item.raw_filename).mtime + item[:updated_at] ||= + item[:updated] || File.stat(item.raw_filename).mtime + end end postprocess do @@ -46,6 +64,44 @@ postprocess do end end end + + # Register URLs for git-annex keys + unless (uribase = ENV['ANNEX_URI_BASE'].to_s.chomp("/")).empty? + Open3.popen2("git", "annex", "registerurl") do |stdin, stdout, result| + @items.each do |item| + l = File.readlink(item.raw_filename) + next unless l =~ %r{/annex/objects/} + + key = File.basename(l) + + # Find output reps corresponding to this key, if any + item.reps.each do |rep| + next unless + FileUtils.identical?(item.raw_filename, rep.raw_path) + + loop do + STDOUT.write(stdout.read_nonblock(100)) + rescue EOFError, IO::WaitReadable + break + end + + stdin.printf("%s %s%s\n", key, uribase, rep.path) + end + rescue Errno::EINVAL + end + + stdin.close + loop do + STDOUT.write(stdout.readpartial(100)) + rescue EOFError + break + end + + unless (rc = result.value).success? + printf("git annex registerurl failed: %s\n", rc.to_s) + end + end + end end compile '/license/gpl*.md' do @@ -75,7 +131,7 @@ compile '/license/cc*.sgml' do filter :sgml2xml layout '/creativecommons.xsl' layout '/default.xml' - layout '/default.xsl' + layout '/default.xsl', "section-links": "yes" filter :relativize_paths, type: :xml filter :xhtml_compat filter :remove_wj @@ -85,6 +141,23 @@ end compile '/license/cc*.xhtml' do layout '/creativecommons.xsl' layout '/default.xml' + layout '/default.xsl', "section-links": "yes" + filter :relativize_paths, type: :xml + filter :xhtml_compat + filter :remove_wj + write to_xhtml +end + +compile '/images/*.jpg', rep: :large do + filename = item.identifier.without_ext + '-t1200.' + item.identifier.ext + filter :imgresize, width: 1200, height: 1200, cache: filename + write filename +end + +compile '/images/*.jpg', rep: :info do + filter :imginfo + layout '/imginfo.xsl' + layout '/default.xml' layout '/default.xsl' filter :relativize_paths, type: :xml filter :xhtml_compat @@ -103,6 +176,10 @@ compile '/**/*.scss' do write @item.identifier.without_ext + '.css' end -passthrough '/**/*' +compile '/**/*' do + filter :copybin if @item.binary? + write @item.identifier.to_s +end + layout '/**/*.xsl', :xsl layout '/**/*', :erb