class Sprockets::Bundle

def self.call(input)

def self.call(input)
  env  = input[:environment]
  type = input[:content_type]
  input[:links] ||= Set.new
  dependencies = Set.new(input[:metadata][:dependencies])
  processed_uri, deps = env.resolve(input[:filename], accept: type, pipeline: :self)
  dependencies.merge(deps)
  # DirectiveProcessor (and any other transformers called here with pipeline=self)
  primary_asset = env.load(processed_uri)
  to_load = primary_asset.metadata.delete(:to_load) || Set.new
  to_link = primary_asset.metadata.delete(:to_link) || Set.new
  to_load.each do |uri|
    loaded_asset = env.load(uri)
    dependencies.merge(loaded_asset.metadata[:dependencies])
    if to_link.include?(uri)
      primary_metadata = primary_asset.metadata
      input[:links]            << loaded_asset.uri
      primary_metadata[:links] << loaded_asset.uri
    end
  end
  find_required = proc { |uri| env.load(uri).metadata[:required] }
  required = Utils.dfs(processed_uri, &find_required)
  stubbed  = Utils.dfs(env.load(processed_uri).metadata[:stubbed], &find_required)
  required.subtract(stubbed)
  dedup(required)
  assets = required.map { |uri| env.load(uri) }
  (required + stubbed).each do |uri|
    dependencies.merge(env.load(uri).metadata[:dependencies])
  end
  reducers = Hash[env.match_mime_type_keys(env.config[:bundle_reducers], type).flat_map(&:to_a)]
  process_bundle_reducers(input, assets, reducers).merge(dependencies: dependencies, included: assets.map(&:uri))
end