Permalink
Browse files

Merge pull request #184 from sebpiq/develop

Added TemplateFilter + tests and docs.
  • Loading branch information...
2 parents f752c7b + c462c5d commit 37a7d78fe523e3733b23d7b2ce3d215d4fa46fff @jezdez jezdez committed Jan 16, 2012
Showing with 64 additions and 1 deletion.
  1. +10 −0 compressor/conf.py
  2. +12 −0 compressor/filters/template.py
  3. +1 −1 compressor/tests/__init__.py
  4. +24 −0 compressor/tests/filters.py
  5. +17 −0 docs/settings.txt
View
@@ -62,6 +62,8 @@ class CompressorConf(AppConf):
OFFLINE_CONTEXT = {}
# The name of the manifest file (e.g. filename.ext)
OFFLINE_MANIFEST = 'manifest.json'
+ # The Context to be used when TemplateFilter is used
+ TEMPLATE_FILTER_CONTEXT = {}
class Meta:
prefix = 'compress'
@@ -107,6 +109,14 @@ def configure_offline_context(self, value):
value['STATIC_URL'] = settings.STATIC_URL
return value
+ def configure_template_filter_context(self, value):
+ if not value:
+ value = {'MEDIA_URL': settings.MEDIA_URL}
+ # Adds the 1.3 STATIC_URL setting to the context if available
+ if getattr(settings, 'STATIC_URL', None):
+ value['STATIC_URL'] = settings.STATIC_URL
+ return value
+
def configure_precompilers(self, value):
if not isinstance(value, (list, tuple)):
raise ImproperlyConfigured("The COMPRESS_PRECOMPILERS setting "
@@ -0,0 +1,12 @@
+from django.template import Template, Context
+from django.conf import settings
+
+from compressor.filters import FilterBase, FilterError
+
+
+class TemplateFilter(FilterBase):
+
+ def input(self, filename=None, basename=None, **kwargs):
+ template = Template(self.content)
+ context = Context(settings.COMPRESS_TEMPLATE_FILTER_CONTEXT)
+ return template.render(context)
@@ -2,7 +2,7 @@
VerboseTestCase, CacheBackendTestCase)
from compressor.tests.filters import (CssTidyTestCase, PrecompilerTestCase,
CssMinTestCase, CssAbsolutizingTestCase, CssAbsolutizingTestCaseWithHash,
- CssDataUriTestCase)
+ CssDataUriTestCase, TemplateTestCase)
from compressor.tests.jinja2ext import TestJinja2CompressorExtension
from compressor.tests.offline import (
OfflineGenerationBlockSuperTestCase, OfflineGenerationConditionTestCase,
@@ -12,6 +12,7 @@
from compressor.filters.base import CompilerFilter
from compressor.filters.cssmin import CSSMinFilter
from compressor.filters.css_default import CssAbsoluteFilter
+from compressor.filters.template import TemplateFilter
from compressor.tests.base import test_dir
@@ -198,3 +199,26 @@ def test_data_uris(self):
datauri_hash = get_hashed_mtime(os.path.join(settings.COMPRESS_ROOT, 'css/datauri.css'))
out = [u'.add { background-image: url(""); }\n.python { background-image: url("/media/img/python.png?%s"); }\n.datauri { background-image: url(" vr4MkhoXe0rZigAAAABJRU5ErkJggg=="); }\n' % datauri_hash]
self.assertEqual(out, list(self.css_node.hunks()))
+
+
+class TemplateTestCase(TestCase):
+ def setUp(self):
+ self.old_context = settings.COMPRESS_TEMPLATE_FILTER_CONTEXT
+
+ def tearDown(self):
+ settings.COMPRESS_TEMPLATE_FILTER_CONTEXT = self.old_context
+
+ def test_template_filter(self):
+ settings.COMPRESS_TEMPLATE_FILTER_CONTEXT = {
+ 'stuff': 'thing',
+ 'gimmick': 'bold'
+ }
+ content = """
+ #content {background-image: url("{{ STATIC_URL|default:stuff }}/images/bg.png");}
+ #footer {font-weight: {{ gimmick }};}
+ """
+ input = """
+ #content {background-image: url("thing/images/bg.png");}
+ #footer {font-weight: bold;}
+ """
+ self.assertEqual(input, TemplateFilter(content).input())
View
@@ -138,6 +138,15 @@ Backend settings
.. _`data: URIs`: http://en.wikipedia.org/wiki/Data_URI_scheme
.. _cssmin: http://pypi.python.org/pypi/cssmin/
+ - ``compressor.filters.template.TemplateFilter``
+
+ A filter that renders the CSS content with Django templating system.
+
+ .. attribute:: COMPRESS_TEMPLATE_FILTER_CONTEXT
+
+ The context to render your css files with.
+
+
.. _compress_js_filters:
.. attribute:: COMPRESS_JS_FILTERS
@@ -185,6 +194,14 @@ Backend settings
The arguments passed to the compressor.
+ - ``compressor.filters.template.TemplateFilter``
+
+ A filter that renders the JavaScript code with Django templating system.
+
+ .. attribute:: COMPRESS_TEMPLATE_FILTER_CONTEXT
+
+ The context to render your JavaScript code with.
+
.. _rJSmin: http://opensource.perlig.de/rjsmin/
.. _`Google Closure compiler`: http://code.google.com/closure/compiler/
.. _`YUI compressor`: http://developer.yahoo.com/yui/compressor/

0 comments on commit 37a7d78

Please sign in to comment.