diff options
Diffstat (limited to '_plugins/lint-hook.rb')
-rw-r--r-- | _plugins/lint-hook.rb | 128 |
1 files changed, 127 insertions, 1 deletions
diff --git a/_plugins/lint-hook.rb b/_plugins/lint-hook.rb index 6d883cd..57c2e27 100644 --- a/_plugins/lint-hook.rb +++ b/_plugins/lint-hook.rb @@ -1,6 +1,8 @@ require 'set' -IGNORED_PAGES = Set['site.json', 'sitemap.xml'] +IGNORED_PAGES = Set['sitemap.xml'] +LANGS = Set['en', 'pt', 'fr', 'eo'] # jp zh es de +TRACKERS = '-a udp://tracker.coppersurfer.tk:6969/announce -a udp://tracker.ccc.de:80/announce -a udp://tracker.publicbt.com:80 -a udp://tracker.istole.it:80 -a http://tracker.openbittorrent.com:80/announce -a http://tracker.ipv6tracker.org:80/announce' module Jekyll class Linter < Generator @@ -32,8 +34,132 @@ module Jekyll end end + def slugify(s) + s.ljust(100) + .gsub(/[\W]+/, ' ') + .strip + .gsub(/\s\s+/, '-') + .downcase + .gsub(' ', '-') + .gsub('_', '-') + end + + def assert(value, message) + unless value + raise message + end + value + end + + def assert_field(document, field) + f = document.data[field] + raise "Undefined '#{field}' for #{document.path}" unless f + f + end + + COLLECTION_LAYOUTS = { + 'page' => 'page', + 'articles' => 'post', + 'pastebins' => 'post', + 'tils' => 'post', + 'slides' => 'slides', + 'podcasts' => 'cast', + 'screencasts' => 'cast' + } + + def assert_frontmatter_fields(config, name, document) + title = assert_field document, 'title' + lang = assert_field document, 'lang' + ref = assert_field document, 'ref' + layout = assert_field document, 'layout' + date = document.date.strftime('%Y-%m-%d') unless layout == 'page' + slug = layout == 'page' ? ref : assert_field(document, 'slug') + extension = name == 'slides' ? 'slides' : 'md' + + unless LANGS.member? lang + raise "Invalid lang '#{lang}' in #{document.path}" + end + + if COLLECTION_LAYOUTS[name] != layout + raise "Layout mismatch: expected '#{COLLECTION_LAYOUTS[name]}', got '#{layout}' for #{document.path}" + end + + if lang == 'en' + unless ['index', 'root', 'tils'].include? ref + if slugify(title) != ref then + raise "#{ref} isn't a slug of the title.\nref: '#{ref}'\ntitle slug: '#{slugify(title)}'" + p slugify(title) + end + end + end + + unless layout == 'page' then + path = "_#{name}/#{date}-#{slug}.#{extension}" + unless path == document.relative_path then + raise "date/filename mismatch:\ndate+slug: #{path}\nfilename: #{document.relative_path}" + end + + if lang == 'en' then + unless ref == slug then + raise "ref/slug mismatch:\nref: #{ref}\nslug: #{slug}" + end + end + end + + if name == 'podcasts' then + flac = "resources/podcasts/#{date}-#{slug}.flac" + unless File.exist? flac then + raise "Missing FLAC file '#{flac}'" + end + + ogg = "resources/podcasts/#{date}-#{slug}.ogg" + unless File.exist? ogg then + puts "Missing '#{ogg}' file, generating..." + puts `ffmpeg -i #{flac} -ar 48000 -vn -c:a libvorbis -b:a 320k #{ogg}` + end + + torrent = "#{ogg}.torrent" + unless File.exist? torrent then + webseed = "#{config['url']}/#{ogg}" + file = "#{date}-#{slug}.ogg" + puts "Missing '#{torrent}' file, generating..." + puts `mktorrent #{TRACKERS} -f -v -d -c '#{document.content}' -n #{file} -w #{webseed} -o #{torrent} #{ogg}` + end + end + + if name == 'screencasts' then + mkv = "resources/screencasts/#{date}-#{slug}.mkv" + unless File.exist? mkv then + raise "Missing MKV file '#{mkv}'" + end + + torrent = "#{mkv}.torrent" + unless File.exist? torrent then + webseed = "#{config['url']}/#{mkv}" + file = "#{date}-#{slug}.mkv" + puts "Missing '#{torrent}' file, generating..." + puts `mktorrent #{TRACKERS} -f -v -d -c '#{document.content}' -n #{file} -w #{webseed} -o #{torrent} #{mkv}` + end + end + end + + def assert_frontmatter(site) + site.collections.each do |name, collection| + collection.docs.each do |document| + assert_frontmatter_fields site.config, name, document + end + end + + site.pages.each do |page| + unless IGNORED_PAGES.include? page.path + assert_frontmatter_fields site.config, 'page', page + end + end + end + def generate(site) assert_unique_ids(site) + assert_frontmatter(site) end end end |