D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
opt
/
td-agent
/
embedded
/
lib
/
ruby
/
gems
/
2.1.0
/
gems
/
sprockets-2.12.4
/
lib
/
sprockets
/
Filename :
processed_asset.rb
back
Copy
require 'sprockets/asset' require 'sprockets/utils' module Sprockets class ProcessedAsset < Asset def initialize(environment, logical_path, pathname) super start_time = Time.now.to_f context = environment.context_class.new(environment, logical_path, pathname) @source = context.evaluate(pathname) @length = Rack::Utils.bytesize(source) @digest = environment.digest.update(source).hexdigest build_required_assets(environment, context) build_dependency_paths(environment, context) @dependency_digest = compute_dependency_digest(environment) elapsed_time = ((Time.now.to_f - start_time) * 1000).to_i environment.logger.debug "Compiled #{logical_path} (#{elapsed_time}ms) (pid #{Process.pid})" end # Interal: Used to check equality attr_reader :dependency_digest attr_reader :source # Initialize `BundledAsset` from serialized `Hash`. def init_with(environment, coder) super @source = coder['source'] @dependency_digest = coder['dependency_digest'] @required_assets = coder['required_paths'].map { |p| p = expand_root_path(p) unless environment.paths.detect { |path| p[path] } raise UnserializeError, "#{p} isn't in paths" end p == pathname.to_s ? self : environment.find_asset(p, :bundle => false) } @dependency_paths = coder['dependency_paths'].map { |h| DependencyFile.new(expand_root_path(h['path']), h['mtime'], h['digest']) } end # Serialize custom attributes in `BundledAsset`. def encode_with(coder) super coder['source'] = source coder['dependency_digest'] = dependency_digest coder['required_paths'] = required_assets.map { |a| relativize_root_path(a.pathname).to_s } coder['dependency_paths'] = dependency_paths.map { |d| { 'path' => relativize_root_path(d.pathname).to_s, 'mtime' => d.mtime.iso8601, 'digest' => d.digest } } end # Checks if Asset is stale by comparing the actual mtime and # digest to the inmemory model. def fresh?(environment) # Check freshness of all declared dependencies @dependency_paths.all? { |dep| dependency_fresh?(environment, dep) } end protected class DependencyFile < Struct.new(:pathname, :mtime, :digest) def initialize(pathname, mtime, digest) pathname = Pathname.new(pathname) unless pathname.is_a?(Pathname) mtime = Time.parse(mtime) if mtime.is_a?(String) super end def eql?(other) other.is_a?(DependencyFile) && pathname.eql?(other.pathname) && mtime.eql?(other.mtime) && digest.eql?(other.digest) end def hash pathname.to_s.hash end end private def build_required_assets(environment, context) @required_assets = resolve_dependencies(environment, context._required_paths + [pathname.to_s]) - resolve_dependencies(environment, context._stubbed_assets.to_a) end def resolve_dependencies(environment, paths) assets = [] cache = {} paths.each do |path| if path == self.pathname.to_s unless cache[self] cache[self] = true assets << self end elsif asset = environment.find_asset(path, :bundle => false) asset.required_assets.each do |asset_dependency| unless cache[asset_dependency] cache[asset_dependency] = true assets << asset_dependency end end end end assets end def build_dependency_paths(environment, context) dependency_paths = {} context._dependency_paths.each do |path| dep = DependencyFile.new(path, environment.stat(path).mtime, environment.file_digest(path).hexdigest) dependency_paths[dep] = true end context._dependency_assets.each do |path| if path == self.pathname.to_s dep = DependencyFile.new(pathname, environment.stat(path).mtime, environment.file_digest(path).hexdigest) dependency_paths[dep] = true elsif asset = environment.find_asset(path, :bundle => false) asset.dependency_paths.each do |d| dependency_paths[d] = true end end end @dependency_paths = dependency_paths.keys end def compute_dependency_digest(environment) required_assets.inject(environment.digest) { |digest, asset| digest.update asset.digest }.hexdigest end end end