more careful sorting of the menu; readme generator more failure-resistant; add missin...
[web.git] / _plugins / readmes.rb
index 272e84936e2f4fab51f5823e61e64be87fcb0b19..82f917f18e1c32597d61849d113f33abb93da559 100644 (file)
@@ -1,7 +1,7 @@
 module Jekyll
 
   class ReadmePage < Page
-    def initialize(site, base, dir, src)
+    def initialize(site, base, dir, src, idx)
       @site = site
       @base = base
       @dir = dir
@@ -13,8 +13,12 @@ module Jekyll
       content = File.read(src, self.merged_file_read_opts({})).each_line.to_a
 
       self.data['layout'] = 'default'
-      self.data['title'] = content[0].match(/^# (.*)\n$/)[1]
-      self.data['slug'] = self.data['title'].match(/^(.*):.*$/)[1]
+      self.data['title'] = content[0].match(/^#* ?(.*)\n$/)[1]
+      slug = self.data['title'].match(/^(.*):.*$/)
+      if slug
+        self.data['slug'] = slug[1]
+      end
+      self.data['sort'] = idx
       self.content = content[1..content.size].join
     end
   end
@@ -26,8 +30,10 @@ module Jekyll
       readmes = site.config['readmes']
       base = readmes['src_base']
       dir = readmes['out_base']
+      idx = 0
       for project in readmes['projects']
-          site.pages << ReadmePage.new(site, site.source, File.join(dir, project['name']), File.join(base, project['name'], 'README.md'))
+          site.pages << ReadmePage.new(site, site.source, File.join(dir, project['name']), File.join(base, project['src'] ? project['src'] : project['name'], 'README.md'), idx)
+          idx += 1
       end
     end
   end