class Sprockets::SassProcessor
For more infomation see:
Processor engine class for the SASS/SCSS compiler. Depends on the ‘sass` gem.
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 = ::Sass::Engine.new(input[:data], options) css = Utils.module_include(::Sass::Script::Functions, @functions) do engine.render end # Track all imported files engine.dependencies.map do |dependency| context.metadata[:dependencies] << URIUtils.build_file_digest_uri(dependency.options[:filename]) end context.metadata.merge(data: css) 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, 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