# along with this program. If not, see <https://www.gnu.org/licenses/>.
preprocess do
+ system("git", "submodule", "update", "--init")
+
# 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/}
+ l = File.readlink(item.raw_filename)
+ true if !File.exists?(item.raw_filename) and l =~ %r{/annex/objects/}
rescue Errno::EINVAL
end
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
+
+ archivedirs = {}
+ @items.find_all('/archive/**/*').each do |item|
+ dir = File.dirname(item.identifier)
+ while dir != "/"
+ archivedirs[dir] = true
+ dir = File.dirname(dir)
+ end
+ end
+
+ archivedirs.keys.sort_by{ |s| -s.length }.each do |dir|
+ attrs = {
+ pattern: "#{dir}/*{,/index.lst}",
+ title: "Index of #{dir}",
+ gitrev: commit,
+ }
+
+ @items.create("", attrs, "#{dir}/index.lst")
+ end
end
postprocess do
# 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|
+ Open3.popen2("git", "-c", "core.bare=false", "annex", "registerurl") do
+ |stdin, stdout, result|
@items.each do |item|
+ next if item.raw_filename.nil?
+
l = File.readlink(item.raw_filename)
next unless l =~ %r{/annex/objects/}
end
end
+compile '/**/index.lst' do
+ layout '/listing.erb'
+ layout '/default.xml'
+ layout '/default.xsl'
+ layout '/embed-svg.xsl'
+ filter :relativize_paths, type: :xml
+ filter :xhtml_compat, fix_doctype: true
+ write item.identifier.without_ext + ".xhtml"
+end
+
compile '/license/gpl*.md' do
filter :kramdown, auto_ids: false, header_offset: -1
layout '/default.xml'
layout '/default.xsl'
filter :relativize_paths, type: :xml
filter :xhtml_compat
- filter :remove_wj
write to_xhtml
end
layout '/default.xsl'
filter :relativize_paths, type: :xml
filter :xhtml_compat
- filter :remove_wj
write to_xhtml
end
layout '/default.xsl', "section-links": "yes"
filter :relativize_paths, type: :xml
filter :xhtml_compat
- filter :remove_wj
write to_xhtml
end
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
- filter :imgresize, width: 1200, height: 1200
- write item.identifier.without_ext + '-t1200.' + item.identifier.ext
+ 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
layout '/default.xsl'
filter :relativize_paths, type: :xml
filter :xhtml_compat
- filter :remove_wj
write to_xhtml
end
write @item.identifier.without_ext + '.css'
end
+compile '/**/*.svg' do
+ filter :scour, comment_stripping: true
+ write @item.identifier.to_s
+end
+
+compile '/icons/**/*.svg', rep: :icon32 do
+ filter :svg2png, width: 32, height: 32
+ write @item.identifier.without_ext + "-32.png"
+end
+
compile '/**/*' do
- filter :copybin if @item.binary?
- write @item.identifier.to_s
+ filter :copybin if @item.binary?
+ write @item.identifier.to_s
end
layout '/**/*.xsl', :xsl