]> git.draconx.ca Git - homepage.git/blobdiff - Rules
Let's start a blog!
[homepage.git] / Rules
diff --git a/Rules b/Rules
index d9130f02ca475b712fb4ae28ca965e02454a60a6..a881607f9b3211cd296780c97a8bdf4678883a61 100644 (file)
--- a/Rules
+++ b/Rules
 # 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
@@ -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,22 @@ 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
+    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
@@ -103,6 +175,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