RETIRED, further work has moved to Debian project infrastructure
Go to file
Briggs Thompson 90b29b3072 Updating remote storages documentation for CachedS3BotoStorage bug.
The example in the docs doesn't quite work as the file stored in
the "content" variable is already closed, and ends up spitting out
encoded data to the destination files. It was properly being sent
to S3, but not getting saved locally.

This saves the file locally first, then using local storage, opens
the file once again for the S3BotoStorage save call.
2016-03-07 21:37:27 -06:00
compressor Merge branch 'master' into develop 2016-01-22 18:10:23 +01:00
docs Updating remote storages documentation for CachedS3BotoStorage bug. 2016-03-07 21:37:27 -06:00
requirements Remove test using django-overextends to simplify codebase 2015-12-24 13:09:41 +01:00
.gitignore Specifically test saving with the gzip middleware. 2013-05-27 12:52:17 +02:00
.travis.yml Fix travis build by downgrading pip/virtualenv for Python3.2 2016-01-22 15:39:09 +05:30
AUTHORS Add support for multiple offline contexts. 2015-09-25 18:53:05 +01:00
LICENSE Year bump (never too late!) 2015-11-19 19:00:23 +01:00
Makefile Remove rcssmin and rjsmin from the repo and make them proper dependencies. ref #664 2015-12-04 22:34:05 +01:00
MANIFEST.in Added a couple of files to the source package manifest. Fixes #410. 2013-05-30 20:10:16 +02:00
README.rst Also remove the downloads count badge, no need for it. 2016-01-22 18:23:46 +01:00
setup.cfg Mark this as a universal wheel 2014-05-10 09:31:22 -07:00
setup.py Updated required django-appconf version. 2016-02-03 15:30:37 +01:00
tox.ini Remove deprecated downloadcache setting from tox.ini - was breaking with pip 7.1.2 2016-01-20 18:04:19 +05:30

Django Compressor

image

image

Build Status

image

Django Compressor combines and compresses linked and inline Javascript or CSS in a Django template into cacheable static files by using the compress template tag.

HTML in between {% compress js/css %} and {% endcompress %} is parsed and searched for CSS or JS. These styles and scripts are subsequently processed with optional, configurable compilers and filters.

The default filter for CSS rewrites paths to static files to be absolute and adds a cache busting timestamp. For Javascript the default filter compresses it using jsmin.

As the final result the template tag outputs a <script> or <link> tag pointing to the optimized file. These files are stored inside a folder and given a unique name based on their content. Alternatively it can also return the resulting content to the original template directly.

Since the file name is dependent on the content these files can be given a far future expiration date without worrying about stale browser caches.

The concatenation and compressing process can also be jump started outside of the request/response cycle by using the Django management command manage.py compress.

Configurability & Extendibility

Django Compressor is highly configurable and extendible. The HTML parsing is done using lxml or if it's not available Python's built-in HTMLParser by default. As an alternative Django Compressor provides a BeautifulSoup and a html5lib based parser, as well as an abstract base class that makes it easy to write a custom parser.

Django Compressor also comes with built-in support for YUI CSS and JS compressor, yUglify CSS and JS compressor, the Google's Closure Compiler, a Python port of Douglas Crockford's JSmin, a Python port of the YUI CSS Compressor csscompressor and a filter to convert (some) images into data URIs.

If your setup requires a different compressor or other post-processing tool it will be fairly easy to implement a custom filter. Simply extend from one of the available base classes.

More documentation about the usage and settings of Django Compressor can be found on django-compressor.readthedocs.org.

The source code for Django Compressor can be found and contributed to on github.com/django-compressor/django-compressor. There you can also file tickets.

The in-development version of Django Compressor can be installed with pip install http://github.com/django-compressor/django-compressor/tarball/develop.