lib/sprockets/bundled_asset.rb
require 'sprockets/asset' require 'sprockets/errors' require 'fileutils' require 'set' require 'zlib' module Sprockets # `BundledAsset`s are used for files that need to be processed and # concatenated with other assets. Use for `.js` and `.css` files. class BundledAsset < Asset attr_reader :source def initialize(environment, logical_path, pathname) super(environment, logical_path, pathname) @processed_asset = environment.find_asset(pathname, :bundle => false) @required_assets = @processed_asset.required_assets @dependency_paths = @processed_asset.dependency_paths # Explode Asset into parts and gather the dependency bodies @source = to_a.map { |dependency| dependency.to_s }.join # Run bundle processors on concatenated source context = environment.context_class.new(environment, logical_path, pathname) @source = context.evaluate(pathname, :data => @source, :processors => environment.bundle_processors(content_type)) @mtime = (to_a + @dependency_paths).map(&:mtime).max @length = Rack::Utils.bytesize(source) @digest = environment.digest.update(source).hexdigest end # Initialize `BundledAsset` from serialized `Hash`. def init_with(environment, coder) super @processed_asset = environment.find_asset(pathname, :bundle => false) @required_assets = @processed_asset.required_assets if @processed_asset.dependency_digest != coder['required_assets_digest'] raise UnserializeError, "processed asset belongs to a stale environment" end @source = coder['source'] end # Serialize custom attributes in `BundledAsset`. def encode_with(coder) super coder['source'] = source coder['required_assets_digest'] = @processed_asset.dependency_digest end # Get asset's own processed contents. Excludes any of its required # dependencies but does run any processors or engines on the # original file. def body @processed_asset.source end # Return an `Array` of `Asset` files that are declared dependencies. def dependencies to_a.reject { |a| a.eql?(@processed_asset) } end # Expand asset into an `Array` of parts. def to_a required_assets end # Checks if Asset is stale by comparing the actual mtime and # digest to the inmemory model. def fresh?(environment) @processed_asset.fresh?(environment) end end end