# along with this program. If not, see <https://www.gnu.org/licenses/>.
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
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
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
+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
+ filter :remove_wj
+ write to_xhtml
+end
+
compile '/**/*.scss' do
filter :sass, syntax: :scss
filter :css_source, uribase: \
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