Project

multi_css

0.0
No commit activity in last 3 years
No release in over 3 years
A generic swappable back-end for CSS minification.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

>= 0
>= 0
>= 0

Runtime

 Project Readme

MultiCss Build Status Dependency Status Code Climate

There are lot of Ruby libraries to minify CSS. Instead of choosing a single implementation and forcing users of your library to be stuck with it, you can use MultiCss instead, which will simply choose the best available CSS minifier. Here's how to use it:

require 'multi_css'

MultiCss.min('a { color: red; }') #=> 'a{color:red}'

The use method, which sets the MultiCss adapter, takes either a symbol or a class (to allow for custom CSS minifier) that responds to .min at the class level.

MultiCss tries to have intelligent defaulting. That is, if you have any of the supported engines already loaded, it will utilize them before attempting to load any. It will load libraries in following order:

If no other library is available, MultiCss falls back to css_press.

TODO

  • benchmark against most popular css frameworks (speed, size)
  • generate benchmark report (html or md)
  • write test suite
  • generate comparison table (html or md) with the help of test suite

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request