Callbacks for the following events:
* sprite_saved * sprite_generated * stylesheet_saved * stylesheet_error From the compass configuration file you can attach code to run when the event occurs like so: on_stylesheet_error do |filename, message| # do something end
This commit is contained in:
parent
9fd7ac6e52
commit
2142430735
@ -331,3 +331,36 @@ more than once. Example:
|
|||||||
|
|
||||||
This code will be called if the file is added, updated, or removed. Be sure to check for existence
|
This code will be called if the file is added, updated, or removed. Be sure to check for existence
|
||||||
to avoid crashing the watcher in the case where the file has been removed.
|
to avoid crashing the watcher in the case where the file has been removed.
|
||||||
|
|
||||||
|
## Callbacks
|
||||||
|
|
||||||
|
**`on_sprite_saved`** -- Pass this function a block of code that gets executed after a sprite is saved to disk. The block will be passed the filename. Can be invoked more then once. Example:
|
||||||
|
|
||||||
|
on_sprite_saved do |filename|
|
||||||
|
post_process(filename) if File.exists?(filename)
|
||||||
|
end
|
||||||
|
|
||||||
|
**`on_sprite_generated`** -- Pass this function a block of code that gets executed after a sprite is generated but before its saved to disk. The block will be passed an instance of `ChunkyPNG::Image`. Can be invoked more then once. Example:
|
||||||
|
|
||||||
|
on_sprite_generated do |sprite_data|
|
||||||
|
sprite_data.metadata['Caption'] = "This Image is © My Company 2011"
|
||||||
|
end
|
||||||
|
|
||||||
|
**`on_stylesheet_saved`** -- Pass this function a block of code that gets executed after a stylesheet is processed. The block will be passed the filename. Can be invoked more then once. Example:
|
||||||
|
|
||||||
|
on_stylesheet_saved do |filename|
|
||||||
|
Growl.notify {
|
||||||
|
self.message "#{filename} updated!"
|
||||||
|
self.icon = '/path/to/success.jpg'
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
**`on_stylesheet_error`** -- Pass this function a block of code that gets executed if a stylesheet has an error while processing. The block will be passed the filename and the error message. Can be invoked more then once. Example:
|
||||||
|
|
||||||
|
on_stylesheet_error do |filename, message|
|
||||||
|
Growl.notify {
|
||||||
|
self.message = "#{filename}: #{message}"
|
||||||
|
self.icon = '/path/to/fail.jpg'
|
||||||
|
sticky!
|
||||||
|
}
|
||||||
|
end
|
@ -5,6 +5,8 @@ end
|
|||||||
require "compass/#{lib}"
|
require "compass/#{lib}"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
require 'sass/callbacks'
|
||||||
|
|
||||||
module Compass
|
module Compass
|
||||||
def base_directory
|
def base_directory
|
||||||
File.expand_path(File.join(File.dirname(__FILE__), '..'))
|
File.expand_path(File.join(File.dirname(__FILE__), '..'))
|
||||||
|
@ -119,6 +119,7 @@ module Compass
|
|||||||
end
|
end
|
||||||
duration = additional_options[:time] ? "(#{(css_content.__duration * 1000).round / 1000.0}s)" : ""
|
duration = additional_options[:time] ? "(#{(css_content.__duration * 1000).round / 1000.0}s)" : ""
|
||||||
write_file(css_filename, css_content, options.merge(:force => true, :extra => duration))
|
write_file(css_filename, css_content, options.merge(:force => true, :extra => duration))
|
||||||
|
Compass.configuration.send(:run_stylesheet_saved, File.basename(css_filename)) #run callback
|
||||||
end
|
end
|
||||||
|
|
||||||
def should_compile?(sass_filename, css_filename)
|
def should_compile?(sass_filename, css_filename)
|
||||||
@ -136,7 +137,10 @@ module Compass
|
|||||||
# formatted to display in the browser (in development mode)
|
# formatted to display in the browser (in development mode)
|
||||||
# if there's an error.
|
# if there's an error.
|
||||||
def handle_exception(sass_filename, css_filename, e)
|
def handle_exception(sass_filename, css_filename, e)
|
||||||
logger.record :error, basename(sass_filename), "(Line #{e.sass_line}: #{e.message})"
|
formatted_error = "(Line #{e.sass_line}: #{e.message})"
|
||||||
|
file = basename(sass_filename)
|
||||||
|
logger.record :error, file, formatted_error
|
||||||
|
Compass.configuration.send(:run_styesheet_error, file, formatted_error) #run callback
|
||||||
write_file css_filename, error_contents(e, sass_filename), options.merge(:force => true)
|
write_file css_filename, error_contents(e, sass_filename), options.merge(:force => true)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -43,6 +43,6 @@ module Compass
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
['adapters', 'comments', 'defaults', 'helpers', 'inheritance', 'serialization', 'paths', 'data'].each do |lib|
|
['adapters', 'callbacks', 'comments', 'defaults', 'helpers', 'inheritance', 'serialization', 'paths', 'data'].each do |lib|
|
||||||
require "compass/configuration/#{lib}"
|
require "compass/configuration/#{lib}"
|
||||||
end
|
end
|
||||||
|
25
lib/compass/configuration/callbacks.rb
Normal file
25
lib/compass/configuration/callbacks.rb
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
module Compass
|
||||||
|
module Configuration
|
||||||
|
module CallbackMethods
|
||||||
|
extend ::Sass::Callbacks
|
||||||
|
|
||||||
|
# on_sprite_generated
|
||||||
|
# yields the filename
|
||||||
|
# usage: on_sprite_save {|filename| do_somethign(filename) }
|
||||||
|
define_callback :sprite_saved
|
||||||
|
# on_sprite_generated
|
||||||
|
# yields 'ChunkyPNG::Image'
|
||||||
|
# usage: on_sprite_generated {|sprite_data| do_something(sprite_data) }
|
||||||
|
define_callback :sprite_generated
|
||||||
|
|
||||||
|
define_callback :stylesheet_saved
|
||||||
|
define_callback :stylesheet_error
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
class Callbacks
|
||||||
|
extend CallbackMethods
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
end
|
@ -141,9 +141,11 @@ module Compass
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def method_missing(meth)
|
def method_missing(meth, *args, &block)
|
||||||
if inherited_data
|
if inherited_data
|
||||||
inherited_data.send(meth)
|
inherited_data.send(meth, *args, &block)
|
||||||
|
elsif Callbacks.respond_to?(meth, true)
|
||||||
|
Callbacks.send(meth, *args, &block)
|
||||||
else
|
else
|
||||||
raise NoMethodError, meth.to_s
|
raise NoMethodError, meth.to_s
|
||||||
end
|
end
|
||||||
|
@ -124,6 +124,7 @@ module Compass::SassExtensions::Functions::Sprites
|
|||||||
def generate
|
def generate
|
||||||
if generation_required?
|
if generation_required?
|
||||||
save!(construct_sprite)
|
save!(construct_sprite)
|
||||||
|
Compass.configuration.send(:run_sprite_generated, construct_sprite)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -180,7 +181,9 @@ module Compass::SassExtensions::Functions::Sprites
|
|||||||
|
|
||||||
# saves the sprite for later retrieval
|
# saves the sprite for later retrieval
|
||||||
def save!(output_png)
|
def save!(output_png)
|
||||||
output_png.save filename
|
saved = output_png.save filename
|
||||||
|
Compass.configuration.send(:run_sprite_saved, filename)
|
||||||
|
saved
|
||||||
end
|
end
|
||||||
|
|
||||||
# All the full-path filenames involved in this sprite
|
# All the full-path filenames involved in this sprite
|
||||||
|
@ -41,8 +41,33 @@ describe Compass::Sprites do
|
|||||||
" #{css.gsub('@charset "UTF-8";', '').gsub(/\n/, "\n ").strip}\n"
|
" #{css.gsub('@charset "UTF-8";', '').gsub(/\n/, "\n ").strip}\n"
|
||||||
end
|
end
|
||||||
|
|
||||||
# DEFAULT USAGE:
|
#Callbacks
|
||||||
|
describe 'callbacks' do
|
||||||
|
it "should fire on_sprite_saved" do
|
||||||
|
saved = false
|
||||||
|
path = nil
|
||||||
|
Compass.configuration.on_sprite_saved {|filepath| path = filepath; saved = true }
|
||||||
|
render <<-SCSS
|
||||||
|
@import "squares/*.png";
|
||||||
|
@include all-squares-sprites;
|
||||||
|
SCSS
|
||||||
|
saved.should eq true
|
||||||
|
path.should be_kind_of String
|
||||||
|
end
|
||||||
|
it "should fire on_sprite_generated" do
|
||||||
|
saved = false
|
||||||
|
sprite_data = nil
|
||||||
|
Compass.configuration.on_sprite_generated {|data| sprite_data = data; saved = true }
|
||||||
|
render <<-SCSS
|
||||||
|
@import "squares/*.png";
|
||||||
|
@include all-squares-sprites;
|
||||||
|
SCSS
|
||||||
|
sprite_data.should be_kind_of ChunkyPNG::Image
|
||||||
|
saved.should eq true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# DEFAULT USAGE:
|
||||||
it "should generate sprite classes" do
|
it "should generate sprite classes" do
|
||||||
css = render <<-SCSS
|
css = render <<-SCSS
|
||||||
@import "squares/*.png";
|
@import "squares/*.png";
|
||||||
|
@ -20,6 +20,26 @@ class CompassTest < Test::Unit::TestCase
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_on_stylesheet_saved_callback
|
||||||
|
saved = false
|
||||||
|
filepath = nil
|
||||||
|
Compass.configuration.on_stylesheet_saved {|filepath| path = filepath; saved = true }
|
||||||
|
within_project(:blueprint) { } #requires a block but we don't need to pass anything - sdavis
|
||||||
|
assert saved, "Stylesheet callback didn't get called"
|
||||||
|
assert filepath.is_a?(String), "Path is not a string"
|
||||||
|
end
|
||||||
|
|
||||||
|
# no project with errors exists to test aginst - leep of FAITH!
|
||||||
|
# *chriseppstein flogs himself*
|
||||||
|
# def test_on_stylesheet_error_callback
|
||||||
|
# error = false
|
||||||
|
# file = nil
|
||||||
|
# Compass.configuration.on_stylesheet_error {|filename, message| file = filename; error = true }
|
||||||
|
# within_project(:error) { } #requires a block but we don't need to pass anything - sdavis
|
||||||
|
# assert error, "Project did not throw a compile error"
|
||||||
|
# assert file.is_a?(String), "Filename was not a string"
|
||||||
|
# end
|
||||||
|
|
||||||
def test_empty_project
|
def test_empty_project
|
||||||
# With no sass files, we should have no css files.
|
# With no sass files, we should have no css files.
|
||||||
within_project(:empty) do |proj|
|
within_project(:empty) do |proj|
|
||||||
|
Loading…
Reference in New Issue
Block a user