compass-sourcemaps 0.12.3.sourcemaps.a4836f1 → 0.12.4.sourcemaps.a4836f1

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.
Files changed (495) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE.markdown +29 -29
  3. data/README.markdown +39 -39
  4. data/Rakefile +157 -157
  5. data/VERSION.yml +5 -5
  6. data/bin/compass +45 -45
  7. data/examples/README.markdown +3 -3
  8. data/examples/blueprint_default/config.rb +7 -7
  9. data/examples/blueprint_default/index.html.haml +85 -85
  10. data/examples/blueprint_default/parts/elements.html.haml +282 -282
  11. data/examples/blueprint_default/parts/forms.html.haml +200 -200
  12. data/examples/blueprint_default/parts/grid.html.haml +274 -274
  13. data/examples/blueprint_default/src/ie.scss +3 -3
  14. data/examples/blueprint_default/src/print.scss +3 -3
  15. data/examples/blueprint_default/src/screen.scss +9 -9
  16. data/examples/blueprint_plugins/config.rb +8 -8
  17. data/examples/blueprint_plugins/index.html.haml +96 -96
  18. data/examples/blueprint_plugins/plugins/buttons.html.haml +67 -67
  19. data/examples/blueprint_plugins/plugins/fancy_type.html.haml +100 -100
  20. data/examples/blueprint_plugins/plugins/link_icons.html.haml +61 -61
  21. data/examples/blueprint_plugins/plugins/rtl.html.haml +100 -100
  22. data/examples/blueprint_plugins/src/buttons.scss +47 -47
  23. data/examples/blueprint_plugins/src/ie.scss +3 -3
  24. data/examples/blueprint_plugins/src/link_icons.scss +13 -13
  25. data/examples/blueprint_plugins/src/print.scss +3 -3
  26. data/examples/blueprint_plugins/src/rtl_screen.scss +15 -15
  27. data/examples/blueprint_plugins/src/screen.scss +12 -12
  28. data/examples/blueprint_scoped/src/ie.scss +4 -4
  29. data/examples/blueprint_scoped/src/print.scss +4 -4
  30. data/examples/blueprint_scoped/src/screen.scss +5 -5
  31. data/examples/blueprint_scoped_form/src/ie.scss +3 -3
  32. data/examples/blueprint_scoped_form/src/print.scss +3 -3
  33. data/examples/blueprint_scoped_form/src/screen.scss +15 -15
  34. data/examples/blueprint_semantic/config.rb +7 -7
  35. data/examples/blueprint_semantic/index.html.haml +86 -86
  36. data/examples/blueprint_semantic/parts/fancy_type.html.haml +100 -100
  37. data/examples/blueprint_semantic/parts/liquid.html.haml +100 -100
  38. data/examples/blueprint_semantic/src/ie.scss +3 -3
  39. data/examples/blueprint_semantic/src/liquid.scss +69 -69
  40. data/examples/blueprint_semantic/src/print.scss +3 -3
  41. data/examples/blueprint_semantic/src/screen.scss +69 -69
  42. data/examples/compass/bootstrap.rb +3 -3
  43. data/examples/compass/clean.rb +1 -1
  44. data/examples/compass/compass.html.haml +39 -39
  45. data/examples/compass/config.rb +8 -8
  46. data/examples/compass/pie.html.haml +73 -73
  47. data/examples/compass/sprites.html.haml +37 -37
  48. data/examples/compass/src/bp_layout.scss +18 -18
  49. data/examples/compass/src/compass.scss +46 -46
  50. data/examples/compass/src/pie.scss +110 -110
  51. data/examples/compass/src/sprites.scss +24 -24
  52. data/examples/compass/src/sticky_footer.scss +11 -11
  53. data/examples/compass/src/utilities.scss +108 -108
  54. data/examples/compass/sticky_footer.html.haml +13 -13
  55. data/examples/compass/utilities.html.haml +189 -189
  56. data/examples/css3/bootstrap.rb +3 -3
  57. data/examples/css3/clean.rb +2 -2
  58. data/examples/css3/config.rb +6 -6
  59. data/examples/css3/extensions/fancy-fonts/templates/project/fancy-fonts.sass +10 -10
  60. data/examples/css3/extensions/fancy-fonts/templates/project/manifest.rb +6 -6
  61. data/examples/css3/gradients.html.haml +68 -68
  62. data/examples/css3/index.html.haml +57 -57
  63. data/examples/css3/src/_base.scss +13 -13
  64. data/examples/css3/src/fancy-fonts.scss +13 -13
  65. data/examples/css3/src/gradients.scss +85 -85
  66. data/examples/css3/src/main.scss +108 -108
  67. data/examples/downloader.rb +58 -58
  68. data/examples/ninesixty/bootstrap.rb +4 -4
  69. data/examples/ninesixty/clean.rb +1 -1
  70. data/examples/ninesixty/config.rb +9 -9
  71. data/examples/ninesixty/src/grid.scss +15 -15
  72. data/examples/ninesixty/src/text.scss +8 -8
  73. data/examples/susy/bootstrap.rb +3 -3
  74. data/examples/susy/clean.rb +1 -1
  75. data/examples/susy/config.rb +9 -9
  76. data/examples/susy/src/_base.scss +61 -61
  77. data/examples/susy/src/_defaults.scss +140 -140
  78. data/examples/susy/src/screen.scss +100 -100
  79. data/examples/yui/bootstrap.rb +2 -2
  80. data/examples/yui/clean.rb +1 -1
  81. data/examples/yui/divisions.html.haml +179 -179
  82. data/examples/yui/index.html.haml +19 -19
  83. data/examples/yui/src/screen.scss +13 -13
  84. data/examples/yui/sub_divisions.html.haml +169 -169
  85. data/examples/yui/templates.html.haml +54 -54
  86. data/examples/yui/typography.html.haml +132 -132
  87. data/features/command_line.feature +292 -292
  88. data/features/extensions.feature +27 -27
  89. data/features/step_definitions/command_line_steps.rb +268 -268
  90. data/features/step_definitions/extension_steps.rb +24 -24
  91. data/frameworks/blueprint/stylesheets/_blueprint.scss +37 -37
  92. data/frameworks/blueprint/stylesheets/blueprint/_buttons.scss +100 -100
  93. data/frameworks/blueprint/stylesheets/blueprint/_colors.scss +36 -36
  94. data/frameworks/blueprint/stylesheets/blueprint/_debug.scss +28 -28
  95. data/frameworks/blueprint/stylesheets/blueprint/_fancy-type.scss +88 -88
  96. data/frameworks/blueprint/stylesheets/blueprint/_form.scss +66 -66
  97. data/frameworks/blueprint/stylesheets/blueprint/_grid.scss +258 -258
  98. data/frameworks/blueprint/stylesheets/blueprint/_ie.scss +111 -111
  99. data/frameworks/blueprint/stylesheets/blueprint/_interaction.scss +66 -66
  100. data/frameworks/blueprint/stylesheets/blueprint/_link-icons.scss +37 -37
  101. data/frameworks/blueprint/stylesheets/blueprint/_liquid.scss +152 -152
  102. data/frameworks/blueprint/stylesheets/blueprint/_print.scss +86 -86
  103. data/frameworks/blueprint/stylesheets/blueprint/_reset.scss +2 -2
  104. data/frameworks/blueprint/stylesheets/blueprint/_rtl.scss +121 -121
  105. data/frameworks/blueprint/stylesheets/blueprint/_scaffolding.scss +52 -52
  106. data/frameworks/blueprint/stylesheets/blueprint/_typography.scss +90 -90
  107. data/frameworks/blueprint/stylesheets/blueprint/_utilities.scss +37 -37
  108. data/frameworks/blueprint/stylesheets/blueprint/reset/_utilities.scss +83 -83
  109. data/frameworks/blueprint/templates/basic/ie.sass +4 -4
  110. data/frameworks/blueprint/templates/basic/manifest.rb +30 -30
  111. data/frameworks/blueprint/templates/basic/partials/_base.sass +10 -10
  112. data/frameworks/blueprint/templates/basic/print.sass +4 -4
  113. data/frameworks/blueprint/templates/basic/screen.sass +12 -12
  114. data/frameworks/blueprint/templates/buttons/buttons.sass +49 -49
  115. data/frameworks/blueprint/templates/buttons/buttons/cross.png +0 -0
  116. data/frameworks/blueprint/templates/buttons/buttons/key.png +0 -0
  117. data/frameworks/blueprint/templates/buttons/buttons/tick.png +0 -0
  118. data/frameworks/blueprint/templates/buttons/manifest.rb +17 -17
  119. data/frameworks/blueprint/templates/link_icons/link_icons.sass +13 -13
  120. data/frameworks/blueprint/templates/link_icons/manifest.rb +23 -23
  121. data/frameworks/blueprint/templates/project/ie.sass +16 -16
  122. data/frameworks/blueprint/templates/project/manifest.rb +30 -30
  123. data/frameworks/blueprint/templates/project/partials/_base.sass +11 -11
  124. data/frameworks/blueprint/templates/project/print.sass +7 -7
  125. data/frameworks/blueprint/templates/project/screen.sass +46 -46
  126. data/frameworks/blueprint/templates/semantic/ie.sass +16 -16
  127. data/frameworks/blueprint/templates/semantic/manifest.rb +33 -33
  128. data/frameworks/blueprint/templates/semantic/partials/_base.sass +10 -10
  129. data/frameworks/blueprint/templates/semantic/partials/_form.sass +5 -5
  130. data/frameworks/blueprint/templates/semantic/partials/_page.sass +17 -17
  131. data/frameworks/blueprint/templates/semantic/partials/_two_col.sass +38 -38
  132. data/frameworks/blueprint/templates/semantic/print.sass +4 -4
  133. data/frameworks/blueprint/templates/semantic/screen.sass +14 -14
  134. data/frameworks/compass/stylesheets/_compass.scss +3 -3
  135. data/frameworks/compass/stylesheets/_lemonade.scss +37 -37
  136. data/frameworks/compass/stylesheets/compass/_css3.scss +20 -20
  137. data/frameworks/compass/stylesheets/compass/_layout.scss +3 -3
  138. data/frameworks/compass/stylesheets/compass/_reset-legacy.scss +3 -3
  139. data/frameworks/compass/stylesheets/compass/_reset.scss +3 -3
  140. data/frameworks/compass/stylesheets/compass/_support.scss +40 -40
  141. data/frameworks/compass/stylesheets/compass/_typography.scss +4 -4
  142. data/frameworks/compass/stylesheets/compass/_utilities.scss +9 -9
  143. data/frameworks/compass/stylesheets/compass/css3/_appearance.scss +17 -17
  144. data/frameworks/compass/stylesheets/compass/css3/_background-clip.scss +43 -43
  145. data/frameworks/compass/stylesheets/compass/css3/_background-origin.scss +42 -42
  146. data/frameworks/compass/stylesheets/compass/css3/_background-size.scss +26 -26
  147. data/frameworks/compass/stylesheets/compass/css3/_border-radius.scss +130 -130
  148. data/frameworks/compass/stylesheets/compass/css3/_box-shadow.scss +76 -76
  149. data/frameworks/compass/stylesheets/compass/css3/_box-sizing.scss +13 -13
  150. data/frameworks/compass/stylesheets/compass/css3/_box.scss +111 -111
  151. data/frameworks/compass/stylesheets/compass/css3/_columns.scss +156 -156
  152. data/frameworks/compass/stylesheets/compass/css3/_filter.scss +23 -23
  153. data/frameworks/compass/stylesheets/compass/css3/_font-face.scss +48 -48
  154. data/frameworks/compass/stylesheets/compass/css3/_hyphenation.scss +77 -77
  155. data/frameworks/compass/stylesheets/compass/css3/_images.scss +132 -132
  156. data/frameworks/compass/stylesheets/compass/css3/_inline-block.scss +22 -22
  157. data/frameworks/compass/stylesheets/compass/css3/_opacity.scss +19 -19
  158. data/frameworks/compass/stylesheets/compass/css3/_pie.scss +72 -72
  159. data/frameworks/compass/stylesheets/compass/css3/_regions.scss +21 -21
  160. data/frameworks/compass/stylesheets/compass/css3/_shared.scss +38 -38
  161. data/frameworks/compass/stylesheets/compass/css3/_text-shadow.scss +87 -87
  162. data/frameworks/compass/stylesheets/compass/css3/_transform-legacy.scss +87 -87
  163. data/frameworks/compass/stylesheets/compass/css3/_transform.scss +598 -598
  164. data/frameworks/compass/stylesheets/compass/css3/_transition.scss +221 -221
  165. data/frameworks/compass/stylesheets/compass/css3/_user-interface.scss +17 -17
  166. data/frameworks/compass/stylesheets/compass/layout/_grid-background.scss +178 -178
  167. data/frameworks/compass/stylesheets/compass/layout/_sticky-footer.scss +23 -23
  168. data/frameworks/compass/stylesheets/compass/layout/_stretching.scss +23 -23
  169. data/frameworks/compass/stylesheets/compass/reset/_utilities-legacy.scss +135 -135
  170. data/frameworks/compass/stylesheets/compass/reset/_utilities.scss +142 -142
  171. data/frameworks/compass/stylesheets/compass/typography/_links.scss +3 -3
  172. data/frameworks/compass/stylesheets/compass/typography/_lists.scss +4 -4
  173. data/frameworks/compass/stylesheets/compass/typography/_text.scss +4 -4
  174. data/frameworks/compass/stylesheets/compass/typography/_vertical_rhythm.scss +221 -221
  175. data/frameworks/compass/stylesheets/compass/typography/links/_hover-link.scss +5 -5
  176. data/frameworks/compass/stylesheets/compass/typography/links/_link-colors.scss +28 -28
  177. data/frameworks/compass/stylesheets/compass/typography/links/_unstyled-link.scss +7 -7
  178. data/frameworks/compass/stylesheets/compass/typography/lists/_bullets.scss +34 -34
  179. data/frameworks/compass/stylesheets/compass/typography/lists/_horizontal-list.scss +61 -61
  180. data/frameworks/compass/stylesheets/compass/typography/lists/_inline-block-list.scss +50 -50
  181. data/frameworks/compass/stylesheets/compass/typography/lists/_inline-list.scss +44 -44
  182. data/frameworks/compass/stylesheets/compass/typography/text/_ellipsis.scss +25 -25
  183. data/frameworks/compass/stylesheets/compass/typography/text/_force-wrap.scss +12 -12
  184. data/frameworks/compass/stylesheets/compass/typography/text/_nowrap.scss +2 -2
  185. data/frameworks/compass/stylesheets/compass/typography/text/_replacement.scss +68 -68
  186. data/frameworks/compass/stylesheets/compass/utilities/_general.scss +6 -6
  187. data/frameworks/compass/stylesheets/compass/utilities/_links.scss +5 -5
  188. data/frameworks/compass/stylesheets/compass/utilities/_lists.scss +6 -6
  189. data/frameworks/compass/stylesheets/compass/utilities/_print.scss +17 -17
  190. data/frameworks/compass/stylesheets/compass/utilities/_sprites.scss +2 -2
  191. data/frameworks/compass/stylesheets/compass/utilities/_tables.scss +3 -3
  192. data/frameworks/compass/stylesheets/compass/utilities/_text.scss +5 -5
  193. data/frameworks/compass/stylesheets/compass/utilities/color/_contrast.scss +27 -27
  194. data/frameworks/compass/stylesheets/compass/utilities/general/_clearfix.scss +44 -44
  195. data/frameworks/compass/stylesheets/compass/utilities/general/_float.scss +29 -29
  196. data/frameworks/compass/stylesheets/compass/utilities/general/_hacks.scss +46 -46
  197. data/frameworks/compass/stylesheets/compass/utilities/general/_min.scss +16 -16
  198. data/frameworks/compass/stylesheets/compass/utilities/general/_reset.scss +1 -1
  199. data/frameworks/compass/stylesheets/compass/utilities/general/_tabs.scss +1 -1
  200. data/frameworks/compass/stylesheets/compass/utilities/general/_tag-cloud.scss +18 -18
  201. data/frameworks/compass/stylesheets/compass/utilities/links/_hover-link.scss +3 -3
  202. data/frameworks/compass/stylesheets/compass/utilities/links/_link-colors.scss +3 -3
  203. data/frameworks/compass/stylesheets/compass/utilities/links/_unstyled-link.scss +3 -3
  204. data/frameworks/compass/stylesheets/compass/utilities/lists/_bullets.scss +3 -3
  205. data/frameworks/compass/stylesheets/compass/utilities/lists/_horizontal-list.scss +3 -3
  206. data/frameworks/compass/stylesheets/compass/utilities/lists/_inline-block-list.scss +3 -3
  207. data/frameworks/compass/stylesheets/compass/utilities/lists/_inline-list.scss +3 -3
  208. data/frameworks/compass/stylesheets/compass/utilities/sprites/_base.scss +65 -65
  209. data/frameworks/compass/stylesheets/compass/utilities/sprites/_sprite-img.scss +78 -78
  210. data/frameworks/compass/stylesheets/compass/utilities/tables/_alternating-rows-and-columns.scss +22 -22
  211. data/frameworks/compass/stylesheets/compass/utilities/tables/_borders.scss +33 -33
  212. data/frameworks/compass/stylesheets/compass/utilities/tables/_scaffolding.scss +9 -9
  213. data/frameworks/compass/stylesheets/compass/utilities/text/_ellipsis.scss +3 -3
  214. data/frameworks/compass/stylesheets/compass/utilities/text/_nowrap.scss +3 -3
  215. data/frameworks/compass/stylesheets/compass/utilities/text/_replacement.scss +3 -3
  216. data/frameworks/compass/templates/ellipsis/ellipsis.sass +8 -8
  217. data/frameworks/compass/templates/ellipsis/manifest.rb +26 -26
  218. data/frameworks/compass/templates/ellipsis/xml/ellipsis.xml +13 -13
  219. data/frameworks/compass/templates/extension/manifest.rb +26 -26
  220. data/frameworks/compass/templates/extension/stylesheets/main.sass +1 -1
  221. data/frameworks/compass/templates/extension/templates/project/manifest.rb +2 -2
  222. data/frameworks/compass/templates/extension/templates/project/screen.sass +1 -1
  223. data/frameworks/compass/templates/pie/LICENSE +12 -12
  224. data/frameworks/compass/templates/pie/LICENSE-APACHE2.txt +13 -13
  225. data/frameworks/compass/templates/pie/LICENSE-GPL2.txt +277 -277
  226. data/frameworks/compass/templates/pie/PIE.htc +96 -96
  227. data/frameworks/compass/templates/pie/manifest.rb +39 -39
  228. data/frameworks/compass/templates/pie/pie.scss +73 -73
  229. data/frameworks/compass/templates/project/USAGE.markdown +32 -32
  230. data/frameworks/compass/templates/project/ie.sass +6 -6
  231. data/frameworks/compass/templates/project/manifest.rb +3 -3
  232. data/frameworks/compass/templates/project/print.sass +6 -6
  233. data/frameworks/compass/templates/project/screen.sass +7 -7
  234. data/lib/compass.rb +37 -37
  235. data/lib/compass/actions.rb +115 -115
  236. data/lib/compass/app_integration.rb +39 -39
  237. data/lib/compass/app_integration/rails.rb +18 -18
  238. data/lib/compass/app_integration/stand_alone.rb +22 -22
  239. data/lib/compass/app_integration/stand_alone/configuration_defaults.rb +32 -32
  240. data/lib/compass/app_integration/stand_alone/installer.rb +83 -83
  241. data/lib/compass/browser_support.rb +62 -62
  242. data/lib/compass/commands.rb +12 -12
  243. data/lib/compass/commands/base.rb +44 -44
  244. data/lib/compass/commands/clean_project.rb +79 -79
  245. data/lib/compass/commands/create_project.rb +131 -131
  246. data/lib/compass/commands/default.rb +50 -50
  247. data/lib/compass/commands/extension_command.rb +60 -60
  248. data/lib/compass/commands/generate_grid_background.rb +96 -96
  249. data/lib/compass/commands/help.rb +85 -85
  250. data/lib/compass/commands/imports.rb +35 -35
  251. data/lib/compass/commands/installer_command.rb +32 -32
  252. data/lib/compass/commands/interactive.rb +61 -61
  253. data/lib/compass/commands/list_frameworks.rb +38 -38
  254. data/lib/compass/commands/print_version.rb +99 -99
  255. data/lib/compass/commands/project_base.rb +103 -103
  256. data/lib/compass/commands/project_stats.rb +178 -178
  257. data/lib/compass/commands/project_structure.rb +93 -93
  258. data/lib/compass/commands/registry.rb +40 -40
  259. data/lib/compass/commands/sprite.rb +89 -89
  260. data/lib/compass/commands/stamp_pattern.rb +90 -90
  261. data/lib/compass/commands/unpack_extension.rb +120 -120
  262. data/lib/compass/commands/update_project.rb +139 -139
  263. data/lib/compass/commands/validate_project.rb +77 -77
  264. data/lib/compass/commands/watch_project.rb +170 -170
  265. data/lib/compass/commands/write_configuration.rb +125 -125
  266. data/lib/compass/compiler.rb +200 -200
  267. data/lib/compass/configuration.rb +91 -91
  268. data/lib/compass/configuration/adapters.rb +77 -77
  269. data/lib/compass/configuration/comments.rb +59 -59
  270. data/lib/compass/configuration/data.rb +193 -193
  271. data/lib/compass/configuration/defaults.rb +187 -187
  272. data/lib/compass/configuration/file_data.rb +21 -21
  273. data/lib/compass/configuration/helpers.rb +160 -160
  274. data/lib/compass/configuration/inheritance.rb +304 -304
  275. data/lib/compass/configuration/paths.rb +19 -19
  276. data/lib/compass/configuration/serialization.rb +88 -88
  277. data/lib/compass/dependencies.rb +12 -12
  278. data/lib/compass/errors.rb +11 -11
  279. data/lib/compass/exec.rb +23 -23
  280. data/lib/compass/exec/command_option_parser.rb +23 -23
  281. data/lib/compass/exec/global_options_parser.rb +63 -63
  282. data/lib/compass/exec/helpers.rb +21 -21
  283. data/lib/compass/exec/project_options_parser.rb +66 -66
  284. data/lib/compass/exec/sub_command_ui.rb +51 -51
  285. data/lib/compass/exec/switch_ui.rb +179 -179
  286. data/lib/compass/frameworks.rb +133 -133
  287. data/lib/compass/grid_builder.rb +102 -102
  288. data/lib/compass/installers.rb +3 -3
  289. data/lib/compass/installers/bare_installer.rb +58 -58
  290. data/lib/compass/installers/base.rb +187 -187
  291. data/lib/compass/installers/manifest.rb +161 -161
  292. data/lib/compass/installers/manifest_installer.rb +61 -61
  293. data/lib/compass/installers/template_context.rb +43 -43
  294. data/lib/compass/logger.rb +103 -103
  295. data/lib/compass/quick_cache.rb +15 -15
  296. data/lib/compass/rails.rb +2 -2
  297. data/lib/compass/sass_extensions.rb +10 -10
  298. data/lib/compass/sass_extensions/functions.rb +34 -34
  299. data/lib/compass/sass_extensions/functions/colors.rb +67 -67
  300. data/lib/compass/sass_extensions/functions/constants.rb +74 -74
  301. data/lib/compass/sass_extensions/functions/cross_browser_support.rb +70 -70
  302. data/lib/compass/sass_extensions/functions/display.rb +27 -27
  303. data/lib/compass/sass_extensions/functions/enumerate.rb +6 -6
  304. data/lib/compass/sass_extensions/functions/env.rb +5 -5
  305. data/lib/compass/sass_extensions/functions/font_files.rb +41 -41
  306. data/lib/compass/sass_extensions/functions/gradient_support.rb +540 -540
  307. data/lib/compass/sass_extensions/functions/image_size.rb +113 -113
  308. data/lib/compass/sass_extensions/functions/inline_image.rb +64 -64
  309. data/lib/compass/sass_extensions/functions/lists.rb +101 -101
  310. data/lib/compass/sass_extensions/functions/math.rb +63 -63
  311. data/lib/compass/sass_extensions/functions/selectors.rb +63 -63
  312. data/lib/compass/sass_extensions/functions/sprites.rb +218 -218
  313. data/lib/compass/sass_extensions/functions/urls.rb +266 -266
  314. data/lib/compass/sass_extensions/monkey_patches.rb +3 -3
  315. data/lib/compass/sass_extensions/monkey_patches/browser_support.rb +95 -95
  316. data/lib/compass/sass_extensions/monkey_patches/traversal.rb +23 -23
  317. data/lib/compass/sass_extensions/sprites.rb +19 -19
  318. data/lib/compass/sass_extensions/sprites/engines.rb +25 -25
  319. data/lib/compass/sass_extensions/sprites/engines/chunky_png_engine.rb +30 -30
  320. data/lib/compass/sass_extensions/sprites/image.rb +151 -151
  321. data/lib/compass/sass_extensions/sprites/image_methods.rb +31 -31
  322. data/lib/compass/sass_extensions/sprites/image_row.rb +46 -46
  323. data/lib/compass/sass_extensions/sprites/layout_methods.rb +158 -158
  324. data/lib/compass/sass_extensions/sprites/row_fitter.rb +91 -91
  325. data/lib/compass/sass_extensions/sprites/sprite_map.rb +86 -86
  326. data/lib/compass/sass_extensions/sprites/sprite_methods.rb +141 -141
  327. data/lib/compass/sprite_importer.rb +116 -116
  328. data/lib/compass/sprite_importer/binding.rb +10 -10
  329. data/lib/compass/sprite_importer/content.erb +80 -80
  330. data/lib/compass/stats.rb +99 -99
  331. data/lib/compass/test_case.rb +38 -38
  332. data/lib/compass/util.rb +29 -29
  333. data/lib/compass/validator.rb +16 -16
  334. data/lib/compass/version.rb +60 -60
  335. data/test/fixtures/extensions/only_stylesheets/compass_init.rb +1 -1
  336. data/test/fixtures/extensions/only_stylesheets/scss/only_stylesheets/foo.scss +3 -3
  337. data/test/fixtures/fonts/bgrove.base64.txt +1 -1
  338. data/test/fixtures/fonts/bgrove.ttf +0 -0
  339. data/test/fixtures/sprites/public/images/ko/starbg26x27.png +0 -0
  340. data/test/fixtures/stylesheets/blueprint/config.rb +14 -14
  341. data/test/fixtures/stylesheets/blueprint/css/ie.css +76 -76
  342. data/test/fixtures/stylesheets/blueprint/css/print.css +56 -56
  343. data/test/fixtures/stylesheets/blueprint/css/screen.css +815 -815
  344. data/test/fixtures/stylesheets/blueprint/css/single-imports/buttons.css +56 -56
  345. data/test/fixtures/stylesheets/blueprint/css/single-imports/colors.css +80 -80
  346. data/test/fixtures/stylesheets/blueprint/css/single-imports/debug.css +11 -11
  347. data/test/fixtures/stylesheets/blueprint/css/single-imports/fancy-type.css +30 -30
  348. data/test/fixtures/stylesheets/blueprint/css/single-imports/form.css +42 -42
  349. data/test/fixtures/stylesheets/blueprint/css/single-imports/grid.css +435 -435
  350. data/test/fixtures/stylesheets/blueprint/css/single-imports/ie.css +76 -76
  351. data/test/fixtures/stylesheets/blueprint/css/single-imports/interaction.css +46 -46
  352. data/test/fixtures/stylesheets/blueprint/css/single-imports/link-icons.css +40 -40
  353. data/test/fixtures/stylesheets/blueprint/css/single-imports/liquid.css +651 -651
  354. data/test/fixtures/stylesheets/blueprint/css/single-imports/print.css +60 -60
  355. data/test/fixtures/stylesheets/blueprint/css/single-imports/reset-utilities.css +75 -75
  356. data/test/fixtures/stylesheets/blueprint/css/single-imports/reset.css +42 -42
  357. data/test/fixtures/stylesheets/blueprint/css/single-imports/rtl.css +437 -437
  358. data/test/fixtures/stylesheets/blueprint/css/single-imports/scaffolding.css +45 -45
  359. data/test/fixtures/stylesheets/blueprint/css/single-imports/typography.css +146 -146
  360. data/test/fixtures/stylesheets/blueprint/css/single-imports/utilities.css +35 -35
  361. data/test/fixtures/stylesheets/blueprint/sass/ie.sass +3 -3
  362. data/test/fixtures/stylesheets/blueprint/sass/print.sass +3 -3
  363. data/test/fixtures/stylesheets/blueprint/sass/screen.sass +18 -18
  364. data/test/fixtures/stylesheets/blueprint/sass/single-imports/buttons.scss +3 -3
  365. data/test/fixtures/stylesheets/blueprint/sass/single-imports/colors.scss +34 -34
  366. data/test/fixtures/stylesheets/blueprint/sass/single-imports/debug.scss +3 -3
  367. data/test/fixtures/stylesheets/blueprint/sass/single-imports/fancy-type.scss +3 -3
  368. data/test/fixtures/stylesheets/blueprint/sass/single-imports/form.scss +4 -4
  369. data/test/fixtures/stylesheets/blueprint/sass/single-imports/grid.scss +2 -2
  370. data/test/fixtures/stylesheets/blueprint/sass/single-imports/ie.scss +2 -2
  371. data/test/fixtures/stylesheets/blueprint/sass/single-imports/interaction.scss +3 -3
  372. data/test/fixtures/stylesheets/blueprint/sass/single-imports/link-icons.scss +12 -12
  373. data/test/fixtures/stylesheets/blueprint/sass/single-imports/liquid.scss +2 -2
  374. data/test/fixtures/stylesheets/blueprint/sass/single-imports/print.scss +4 -4
  375. data/test/fixtures/stylesheets/blueprint/sass/single-imports/reset-utilities.scss +4 -4
  376. data/test/fixtures/stylesheets/blueprint/sass/single-imports/reset.scss +1 -1
  377. data/test/fixtures/stylesheets/blueprint/sass/single-imports/rtl.scss +2 -2
  378. data/test/fixtures/stylesheets/blueprint/sass/single-imports/scaffolding.scss +5 -5
  379. data/test/fixtures/stylesheets/blueprint/sass/single-imports/typography.scss +3 -3
  380. data/test/fixtures/stylesheets/blueprint/sass/single-imports/utilities.scss +3 -3
  381. data/test/fixtures/stylesheets/busted_image_urls/config.rb +29 -29
  382. data/test/fixtures/stylesheets/busted_image_urls/css/screen.css +9 -9
  383. data/test/fixtures/stylesheets/busted_image_urls/sass/screen.sass +13 -13
  384. data/test/fixtures/stylesheets/compass/config.rb +16 -16
  385. data/test/fixtures/stylesheets/compass/css/background-clip.css +10 -10
  386. data/test/fixtures/stylesheets/compass/css/border_radius.css +14 -14
  387. data/test/fixtures/stylesheets/compass/css/box-sizeing.css +9 -9
  388. data/test/fixtures/stylesheets/compass/css/box.css +103 -103
  389. data/test/fixtures/stylesheets/compass/css/box_shadow.css +14 -14
  390. data/test/fixtures/stylesheets/compass/css/columns.css +161 -161
  391. data/test/fixtures/stylesheets/compass/css/filters.css +29 -29
  392. data/test/fixtures/stylesheets/compass/css/fonts.css +4 -4
  393. data/test/fixtures/stylesheets/compass/css/force-wrap.css +9 -9
  394. data/test/fixtures/stylesheets/compass/css/gradients.css +202 -202
  395. data/test/fixtures/stylesheets/compass/css/grid_background.css +71 -71
  396. data/test/fixtures/stylesheets/compass/css/hyphenation.css +16 -16
  397. data/test/fixtures/stylesheets/compass/css/image_size.css +15 -15
  398. data/test/fixtures/stylesheets/compass/css/images.css +8 -8
  399. data/test/fixtures/stylesheets/compass/css/layout.css +16 -16
  400. data/test/fixtures/stylesheets/compass/css/legacy_clearfix.css +26 -26
  401. data/test/fixtures/stylesheets/compass/css/lists.css +151 -151
  402. data/test/fixtures/stylesheets/compass/css/opacity.css +3 -3
  403. data/test/fixtures/stylesheets/compass/css/pie.css +26 -26
  404. data/test/fixtures/stylesheets/compass/css/print.css +11 -11
  405. data/test/fixtures/stylesheets/compass/css/regions.css +7 -7
  406. data/test/fixtures/stylesheets/compass/css/replacement.css +59 -59
  407. data/test/fixtures/stylesheets/compass/css/reset.css +59 -59
  408. data/test/fixtures/stylesheets/compass/css/sprites.css +1262 -1262
  409. data/test/fixtures/stylesheets/compass/css/stretching.css +66 -66
  410. data/test/fixtures/stylesheets/compass/css/text_shadow.css +29 -29
  411. data/test/fixtures/stylesheets/compass/css/transform.css +441 -441
  412. data/test/fixtures/stylesheets/compass/css/transition.css +128 -128
  413. data/test/fixtures/stylesheets/compass/css/user-interface.css +4 -4
  414. data/test/fixtures/stylesheets/compass/css/utilities.css +56 -56
  415. data/test/fixtures/stylesheets/compass/css/vertical_rhythm.css +45 -45
  416. data/test/fixtures/stylesheets/compass/sass/background-clip.scss +7 -7
  417. data/test/fixtures/stylesheets/compass/sass/border_radius.scss +5 -5
  418. data/test/fixtures/stylesheets/compass/sass/box-sizeing.scss +7 -7
  419. data/test/fixtures/stylesheets/compass/sass/box.sass +49 -49
  420. data/test/fixtures/stylesheets/compass/sass/box_shadow.scss +5 -5
  421. data/test/fixtures/stylesheets/compass/sass/columns.scss +28 -28
  422. data/test/fixtures/stylesheets/compass/sass/filters.scss +24 -24
  423. data/test/fixtures/stylesheets/compass/sass/fonts.sass +2 -2
  424. data/test/fixtures/stylesheets/compass/sass/force-wrap.scss +3 -3
  425. data/test/fixtures/stylesheets/compass/sass/gradients.sass +96 -96
  426. data/test/fixtures/stylesheets/compass/sass/grid_background.scss +33 -33
  427. data/test/fixtures/stylesheets/compass/sass/hyphenation.scss +10 -10
  428. data/test/fixtures/stylesheets/compass/sass/image_size.sass +15 -15
  429. data/test/fixtures/stylesheets/compass/sass/images.scss +8 -8
  430. data/test/fixtures/stylesheets/compass/sass/layout.sass +3 -3
  431. data/test/fixtures/stylesheets/compass/sass/legacy_clearfix.scss +14 -14
  432. data/test/fixtures/stylesheets/compass/sass/lists.scss +11 -11
  433. data/test/fixtures/stylesheets/compass/sass/opacity.scss +5 -5
  434. data/test/fixtures/stylesheets/compass/sass/pie.scss +47 -47
  435. data/test/fixtures/stylesheets/compass/sass/print.sass +5 -5
  436. data/test/fixtures/stylesheets/compass/sass/regions.scss +3 -3
  437. data/test/fixtures/stylesheets/compass/sass/replacement.scss +22 -22
  438. data/test/fixtures/stylesheets/compass/sass/reset.sass +12 -12
  439. data/test/fixtures/stylesheets/compass/sass/sprites.scss +13 -13
  440. data/test/fixtures/stylesheets/compass/sass/stretching.sass +33 -33
  441. data/test/fixtures/stylesheets/compass/sass/text_shadow.scss +11 -11
  442. data/test/fixtures/stylesheets/compass/sass/transform.scss +87 -87
  443. data/test/fixtures/stylesheets/compass/sass/transition.scss +24 -24
  444. data/test/fixtures/stylesheets/compass/sass/user-interface.scss +4 -4
  445. data/test/fixtures/stylesheets/compass/sass/utilities.scss +20 -20
  446. data/test/fixtures/stylesheets/compass/sass/vertical_rhythm.scss +15 -15
  447. data/test/fixtures/stylesheets/envtest/config.rb +9 -9
  448. data/test/fixtures/stylesheets/envtest/css/env.css +2 -2
  449. data/test/fixtures/stylesheets/envtest/sass/env.scss +3 -3
  450. data/test/fixtures/stylesheets/error/config.rb +10 -10
  451. data/test/fixtures/stylesheets/error/sass/screen.sass +2 -2
  452. data/test/fixtures/stylesheets/image_urls/config.rb +19 -19
  453. data/test/fixtures/stylesheets/image_urls/css/screen.css +5 -5
  454. data/test/fixtures/stylesheets/image_urls/sass/screen.sass +8 -8
  455. data/test/fixtures/stylesheets/relative/config.rb +10 -10
  456. data/test/fixtures/stylesheets/relative/css/ie.css +1 -1
  457. data/test/fixtures/stylesheets/relative/css/print.css +1 -1
  458. data/test/fixtures/stylesheets/relative/css/screen.css +1 -1
  459. data/test/fixtures/stylesheets/relative/sass/ie.sass +5 -5
  460. data/test/fixtures/stylesheets/relative/sass/print.sass +3 -3
  461. data/test/fixtures/stylesheets/relative/sass/screen.sass +2 -2
  462. data/test/fixtures/stylesheets/uses_only_stylesheets_ext/config.rb +25 -25
  463. data/test/fixtures/stylesheets/uses_only_stylesheets_ext/sass/ie.scss +5 -5
  464. data/test/fixtures/stylesheets/uses_only_stylesheets_ext/sass/print.scss +3 -3
  465. data/test/fixtures/stylesheets/uses_only_stylesheets_ext/sass/screen.scss +6 -6
  466. data/test/fixtures/stylesheets/uses_only_stylesheets_ext/stylesheets/ie.css +5 -5
  467. data/test/fixtures/stylesheets/uses_only_stylesheets_ext/stylesheets/print.css +3 -3
  468. data/test/fixtures/stylesheets/uses_only_stylesheets_ext/stylesheets/screen.css +68 -68
  469. data/test/fixtures/stylesheets/valid/config.rb +9 -9
  470. data/test/fixtures/stylesheets/valid/sass/simple.sass +1 -1
  471. data/test/helpers/command_line.rb +114 -114
  472. data/test/helpers/diff.rb +48 -48
  473. data/test/helpers/io.rb +36 -36
  474. data/test/helpers/rails.rb +55 -55
  475. data/test/helpers/test_case.rb +62 -62
  476. data/test/integrations/compass_test.rb +224 -224
  477. data/test/integrations/sprites_test.rb +843 -843
  478. data/test/test_helper.rb +73 -73
  479. data/test/units/actions_test.rb +23 -23
  480. data/test/units/command_line_test.rb +60 -60
  481. data/test/units/compass_module_test.rb +36 -36
  482. data/test/units/compass_png_test.rb +45 -45
  483. data/test/units/compiler_test.rb +10 -10
  484. data/test/units/configuration_test.rb +440 -440
  485. data/test/units/regressions_test.rb +35 -35
  486. data/test/units/sass_extensions_test.rb +198 -198
  487. data/test/units/sprites/engine_test.rb +47 -47
  488. data/test/units/sprites/image_row_test.rb +57 -57
  489. data/test/units/sprites/image_test.rb +99 -99
  490. data/test/units/sprites/importer_test.rb +90 -90
  491. data/test/units/sprites/layout_test.rb +154 -154
  492. data/test/units/sprites/row_fitter_test.rb +65 -65
  493. data/test/units/sprites/sprite_command_test.rb +54 -54
  494. data/test/units/sprites/sprite_map_test.rb +130 -130
  495. metadata +1304 -1310
@@ -1,843 +1,843 @@
1
- require 'test_helper'
2
- require 'fileutils'
3
- require 'compass'
4
- require 'compass/logger'
5
- require 'sass/plugin'
6
-
7
-
8
- class SpritesTest < Test::Unit::TestCase
9
-
10
- def setup
11
- Compass.reset_configuration!
12
- @images_src_path = File.join(File.dirname(__FILE__), '..', 'fixtures', 'sprites', 'public', 'images')
13
- @images_tmp_path = File.join(File.dirname(__FILE__), '..', 'fixtures', 'sprites', 'public', 'images-tmp')
14
- @generated_images_tmp_path = File.join(File.dirname(__FILE__), '..', 'fixtures', 'sprites', 'public', 'generated-images-tmp')
15
- ::FileUtils.cp_r @images_src_path, @images_tmp_path
16
- file = StringIO.new("images_path = #{@images_tmp_path.inspect}\n")
17
- Compass.add_configuration(file, "sprite_config")
18
- Compass.configure_sass_plugin!
19
- end
20
-
21
- def teardown
22
- Compass.reset_configuration!
23
- ::FileUtils.rm_r @images_tmp_path
24
- ::FileUtils.rm_rf @generated_images_tmp_path
25
- end
26
-
27
-
28
- def map_location(file)
29
- map_files(file).first
30
- end
31
-
32
- def map_files(glob)
33
- Dir.glob(File.join(@images_tmp_path, glob))
34
- end
35
-
36
- def image_size(file)
37
- open(map_location(file), "rb").read[0x10..0x18].unpack('NN')
38
- end
39
-
40
- def image_md5(file)
41
- md5 = Digest::MD5.new
42
- md5.update IO.read(map_location(file))
43
- md5.hexdigest
44
- end
45
-
46
- def render(scss)
47
- scss = %Q(@import "compass"; #{scss})
48
- options = Compass.sass_engine_options
49
- options[:line_comments] = false
50
- options[:style] = :expanded
51
- options[:syntax] = :scss
52
- options[:compass] ||= {}
53
- options[:compass][:logger] ||= Compass::NullLogger.new
54
- css = Sass::Engine.new(scss, options).render
55
- # reformat to fit result of heredoc:
56
- " #{css.gsub('@charset "UTF-8";', '').gsub(/\n/, "\n ").strip}\n"
57
- end
58
-
59
- def clean(string)
60
- string.gsub("\n", '').gsub(' ', '')
61
- end
62
-
63
- it "should generate sprite classes" do
64
- css = render <<-SCSS
65
- @import "squares/*.png";
66
- @include all-squares-sprites;
67
- SCSS
68
- assert_correct css, <<-CSS
69
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
70
- background: url('/squares-sbbc18e2129.png') no-repeat;
71
- }
72
-
73
- .squares-ten-by-ten {
74
- background-position: 0 0;
75
- }
76
-
77
- .squares-twenty-by-twenty {
78
- background-position: 0 -10px;
79
- }
80
- CSS
81
- assert_equal image_size('squares-s*.png'), [20, 30]
82
- assert_equal image_md5('squares-s*.png'), '7349a0f4e88ea80abddcf6ac2486abe3'
83
- end
84
-
85
- it "should output and serve sprite files using the generated images directory" do
86
- Compass.reset_configuration!
87
- file = StringIO.new(<<-CONFIG)
88
- images_path = #{@images_tmp_path.inspect}
89
- generated_images_path = #{@generated_images_tmp_path.inspect}
90
- http_generated_images_path = "/images/generated"
91
- CONFIG
92
- Compass.add_configuration(file, "sprite_config")
93
- Compass.configure_sass_plugin!
94
- css = render <<-SCSS
95
- @import "squares/*.png";
96
- @include all-squares-sprites;
97
- SCSS
98
- assert_not_nil Dir.glob("#{@generated_images_tmp_path}/squares-s*.png").first
99
- assert_correct <<-CSS, css
100
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
101
- background: url('/images/generated/squares-sbbc18e2129.png') no-repeat;
102
- }
103
-
104
- .squares-ten-by-ten {
105
- background-position: 0 0;
106
- }
107
-
108
- .squares-twenty-by-twenty {
109
- background-position: 0 -10px;
110
- }
111
- CSS
112
- end
113
-
114
- it "should generate sprite classes with dimensions" do
115
- css = render <<-SCSS
116
- $squares-sprite-dimensions: true;
117
- @import "squares/*.png";
118
- @include all-squares-sprites;
119
- SCSS
120
- assert_correct css, <<-CSS
121
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
122
- background: url('/squares-sbbc18e2129.png') no-repeat;
123
- }
124
-
125
- .squares-ten-by-ten {
126
- background-position: 0 0;
127
- height: 10px;
128
- width: 10px;
129
- }
130
-
131
- .squares-twenty-by-twenty {
132
- background-position: 0 -10px;
133
- height: 20px;
134
- width: 20px;
135
- }
136
- CSS
137
- assert_equal image_size('squares-s*.png'), [20, 30]
138
- end
139
-
140
- it "should provide sprite mixin" do
141
- css = render <<-SCSS
142
- @import "squares/*.png";
143
-
144
- .cubicle {
145
- @include squares-sprite("ten-by-ten");
146
- }
147
-
148
- .large-cube {
149
- @include squares-sprite("twenty-by-twenty", true);
150
- }
151
- SCSS
152
- assert_correct css, <<-CSS
153
- .squares-sprite, .cubicle, .large-cube {
154
- background: url('/squares-sbbc18e2129.png') no-repeat;
155
- }
156
-
157
- .cubicle {
158
- background-position: 0 0;
159
- }
160
-
161
- .large-cube {
162
- background-position: 0 -10px;
163
- height: 20px;
164
- width: 20px;
165
- }
166
- CSS
167
- assert_equal image_size('squares-s*.png'), [20, 30]
168
- end
169
-
170
- # CUSTOMIZATIONS:
171
-
172
- it "should be possible to change the base class" do
173
- css = render <<-SCSS
174
- $squares-sprite-base-class: ".circles";
175
- @import "squares/*.png";
176
- SCSS
177
- assert_correct css, <<-CSS
178
- .circles {
179
- background: url('/squares-sbbc18e2129.png') no-repeat;
180
- }
181
- CSS
182
- assert_equal image_size('squares-s*.png'), [20, 30]
183
- end
184
-
185
- it "should calculate the spacing between images but not before first image" do
186
- css = render <<-SCSS
187
- $squares-ten-by-ten-spacing: 33px;
188
- @import "squares/*.png";
189
- @include all-squares-sprites;
190
- SCSS
191
- assert_correct css, <<-CSS
192
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
193
- background: url('/squares-s563a5e0855.png') no-repeat;
194
- }
195
-
196
- .squares-ten-by-ten {
197
- background-position: 0 0;
198
- }
199
-
200
- .squares-twenty-by-twenty {
201
- background-position: 0 -43px;
202
- }
203
- CSS
204
- assert_equal image_size('squares-s*.png'), [20, 63]
205
- end
206
-
207
- it "should calculate the spacing between images" do
208
- css = render <<-SCSS
209
- $squares-twenty-by-twenty-spacing: 33px;
210
- @import "squares/*.png";
211
- @include all-squares-sprites;
212
- SCSS
213
- assert_correct css, <<-CSS
214
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
215
- background: url('/squares-s4ea353fa6d.png') no-repeat;
216
- }
217
-
218
- .squares-ten-by-ten {
219
- background-position: 0 0;
220
- }
221
-
222
- .squares-twenty-by-twenty {
223
- background-position: 0 -43px;
224
- }
225
- CSS
226
- assert_equal image_size('squares-s*.png'), [20, 63]
227
- end
228
-
229
- it "should calculate the maximum spacing between images" do
230
- css = render <<-SCSS
231
- $squares-ten-by-ten-spacing: 44px;
232
- $squares-twenty-by-twenty-spacing: 33px;
233
- @import "squares/*.png";
234
- @include all-squares-sprites;
235
- SCSS
236
- assert_correct css, <<-CSS
237
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
238
- background: url('/squares-sf4771cb124.png') no-repeat;
239
- }
240
-
241
- .squares-ten-by-ten {
242
- background-position: 0 0;
243
- }
244
-
245
- .squares-twenty-by-twenty {
246
- background-position: 0 -54px;
247
- }
248
- CSS
249
- assert_equal image_size('squares-s*.png'), [20, 74]
250
- end
251
-
252
- it "should calculate the maximum spacing between images in reversed order" do
253
- css = render <<-SCSS
254
- $squares-ten-by-ten-spacing: 33px;
255
- $squares-twenty-by-twenty-spacing: 44px;
256
- @import "squares/*.png";
257
- @include all-squares-sprites;
258
- SCSS
259
- assert_correct css, <<-CSS
260
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
261
- background: url('/squares-sc82d6f3cf4.png') no-repeat;
262
- }
263
-
264
- .squares-ten-by-ten {
265
- background-position: 0 0;
266
- }
267
-
268
- .squares-twenty-by-twenty {
269
- background-position: 0 -54px;
270
- }
271
- CSS
272
- assert_equal image_size('squares-s*.png'), [20, 74]
273
- end
274
-
275
- it "should calculate the default spacing between images" do
276
- css = render <<-SCSS
277
- $squares-spacing: 22px;
278
- @import "squares/*.png";
279
- @include all-squares-sprites;
280
- SCSS
281
- assert_correct css, <<-CSS
282
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
283
- background: url('/squares-s2f4aa65dcf.png') no-repeat;
284
- }
285
-
286
- .squares-ten-by-ten {
287
- background-position: 0 0;
288
- }
289
-
290
- .squares-twenty-by-twenty {
291
- background-position: 0 -32px;
292
- }
293
- CSS
294
- assert_equal image_size('squares-s*.png'), [20, 52]
295
- end
296
-
297
- it "should use position adjustments in functions" do
298
- css = render <<-SCSS
299
- $squares: sprite-map("squares/*.png", $position: 100%);
300
- .squares-sprite {
301
- background: $squares no-repeat;
302
- }
303
-
304
- .adjusted-percentage {
305
- background-position: sprite-position($squares, ten-by-ten, 100%);
306
- }
307
-
308
- .adjusted-px-1 {
309
- background-position: sprite-position($squares, ten-by-ten, 4px);
310
- }
311
-
312
- .adjusted-px-2 {
313
- background-position: sprite-position($squares, twenty-by-twenty, -3px, 2px);
314
- }
315
- SCSS
316
- assert_correct css, <<-CSS
317
- .squares-sprite {
318
- background: url('/squares-sce5dc30797.png') no-repeat;
319
- }
320
-
321
- .adjusted-percentage {
322
- background-position: 100% 0;
323
- }
324
-
325
- .adjusted-px-1 {
326
- background-position: -6px 0;
327
- }
328
-
329
- .adjusted-px-2 {
330
- background-position: -3px -8px;
331
- }
332
- CSS
333
- assert_equal image_size('squares-s*.png'), [20, 30]
334
- assert_equal image_md5('squares-s*.png'), '9cc7ce48cfaf304381c2d08adefd2fb6'
335
- end
336
-
337
- it "should use position adjustments in mixins" do
338
- css = render <<-SCSS
339
- $squares-position: 100%;
340
- @import "squares/*.png";
341
-
342
- .adjusted-percentage {
343
- @include squares-sprite("ten-by-ten", $offset-x: 100%);
344
- }
345
-
346
- .adjusted-px-1 {
347
- @include squares-sprite("ten-by-ten", $offset-x: 4px);
348
- }
349
-
350
- .adjusted-px-2 {
351
- @include squares-sprite("twenty-by-twenty", $offset-x: -3px, $offset-y: 2px);
352
- }
353
- SCSS
354
- assert_correct css, <<-CSS
355
- .squares-sprite, .adjusted-percentage, .adjusted-px-1, .adjusted-px-2 {
356
- background: url('/squares-sce5dc30797.png') no-repeat;
357
- }
358
-
359
- .adjusted-percentage {
360
- background-position: 100% 0;
361
- }
362
-
363
- .adjusted-px-1 {
364
- background-position: -6px 0;
365
- }
366
-
367
- .adjusted-px-2 {
368
- background-position: -3px -8px;
369
- }
370
- CSS
371
- assert_equal image_size('squares-s*.png'), [20, 30]
372
- assert_equal image_md5('squares-s*.png'), '9cc7ce48cfaf304381c2d08adefd2fb6'
373
- end
374
-
375
- it "should repeat the image" do
376
- css = render <<-SCSS
377
- $squares-repeat: repeat-x;
378
- @import "squares/*.png";
379
- @include all-squares-sprites;
380
- SCSS
381
- assert_correct css, <<-CSS
382
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
383
- background: url('/squares-s65c43cd573.png') no-repeat;
384
- }
385
-
386
- .squares-ten-by-ten {
387
- background-position: 0 0;
388
- }
389
-
390
- .squares-twenty-by-twenty {
391
- background-position: 0 -10px;
392
- }
393
- CSS
394
- assert_equal image_size('squares-s*.png'), [20, 30]
395
- assert_equal image_md5('squares-s*.png'), 'a77a2fd43f04d791722b706aa7c9f1c1'
396
- end
397
-
398
- it "should allow the position of a sprite to be specified in absolute pixels" do
399
- css = render <<-SCSS
400
- $squares-ten-by-ten-position: 10px;
401
- $squares-twenty-by-twenty-position: 10px;
402
- @import "squares/*.png";
403
- @include all-squares-sprites;
404
- SCSS
405
- assert_correct css, <<-CSS
406
- .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
407
- background: url('/squares-sb9d9a8ca6a.png') no-repeat;
408
- }
409
-
410
- .squares-ten-by-ten {
411
- background-position: -10px 0;
412
- }
413
-
414
- .squares-twenty-by-twenty {
415
- background-position: -10px -10px;
416
- }
417
- CSS
418
- assert_equal image_size('squares-s*.png'), [30, 30]
419
- assert_equal image_md5('squares-s*.png'), '9856ced9e8211b6b28ff782019a0d905'
420
- end
421
-
422
- it "should provide a nice errors for lemonade's old users" do
423
- assert_raise(Sass::SyntaxError) do
424
- render <<-SCSS
425
- .squares {
426
- background: sprite-url("squares/*.png") no-repeat;
427
- }
428
- SCSS
429
- end
430
- assert_raise(Sass::SyntaxError) do
431
- css = render <<-SCSS
432
- .squares {
433
- background: sprite-image("squares/twenty-by-twenty.png") no-repeat;
434
- }
435
- SCSS
436
- end
437
- assert_raise(Sass::SyntaxError) do
438
- css = render <<-SCSS
439
- @import "squares/*.png";
440
-
441
- .squares {
442
- background: sprite-position("squares/twenty-by-twenty.png") no-repeat;
443
- }
444
- SCSS
445
- end
446
- end
447
-
448
- it "should work even if @import is missing" do
449
- css = render <<-SCSS
450
- .squares {
451
- background: sprite(sprite-map("squares/*.png"), twenty-by-twenty) no-repeat;
452
- }
453
- SCSS
454
- assert_correct css, <<-CSS
455
- .squares {
456
- background: url('/squares-sd817b59156.png') 0 -10px no-repeat;
457
- }
458
- CSS
459
- end
460
-
461
- it "should calculate corret sprite demsions when givin spacing via issue#253" do
462
- css = render <<-SCSS
463
- $squares-spacing: 10px;
464
- @import "squares/*.png";
465
- .foo {
466
- @include sprite-background-position($squares-sprites, "twenty-by-twenty");
467
- }
468
- .bar {
469
- @include sprite-background-position($squares-sprites, "ten-by-ten");
470
- }
471
- SCSS
472
- assert_equal image_size('squares-s*.png'), [20, 40]
473
- assert_correct css, <<-CSS
474
- .squares-sprite {
475
- background: url('/squares-s555875d730.png') no-repeat;
476
- }
477
-
478
- .foo {
479
- background-position: 0 -20px;
480
- }
481
-
482
- .bar {
483
- background-position: 0 0;
484
- }
485
- CSS
486
- end
487
-
488
- it "should render correct sprite with css selectors via issue#248" do
489
- css = render <<-SCSS
490
- @import "selectors/*.png";
491
- @include all-selectors-sprites;
492
- SCSS
493
- assert_correct css, <<-CSS
494
- .selectors-sprite, .selectors-ten-by-ten {
495
- background: url('/selectors-s7e84acb3d2.png') no-repeat;
496
- }
497
-
498
- .selectors-ten-by-ten {
499
- background-position: 0 0;
500
- }
501
- .selectors-ten-by-ten:hover, .selectors-ten-by-ten.ten-by-ten_hover, .selectors-ten-by-ten.ten-by-ten-hover {
502
- background-position: 0 -20px;
503
- }
504
- .selectors-ten-by-ten:target, .selectors-ten-by-ten.ten-by-ten_target, .selectors-ten-by-ten.ten-by-ten-target {
505
- background-position: 0 -30px;
506
- }
507
- .selectors-ten-by-ten:active, .selectors-ten-by-ten.ten-by-ten_active, .selectors-ten-by-ten.ten-by-ten-active {
508
- background-position: 0 -10px;
509
- }
510
- CSS
511
- end
512
-
513
- it "should honor offsets when rendering selectors via issue#449" do
514
- css = render <<-SCSS
515
- @import "selectors/*.png";
516
- @include all-selectors-sprites($offset-x: 20px, $offset-y: 20px);
517
- SCSS
518
- assert_correct css, <<-CSS
519
- .selectors-sprite, .selectors-ten-by-ten {
520
- background: url('/selectors-s7e84acb3d2.png') no-repeat;
521
- }
522
-
523
- .selectors-ten-by-ten {
524
- background-position: 20px 20px;
525
- }
526
- .selectors-ten-by-ten:hover, .selectors-ten-by-ten.ten-by-ten_hover, .selectors-ten-by-ten.ten-by-ten-hover {
527
- background-position: 20px 0;
528
- }
529
- .selectors-ten-by-ten:target, .selectors-ten-by-ten.ten-by-ten_target, .selectors-ten-by-ten.ten-by-ten-target {
530
- background-position: 20px -10px;
531
- }
532
- .selectors-ten-by-ten:active, .selectors-ten-by-ten.ten-by-ten_active, .selectors-ten-by-ten.ten-by-ten-active {
533
- background-position: 20px 10px;
534
- }
535
- CSS
536
- end
537
-
538
- it "should render correct sprite with css selectors via magic mixin" do
539
- css = render <<-SCSS
540
- @import "selectors/*.png";
541
- a {
542
- @include selectors-sprite(ten-by-ten)
543
- }
544
- SCSS
545
- assert_correct css, <<-CSS
546
- .selectors-sprite, a {
547
- background: url('/selectors-s7e84acb3d2.png') no-repeat;
548
- }
549
-
550
- a {
551
- background-position: 0 0;
552
- }
553
- a:hover, a.ten-by-ten_hover, a.ten-by-ten-hover {
554
- background-position: 0 -20px;
555
- }
556
- a:target, a.ten-by-ten_target, a.ten-by-ten-target {
557
- background-position: 0 -30px;
558
- }
559
- a:active, a.ten-by-ten_active, a.ten-by-ten-active {
560
- background-position: 0 -10px;
561
- }
562
- CSS
563
- end
564
-
565
-
566
- it "should not render corret sprite with css selectors via magic mixin" do
567
- css = render <<-SCSS
568
- @import "selectors/*.png";
569
- a {
570
- $disable-magic-sprite-selectors:true;
571
- @include selectors-sprite(ten-by-ten)
572
- }
573
- SCSS
574
- assert_correct css, <<-CSS
575
- .selectors-sprite, a {
576
- background: url('/selectors-s7e84acb3d2.png') no-repeat;
577
- }
578
-
579
- a {
580
- background-position: 0 0;
581
- }
582
- CSS
583
- end
584
-
585
- it "should render corret sprite with css selectors via magic mixin with the correct offsets" do
586
- css = render <<-SCSS
587
- @import "selectors/*.png";
588
- a {
589
- @include selectors-sprite(ten-by-ten, false, 5, -5)
590
- }
591
- SCSS
592
- assert_correct css, <<-CSS
593
- .selectors-sprite, a {
594
- background: url('/selectors-s7e84acb3d2.png') no-repeat;
595
- }
596
-
597
- a {
598
- background-position: 5px -5px;
599
- }
600
- a:hover, a.ten-by-ten_hover, a.ten-by-ten-hover {
601
- background-position: 5px -25px;
602
- }
603
- a:target, a.ten-by-ten_target, a.ten-by-ten-target {
604
- background-position: 5px -35px;
605
- }
606
- a:active, a.ten-by-ten_active, a.ten-by-ten-active {
607
- background-position: 5px -15px;
608
- }
609
- CSS
610
- end
611
-
612
- it "should raise error on filenames that are not valid sass syntax" do
613
- assert_raise(Compass::Error) do
614
- css = render <<-SCSS
615
- @import "prefix/*.png";
616
- a {
617
- @include squares-sprite(20-by-20);
618
- }
619
- SCSS
620
- end
621
- end
622
-
623
- it "should generate sprite with bad repeat-x dimensions" do
624
- css = render <<-SCSS
625
- $ko-starbg26x27-repeat: repeat-x;
626
- @import "ko/*.png";
627
- @include all-ko-sprites;
628
- SCSS
629
- assert_correct css, <<-CSS
630
- .ko-sprite, .ko-default_background, .ko-starbg26x27 {
631
- background: url('/ko-sd46dfbab4f.png') no-repeat;
632
- }
633
-
634
- .ko-default_background {
635
- background-position: 0 0;
636
- }
637
-
638
- .ko-starbg26x27 {
639
- background-position: 0 -128px;
640
- }
641
- CSS
642
- end
643
-
644
- it "should generate a sprite and remove the old file" do
645
- FileUtils.touch File.join(@images_tmp_path, "selectors-scc8834Fdd.png")
646
- assert_equal 1, map_files('selectors-s*.png').size
647
- css = render <<-SCSS
648
- @import "selectors/*.png";
649
- a {
650
- $disable-magic-sprite-selectors:true;
651
- @include selectors-sprite(ten-by-ten)
652
- }
653
- SCSS
654
- assert_equal 1, map_files('selectors-s*.png').size, "File was not removed"
655
- end
656
-
657
- it "should generate a sprite and NOT remove the old file" do
658
- FileUtils.touch File.join(@images_tmp_path, "selectors-scc8834Ftest.png")
659
- assert_equal 1, map_files('selectors-s*.png').size
660
- css = render <<-SCSS
661
- $selectors-clean-up: false;
662
- @import "selectors/*.png";
663
- a {
664
- $disable-magic-sprite-selectors:true;
665
- @include selectors-sprite(ten-by-ten)
666
- }
667
- SCSS
668
- assert_equal 2, map_files('selectors-s*.png').size, "File was removed"
669
- end
670
-
671
- it "should generate a sprite if the sprite is a bool" do
672
- css = render <<-SCSS
673
- @import "bool/*.png";
674
- a {
675
- @include bool-sprite(false);
676
- }
677
- a {
678
- @include bool-sprite(true);
679
- }
680
- SCSS
681
- assert !css.empty?
682
- end
683
-
684
-
685
- it "should generate a sprite if the sprite is a colorname" do
686
- css = render <<-SCSS
687
- @import "colors/*.png";
688
- a {
689
- @include colors-sprite(blue);
690
- }
691
- SCSS
692
- assert !css.empty?
693
- end
694
-
695
- it "should generate a sprite from nested folders" do
696
- css = render <<-SCSS
697
- @import "nested/**/*.png";
698
- @include all-nested-sprites;
699
- SCSS
700
- assert_correct css, <<-CSS
701
- .nested-sprite, .nested-ten-by-ten {
702
- background: url('/nested-s7b93e0b6bf.png') no-repeat;
703
- }
704
-
705
- .nested-ten-by-ten {
706
- background-position: 0 0;
707
- }
708
- CSS
709
- end
710
-
711
- it "should create horizontal sprite" do
712
- css = render <<-SCSS
713
- $squares-layout:horizontal;
714
- @import "squares/*.png";
715
- .foo {
716
- @include sprite-background-position($squares-sprites, "twenty-by-twenty");
717
- }
718
- .bar {
719
- @include sprite-background-position($squares-sprites, "ten-by-ten");
720
- }
721
- SCSS
722
- assert_equal [30, 20], image_size('squares-s*.png')
723
- other_css = <<-CSS
724
- .squares-sprite {
725
- background: url('/squares-s4bd95c5c56.png') no-repeat;
726
- }
727
-
728
- .foo {
729
- background-position: -10px 0;
730
- }
731
-
732
- .bar {
733
- background-position: 0 0;
734
- }
735
- CSS
736
- assert_correct clean(css), clean(other_css)
737
- end
738
-
739
- it "should allow use of demension functions" do
740
- css = render <<-SCSS
741
- @import "squares/*.png";
742
- $h: squares-sprite-height(twenty-by-twenty);
743
- $w: squares-sprite-width(twenty-by-twenty);
744
- .div {
745
- height:$h + 1px;
746
- width:$w + 2px;
747
- }
748
- SCSS
749
- other_css = <<-CSS
750
- .squares-sprite {
751
- background: url('/squares-sbbc18e2129.png') no-repeat;
752
- }
753
- .div {
754
- height:21px;
755
- width:22px;
756
- }
757
- CSS
758
- assert_correct clean(css), clean(other_css)
759
- end
760
-
761
- it "should replace text with images and dimensions using sprites" do
762
- css = render <<-SCSS
763
- @import "colors/*.png";
764
- .blue {
765
- @include sprite-replace-text($colors-sprites, blue);
766
- }
767
- .yellow {
768
- @include sprite-replace-text-with-dimensions($colors-sprites, yellow);
769
- }
770
- SCSS
771
- other_css = <<-CSS
772
- .colors-sprite {
773
- background:url('/colors-s58671cb5bb.png') no-repeat;
774
- }
775
- .blue {
776
- text-indent:-119988px;
777
- overflow:hidden;
778
- text-align:left;
779
- background-position:0 0;
780
- background-image:url('/colors-s58671cb5bb.png');
781
- background-repeat:no-repeat;
782
- }
783
-
784
- .yellow {
785
- text-indent:-119988px;
786
- overflow:hidden;
787
- text-align:left;
788
- background-position:0 -10px;
789
- height:10px;
790
- width:10px;
791
- background-image:url('/colors-s58671cb5bb.png');
792
- background-repeat:no-repeat;
793
- }
794
- CSS
795
- assert_correct clean(css), clean(other_css)
796
- end
797
-
798
- it "should inline the sprite file" do
799
- css = render <<-SCSS
800
- $colors-inline:true;
801
- @import "colors/*.png";
802
- @include all-colors-sprites;
803
- SCSS
804
- other_css = <<-CSS
805
- .colors-sprite, .colors-blue, .colors-yellow {
806
- background-image:url('');
807
- }
808
- .colors-blue {
809
- background-position:0 0;
810
- }
811
- .colors-yellow {
812
- background-position:0 -10px;
813
- }
814
- CSS
815
- assert_correct clean(css), clean(other_css)
816
- end
817
-
818
- it "should have a sprite_name function that returns the names of the sprites in a sass list" do
819
- css = render <<-SCSS
820
- $colors-inline:true;
821
- @import "colors/*.png";
822
- @each $color in sprite_names($colors-sprites) {
823
- .\#{$color} {
824
- width:0px;
825
- }
826
- }
827
- SCSS
828
- other_css = <<-CSS
829
- .colors-sprite {
830
- background-image:url('');
831
- }
832
- .blue {
833
- width:0px;
834
- }
835
- .yellow {
836
- width:0px;
837
- }
838
- CSS
839
- assert_correct clean(css), clean(other_css)
840
-
841
- end
842
-
843
- end
1
+ require 'test_helper'
2
+ require 'fileutils'
3
+ require 'compass'
4
+ require 'compass/logger'
5
+ require 'sass/plugin'
6
+
7
+
8
+ class SpritesTest < Test::Unit::TestCase
9
+
10
+ def setup
11
+ Compass.reset_configuration!
12
+ @images_src_path = File.join(File.dirname(__FILE__), '..', 'fixtures', 'sprites', 'public', 'images')
13
+ @images_tmp_path = File.join(File.dirname(__FILE__), '..', 'fixtures', 'sprites', 'public', 'images-tmp')
14
+ @generated_images_tmp_path = File.join(File.dirname(__FILE__), '..', 'fixtures', 'sprites', 'public', 'generated-images-tmp')
15
+ ::FileUtils.cp_r @images_src_path, @images_tmp_path
16
+ file = StringIO.new("images_path = #{@images_tmp_path.inspect}\n")
17
+ Compass.add_configuration(file, "sprite_config")
18
+ Compass.configure_sass_plugin!
19
+ end
20
+
21
+ def teardown
22
+ Compass.reset_configuration!
23
+ ::FileUtils.rm_r @images_tmp_path
24
+ ::FileUtils.rm_rf @generated_images_tmp_path
25
+ end
26
+
27
+
28
+ def map_location(file)
29
+ map_files(file).first
30
+ end
31
+
32
+ def map_files(glob)
33
+ Dir.glob(File.join(@images_tmp_path, glob))
34
+ end
35
+
36
+ def image_size(file)
37
+ open(map_location(file), "rb").read[0x10..0x18].unpack('NN')
38
+ end
39
+
40
+ def image_md5(file)
41
+ md5 = Digest::MD5.new
42
+ md5.update IO.read(map_location(file))
43
+ md5.hexdigest
44
+ end
45
+
46
+ def render(scss)
47
+ scss = %Q(@import "compass"; #{scss})
48
+ options = Compass.sass_engine_options
49
+ options[:line_comments] = false
50
+ options[:style] = :expanded
51
+ options[:syntax] = :scss
52
+ options[:compass] ||= {}
53
+ options[:compass][:logger] ||= Compass::NullLogger.new
54
+ css = Sass::Engine.new(scss, options).render
55
+ # reformat to fit result of heredoc:
56
+ " #{css.gsub('@charset "UTF-8";', '').gsub(/\n/, "\n ").strip}\n"
57
+ end
58
+
59
+ def clean(string)
60
+ string.gsub("\n", '').gsub(' ', '')
61
+ end
62
+
63
+ it "should generate sprite classes" do
64
+ css = render <<-SCSS
65
+ @import "squares/*.png";
66
+ @include all-squares-sprites;
67
+ SCSS
68
+ assert_correct css, <<-CSS
69
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
70
+ background: url('/squares-sbbc18e2129.png') no-repeat;
71
+ }
72
+
73
+ .squares-ten-by-ten {
74
+ background-position: 0 0;
75
+ }
76
+
77
+ .squares-twenty-by-twenty {
78
+ background-position: 0 -10px;
79
+ }
80
+ CSS
81
+ assert_equal image_size('squares-s*.png'), [20, 30]
82
+ assert_equal image_md5('squares-s*.png'), '7349a0f4e88ea80abddcf6ac2486abe3'
83
+ end
84
+
85
+ it "should output and serve sprite files using the generated images directory" do
86
+ Compass.reset_configuration!
87
+ file = StringIO.new(<<-CONFIG)
88
+ images_path = #{@images_tmp_path.inspect}
89
+ generated_images_path = #{@generated_images_tmp_path.inspect}
90
+ http_generated_images_path = "/images/generated"
91
+ CONFIG
92
+ Compass.add_configuration(file, "sprite_config")
93
+ Compass.configure_sass_plugin!
94
+ css = render <<-SCSS
95
+ @import "squares/*.png";
96
+ @include all-squares-sprites;
97
+ SCSS
98
+ assert_not_nil Dir.glob("#{@generated_images_tmp_path}/squares-s*.png").first
99
+ assert_correct <<-CSS, css
100
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
101
+ background: url('/images/generated/squares-sbbc18e2129.png') no-repeat;
102
+ }
103
+
104
+ .squares-ten-by-ten {
105
+ background-position: 0 0;
106
+ }
107
+
108
+ .squares-twenty-by-twenty {
109
+ background-position: 0 -10px;
110
+ }
111
+ CSS
112
+ end
113
+
114
+ it "should generate sprite classes with dimensions" do
115
+ css = render <<-SCSS
116
+ $squares-sprite-dimensions: true;
117
+ @import "squares/*.png";
118
+ @include all-squares-sprites;
119
+ SCSS
120
+ assert_correct css, <<-CSS
121
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
122
+ background: url('/squares-sbbc18e2129.png') no-repeat;
123
+ }
124
+
125
+ .squares-ten-by-ten {
126
+ background-position: 0 0;
127
+ height: 10px;
128
+ width: 10px;
129
+ }
130
+
131
+ .squares-twenty-by-twenty {
132
+ background-position: 0 -10px;
133
+ height: 20px;
134
+ width: 20px;
135
+ }
136
+ CSS
137
+ assert_equal image_size('squares-s*.png'), [20, 30]
138
+ end
139
+
140
+ it "should provide sprite mixin" do
141
+ css = render <<-SCSS
142
+ @import "squares/*.png";
143
+
144
+ .cubicle {
145
+ @include squares-sprite("ten-by-ten");
146
+ }
147
+
148
+ .large-cube {
149
+ @include squares-sprite("twenty-by-twenty", true);
150
+ }
151
+ SCSS
152
+ assert_correct css, <<-CSS
153
+ .squares-sprite, .cubicle, .large-cube {
154
+ background: url('/squares-sbbc18e2129.png') no-repeat;
155
+ }
156
+
157
+ .cubicle {
158
+ background-position: 0 0;
159
+ }
160
+
161
+ .large-cube {
162
+ background-position: 0 -10px;
163
+ height: 20px;
164
+ width: 20px;
165
+ }
166
+ CSS
167
+ assert_equal image_size('squares-s*.png'), [20, 30]
168
+ end
169
+
170
+ # CUSTOMIZATIONS:
171
+
172
+ it "should be possible to change the base class" do
173
+ css = render <<-SCSS
174
+ $squares-sprite-base-class: ".circles";
175
+ @import "squares/*.png";
176
+ SCSS
177
+ assert_correct css, <<-CSS
178
+ .circles {
179
+ background: url('/squares-sbbc18e2129.png') no-repeat;
180
+ }
181
+ CSS
182
+ assert_equal image_size('squares-s*.png'), [20, 30]
183
+ end
184
+
185
+ it "should calculate the spacing between images but not before first image" do
186
+ css = render <<-SCSS
187
+ $squares-ten-by-ten-spacing: 33px;
188
+ @import "squares/*.png";
189
+ @include all-squares-sprites;
190
+ SCSS
191
+ assert_correct css, <<-CSS
192
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
193
+ background: url('/squares-s563a5e0855.png') no-repeat;
194
+ }
195
+
196
+ .squares-ten-by-ten {
197
+ background-position: 0 0;
198
+ }
199
+
200
+ .squares-twenty-by-twenty {
201
+ background-position: 0 -43px;
202
+ }
203
+ CSS
204
+ assert_equal image_size('squares-s*.png'), [20, 63]
205
+ end
206
+
207
+ it "should calculate the spacing between images" do
208
+ css = render <<-SCSS
209
+ $squares-twenty-by-twenty-spacing: 33px;
210
+ @import "squares/*.png";
211
+ @include all-squares-sprites;
212
+ SCSS
213
+ assert_correct css, <<-CSS
214
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
215
+ background: url('/squares-s4ea353fa6d.png') no-repeat;
216
+ }
217
+
218
+ .squares-ten-by-ten {
219
+ background-position: 0 0;
220
+ }
221
+
222
+ .squares-twenty-by-twenty {
223
+ background-position: 0 -43px;
224
+ }
225
+ CSS
226
+ assert_equal image_size('squares-s*.png'), [20, 63]
227
+ end
228
+
229
+ it "should calculate the maximum spacing between images" do
230
+ css = render <<-SCSS
231
+ $squares-ten-by-ten-spacing: 44px;
232
+ $squares-twenty-by-twenty-spacing: 33px;
233
+ @import "squares/*.png";
234
+ @include all-squares-sprites;
235
+ SCSS
236
+ assert_correct css, <<-CSS
237
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
238
+ background: url('/squares-sf4771cb124.png') no-repeat;
239
+ }
240
+
241
+ .squares-ten-by-ten {
242
+ background-position: 0 0;
243
+ }
244
+
245
+ .squares-twenty-by-twenty {
246
+ background-position: 0 -54px;
247
+ }
248
+ CSS
249
+ assert_equal image_size('squares-s*.png'), [20, 74]
250
+ end
251
+
252
+ it "should calculate the maximum spacing between images in reversed order" do
253
+ css = render <<-SCSS
254
+ $squares-ten-by-ten-spacing: 33px;
255
+ $squares-twenty-by-twenty-spacing: 44px;
256
+ @import "squares/*.png";
257
+ @include all-squares-sprites;
258
+ SCSS
259
+ assert_correct css, <<-CSS
260
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
261
+ background: url('/squares-sc82d6f3cf4.png') no-repeat;
262
+ }
263
+
264
+ .squares-ten-by-ten {
265
+ background-position: 0 0;
266
+ }
267
+
268
+ .squares-twenty-by-twenty {
269
+ background-position: 0 -54px;
270
+ }
271
+ CSS
272
+ assert_equal image_size('squares-s*.png'), [20, 74]
273
+ end
274
+
275
+ it "should calculate the default spacing between images" do
276
+ css = render <<-SCSS
277
+ $squares-spacing: 22px;
278
+ @import "squares/*.png";
279
+ @include all-squares-sprites;
280
+ SCSS
281
+ assert_correct css, <<-CSS
282
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
283
+ background: url('/squares-s2f4aa65dcf.png') no-repeat;
284
+ }
285
+
286
+ .squares-ten-by-ten {
287
+ background-position: 0 0;
288
+ }
289
+
290
+ .squares-twenty-by-twenty {
291
+ background-position: 0 -32px;
292
+ }
293
+ CSS
294
+ assert_equal image_size('squares-s*.png'), [20, 52]
295
+ end
296
+
297
+ it "should use position adjustments in functions" do
298
+ css = render <<-SCSS
299
+ $squares: sprite-map("squares/*.png", $position: 100%);
300
+ .squares-sprite {
301
+ background: $squares no-repeat;
302
+ }
303
+
304
+ .adjusted-percentage {
305
+ background-position: sprite-position($squares, ten-by-ten, 100%);
306
+ }
307
+
308
+ .adjusted-px-1 {
309
+ background-position: sprite-position($squares, ten-by-ten, 4px);
310
+ }
311
+
312
+ .adjusted-px-2 {
313
+ background-position: sprite-position($squares, twenty-by-twenty, -3px, 2px);
314
+ }
315
+ SCSS
316
+ assert_correct css, <<-CSS
317
+ .squares-sprite {
318
+ background: url('/squares-sce5dc30797.png') no-repeat;
319
+ }
320
+
321
+ .adjusted-percentage {
322
+ background-position: 100% 0;
323
+ }
324
+
325
+ .adjusted-px-1 {
326
+ background-position: -6px 0;
327
+ }
328
+
329
+ .adjusted-px-2 {
330
+ background-position: -3px -8px;
331
+ }
332
+ CSS
333
+ assert_equal image_size('squares-s*.png'), [20, 30]
334
+ assert_equal image_md5('squares-s*.png'), '9cc7ce48cfaf304381c2d08adefd2fb6'
335
+ end
336
+
337
+ it "should use position adjustments in mixins" do
338
+ css = render <<-SCSS
339
+ $squares-position: 100%;
340
+ @import "squares/*.png";
341
+
342
+ .adjusted-percentage {
343
+ @include squares-sprite("ten-by-ten", $offset-x: 100%);
344
+ }
345
+
346
+ .adjusted-px-1 {
347
+ @include squares-sprite("ten-by-ten", $offset-x: 4px);
348
+ }
349
+
350
+ .adjusted-px-2 {
351
+ @include squares-sprite("twenty-by-twenty", $offset-x: -3px, $offset-y: 2px);
352
+ }
353
+ SCSS
354
+ assert_correct css, <<-CSS
355
+ .squares-sprite, .adjusted-percentage, .adjusted-px-1, .adjusted-px-2 {
356
+ background: url('/squares-sce5dc30797.png') no-repeat;
357
+ }
358
+
359
+ .adjusted-percentage {
360
+ background-position: 100% 0;
361
+ }
362
+
363
+ .adjusted-px-1 {
364
+ background-position: -6px 0;
365
+ }
366
+
367
+ .adjusted-px-2 {
368
+ background-position: -3px -8px;
369
+ }
370
+ CSS
371
+ assert_equal image_size('squares-s*.png'), [20, 30]
372
+ assert_equal image_md5('squares-s*.png'), '9cc7ce48cfaf304381c2d08adefd2fb6'
373
+ end
374
+
375
+ it "should repeat the image" do
376
+ css = render <<-SCSS
377
+ $squares-repeat: repeat-x;
378
+ @import "squares/*.png";
379
+ @include all-squares-sprites;
380
+ SCSS
381
+ assert_correct css, <<-CSS
382
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
383
+ background: url('/squares-s65c43cd573.png') no-repeat;
384
+ }
385
+
386
+ .squares-ten-by-ten {
387
+ background-position: 0 0;
388
+ }
389
+
390
+ .squares-twenty-by-twenty {
391
+ background-position: 0 -10px;
392
+ }
393
+ CSS
394
+ assert_equal image_size('squares-s*.png'), [20, 30]
395
+ assert_equal image_md5('squares-s*.png'), 'a77a2fd43f04d791722b706aa7c9f1c1'
396
+ end
397
+
398
+ it "should allow the position of a sprite to be specified in absolute pixels" do
399
+ css = render <<-SCSS
400
+ $squares-ten-by-ten-position: 10px;
401
+ $squares-twenty-by-twenty-position: 10px;
402
+ @import "squares/*.png";
403
+ @include all-squares-sprites;
404
+ SCSS
405
+ assert_correct css, <<-CSS
406
+ .squares-sprite, .squares-ten-by-ten, .squares-twenty-by-twenty {
407
+ background: url('/squares-sb9d9a8ca6a.png') no-repeat;
408
+ }
409
+
410
+ .squares-ten-by-ten {
411
+ background-position: -10px 0;
412
+ }
413
+
414
+ .squares-twenty-by-twenty {
415
+ background-position: -10px -10px;
416
+ }
417
+ CSS
418
+ assert_equal image_size('squares-s*.png'), [30, 30]
419
+ assert_equal image_md5('squares-s*.png'), '9856ced9e8211b6b28ff782019a0d905'
420
+ end
421
+
422
+ it "should provide a nice errors for lemonade's old users" do
423
+ assert_raise(Sass::SyntaxError) do
424
+ render <<-SCSS
425
+ .squares {
426
+ background: sprite-url("squares/*.png") no-repeat;
427
+ }
428
+ SCSS
429
+ end
430
+ assert_raise(Sass::SyntaxError) do
431
+ css = render <<-SCSS
432
+ .squares {
433
+ background: sprite-image("squares/twenty-by-twenty.png") no-repeat;
434
+ }
435
+ SCSS
436
+ end
437
+ assert_raise(Sass::SyntaxError) do
438
+ css = render <<-SCSS
439
+ @import "squares/*.png";
440
+
441
+ .squares {
442
+ background: sprite-position("squares/twenty-by-twenty.png") no-repeat;
443
+ }
444
+ SCSS
445
+ end
446
+ end
447
+
448
+ it "should work even if @import is missing" do
449
+ css = render <<-SCSS
450
+ .squares {
451
+ background: sprite(sprite-map("squares/*.png"), twenty-by-twenty) no-repeat;
452
+ }
453
+ SCSS
454
+ assert_correct css, <<-CSS
455
+ .squares {
456
+ background: url('/squares-sd817b59156.png') 0 -10px no-repeat;
457
+ }
458
+ CSS
459
+ end
460
+
461
+ it "should calculate corret sprite demsions when givin spacing via issue#253" do
462
+ css = render <<-SCSS
463
+ $squares-spacing: 10px;
464
+ @import "squares/*.png";
465
+ .foo {
466
+ @include sprite-background-position($squares-sprites, "twenty-by-twenty");
467
+ }
468
+ .bar {
469
+ @include sprite-background-position($squares-sprites, "ten-by-ten");
470
+ }
471
+ SCSS
472
+ assert_equal image_size('squares-s*.png'), [20, 40]
473
+ assert_correct css, <<-CSS
474
+ .squares-sprite {
475
+ background: url('/squares-s555875d730.png') no-repeat;
476
+ }
477
+
478
+ .foo {
479
+ background-position: 0 -20px;
480
+ }
481
+
482
+ .bar {
483
+ background-position: 0 0;
484
+ }
485
+ CSS
486
+ end
487
+
488
+ it "should render correct sprite with css selectors via issue#248" do
489
+ css = render <<-SCSS
490
+ @import "selectors/*.png";
491
+ @include all-selectors-sprites;
492
+ SCSS
493
+ assert_correct css, <<-CSS
494
+ .selectors-sprite, .selectors-ten-by-ten {
495
+ background: url('/selectors-s7e84acb3d2.png') no-repeat;
496
+ }
497
+
498
+ .selectors-ten-by-ten {
499
+ background-position: 0 0;
500
+ }
501
+ .selectors-ten-by-ten:hover, .selectors-ten-by-ten.ten-by-ten_hover, .selectors-ten-by-ten.ten-by-ten-hover {
502
+ background-position: 0 -20px;
503
+ }
504
+ .selectors-ten-by-ten:target, .selectors-ten-by-ten.ten-by-ten_target, .selectors-ten-by-ten.ten-by-ten-target {
505
+ background-position: 0 -30px;
506
+ }
507
+ .selectors-ten-by-ten:active, .selectors-ten-by-ten.ten-by-ten_active, .selectors-ten-by-ten.ten-by-ten-active {
508
+ background-position: 0 -10px;
509
+ }
510
+ CSS
511
+ end
512
+
513
+ it "should honor offsets when rendering selectors via issue#449" do
514
+ css = render <<-SCSS
515
+ @import "selectors/*.png";
516
+ @include all-selectors-sprites($offset-x: 20px, $offset-y: 20px);
517
+ SCSS
518
+ assert_correct css, <<-CSS
519
+ .selectors-sprite, .selectors-ten-by-ten {
520
+ background: url('/selectors-s7e84acb3d2.png') no-repeat;
521
+ }
522
+
523
+ .selectors-ten-by-ten {
524
+ background-position: 20px 20px;
525
+ }
526
+ .selectors-ten-by-ten:hover, .selectors-ten-by-ten.ten-by-ten_hover, .selectors-ten-by-ten.ten-by-ten-hover {
527
+ background-position: 20px 0;
528
+ }
529
+ .selectors-ten-by-ten:target, .selectors-ten-by-ten.ten-by-ten_target, .selectors-ten-by-ten.ten-by-ten-target {
530
+ background-position: 20px -10px;
531
+ }
532
+ .selectors-ten-by-ten:active, .selectors-ten-by-ten.ten-by-ten_active, .selectors-ten-by-ten.ten-by-ten-active {
533
+ background-position: 20px 10px;
534
+ }
535
+ CSS
536
+ end
537
+
538
+ it "should render correct sprite with css selectors via magic mixin" do
539
+ css = render <<-SCSS
540
+ @import "selectors/*.png";
541
+ a {
542
+ @include selectors-sprite(ten-by-ten)
543
+ }
544
+ SCSS
545
+ assert_correct css, <<-CSS
546
+ .selectors-sprite, a {
547
+ background: url('/selectors-s7e84acb3d2.png') no-repeat;
548
+ }
549
+
550
+ a {
551
+ background-position: 0 0;
552
+ }
553
+ a:hover, a.ten-by-ten_hover, a.ten-by-ten-hover {
554
+ background-position: 0 -20px;
555
+ }
556
+ a:target, a.ten-by-ten_target, a.ten-by-ten-target {
557
+ background-position: 0 -30px;
558
+ }
559
+ a:active, a.ten-by-ten_active, a.ten-by-ten-active {
560
+ background-position: 0 -10px;
561
+ }
562
+ CSS
563
+ end
564
+
565
+
566
+ it "should not render corret sprite with css selectors via magic mixin" do
567
+ css = render <<-SCSS
568
+ @import "selectors/*.png";
569
+ a {
570
+ $disable-magic-sprite-selectors:true;
571
+ @include selectors-sprite(ten-by-ten)
572
+ }
573
+ SCSS
574
+ assert_correct css, <<-CSS
575
+ .selectors-sprite, a {
576
+ background: url('/selectors-s7e84acb3d2.png') no-repeat;
577
+ }
578
+
579
+ a {
580
+ background-position: 0 0;
581
+ }
582
+ CSS
583
+ end
584
+
585
+ it "should render corret sprite with css selectors via magic mixin with the correct offsets" do
586
+ css = render <<-SCSS
587
+ @import "selectors/*.png";
588
+ a {
589
+ @include selectors-sprite(ten-by-ten, false, 5, -5)
590
+ }
591
+ SCSS
592
+ assert_correct css, <<-CSS
593
+ .selectors-sprite, a {
594
+ background: url('/selectors-s7e84acb3d2.png') no-repeat;
595
+ }
596
+
597
+ a {
598
+ background-position: 5px -5px;
599
+ }
600
+ a:hover, a.ten-by-ten_hover, a.ten-by-ten-hover {
601
+ background-position: 5px -25px;
602
+ }
603
+ a:target, a.ten-by-ten_target, a.ten-by-ten-target {
604
+ background-position: 5px -35px;
605
+ }
606
+ a:active, a.ten-by-ten_active, a.ten-by-ten-active {
607
+ background-position: 5px -15px;
608
+ }
609
+ CSS
610
+ end
611
+
612
+ it "should raise error on filenames that are not valid sass syntax" do
613
+ assert_raise(Compass::Error) do
614
+ css = render <<-SCSS
615
+ @import "prefix/*.png";
616
+ a {
617
+ @include squares-sprite(20-by-20);
618
+ }
619
+ SCSS
620
+ end
621
+ end
622
+
623
+ it "should generate sprite with bad repeat-x dimensions" do
624
+ css = render <<-SCSS
625
+ $ko-starbg26x27-repeat: repeat-x;
626
+ @import "ko/*.png";
627
+ @include all-ko-sprites;
628
+ SCSS
629
+ assert_correct css, <<-CSS
630
+ .ko-sprite, .ko-default_background, .ko-starbg26x27 {
631
+ background: url('/ko-sd46dfbab4f.png') no-repeat;
632
+ }
633
+
634
+ .ko-default_background {
635
+ background-position: 0 0;
636
+ }
637
+
638
+ .ko-starbg26x27 {
639
+ background-position: 0 -128px;
640
+ }
641
+ CSS
642
+ end
643
+
644
+ it "should generate a sprite and remove the old file" do
645
+ FileUtils.touch File.join(@images_tmp_path, "selectors-scc8834Fdd.png")
646
+ assert_equal 1, map_files('selectors-s*.png').size
647
+ css = render <<-SCSS
648
+ @import "selectors/*.png";
649
+ a {
650
+ $disable-magic-sprite-selectors:true;
651
+ @include selectors-sprite(ten-by-ten)
652
+ }
653
+ SCSS
654
+ assert_equal 1, map_files('selectors-s*.png').size, "File was not removed"
655
+ end
656
+
657
+ it "should generate a sprite and NOT remove the old file" do
658
+ FileUtils.touch File.join(@images_tmp_path, "selectors-scc8834Ftest.png")
659
+ assert_equal 1, map_files('selectors-s*.png').size
660
+ css = render <<-SCSS
661
+ $selectors-clean-up: false;
662
+ @import "selectors/*.png";
663
+ a {
664
+ $disable-magic-sprite-selectors:true;
665
+ @include selectors-sprite(ten-by-ten)
666
+ }
667
+ SCSS
668
+ assert_equal 2, map_files('selectors-s*.png').size, "File was removed"
669
+ end
670
+
671
+ it "should generate a sprite if the sprite is a bool" do
672
+ css = render <<-SCSS
673
+ @import "bool/*.png";
674
+ a {
675
+ @include bool-sprite(false);
676
+ }
677
+ a {
678
+ @include bool-sprite(true);
679
+ }
680
+ SCSS
681
+ assert !css.empty?
682
+ end
683
+
684
+
685
+ it "should generate a sprite if the sprite is a colorname" do
686
+ css = render <<-SCSS
687
+ @import "colors/*.png";
688
+ a {
689
+ @include colors-sprite(blue);
690
+ }
691
+ SCSS
692
+ assert !css.empty?
693
+ end
694
+
695
+ it "should generate a sprite from nested folders" do
696
+ css = render <<-SCSS
697
+ @import "nested/**/*.png";
698
+ @include all-nested-sprites;
699
+ SCSS
700
+ assert_correct css, <<-CSS
701
+ .nested-sprite, .nested-ten-by-ten {
702
+ background: url('/nested-s7b93e0b6bf.png') no-repeat;
703
+ }
704
+
705
+ .nested-ten-by-ten {
706
+ background-position: 0 0;
707
+ }
708
+ CSS
709
+ end
710
+
711
+ it "should create horizontal sprite" do
712
+ css = render <<-SCSS
713
+ $squares-layout:horizontal;
714
+ @import "squares/*.png";
715
+ .foo {
716
+ @include sprite-background-position($squares-sprites, "twenty-by-twenty");
717
+ }
718
+ .bar {
719
+ @include sprite-background-position($squares-sprites, "ten-by-ten");
720
+ }
721
+ SCSS
722
+ assert_equal [30, 20], image_size('squares-s*.png')
723
+ other_css = <<-CSS
724
+ .squares-sprite {
725
+ background: url('/squares-s4bd95c5c56.png') no-repeat;
726
+ }
727
+
728
+ .foo {
729
+ background-position: -10px 0;
730
+ }
731
+
732
+ .bar {
733
+ background-position: 0 0;
734
+ }
735
+ CSS
736
+ assert_correct clean(css), clean(other_css)
737
+ end
738
+
739
+ it "should allow use of demension functions" do
740
+ css = render <<-SCSS
741
+ @import "squares/*.png";
742
+ $h: squares-sprite-height(twenty-by-twenty);
743
+ $w: squares-sprite-width(twenty-by-twenty);
744
+ .div {
745
+ height:$h + 1px;
746
+ width:$w + 2px;
747
+ }
748
+ SCSS
749
+ other_css = <<-CSS
750
+ .squares-sprite {
751
+ background: url('/squares-sbbc18e2129.png') no-repeat;
752
+ }
753
+ .div {
754
+ height:21px;
755
+ width:22px;
756
+ }
757
+ CSS
758
+ assert_correct clean(css), clean(other_css)
759
+ end
760
+
761
+ it "should replace text with images and dimensions using sprites" do
762
+ css = render <<-SCSS
763
+ @import "colors/*.png";
764
+ .blue {
765
+ @include sprite-replace-text($colors-sprites, blue);
766
+ }
767
+ .yellow {
768
+ @include sprite-replace-text-with-dimensions($colors-sprites, yellow);
769
+ }
770
+ SCSS
771
+ other_css = <<-CSS
772
+ .colors-sprite {
773
+ background:url('/colors-s58671cb5bb.png') no-repeat;
774
+ }
775
+ .blue {
776
+ text-indent:-119988px;
777
+ overflow:hidden;
778
+ text-align:left;
779
+ background-position:0 0;
780
+ background-image:url('/colors-s58671cb5bb.png');
781
+ background-repeat:no-repeat;
782
+ }
783
+
784
+ .yellow {
785
+ text-indent:-119988px;
786
+ overflow:hidden;
787
+ text-align:left;
788
+ background-position:0 -10px;
789
+ height:10px;
790
+ width:10px;
791
+ background-image:url('/colors-s58671cb5bb.png');
792
+ background-repeat:no-repeat;
793
+ }
794
+ CSS
795
+ assert_correct clean(css), clean(other_css)
796
+ end
797
+
798
+ it "should inline the sprite file" do
799
+ css = render <<-SCSS
800
+ $colors-inline:true;
801
+ @import "colors/*.png";
802
+ @include all-colors-sprites;
803
+ SCSS
804
+ other_css = <<-CSS
805
+ .colors-sprite, .colors-blue, .colors-yellow {
806
+ background-image:url('');
807
+ }
808
+ .colors-blue {
809
+ background-position:0 0;
810
+ }
811
+ .colors-yellow {
812
+ background-position:0 -10px;
813
+ }
814
+ CSS
815
+ assert_correct clean(css), clean(other_css)
816
+ end
817
+
818
+ it "should have a sprite_name function that returns the names of the sprites in a sass list" do
819
+ css = render <<-SCSS
820
+ $colors-inline:true;
821
+ @import "colors/*.png";
822
+ @each $color in sprite_names($colors-sprites) {
823
+ .\#{$color} {
824
+ width:0px;
825
+ }
826
+ }
827
+ SCSS
828
+ other_css = <<-CSS
829
+ .colors-sprite {
830
+ background-image:url('');
831
+ }
832
+ .blue {
833
+ width:0px;
834
+ }
835
+ .yellow {
836
+ width:0px;
837
+ }
838
+ CSS
839
+ assert_correct clean(css), clean(other_css)
840
+
841
+ end
842
+
843
+ end