# frozen_string_literal: true namespace :guides do desc 'Generate guides (for authors), use ONLY=foo to process just "foo.md"' task generate: "generate:html" # Guides are written in UTF-8, but the environment may be configured for some # other locale, these tasks are responsible for ensuring the default external # encoding is UTF-8. # # Real use cases: Generation was reported to fail on a machine configured with # GBK (Chinese). The docs server once got misconfigured somehow and had "C", # which broke generation too. task :encoding do %w(LANG LANGUAGE LC_ALL).each do |env_var| ENV[env_var] = "en_US.UTF-8" end end namespace :generate do desc "Generate HTML guides" task html: :encoding do ENV["WARNINGS"] = "1" # authors can't disable this ruby "rails_guides.rb" end desc "Generate .mobi file. The kindlegen executable must be in your PATH. You can get it for free from http://www.amazon.com/gp/feature.html?docId=1000765211" task kindle: :encoding do require "kindlerb" unless Kindlerb.kindlegen_available? abort "Please run `setupkindlerb` to install kindlegen" end unless /convert/.match?(`convert`) abort "Please install ImageMagick" end ENV["KINDLE"] = "1" Rake::Task["guides:generate:html"].invoke end end # Validate guides ------------------------------------------------------------------------- desc 'Validate guides, use ONLY=foo to process just "foo.html"' task validate: :encoding do ruby "w3c_validator.rb" end desc "Show help" task :help do puts < folder (such as source/es) Examples: $ rake guides:generate ALL=1 RAILS_VERSION=v5.1.0 $ rake guides:generate ONLY=migrations $ rake guides:generate:kindle $ rake guides:generate GUIDES_LANGUAGE=es HELP end end task :test do templates = Dir.glob("bug_report_templates/*.rb") counter = templates.count do |file| puts "--- Running #{file}" Bundler.clean_system(Gem.ruby, "-w", file) || puts("+++ 💥 FAILED (exit #{$?.exitstatus})") end puts "+++ #{counter} / #{templates.size} templates executed successfully" exit 1 if counter < templates.size end task default: "guides:help"