diff options
author | Joshua Peek <josh@joshpeek.com> | 2011-08-24 10:54:01 -0500 |
---|---|---|
committer | Joshua Peek <josh@joshpeek.com> | 2011-08-24 10:58:43 -0500 |
commit | 5493d22419913c279a8baf38a10ffe6a9782c274 (patch) | |
tree | 398b9c66b9421cf35fe941b59eecaf22e0269571 /actionpack/lib | |
parent | 976b2be1085aa22f84c6fcbe40ba25ba4f89051c (diff) | |
download | rails-5493d22419913c279a8baf38a10ffe6a9782c274.tar.gz rails-5493d22419913c279a8baf38a10ffe6a9782c274.tar.bz2 rails-5493d22419913c279a8baf38a10ffe6a9782c274.zip |
Bring in sprockets precompile task
Diffstat (limited to 'actionpack/lib')
-rw-r--r-- | actionpack/lib/sprockets/assets.rake | 29 |
1 files changed, 26 insertions, 3 deletions
diff --git a/actionpack/lib/sprockets/assets.rake b/actionpack/lib/sprockets/assets.rake index acf2f256c2..7594ee4296 100644 --- a/actionpack/lib/sprockets/assets.rake +++ b/actionpack/lib/sprockets/assets.rake @@ -17,9 +17,32 @@ namespace :assets do Rails.application.config.action_controller.perform_caching = true config = Rails.application.config - assets = config.assets.precompile.dup - assets << {:to => File.join(Rails.public_path, config.assets.prefix)} - Rails.application.assets.precompile(*assets) + env = Rails.application.assets + target = Rails.root.join("public#{config.assets.prefix}") + + if env.respond_to?(:each_logical_path) + config.assets.precompile.each do |path| + env.each_logical_path do |logical_path| + if path.is_a?(Regexp) + next unless path.match(logical_path) + else + next unless File.fnmatch(path.to_s, logical_path) + end + + if asset = env.find_asset(logical_path) + filename = target.join(asset.digest_path) + mkdir_p filename.dirname + asset.write_to(filename) + asset.write_to("#{filename}.gz") if filename.to_s =~ /\.(css|js)$/ + end + end + end + else + # TODO: Remove this once we're depending on sprockets beta 15 + assets = config.assets.precompile.dup + assets << {:to => target} + env.precompile(*assets) + end end end |