Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
A generic swappable back-end for HTML minifiers
Ruby
branch: master

Fetching latest commit…

Cannot retrieve the latest commit at this time

Failed to load latest commit information.
lib
spec
.gitignore
.travis.yml
Gemfile
LICENSE.txt
README.md
Rakefile
multi_html.gemspec

README.md

MultiHtml Build Status Dependency Status Code Climate

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

require 'multi_html'

MultiHtml.min('<div>  <p>test</p>  </div>') #=> '<div><p>test</p></div>'

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

MultiHtml 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, MultiHtml falls back to html_press.

HTML::Pipeline

pipeline = HTML::Pipeline.new [
  MultiHtml::Filter
]
pipeline.call('<div>  <p>test</p>  </div>') #=> '<div><p>test</p></div>'

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
Something went wrong with that request. Please try again.