Extended docs.
This commit is contained in:
		| @@ -78,7 +78,7 @@ class CompressorSettings(AppSettings): | |||||||
|             if ("compressor.finders.CompressorFinder" not in |             if ("compressor.finders.CompressorFinder" not in | ||||||
|                     staticfiles_settings.STATICFILES_FINDERS): |                     staticfiles_settings.STATICFILES_FINDERS): | ||||||
|                 raise ImproperlyConfigured( |                 raise ImproperlyConfigured( | ||||||
|                     "When using django_compressor together with staticfiles, " |                     "When using Django Compressor together with staticfiles, " | ||||||
|                     "please add 'compressor.finders.CompressorFinder' to the " |                     "please add 'compressor.finders.CompressorFinder' to the " | ||||||
|                     "STATICFILES_FINDERS setting.") |                     "STATICFILES_FINDERS setting.") | ||||||
|         return value |         return value | ||||||
|   | |||||||
							
								
								
									
										69
									
								
								docs/changelog.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								docs/changelog.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | |||||||
|  | Changelog | ||||||
|  | ========= | ||||||
|  |  | ||||||
|  | 0.6.1 | ||||||
|  | ----- | ||||||
|  |  | ||||||
|  | - Fixed staticfiles support to also use its finder API to find files during | ||||||
|  |   developement -- when the static files haven't been collected in | ||||||
|  |   ``STATIC_ROOT``. | ||||||
|  |  | ||||||
|  | - Fixed regression with the ``COMPRESS`` setting, pre-compilation and | ||||||
|  |   staticfiles. | ||||||
|  |  | ||||||
|  | 0.6 | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | Major improvements and a lot of bugfixes, some of which are: | ||||||
|  |  | ||||||
|  | - New precompilation support, which allows compilation of files and | ||||||
|  |   hunks with easily configurable compilers before calling the actual | ||||||
|  |   output filters. See the | ||||||
|  |   :ref:`COMPRESS_PRECOMPILERS <compress_precompilers>` for more details. | ||||||
|  |  | ||||||
|  | - New staticfiles support. With the introduction of the staticfiles app | ||||||
|  |   to Django 1.3, compressor officially supports finding the files to | ||||||
|  |   compress using the app's finder API. Have a look at the documentation | ||||||
|  |   about :ref:`remote storages <remote_storages>` in case you want to use | ||||||
|  |   those together with compressor. | ||||||
|  |  | ||||||
|  | - New ``compress`` management command which allows pre-running of what the | ||||||
|  |   compress template tag does. See the | ||||||
|  |   :ref:`pre-compression <pre-compression>` docs for more information. | ||||||
|  |  | ||||||
|  | - Various perfomance improvements by better caching and mtime cheking. | ||||||
|  |  | ||||||
|  | - Deprecated ``COMPRESS_LESSC_BINARY`` setting because it's now | ||||||
|  |   superseded by the :ref:`COMPRESS_PRECOMPILERS <compress_precompilers>` | ||||||
|  |   setting. Just make sure to use the correct mimetype when linking to less | ||||||
|  |   files or adding inline code and add the following to your settings:: | ||||||
|  |  | ||||||
|  |       COMPRESS_PRECOMPILERS = ( | ||||||
|  |           ('text/less', 'lessc {infile} {outfile}'), | ||||||
|  |       ) | ||||||
|  |  | ||||||
|  | - Added cssmin_ filter (``compressor.filters.CSSMinFilter``) based on | ||||||
|  |   Zachary Voase's Python port of the YUI CSS compression algorithm. | ||||||
|  |  | ||||||
|  | - Reimplemented the dog-piling prevention. | ||||||
|  |  | ||||||
|  | - Make sure the CssAbsoluteFilter works for relative paths. | ||||||
|  |  | ||||||
|  | - Added inline render mode. See :ref:`usage <usage>` docs. | ||||||
|  |  | ||||||
|  | - Added ``mtime_cache`` management command to add and/or remove all mtimes | ||||||
|  |   from the cache. | ||||||
|  |  | ||||||
|  | - Moved docs to Read The Docs: http://django_compressor.readthedocs.org | ||||||
|  |  | ||||||
|  | - Added optional ``compressor.storage.GzipCompressorFileStorage`` storage | ||||||
|  |   backend that gzips of the saved files automatically for easier deployment. | ||||||
|  |  | ||||||
|  | - Reimplemented a few filters on top of the new | ||||||
|  |   ``compressor.filters.base.CompilerFilter`` to be a bit more DRY. | ||||||
|  |  | ||||||
|  | - Added tox based test configuration, testing on Django 1.1-1.3 and Python | ||||||
|  |   2.5-2.7. | ||||||
|  |  | ||||||
|  | .. _cssmin: http://pypi.python.org/pypi/cssmin/ | ||||||
|  |  | ||||||
| @@ -40,4 +40,4 @@ Contents | |||||||
|  settings |  settings | ||||||
|  remote-storages |  remote-storages | ||||||
|  behind-the-scenes |  behind-the-scenes | ||||||
|  |  changelog | ||||||
|   | |||||||
| @@ -16,7 +16,7 @@ Installation | |||||||
|   default behaviour and make adjustements for your website. |   default behaviour and make adjustements for your website. | ||||||
|  |  | ||||||
| * In case you use Django 1.3's staticfiles_ contrib app (or its standalone | * In case you use Django 1.3's staticfiles_ contrib app (or its standalone | ||||||
|   clone django-staticfiles_) you have to add django_compressor's file finder |   clone django-staticfiles_) you have to add Django Compressor's file finder | ||||||
|   to the ``STATICFILES_FINDERS`` setting:: |   to the ``STATICFILES_FINDERS`` setting:: | ||||||
|  |  | ||||||
|     STATICFILES_FINDERS = ( |     STATICFILES_FINDERS = ( | ||||||
| @@ -58,11 +58,3 @@ Deprecation | |||||||
| This section lists features and settings that are deprecated or removed | This section lists features and settings that are deprecated or removed | ||||||
| in newer versions of Django Compressor. | in newer versions of Django Compressor. | ||||||
|  |  | ||||||
| * ``COMPRESS_LESSC_BINARY`` |  | ||||||
|     Superseded by the :ref:`COMPRESS_PRECOMPILERS <compress_precompilers>` |  | ||||||
|     setting. Just make sure to use the correct mimetype when linking to less |  | ||||||
|     files or adding inline code and add the following to your settings:: |  | ||||||
|  |  | ||||||
|         COMPRESS_PRECOMPILERS = ( |  | ||||||
|             ('text/less', 'lessc {infile} {outfile}'), |  | ||||||
|         ) |  | ||||||
|   | |||||||
| @@ -1,3 +1,5 @@ | |||||||
|  | .. _remote_storages: | ||||||
|  |  | ||||||
| Remote storages | Remote storages | ||||||
| --------------- | --------------- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -241,6 +241,8 @@ Compressor from performing the actual compression. Only useful for debugging. | |||||||
|  |  | ||||||
| .. _RequestContext: http://docs.djangoproject.com/en/dev/ref/templates/api/#django.template.RequestContext | .. _RequestContext: http://docs.djangoproject.com/en/dev/ref/templates/api/#django.template.RequestContext | ||||||
|  |  | ||||||
|  | .. _compress_offline: | ||||||
|  |  | ||||||
| COMPRESS_OFFLINE | COMPRESS_OFFLINE | ||||||
| ^^^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^^^ | ||||||
|  |  | ||||||
| @@ -251,20 +253,7 @@ request/response loop -- independent from user requests. This allows to | |||||||
| pre-compress CSS and JavaScript files and works just like the automatic | pre-compress CSS and JavaScript files and works just like the automatic | ||||||
| compression with the ``{% compress %}`` tag. | compression with the ``{% compress %}`` tag. | ||||||
|  |  | ||||||
| To compress the files "offline" and update the offline cache you have | .. _compress_offline_timeout: | ||||||
| to use the ``compress`` management command, e.g. during deployment. |  | ||||||
| In case you don't use the ``compress`` management command, Django |  | ||||||
| Compressor will automatically fallback to the automatic compression. |  | ||||||
|  |  | ||||||
| It'll will look in the templates that can be found with the template |  | ||||||
| loader you specify in ``TEMPLATE_LOADERS`` for ``{% compress %}`` blocks |  | ||||||
| and use COMPRESS_OFFLINE_CONTEXT_ to render its content. So if you use |  | ||||||
| any variables inside the ``{% compress %}`` blocks, make sure to list |  | ||||||
| all values you require in COMPRESS_OFFLINE_CONTEXT_. |  | ||||||
|  |  | ||||||
| The result of running the ``compress`` management command will be saved |  | ||||||
| in the cache as defined in COMPRESS_CACHE_BACKEND_ for the number of |  | ||||||
| seconds defined in COMPRESS_OFFLINE_TIMEOUT_. |  | ||||||
|  |  | ||||||
| COMPRESS_OFFLINE_TIMEOUT | COMPRESS_OFFLINE_TIMEOUT | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^^^^^^^^^^^ | ||||||
| @@ -275,6 +264,8 @@ The period of time with which the ``compress`` management command stores | |||||||
| the pre-compressed the contents of ``{% compress %}`` template tags in | the pre-compressed the contents of ``{% compress %}`` template tags in | ||||||
| the cache. | the cache. | ||||||
|  |  | ||||||
|  | .. _compress_offline_context: | ||||||
|  |  | ||||||
| COMPRESS_OFFLINE_CONTEXT | COMPRESS_OFFLINE_CONTEXT | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^^^^^^^^^^^ | ||||||
|  |  | ||||||
| @@ -282,27 +273,4 @@ COMPRESS_OFFLINE_CONTEXT | |||||||
|  |  | ||||||
| The context to be used by the ``compress`` management command when rendering | The context to be used by the ``compress`` management command when rendering | ||||||
| the contents of ``{% compress %}`` template tags and saving the result in the | the contents of ``{% compress %}`` template tags and saving the result in the | ||||||
| offline cache. It's similar to a template context and should be used if a | offline cache. | ||||||
| variable is used in the blocks, e.g.: |  | ||||||
|  |  | ||||||
| .. code-block:: django |  | ||||||
|  |  | ||||||
|     {% load compress %} |  | ||||||
|     {% compress js %} |  | ||||||
|     <script src="{{ path_to_files }}js/one.js" type="text/javascript" charset="utf-8"></script> |  | ||||||
|     {% endcompress %} |  | ||||||
|  |  | ||||||
| Since this template requires a variable (``path_to_files``) you need to |  | ||||||
| specify this in your settings before using the ``compress`` management |  | ||||||
| command:: |  | ||||||
|  |  | ||||||
|     COMPRESS_OFFLINE_CONTEXT = { |  | ||||||
|         'path_to_files': '/static/js/', |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| If not specified the COMPRESS_OFFLINE_CONTEXT will fall back to contain |  | ||||||
| the commonly used setting to refer to saved files ``MEDIA_URL``. |  | ||||||
|  |  | ||||||
| For forward compatibility Django Compressor will also add the ``STATIC_URL`` |  | ||||||
| setting (added in Django 1.3) to the COMPRESS_OFFLINE_CONTEXT_ if it's |  | ||||||
| available. |  | ||||||
|   | |||||||
| @@ -1,10 +1,12 @@ | |||||||
|  | .. _usage: | ||||||
|  |  | ||||||
| Usage | Usage | ||||||
| ===== | ===== | ||||||
|  |  | ||||||
| .. code-block:: django | .. code-block:: django | ||||||
|  |  | ||||||
|     {% load compress %} |     {% load compress %} | ||||||
|     {% compress <js/css> %} |     {% compress <js/css> [<file/infile>] %} | ||||||
|     <html of inline or linked JS/CSS> |     <html of inline or linked JS/CSS> | ||||||
|     {% endcompress %} |     {% endcompress %} | ||||||
|  |  | ||||||
| @@ -44,7 +46,7 @@ Which would be rendered something like: | |||||||
|  |  | ||||||
|     <script type="text/javascript" src="/static/CACHE/js/3f33b9146e12.js" charset="utf-8"></script> |     <script type="text/javascript" src="/static/CACHE/js/3f33b9146e12.js" charset="utf-8"></script> | ||||||
|  |  | ||||||
| Linked files must be accesible via :ref:`COMPRESS_URL <compress_url>`. | Linked files **must** be accesible via :ref:`COMPRESS_URL <compress_url>`. | ||||||
| If DEBUG is ``True``, off-site files will throw exceptions. If DEBUG is | If DEBUG is ``True``, off-site files will throw exceptions. If DEBUG is | ||||||
| ``False`` they will be silently stripped. | ``False`` they will be silently stripped. | ||||||
|  |  | ||||||
| @@ -60,9 +62,82 @@ what it was given, to ease development. | |||||||
|     :ref:`COMPRESS_CACHE_BACKEND <compress_cache_backend>` and |     :ref:`COMPRESS_CACHE_BACKEND <compress_cache_backend>` and | ||||||
|     Django's `caching documentation`_). |     Django's `caching documentation`_). | ||||||
|  |  | ||||||
|  | The compress template tag supports a second arguemnt specifying the output | ||||||
|  | mode and defaults to saving the result in a file. Alternatively you can | ||||||
|  | pass '``inline``' to the template tag to return the content directly to the | ||||||
|  | rendered page, e.g.: | ||||||
|  |  | ||||||
|  | .. code-block:: django | ||||||
|  |  | ||||||
|  |     {% load compress %} | ||||||
|  |  | ||||||
|  |     {% compress js inline %} | ||||||
|  |     <script src="/static/js/one.js" type="text/javascript" charset="utf-8"></script> | ||||||
|  |     <script type="text/javascript" charset="utf-8">obj.value = "value";</script> | ||||||
|  |     {% endcompress %} | ||||||
|  |  | ||||||
|  | would be rendered something like: | ||||||
|  |  | ||||||
|  |     <script type="text/javascript" charset="utf-8"> | ||||||
|  |     obj = {}; | ||||||
|  |     obj.value = "value"; | ||||||
|  |     </script> | ||||||
|  |  | ||||||
| .. _memcached: http://memcached.org/ | .. _memcached: http://memcached.org/ | ||||||
| .. _caching documentation: http://docs.djangoproject.com/en/1.2/topics/cache/#memcached | .. _caching documentation: http://docs.djangoproject.com/en/1.2/topics/cache/#memcached | ||||||
|  |  | ||||||
|  | .. _pre-compression: | ||||||
|  |  | ||||||
|  | Pre-compression | ||||||
|  | --------------- | ||||||
|  |  | ||||||
|  | Django Compressor comes with an optional ``compress`` mangement command to | ||||||
|  | run the compression outside of the request/response loop -- independent | ||||||
|  | from user requests. This allows to pre-compress CSS and JavaScript files and | ||||||
|  | works just like the automatic compression with the ``{% compress %}`` tag. | ||||||
|  |  | ||||||
|  | To compress the files "offline" and update the offline cache you have | ||||||
|  | to use the ``compress`` management command, ideally during deployment. | ||||||
|  | Also make sure to enable the :ref:`COMPRESS_OFFLINE <compress_offline>` | ||||||
|  | setting. In case you don't use the ``compress`` management command, Django | ||||||
|  | Compressor will automatically fallback to the automatic compression using | ||||||
|  | the template tag. | ||||||
|  |  | ||||||
|  | The command parses all templates that can be found with the template | ||||||
|  | loader (as specified in the TEMPLATE_LOADERS_ setting) and looks for | ||||||
|  | ``{% compress %}`` blocks. It then will use the context as defined in | ||||||
|  | :ref:`COMPRESS_OFFLINE_CONTEXT <compress_offline_context>` to render its | ||||||
|  | content. So if you use any variables inside the ``{% compress %}`` blocks, | ||||||
|  | make sure to list all values you require in ``COMPRESS_OFFLINE_CONTEXT``. | ||||||
|  | It's similar to a template context and should be used if a variable is used | ||||||
|  | in the blocks, e.g.: | ||||||
|  |  | ||||||
|  | .. code-block:: django | ||||||
|  |  | ||||||
|  |     {% load compress %} | ||||||
|  |     {% compress js %} | ||||||
|  |     <script src="{{ path_to_files }}js/one.js" type="text/javascript" charset="utf-8"></script> | ||||||
|  |     {% endcompress %} | ||||||
|  |  | ||||||
|  | Since this template requires a variable (``path_to_files``) you need to | ||||||
|  | specify this in your settings before using the ``compress`` management | ||||||
|  | command:: | ||||||
|  |  | ||||||
|  |     COMPRESS_OFFLINE_CONTEXT = { | ||||||
|  |         'path_to_files': '/static/js/', | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | If not specified, the ``COMPRESS_OFFLINE_CONTEXT`` will by default contain | ||||||
|  | the commonly used setting to refer to saved files ``MEDIA_URL`` and | ||||||
|  | ``STATIC_URL`` (if specified in the settings). | ||||||
|  |  | ||||||
|  | The result of running the ``compress`` management command will be saved | ||||||
|  | in the cache defined in :ref:`COMPRESS_CACHE_BACKEND <compress_cache_backend>` | ||||||
|  | for the number of seconds defined in the | ||||||
|  | :ref:`COMPRESS_OFFLINE_TIMEOUT <compress_offline_timeout>` setting. | ||||||
|  |  | ||||||
|  | .. _TEMPLATE_LOADERS: http://docs.djangoproject.com/en/dev/ref/settings/#template-loaders | ||||||
|  |  | ||||||
| CSS Notes | CSS Notes | ||||||
| --------- | --------- | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Jannis Leidel
					Jannis Leidel