compass 0.13.alpha.2 → 0.13.alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/README.markdown +1 -1
- data/Rakefile +5 -9
- data/VERSION.yml +1 -1
- data/features/command_line.feature +3 -23
- data/frameworks/compass/stylesheets/compass/_support.scss +2 -4
- data/frameworks/compass/stylesheets/compass/css3/_animation.scss +3 -10
- data/frameworks/compass/stylesheets/compass/css3/_appearance.scss +4 -5
- data/frameworks/compass/stylesheets/compass/css3/_background-clip.scss +4 -7
- data/frameworks/compass/stylesheets/compass/css3/_background-origin.scss +3 -8
- data/frameworks/compass/stylesheets/compass/css3/_background-size.scss +4 -7
- data/frameworks/compass/stylesheets/compass/css3/_border-radius.scss +4 -7
- data/frameworks/compass/stylesheets/compass/css3/_box-shadow.scss +10 -18
- data/frameworks/compass/stylesheets/compass/css3/_box-sizing.scss +4 -5
- data/frameworks/compass/stylesheets/compass/css3/_box.scss +13 -16
- data/frameworks/compass/stylesheets/compass/css3/_columns.scss +7 -8
- data/frameworks/compass/stylesheets/compass/css3/_filter.scss +4 -5
- data/frameworks/compass/stylesheets/compass/css3/_hyphenation.scss +13 -22
- data/frameworks/compass/stylesheets/compass/css3/_images.scss +39 -48
- data/frameworks/compass/stylesheets/compass/css3/_regions.scss +12 -8
- data/frameworks/compass/stylesheets/compass/css3/_shared.scss +3 -3
- data/frameworks/compass/stylesheets/compass/css3/_text-shadow.scss +21 -26
- data/frameworks/compass/stylesheets/compass/css3/_transform-legacy.scss +3 -3
- data/frameworks/compass/stylesheets/compass/css3/_transform.scss +8 -8
- data/frameworks/compass/stylesheets/compass/css3/_transition.scss +3 -3
- data/frameworks/compass/stylesheets/compass/css3/_user-interface.scss +4 -6
- data/lib/compass/commands.rb +1 -1
- data/lib/compass/commands/update_project.rb +0 -1
- data/lib/compass/configuration/data.rb +1 -1
- data/lib/compass/exec/project_options_parser.rb +13 -1
- data/lib/compass/sass_extensions/functions/cross_browser_support.rb +1 -1
- data/lib/compass/sass_extensions/functions/gradient_support.rb +68 -28
- data/lib/compass/sass_extensions/functions/sprites.rb +10 -14
- data/lib/compass/sass_extensions/functions/urls.rb +8 -4
- data/lib/compass/sass_extensions/functions/utility.rb +10 -0
- data/lib/compass/sass_extensions/sprites/engines.rb +3 -3
- data/lib/compass/sprite_importer/content.erb +2 -1
- data/lib/compass/watcher/project_watcher.rb +5 -2
- data/test/fixtures/stylesheets/compass/css/gradients.css +40 -39
- data/test/fixtures/stylesheets/compass/css/grid_background.css +7 -14
- data/test/fixtures/stylesheets/compass/css/hyphenation.css +4 -2
- data/test/fixtures/stylesheets/compass/css/pie.css +0 -1
- data/test/fixtures/stylesheets/compass/css/regions.css +4 -2
- data/test/fixtures/stylesheets/compass/css/sprites.css +2 -1
- data/test/fixtures/stylesheets/compass/css/text_shadow.css +6 -6
- data/test/fixtures/stylesheets/compass/css/vertical_rhythm.css +3 -6
- data/test/fixtures/stylesheets/compass/sass/gradients.sass +22 -0
- data/test/fixtures/stylesheets/envtest/tmp/env.css +4 -4
- data/test/helpers/diff.rb +1 -1
- data/test/integrations/sprites_test.rb +82 -48
- data/test/test_helper.rb +0 -13
- data/test/units/configuration_test.rb +12 -0
- data/test/units/regressions_test.rb +8 -8
- data/test/units/sass_extenstions/gradients_test.rb +33 -0
- data/test/units/sprites/layout_test.rb +11 -2
- data/test/units/watcher/project_watcher_test.rb +8 -0
- metadata +30 -16
- data/lib/compass/commands/generate_grid_background.rb +0 -96
- data/lib/compass/grid_builder.rb +0 -102
- data/test/units/compass_png_test.rb +0 -46
@@ -68,7 +68,7 @@ $transitionable-prefixed-values: transform, transform-origin !default;
|
|
68
68
|
@if type-of($duration-1) == string { $duration-1: unquote($duration-1); }
|
69
69
|
$durations: compact($duration-1, $duration-2, $duration-3, $duration-4, $duration-5, $duration-6, $duration-7, $duration-8, $duration-9, $duration-10);
|
70
70
|
@include experimental(transition-duration, $durations,
|
71
|
-
-moz, -webkit,
|
71
|
+
-moz, -webkit, not -ms, -o, not -khtml, official
|
72
72
|
);
|
73
73
|
}
|
74
74
|
|
@@ -92,7 +92,7 @@ $transitionable-prefixed-values: transform, transform-origin !default;
|
|
92
92
|
$function-1: unquote($function-1);
|
93
93
|
$functions: compact($function-1, $function-2, $function-3, $function-4, $function-5, $function-6, $function-7, $function-8, $function-9, $function-10);
|
94
94
|
@include experimental(transition-timing-function, $functions,
|
95
|
-
-moz, -webkit,
|
95
|
+
-moz, -webkit, not -ms, -o, not -khtml, official
|
96
96
|
);
|
97
97
|
}
|
98
98
|
|
@@ -115,7 +115,7 @@ $transitionable-prefixed-values: transform, transform-origin !default;
|
|
115
115
|
@if type-of($delay-1) == string { $delay-1: unquote($delay-1); }
|
116
116
|
$delays: compact($delay-1, $delay-2, $delay-3, $delay-4, $delay-5, $delay-6, $delay-7, $delay-8, $delay-9, $delay-10);
|
117
117
|
@include experimental(transition-delay, $delays,
|
118
|
-
-moz, -webkit,
|
118
|
+
-moz, -webkit, not -ms, -o, not -khtml, official
|
119
119
|
);
|
120
120
|
}
|
121
121
|
|
@@ -1,17 +1,15 @@
|
|
1
|
-
// User Interface
|
1
|
+
// User Interface
|
2
2
|
// This file can be expanded to handle all the user interface properties as
|
3
3
|
// they become available in browsers:
|
4
4
|
// http://www.w3.org/TR/2000/WD-css3-userint-20000216
|
5
|
+
|
5
6
|
@import "shared";
|
6
7
|
|
7
|
-
// ----------------------------------------------------------------------------
|
8
8
|
// @private css3-feature-support variables must always include a list of five boolean values
|
9
|
-
// representing in order: -moz, -webkit, -
|
9
|
+
// representing in order: -moz, -webkit, -ms, -o, -khtml
|
10
10
|
// - mozilla support handled seperately below
|
11
|
-
$userselect-support: not -moz, -webkit, not -o, -
|
11
|
+
$userselect-support: not -moz, -webkit, -ms, not -o, -khtml;
|
12
12
|
|
13
|
-
// ----------------------------------------------------------------------------
|
14
|
-
// Mixins
|
15
13
|
|
16
14
|
// This property controls the selection model and granularity of an element.
|
17
15
|
//
|
data/lib/compass/commands.rb
CHANGED
@@ -3,7 +3,7 @@ end
|
|
3
3
|
|
4
4
|
require 'compass/commands/registry'
|
5
5
|
|
6
|
-
%w(base
|
6
|
+
%w(base project_base default help list_frameworks
|
7
7
|
update_project watch_project create_project clean_project extension_command
|
8
8
|
imports installer_command print_version project_stats stamp_pattern
|
9
9
|
sprite validate_project write_configuration interactive unpack_extension
|
@@ -20,6 +20,10 @@ module Compass::Exec::ProjectOptionsParser
|
|
20
20
|
self.options[:project_type] = project_type.to_sym
|
21
21
|
end
|
22
22
|
|
23
|
+
opts.on('--app-dir PATH', 'The base directory for your application.') do |project_path|
|
24
|
+
self.options[:project_path] = project_path
|
25
|
+
end
|
26
|
+
|
23
27
|
opts.on('--sass-dir SRC_DIR', "The source directory where you keep your sass stylesheets.") do |sass_dir|
|
24
28
|
set_dir_or_path(:sass, sass_dir)
|
25
29
|
end
|
@@ -35,7 +39,7 @@ module Compass::Exec::ProjectOptionsParser
|
|
35
39
|
opts.on('--javascripts-dir JS_DIR', "The directory where you keep your javascripts.") do |javascripts_dir|
|
36
40
|
set_dir_or_path(:javascripts, javascripts_dir)
|
37
41
|
end
|
38
|
-
|
42
|
+
|
39
43
|
opts.on('--fonts-dir FONTS_DIR', "The directory where you keep your fonts.") do |fonts_dir|
|
40
44
|
set_dir_or_path(:fonts, fonts_dir)
|
41
45
|
end
|
@@ -57,6 +61,14 @@ module Compass::Exec::ProjectOptionsParser
|
|
57
61
|
opts.on('--no-line-comments', :NONE, 'Disable line comments.') do
|
58
62
|
self.options[:line_comments] = false
|
59
63
|
end
|
64
|
+
|
65
|
+
opts.on('--http-path HTTP_PATH', 'Set this to the root of your project when deployed') do |http_path|
|
66
|
+
self.options[:http_path] = http_path
|
67
|
+
end
|
68
|
+
|
69
|
+
opts.on('--generated-images-path GENERATED_IMAGES_PATH', 'The path where you generate your images') do |generated_images_path|
|
70
|
+
self.options[:generated_images_path] = generated_images_path
|
71
|
+
end
|
60
72
|
end
|
61
73
|
|
62
74
|
end
|
@@ -33,7 +33,7 @@ module Compass::SassExtensions::Functions::CrossBrowserSupport
|
|
33
33
|
Sass::Script::Bool.new(needed)
|
34
34
|
end
|
35
35
|
|
36
|
-
%w(webkit moz o ms svg pie css2
|
36
|
+
%w(webkit moz o ms svg pie css2).each do |prefix|
|
37
37
|
class_eval <<-RUBY, __FILE__, __LINE__ + 1
|
38
38
|
# Syntactic sugar to apply the given prefix
|
39
39
|
# -moz($arg) is the same as calling prefix(-moz, $arg)
|
@@ -79,7 +79,7 @@ module Compass::SassExtensions::Functions::GradientSupport
|
|
79
79
|
def standardized_prefix(prefix)
|
80
80
|
class_eval %Q{
|
81
81
|
def to_#{prefix}(options = self.options)
|
82
|
-
Sass::Script::String.new("-#{prefix}-\#{
|
82
|
+
Sass::Script::String.new("-#{prefix}-\#{to_s_prefixed(options)}")
|
83
83
|
end
|
84
84
|
}
|
85
85
|
end
|
@@ -134,22 +134,14 @@ module Compass::SassExtensions::Functions::GradientSupport
|
|
134
134
|
s << color_stops.to_s(options)
|
135
135
|
s << ")"
|
136
136
|
end
|
137
|
+
|
138
|
+
def to_s_prefixed(options = self.options)
|
139
|
+
to_s(options)
|
140
|
+
end
|
137
141
|
|
138
142
|
standardized_prefix :webkit
|
139
143
|
standardized_prefix :moz
|
140
144
|
standardized_prefix :o
|
141
|
-
|
142
|
-
def to_owg(options = self.options)
|
143
|
-
args = [
|
144
|
-
grad_point(position || _center_position),
|
145
|
-
Sass::Script::String.new("0"),
|
146
|
-
grad_point(position || _center_position),
|
147
|
-
grad_end_position(color_stops, Sass::Script::Bool.new(true)),
|
148
|
-
grad_color_stops(color_stops)
|
149
|
-
]
|
150
|
-
args.each {|a| a.options = options}
|
151
|
-
Sass::Script::String.new("-webkit-gradient(radial, #{args.join(', ')})")
|
152
|
-
end
|
153
145
|
|
154
146
|
def to_svg(options = self.options)
|
155
147
|
# XXX Add shape support if possible
|
@@ -169,23 +161,48 @@ module Compass::SassExtensions::Functions::GradientSupport
|
|
169
161
|
class LinearGradient < Sass::Script::Literal
|
170
162
|
include Gradient
|
171
163
|
|
172
|
-
attr_accessor :color_stops, :position_or_angle
|
164
|
+
attr_accessor :color_stops, :position_or_angle, :legacy
|
173
165
|
|
174
166
|
def children
|
175
167
|
[color_stops, position_or_angle].compact
|
176
168
|
end
|
177
169
|
|
178
|
-
def initialize(position_or_angle, color_stops)
|
170
|
+
def initialize(position_or_angle, color_stops, legacy=false)
|
179
171
|
unless color_stops.value.size >= 2
|
180
172
|
raise Sass::SyntaxError, "At least two color stops are required for a linear-gradient"
|
181
173
|
end
|
182
174
|
self.position_or_angle = position_or_angle
|
183
175
|
self.color_stops = color_stops
|
176
|
+
self.legacy = legacy
|
184
177
|
end
|
185
178
|
|
186
|
-
def
|
179
|
+
def to_s_prefixed(options = self.options)
|
187
180
|
s = "linear-gradient("
|
188
|
-
|
181
|
+
if legacy
|
182
|
+
s << position_or_angle.to_s(options) << ", " if position_or_angle
|
183
|
+
else
|
184
|
+
s << convert_to_or_from_legacy(position_or_angle, options) << ", " if position_or_angle
|
185
|
+
end
|
186
|
+
s << color_stops.to_s(options)
|
187
|
+
s << ")"
|
188
|
+
end
|
189
|
+
|
190
|
+
def convert_to_or_from_legacy(position_or_angle, options = self.options)
|
191
|
+
input = if position_or_angle.is_a?(Sass::Script::Number)
|
192
|
+
position_or_angle
|
193
|
+
else
|
194
|
+
Sass::Script::List.new(position_or_angle.to_s.split(' ').map {|s| Sass::Script::String.new(s) }, :space)
|
195
|
+
end
|
196
|
+
return convert_angle_from_offical(input).to_s(options)
|
197
|
+
end
|
198
|
+
|
199
|
+
def to_s(options = self.options)
|
200
|
+
s = 'linear-gradient('
|
201
|
+
if legacy
|
202
|
+
s << convert_to_or_from_legacy(position_or_angle, options) << ", " if position_or_angle
|
203
|
+
else
|
204
|
+
s << position_or_angle.to_s(options) << ", " if position_or_angle
|
205
|
+
end
|
189
206
|
s << color_stops.to_s(options)
|
190
207
|
s << ")"
|
191
208
|
end
|
@@ -203,16 +220,6 @@ module Compass::SassExtensions::Functions::GradientSupport
|
|
203
220
|
end
|
204
221
|
end
|
205
222
|
|
206
|
-
# Output the original webkit gradient syntax
|
207
|
-
def to_owg(options = self.options)
|
208
|
-
args = []
|
209
|
-
args << grad_point(position_or_angle || Sass::Script::String.new("top"))
|
210
|
-
args << linear_end_position(position_or_angle, color_stops)
|
211
|
-
args << grad_color_stops(color_stops)
|
212
|
-
args.each{|a| a.options = options}
|
213
|
-
Sass::Script::String.new("-webkit-gradient(linear, #{args.join(', ')})")
|
214
|
-
end
|
215
|
-
|
216
223
|
def to_svg(options = self.options)
|
217
224
|
linear_svg_gradient(color_stops, position_or_angle || Sass::Script::String.new("top"))
|
218
225
|
end
|
@@ -229,6 +236,29 @@ module Compass::SassExtensions::Functions::GradientSupport
|
|
229
236
|
end
|
230
237
|
|
231
238
|
module Functions
|
239
|
+
|
240
|
+
def convert_angle_from_offical(deg)
|
241
|
+
if deg.is_a?(Sass::Script::Number)
|
242
|
+
return Sass::Script::Number.new((deg.value.to_f - 450).abs % 360, ['deg'])
|
243
|
+
else
|
244
|
+
args = deg.value
|
245
|
+
direction = []
|
246
|
+
if args[0] == Sass::Script::String.new('to')
|
247
|
+
if args.size < 2
|
248
|
+
direction = args
|
249
|
+
else
|
250
|
+
direction << opposite_position(args[1])
|
251
|
+
end
|
252
|
+
else
|
253
|
+
direction << Sass::Script::String.new('to')
|
254
|
+
args.each do |pos|
|
255
|
+
direction << opposite_position(pos)
|
256
|
+
end
|
257
|
+
end
|
258
|
+
return Sass::Script::String.new(direction.join(' '))
|
259
|
+
end
|
260
|
+
end
|
261
|
+
|
232
262
|
# given a position list, return a corresponding position in percents
|
233
263
|
# otherwise, returns the original argument
|
234
264
|
def grad_point(position)
|
@@ -314,7 +344,7 @@ module Compass::SassExtensions::Functions::GradientSupport
|
|
314
344
|
RadialGradient.new(position_or_angle, shape_and_size, send(:color_stops, *color_stops))
|
315
345
|
end
|
316
346
|
|
317
|
-
def
|
347
|
+
def _build_linear_gradient(position_or_angle, *color_stops)
|
318
348
|
if color_stop?(position_or_angle)
|
319
349
|
color_stops.unshift(position_or_angle)
|
320
350
|
position_or_angle = nil
|
@@ -328,9 +358,19 @@ module Compass::SassExtensions::Functions::GradientSupport
|
|
328
358
|
if color_stops.size == 1 && (stops = list_of_color_stops?(color_stops.first))
|
329
359
|
color_stops = stops
|
330
360
|
end
|
361
|
+
return [position_or_angle, color_stops]
|
362
|
+
end
|
363
|
+
|
364
|
+
def _linear_gradient(position_or_angle, *color_stops)
|
365
|
+
position_or_angle, color_stops = _build_linear_gradient(position_or_angle, *color_stops)
|
331
366
|
LinearGradient.new(position_or_angle, send(:color_stops, *color_stops))
|
332
367
|
end
|
333
368
|
|
369
|
+
def _linear_gradient_legacy(position_or_angle, *color_stops)
|
370
|
+
position_or_angle, color_stops = _build_linear_gradient(position_or_angle, *color_stops)
|
371
|
+
LinearGradient.new(position_or_angle, send(:color_stops, *color_stops), true)
|
372
|
+
end
|
373
|
+
|
334
374
|
# returns color-stop() calls for use in webkit.
|
335
375
|
def grad_color_stops(color_list)
|
336
376
|
stops = color_stops_in_percentages(color_list).map do |stop, color|
|
@@ -14,11 +14,7 @@ module Compass::SassExtensions::Functions::Sprites
|
|
14
14
|
# Returns the width of the generated sprite map
|
15
15
|
def sprite_width(map, sprite=nil)
|
16
16
|
verify_map(map, 'sprite-width')
|
17
|
-
file =
|
18
|
-
map.image_for(sprite).file
|
19
|
-
else
|
20
|
-
map.filename
|
21
|
-
end
|
17
|
+
file = get_sprite_file(map, sprite)
|
22
18
|
width, _ = image_dimensions(file)
|
23
19
|
Sass::Script::Number.new(width, ["px"])
|
24
20
|
end
|
@@ -28,11 +24,7 @@ module Compass::SassExtensions::Functions::Sprites
|
|
28
24
|
# Returns the height of the generated sprite map
|
29
25
|
def sprite_height(map, sprite=nil)
|
30
26
|
verify_map(map, 'sprite-height')
|
31
|
-
file =
|
32
|
-
map.image_for(sprite).file
|
33
|
-
else
|
34
|
-
map.filename
|
35
|
-
end
|
27
|
+
file = get_sprite_file(map, sprite)
|
36
28
|
_, height = image_dimensions(file)
|
37
29
|
Sass::Script::Number.new(height, ["px"])
|
38
30
|
end
|
@@ -234,12 +226,16 @@ module Compass::SassExtensions::Functions::Sprites
|
|
234
226
|
Sass::Script::Functions.declare :sprite_position, [:map, :sprite, :offset_x, :offset_y]
|
235
227
|
Sass::Script::Functions.declare :sprite_position, [:map, :sprite, :offset_x, :offset_y, :use_percentages]
|
236
228
|
|
237
|
-
def sprite_image(*args)
|
238
|
-
raise Sass::SyntaxError, %Q(The sprite-image() function has been replaced by sprite(). See http://compass-style.org/help/tutorials/spriting/ for more information.)
|
239
|
-
end
|
240
|
-
|
241
229
|
protected
|
242
230
|
|
231
|
+
def get_sprite_file(map, sprite=nil)
|
232
|
+
if sprite
|
233
|
+
map.image_for(sprite).file
|
234
|
+
else
|
235
|
+
map.filename
|
236
|
+
end
|
237
|
+
end
|
238
|
+
|
243
239
|
def reversed_color_names
|
244
240
|
if Sass::Script::Color.const_defined?(:HTML4_COLORS_REVERSE)
|
245
241
|
Sass::Script::Color::HTML4_COLORS_REVERSE
|
@@ -130,8 +130,10 @@ module Compass::SassExtensions::Functions::Urls
|
|
130
130
|
end
|
131
131
|
|
132
132
|
# Compute the real path to the image on the file stystem if the images_dir is set.
|
133
|
-
real_path = if Compass.configuration.
|
134
|
-
File.join(Compass.configuration.
|
133
|
+
real_path = if Compass.configuration.images_path
|
134
|
+
File.join(Compass.configuration.images_path, path)
|
135
|
+
else
|
136
|
+
File.join(Compass.configuration.project_path, path)
|
135
137
|
end
|
136
138
|
|
137
139
|
# prepend the path to the image if there's one
|
@@ -195,8 +197,10 @@ module Compass::SassExtensions::Functions::Urls
|
|
195
197
|
end
|
196
198
|
|
197
199
|
# Compute the real path to the image on the file stystem if the generated_images_dir is set.
|
198
|
-
real_path = if Compass.configuration.
|
199
|
-
File.join(Compass.configuration.
|
200
|
+
real_path = if Compass.configuration.images_path
|
201
|
+
File.join(Compass.configuration.images_path, path)
|
202
|
+
else
|
203
|
+
File.join(Compass.configuration.project_path, path)
|
200
204
|
end
|
201
205
|
|
202
206
|
# prepend the path to the image if there's one
|
@@ -0,0 +1,10 @@
|
|
1
|
+
module Compass::SassExtensions::Functions::Utility
|
2
|
+
|
3
|
+
def file_exists(path_to_file)
|
4
|
+
path = path_to_file.respond_to?(:value) ? path_to_file.value : path_to_file
|
5
|
+
Sass::Script::Bool.new(File.exists?(path));
|
6
|
+
end
|
7
|
+
|
8
|
+
Sass::Script::Functions.declare :file_exists, [:path_to_file]
|
9
|
+
|
10
|
+
end
|
@@ -9,11 +9,11 @@ module Compass
|
|
9
9
|
end
|
10
10
|
|
11
11
|
def construct_sprite
|
12
|
-
raise ::Compass::Error, "You must
|
12
|
+
raise ::Compass::Error, "You must implement construct_sprite"
|
13
13
|
end
|
14
14
|
|
15
15
|
def save(filename)
|
16
|
-
raise ::Compass::Error, "You must
|
16
|
+
raise ::Compass::Error, "You must implement save(filename)"
|
17
17
|
end
|
18
18
|
|
19
19
|
end
|
@@ -22,4 +22,4 @@ module Compass
|
|
22
22
|
end
|
23
23
|
|
24
24
|
|
25
|
-
require 'compass/sass_extensions/sprites/engines/chunky_png_engine'
|
25
|
+
require 'compass/sass_extensions/sprites/engines/chunky_png_engine'
|
@@ -47,7 +47,8 @@ $<%= name %>-sort-by : 'none' !default;
|
|
47
47
|
}
|
48
48
|
} @else {
|
49
49
|
#{$<%= name %>-sprite-base-class} {
|
50
|
-
background: $<%= name %>-sprites
|
50
|
+
background-image: $<%= name %>-sprites;
|
51
|
+
background-repeat: no-repeat;
|
51
52
|
}
|
52
53
|
}
|
53
54
|
//sass functions to return the dimensions of a sprite image as units
|
@@ -55,6 +55,9 @@ module Compass
|
|
55
55
|
load_path = Pathname.new(load_path).relative_path_from(Pathname.new(project_path))
|
56
56
|
filter = File.join(load_path, SASS_FILTER)
|
57
57
|
children = File.join(load_path, ALL_CHILDREN_SASS_FILTER)
|
58
|
+
if filter.match(%r{^./})
|
59
|
+
watches << Watcher::Watch.new(SASS_FILTER, &method(:sass_callback))
|
60
|
+
end
|
58
61
|
watches << Watcher::Watch.new(filter, &method(:sass_callback))
|
59
62
|
watches << Watcher::Watch.new(children, &method(:sass_callback))
|
60
63
|
end
|
@@ -62,7 +65,7 @@ module Compass
|
|
62
65
|
end
|
63
66
|
|
64
67
|
def listen_callback(modified_file, added_file, removed_file)
|
65
|
-
#log_action(:info, ">>> Listen Callback fired", {})
|
68
|
+
#log_action(:info, ">>> Listen Callback fired added: #{added_file}, mod: #{modified_file}, rem: #{removed_file}", {})
|
66
69
|
action = nil
|
67
70
|
action ||= :modified unless modified_file.empty?
|
68
71
|
action ||= :added unless added_file.empty?
|
@@ -78,7 +81,7 @@ module Compass
|
|
78
81
|
end
|
79
82
|
|
80
83
|
def sass_callback(base, file, action)
|
81
|
-
#log_action(:info, ">>> Sass Callback fired #{action}", {})
|
84
|
+
#log_action(:info, ">>> Sass Callback fired #{action}, #{file}", {})
|
82
85
|
sass_modified(file) if action == :modified
|
83
86
|
sass_added(file) if action == :added
|
84
87
|
sass_removed(file) if action == :removed
|
@@ -3,43 +3,39 @@
|
|
3
3
|
|
4
4
|
.bg-shortcut-linear-gradient {
|
5
5
|
background: white url('');
|
6
|
-
background: white -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa));
|
7
6
|
background: white -webkit-linear-gradient(top left, #dddddd, #aaaaaa);
|
8
7
|
background: white -moz-linear-gradient(top left, #dddddd, #aaaaaa);
|
9
8
|
background: white -o-linear-gradient(top left, #dddddd, #aaaaaa);
|
10
|
-
background: white linear-gradient(
|
9
|
+
background: white linear-gradient(to bottom right, #dddddd, #aaaaaa); }
|
11
10
|
|
12
11
|
.bg-shortcut-radial-gradient {
|
13
12
|
background: white url('');
|
14
|
-
background: white -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 100, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa));
|
15
13
|
background: white -webkit-radial-gradient(center center, #dddddd, #aaaaaa 100px);
|
16
14
|
background: white -moz-radial-gradient(center center, #dddddd, #aaaaaa 100px);
|
17
15
|
background: white -o-radial-gradient(center center, #dddddd, #aaaaaa 100px);
|
18
16
|
background: white radial-gradient(center center, #dddddd, #aaaaaa 100px); }
|
19
17
|
|
20
18
|
.bg-linear-gradient-angle-svg {
|
21
|
-
background-image: -webkit-linear-gradient(
|
22
|
-
background-image: -moz-linear-gradient(
|
23
|
-
background-image: -o-linear-gradient(
|
19
|
+
background-image: -webkit-linear-gradient(135deg, #0000ff, #000000);
|
20
|
+
background-image: -moz-linear-gradient(135deg, #0000ff, #000000);
|
21
|
+
background-image: -o-linear-gradient(135deg, #0000ff, #000000);
|
24
22
|
background-image: linear-gradient(-45deg, #0000ff, #000000); }
|
25
23
|
|
26
24
|
.bg-linear-gradient-angle2-svg {
|
27
25
|
background-image: url('');
|
28
26
|
background-size: 100%;
|
29
|
-
background-image: -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, #0000ff), color-stop(100%, #000000));
|
30
27
|
background-image: -webkit-linear-gradient(top left, #0000ff, #000000);
|
31
28
|
background-image: -moz-linear-gradient(top left, #0000ff, #000000);
|
32
29
|
background-image: -o-linear-gradient(top left, #0000ff, #000000);
|
33
|
-
background-image: linear-gradient(
|
30
|
+
background-image: linear-gradient(to bottom right, #0000ff, #000000); }
|
34
31
|
|
35
32
|
.bg-all-gradient-types-with-simplification {
|
36
33
|
background: #ffcc00;
|
37
34
|
background: url('/images/4x6.png?busted=true'), url(''), url(''), #ffcc00;
|
38
|
-
background: url('/images/4x6.png?busted=true'), -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa)), -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 100, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa)), #ffcc00;
|
39
35
|
background: url('/images/4x6.png?busted=true'), -webkit-linear-gradient(top left, #dddddd, #aaaaaa), -webkit-radial-gradient(center center, #dddddd, #aaaaaa 100px), #ffcc00;
|
40
36
|
background: url('/images/4x6.png?busted=true'), -moz-linear-gradient(top left, #dddddd, #aaaaaa), -moz-radial-gradient(center center, #dddddd, #aaaaaa 100px), #ffcc00;
|
41
37
|
background: url('/images/4x6.png?busted=true'), -o-linear-gradient(top left, #dddddd, #aaaaaa), -o-radial-gradient(center center, #dddddd, #aaaaaa 100px), #ffcc00;
|
42
|
-
background: url('/images/4x6.png?busted=true'), linear-gradient(
|
38
|
+
background: url('/images/4x6.png?busted=true'), linear-gradient(to bottom right, #dddddd, #aaaaaa), radial-gradient(center center, #dddddd, #aaaaaa 100px), #ffcc00; }
|
43
39
|
|
44
40
|
.bg-simple-image {
|
45
41
|
background-image: url("foo.png"); }
|
@@ -47,61 +43,54 @@
|
|
47
43
|
.bg-linear-gradient {
|
48
44
|
background-image: url('');
|
49
45
|
background-size: 100%;
|
50
|
-
background-image: -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa));
|
51
46
|
background-image: -webkit-linear-gradient(top left, #dddddd, #aaaaaa);
|
52
47
|
background-image: -moz-linear-gradient(top left, #dddddd, #aaaaaa);
|
53
48
|
background-image: -o-linear-gradient(top left, #dddddd, #aaaaaa);
|
54
|
-
background-image: linear-gradient(
|
49
|
+
background-image: linear-gradient(to bottom right, #dddddd, #aaaaaa); }
|
55
50
|
|
56
51
|
.bg-linear-gradient-pixel-stop-from-top {
|
57
52
|
background-image: url('');
|
58
53
|
background-size: 100%;
|
59
|
-
background-image: -webkit-gradient(linear, 50% 0%, 50% 40, color-stop(25%, #dddddd), color-stop(100%, #aaaaaa));
|
60
54
|
background-image: -webkit-linear-gradient(top, #dddddd 10px, #aaaaaa 40px);
|
61
55
|
background-image: -moz-linear-gradient(top, #dddddd 10px, #aaaaaa 40px);
|
62
56
|
background-image: -o-linear-gradient(top, #dddddd 10px, #aaaaaa 40px);
|
63
|
-
background-image: linear-gradient(
|
57
|
+
background-image: linear-gradient(to bottom, #dddddd 10px, #aaaaaa 40px); }
|
64
58
|
|
65
59
|
.bg-linear-gradient-pixel-stop-from-left {
|
66
60
|
background-image: url('');
|
67
61
|
background-size: 100%;
|
68
|
-
background-image: -webkit-gradient(linear, 0% 50%, 40 50%, color-stop(25%, #dddddd), color-stop(100%, #aaaaaa));
|
69
62
|
background-image: -webkit-linear-gradient(left, #dddddd 10px, #aaaaaa 40px);
|
70
63
|
background-image: -moz-linear-gradient(left, #dddddd 10px, #aaaaaa 40px);
|
71
64
|
background-image: -o-linear-gradient(left, #dddddd 10px, #aaaaaa 40px);
|
72
|
-
background-image: linear-gradient(
|
65
|
+
background-image: linear-gradient(to right, #dddddd 10px, #aaaaaa 40px); }
|
73
66
|
|
74
67
|
.transparent-in-linear-gradient {
|
75
68
|
background-image: white url('');
|
76
69
|
background-size: 100%;
|
77
|
-
background-image: white -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, transparent), color-stop(100%, #aaaaaa));
|
78
70
|
background-image: white -webkit-linear-gradient(top left, transparent, #aaaaaa);
|
79
71
|
background-image: white -moz-linear-gradient(top left, transparent, #aaaaaa);
|
80
72
|
background-image: white -o-linear-gradient(top left, transparent, #aaaaaa);
|
81
|
-
background-image: white linear-gradient(
|
73
|
+
background-image: white linear-gradient(to bottom right, transparent, #aaaaaa); }
|
82
74
|
|
83
75
|
.currentColor-in-linear-gradient {
|
84
76
|
background-image: white url('');
|
85
77
|
background-size: 100%;
|
86
|
-
background-image: white -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, transparent), color-stop(100%, currentColor));
|
87
78
|
background-image: white -webkit-linear-gradient(top left, transparent, currentColor);
|
88
79
|
background-image: white -moz-linear-gradient(top left, transparent, currentColor);
|
89
80
|
background-image: white -o-linear-gradient(top left, transparent, currentColor);
|
90
|
-
background-image: white linear-gradient(
|
81
|
+
background-image: white linear-gradient(to bottom right, transparent, currentColor); }
|
91
82
|
|
92
83
|
.rgba-in-linear-gradient {
|
93
84
|
background-image: white url('');
|
94
85
|
background-size: 100%;
|
95
|
-
background-image: white -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, rgba(255, 255, 255, 0.8)), color-stop(100%, rgba(0, 0, 0, 0.1)));
|
96
86
|
background-image: white -webkit-linear-gradient(top left, rgba(255, 255, 255, 0.8), rgba(0, 0, 0, 0.1));
|
97
87
|
background-image: white -moz-linear-gradient(top left, rgba(255, 255, 255, 0.8), rgba(0, 0, 0, 0.1));
|
98
88
|
background-image: white -o-linear-gradient(top left, rgba(255, 255, 255, 0.8), rgba(0, 0, 0, 0.1));
|
99
|
-
background-image: white linear-gradient(
|
89
|
+
background-image: white linear-gradient(to bottom right, rgba(255, 255, 255, 0.8), rgba(0, 0, 0, 0.1)); }
|
100
90
|
|
101
91
|
.bg-radial-gradient {
|
102
92
|
background-image: url('');
|
103
93
|
background-size: 100%;
|
104
|
-
background-image: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 100, color-stop(0%, #dddddd), color-stop(100%, transparent));
|
105
94
|
background-image: -webkit-radial-gradient(center center, #dddddd, transparent 100px);
|
106
95
|
background-image: -moz-radial-gradient(center center, #dddddd, transparent 100px);
|
107
96
|
background-image: -o-radial-gradient(center center, #dddddd, transparent 100px);
|
@@ -110,22 +99,20 @@
|
|
110
99
|
.currentColor-in-radial-gradient {
|
111
100
|
background-image: url('');
|
112
101
|
background-size: 100%;
|
113
|
-
background-image: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 100, color-stop(0%, currentColor), color-stop(100%, transparent));
|
114
102
|
background-image: -webkit-radial-gradient(center center, currentColor, transparent 100px);
|
115
103
|
background-image: -moz-radial-gradient(center center, currentColor, transparent 100px);
|
116
104
|
background-image: -o-radial-gradient(center center, currentColor, transparent 100px);
|
117
105
|
background-image: radial-gradient(center center, currentColor, transparent 100px); }
|
118
106
|
|
119
107
|
.bg-linear-gradient-with-angle {
|
120
|
-
background-image: -webkit-linear-gradient(
|
121
|
-
background-image: -moz-linear-gradient(
|
122
|
-
background-image: -o-linear-gradient(
|
108
|
+
background-image: -webkit-linear-gradient(135deg, #dddddd, #aaaaaa);
|
109
|
+
background-image: -moz-linear-gradient(135deg, #dddddd, #aaaaaa);
|
110
|
+
background-image: -o-linear-gradient(135deg, #dddddd, #aaaaaa);
|
123
111
|
background-image: linear-gradient(-45deg, #dddddd, #aaaaaa); }
|
124
112
|
|
125
113
|
.bg-radial-gradient-with-angle-and-shape {
|
126
114
|
background-image: url('');
|
127
115
|
background-size: 100%;
|
128
|
-
background-image: -webkit-gradient(radial, ellipse cover, 0, ellipse cover, 100, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa));
|
129
116
|
background-image: -webkit-radial-gradient(ellipse cover, #dddddd, #aaaaaa 100px);
|
130
117
|
background-image: -moz-radial-gradient(ellipse cover, #dddddd, #aaaaaa 100px);
|
131
118
|
background-image: -o-radial-gradient(ellipse cover, #dddddd, #aaaaaa 100px);
|
@@ -134,15 +121,13 @@
|
|
134
121
|
.bg-all-gradient-types {
|
135
122
|
background-image: url('/images/4x6.png?busted=true'), url(''), url('');
|
136
123
|
background-size: 100%;
|
137
|
-
background-image: url('/images/4x6.png?busted=true'), -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa)), -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 100, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa));
|
138
124
|
background-image: url('/images/4x6.png?busted=true'), -webkit-linear-gradient(top left, #dddddd, #aaaaaa), -webkit-radial-gradient(center center, #dddddd, #aaaaaa 100px);
|
139
125
|
background-image: url('/images/4x6.png?busted=true'), -moz-linear-gradient(top left, #dddddd, #aaaaaa), -moz-radial-gradient(center center, #dddddd, #aaaaaa 100px);
|
140
126
|
background-image: url('/images/4x6.png?busted=true'), -o-linear-gradient(top left, #dddddd, #aaaaaa), -o-radial-gradient(center center, #dddddd, #aaaaaa 100px);
|
141
|
-
background-image: url('/images/4x6.png?busted=true'), linear-gradient(
|
127
|
+
background-image: url('/images/4x6.png?busted=true'), linear-gradient(to bottom right, #dddddd, #aaaaaa), radial-gradient(center center, #dddddd, #aaaaaa 100px); }
|
142
128
|
|
143
129
|
.border-image-gradient {
|
144
130
|
-moz-border-image: -moz-radial-gradient(#00ff00, #ff0000 100px) 100 stretch;
|
145
|
-
-webkit-border-image: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 100, color-stop(0%, #00ff00), color-stop(100%, #ff0000)) 100 stretch;
|
146
131
|
-webkit-border-image: -webkit-radial-gradient(#00ff00, #ff0000 100px) 100 stretch;
|
147
132
|
-o-border-image: -o-radial-gradient(#00ff00, #ff0000 100px) 100 stretch;
|
148
133
|
border-image: url('') 100 stretch;
|
@@ -156,7 +141,6 @@
|
|
156
141
|
|
157
142
|
.direct-list-image-with-gradient {
|
158
143
|
list-style-image: -moz-radial-gradient(#00ff00, #ff0000 10px);
|
159
|
-
list-style-image: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 10, color-stop(0%, #00ff00), color-stop(100%, #ff0000));
|
160
144
|
list-style-image: -webkit-radial-gradient(#00ff00, #ff0000 10px);
|
161
145
|
list-style-image: -o-radial-gradient(#00ff00, #ff0000 10px);
|
162
146
|
list-style-image: url('');
|
@@ -164,7 +148,6 @@
|
|
164
148
|
|
165
149
|
.shorthand-list-image-with-gradient {
|
166
150
|
list-style-image: outside -moz-radial-gradient(#00ff00, #ff0000 10px);
|
167
|
-
list-style-image: outside -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 10, color-stop(0%, #00ff00), color-stop(100%, #ff0000));
|
168
151
|
list-style-image: outside -webkit-radial-gradient(#00ff00, #ff0000 10px);
|
169
152
|
list-style-image: outside -o-radial-gradient(#00ff00, #ff0000 10px);
|
170
153
|
list-style-image: outside url('');
|
@@ -175,42 +158,36 @@
|
|
175
158
|
|
176
159
|
.content-with-gradient {
|
177
160
|
content: -moz-radial-gradient(#00ff00, #ff0000 10px);
|
178
|
-
content: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 10, color-stop(0%, #00ff00), color-stop(100%, #ff0000));
|
179
161
|
content: -webkit-radial-gradient(#00ff00, #ff0000 10px);
|
180
162
|
content: -o-radial-gradient(#00ff00, #ff0000 10px);
|
181
163
|
content: url('');
|
182
164
|
content: radial-gradient(#00ff00, #ff0000 10px); }
|
183
165
|
|
184
166
|
.bg-linear-gradient-no-position {
|
185
|
-
background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa));
|
186
167
|
background-image: -webkit-linear-gradient(#dddddd, #aaaaaa);
|
187
168
|
background-image: -moz-linear-gradient(#dddddd, #aaaaaa);
|
188
169
|
background-image: -o-linear-gradient(#dddddd, #aaaaaa);
|
189
170
|
background-image: linear-gradient(#dddddd, #aaaaaa); }
|
190
171
|
|
191
172
|
.bg-radial-gradient-no-position {
|
192
|
-
background-image: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 100, color-stop(0%, #dddddd), color-stop(100%, #aaaaaa));
|
193
173
|
background-image: -webkit-radial-gradient(#dddddd, #aaaaaa 100px);
|
194
174
|
background-image: -moz-radial-gradient(#dddddd, #aaaaaa 100px);
|
195
175
|
background-image: -o-radial-gradient(#dddddd, #aaaaaa 100px);
|
196
176
|
background-image: radial-gradient(#dddddd, #aaaaaa 100px); }
|
197
177
|
|
198
178
|
.image-fallback {
|
199
|
-
background-image: image(radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true'), #cc0000);
|
200
179
|
background-image: image(-webkit-radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true'), #cc0000);
|
201
180
|
background-image: image(-moz-radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true'), #cc0000);
|
202
181
|
background-image: image(-o-radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true'), #cc0000);
|
203
182
|
background-image: image(radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true'), #cc0000); }
|
204
183
|
|
205
184
|
.cross-fade {
|
206
|
-
background-image: cross-fade(radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true'));
|
207
185
|
background-image: cross-fade(-webkit-radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true'));
|
208
186
|
background-image: cross-fade(-moz-radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true'));
|
209
187
|
background-image: cross-fade(-o-radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true'));
|
210
188
|
background-image: cross-fade(radial-gradient(#dddddd, #aaaaaa 100px), url('/images/4x6.png?busted=true')); }
|
211
189
|
|
212
190
|
.unknown-function-wrapper {
|
213
|
-
background: foo(radial-gradient(#dddddd, #aaaaaa 100px));
|
214
191
|
background: foo(-webkit-radial-gradient(#dddddd, #aaaaaa 100px));
|
215
192
|
background: foo(-moz-radial-gradient(#dddddd, #aaaaaa 100px));
|
216
193
|
background: foo(-o-radial-gradient(#dddddd, #aaaaaa 100px));
|
@@ -227,3 +204,27 @@
|
|
227
204
|
.ie-alpha-filter {
|
228
205
|
*zoom: 1;
|
229
206
|
filter: progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorstr='#FFFFFFFF', endColorstr='#00FFFFFF'); }
|
207
|
+
|
208
|
+
.linear-gradient-new {
|
209
|
+
background: -webkit-linear-gradient(top, #ff0000 0%, #88aa44 100%);
|
210
|
+
background: -moz-linear-gradient(top, #ff0000 0%, #88aa44 100%);
|
211
|
+
background: -o-linear-gradient(top, #ff0000 0%, #88aa44 100%);
|
212
|
+
background: linear-gradient(to bottom, #ff0000 0%, #88aa44 100%); }
|
213
|
+
|
214
|
+
.linear-gradient-old {
|
215
|
+
background: -webkit-linear-gradient(top, #ff0000 0%, #88aa44 100%);
|
216
|
+
background: -moz-linear-gradient(top, #ff0000 0%, #88aa44 100%);
|
217
|
+
background: -o-linear-gradient(top, #ff0000 0%, #88aa44 100%);
|
218
|
+
background: linear-gradient(to bottom, #ff0000 0%, #88aa44 100%); }
|
219
|
+
|
220
|
+
.linear-gradient-unknown-new {
|
221
|
+
background: -webkit-linear-gradient(330deg, #ff0000 0%, #88aa44 100%);
|
222
|
+
background: -moz-linear-gradient(330deg, #ff0000 0%, #88aa44 100%);
|
223
|
+
background: -o-linear-gradient(330deg, #ff0000 0%, #88aa44 100%);
|
224
|
+
background: linear-gradient(120deg, #ff0000 0%, #88aa44 100%); }
|
225
|
+
|
226
|
+
.linear-gradient-unknown-old {
|
227
|
+
background: -webkit-linear-gradient(120deg, #ff0000 0%, #88aa44 100%);
|
228
|
+
background: -moz-linear-gradient(120deg, #ff0000 0%, #88aa44 100%);
|
229
|
+
background: -o-linear-gradient(120deg, #ff0000 0%, #88aa44 100%);
|
230
|
+
background: linear-gradient(330deg, #ff0000 0%, #88aa44 100%); }
|