class Sprockets::SassProcessor
def self.cache_key
def self.cache_key instance.cache_key end
def self.call(input)
def self.call(input) instance.call(input) end
def self.instance
Public: Return singleton instance with default options.
def self.instance @instance ||= new end
def self.syntax
Internal: Defines default sass syntax to use. Exposed so the ScssProcessor
def self.syntax :sass end
def call(input)
def call(input) context = input[:environment].context_class.new(input) options = { filename: input[:filename], syntax: self.class.syntax, cache_store: CacheStore.new(input[:cache], @cache_version), load_paths: input[:environment].paths, sprockets: { context: context, environment: input[:environment], dependencies: context.metadata[:dependencies] } } engine = Autoload::Sass::Engine.new(input[:data], options) css = Utils.module_include(Autoload::Sass::Script::Functions, @functions) do engine.render end # Track all imported files sass_dependencies = Set.new([input[:filename]]) engine.dependencies.map do |dependency| sass_dependencies << dependency.options[:filename] context.metadata[:dependencies] << URIUtils.build_file_digest_uri(dependency.options[:filename]) end context.metadata.merge(data: css, sass_dependencies: sass_dependencies) end
def initialize(options = {}, &block)
change after code changes are made to Sass Functions.
cache_version - String custom cache version. Used to force a cache
options - Hash
Public: Initialize template with custom options.
def initialize(options = {}, &block) @cache_version = options[:cache_version] @cache_key = "#{self.class.name}:#{VERSION}:#{Autoload::Sass::VERSION}:#{@cache_version}".freeze @functions = Module.new do include Functions include options[:functions] if options[:functions] class_eval(&block) if block_given? end end