Skip to content

Commit

Permalink
Merge pull request #14 from edward/support-returning-color-types
Browse files Browse the repository at this point in the history
Add support for returning Sass Color types
  • Loading branch information
bolandrm committed Jul 13, 2015
2 parents 93735f1 + 1666a3d commit b618d32
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 1 deletion.
3 changes: 3 additions & 0 deletions lib/sassc/native/native_functions_api.rb
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,9 @@ module Native
# ADDAPI union Sass_Value* ADDCALL sass_make_qstring (const char* val);
attach_function :sass_make_qstring, [:string], :sass_value_ptr

# ADDAPI union Sass_Value* ADDCALL sass_make_color (double r, double g, double b, double a);
attach_function :sass_make_color, [:double, :double, :double, :double], :sass_value_ptr

# ADDAPI union Sass_Value* ADDCALL sass_make_error (const char* msg);
attach_function :sass_make_error, [:string], :sass_value_ptr

Expand Down
2 changes: 1 addition & 1 deletion lib/sassc/script/color.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ module SassC
module Script
class Color < ::Sass::Script::Value::Color
def to_native
Native::make_string(to_s)
Native::make_color(red, green, blue, alpha)
end
end
end
Expand Down
16 changes: 16 additions & 0 deletions test/functions_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,18 @@ def test_function_with_no_return_value
EOS
end

def test_function_that_returns_a_color
engine = Engine.new(<<-SCSS)
div {
background: returns-a-color(); }
SCSS

assert_equal <<-EXPECTED_SCSS, engine.render
div {
background: black; }
EXPECTED_SCSS
end

def test_function_with_optional_arguments
engine = Engine.new(<<-SCSS)
div {
Expand Down Expand Up @@ -139,6 +151,10 @@ def nice_color_argument(color)
return Script::String.new(color.to_s, :string)
end

def returns_a_color()
return Script::Color.new(red: 0, green: 0, blue: 0)
end

module Compass
def stylesheet_path(path)
Script::String.new("/css/#{path.value}", :identifier)
Expand Down

0 comments on commit b618d32

Please sign in to comment.