1
0

assets.thor 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  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. manifest.compile App.assets_compile
  16. manifest.clean(options[:keep]) if options[:clean]
  17. end
  18. desc 'clean [--keep=<n>] [--verbose]', 'Clean old assets'
  19. option :keep, type: :numeric, default: 0, desc: 'Number of old assets to keep'
  20. option :verbose, type: :boolean
  21. def clean
  22. manifest.clean(options[:keep])
  23. end
  24. private
  25. def sprockets
  26. @sprockets ||= App.sprockets.tap do |sprockets|
  27. sprockets.logger = logger
  28. sprockets.cache = nil
  29. end
  30. end
  31. def manifest
  32. @manifest ||= Sprockets::Manifest.new sprockets.index, App.assets_manifest_path
  33. end
  34. def logger
  35. @logger ||= Logger.new($stdout).tap do |logger|
  36. logger.level = options[:verbose] ? Logger::DEBUG : Logger::INFO
  37. logger.formatter = proc { |severity, datetime, progname, msg| "#{msg}\n" }
  38. end
  39. end
  40. end