assets.thor 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. class AssetsCLI < Thor
  2. def self.to_s
  3. 'Assets'
  4. end
  5. def initialize(*args)
  6. ENV['RACK_ENV'] = 'production'
  7. require 'app'
  8. super
  9. end
  10. desc 'compile [--clean] [--keep=<n>] [--verbose]', 'Compile all assets'
  11. option :clean, type: :boolean, desc: 'Clean old assets after compilation'
  12. option :keep, type: :numeric, default: 0, desc: 'Number of old assets to keep'
  13. option :verbose, type: :boolean
  14. def compile
  15. invoke 'sprites:generate', [], :verbose => options[:verbose]
  16. manifest.compile App.assets_compile
  17. manifest.clean(options[:keep]) if options[:clean]
  18. end
  19. desc 'clean [--keep=<n>] [--verbose]', 'Clean old assets'
  20. option :keep, type: :numeric, default: 0, desc: 'Number of old assets to keep'
  21. option :verbose, type: :boolean
  22. def clean
  23. manifest.clean(options[:keep])
  24. end
  25. private
  26. def sprockets
  27. @sprockets ||= App.sprockets.tap do |sprockets|
  28. sprockets.logger = logger
  29. sprockets.cache = nil
  30. end
  31. end
  32. def manifest
  33. @manifest ||= Sprockets::Manifest.new sprockets.index, App.assets_manifest_path
  34. end
  35. def logger
  36. @logger ||= Logger.new($stdout).tap do |logger|
  37. logger.level = options[:verbose] ? Logger::DEBUG : Logger::INFO
  38. logger.formatter = proc { |severity, datetime, progname, msg| "#{msg}\n" }
  39. end
  40. end
  41. end