0.0
Low commit activity in last 3 years
A long-lived project that still receives updates
Create an offline version of a HTML file.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

~> 0.4.6
 Project Readme

Gem Version Build Status Code Climate

Asset Packager

Given a HTML file (local or remote), asset packager will download all assets (images, stylesheets, scripts) to a local folder, and rewrite the HTML file to point to the local files. The result can be easily copied onto a USB stick and used off-line.

Asset Packager is part of Slippery, a tool for creating presentations with Markdown, but can also be used stand-alone.

Command line usage

asset_packer file.html target.html
asset_packer http://example.org/file.html target.html

This will create target.html, and a directory target_assets containing all the assets.

Hexp usage

Asset Packager is at its core a Hexp transformation, it transform one HTML DOM tree into another. While doing so it creates some files. To use it directly on a Hexp document you need to pass it a bit of extra information

  • the source URI, needed to resolve relative URI's
  • the asset directory, where assets will be stored. Will be created if it doesn't exist
  • the destination HTML file name, used to calculate new relative URI's for the assets
doc = Hexp.parse(...)
doc = AssetPacker::Processor::Local.new('http://foo/bar', '/tmp/assets', '/tmp/result.html').call(doc)
File.write('/tmp/result.html', doc.to_html)

Transformations

So far, the following assets are recognized

  • img[src]
  • link[rel="stylesheet"][href]
  • script[src]

Mutation Testing

Asset Packager has 100% mutation coverage using Mutant. It is a rewrite of functionality originally included in Slippery, used to demonstrate the concept of mutation testing for an article for Sitepoint.

Contributing

Use a feature branch, make sure rake mutant tells you all is fine, then send a pull request.

License

Copyright 2014 Arne Brasseur

Available under the MIT license, see LICENSE file for details.