diff --git a/compressor/base.py b/compressor/base.py index ee235f1..a1ee033 100644 --- a/compressor/base.py +++ b/compressor/base.py @@ -123,7 +123,7 @@ class Compressor(object): return get_hexdigest(''.join( [self.content] + self.mtimes).encode(self.charset), 12) - def hunks(self, mode='file', forced=False): + def hunks(self, forced=False): """ The heart of content parsing, iterates of the list of split contents and looks at its kind @@ -152,29 +152,29 @@ class Compressor(object): if enabled: value = self.filter(value, **options) - yield mode, smart_unicode(value, charset.lower()) + yield smart_unicode(value, charset.lower()) else: if precompiled: value = self.handle_output(kind, value, forced=True, basename=basename) - yield "verbatim", smart_unicode(value, charset.lower()) + yield smart_unicode(value, charset.lower()) else: - yield mode, self.parser.elem_str(elem) + yield self.parser.elem_str(elem) - def filtered_output(self, content): + def filter_output(self, content): """ Passes the concatenated content to the 'output' methods of the compressor filters. """ return self.filter(content, method=METHOD_OUTPUT) - def filtered_input(self, mode='file', forced=False): + def filter_input(self, forced=False): """ Passes each hunk (file or code) to the 'input' methods of the compressor filters. """ content = [] - for mode, hunk in self.hunks(mode, forced): - content.append((mode, hunk)) + for hunk in self.hunks(forced): + content.append(hunk) return content def precompile(self, content, kind=None, elem=None, filename=None, **kwargs): @@ -211,17 +211,15 @@ class Compressor(object): any custom modification. Calls other mode specific methods or simply returns the content directly. """ - content = self.filtered_input(mode, forced) + content = self.filter_input(forced) if not content: return '' - charset = self.charset - output = '\n'.join(c.encode(charset) for (m, c) in content) + output = '\n'.join(c.encode(self.charset) for c in content) if settings.COMPRESS_ENABLED or forced: - filtered_content = self.filtered_output(output) - finished_content = self.handle_output(mode, filtered_content, forced) - output = finished_content + filtered_output = self.filter_output(output) + return self.handle_output(mode, filtered_output, forced) return output diff --git a/compressor/templatetags/compress.py b/compressor/templatetags/compress.py index 35a5224..f1b1f01 100644 --- a/compressor/templatetags/compress.py +++ b/compressor/templatetags/compress.py @@ -69,6 +69,9 @@ class CompressorNode(template.Node): return cache_key, cache_content return None, None + def render_output(self, compressor, forced=False): + return compressor.output(self.mode, forced=forced) + def render(self, context, forced=False): # Check if in debug mode @@ -90,7 +93,7 @@ class CompressorNode(template.Node): return cache_content # call compressor output method and handle exceptions - rendered_output = compressor.output(self.mode, forced=forced) + rendered_output = self.render_output(compressor, forced) if cache_key: cache_set(cache_key, rendered_output) return rendered_output diff --git a/tests/tests/base.py b/tests/tests/base.py index 1b902f6..097fabe 100644 --- a/tests/tests/base.py +++ b/tests/tests/base.py @@ -51,12 +51,11 @@ class CompressorTestCase(TestCase): def test_css_hunks(self): out = ['body { background:#990; }', u'p { border:5px solid green;}', 'body { color:#fff; }'] - hunks = [h for m, h in self.css_node.hunks()] - self.assertEqual(out, hunks) + self.assertEqual(out, list(self.css_node.hunks())) def test_css_output(self): out = u'body { background:#990; }\np { border:5px solid green;}\nbody { color:#fff; }' - hunks = '\n'.join([h for m, h in self.css_node.hunks()]) + hunks = '\n'.join([h for h in self.css_node.hunks()]) self.assertEqual(out, hunks) def test_css_mtimes(self): @@ -89,8 +88,7 @@ class CompressorTestCase(TestCase): def test_js_hunks(self): out = ['obj = {};', u'obj.value = "value";'] - hunks = [h for m, h in self.js_node.hunks()] - self.assertEqual(out, hunks) + self.assertEqual(out, list(self.js_node.hunks())) def test_js_output(self): out = u'' diff --git a/tests/tests/filters.py b/tests/tests/filters.py index abf74ed..92fd551 100644 --- a/tests/tests/filters.py +++ b/tests/tests/filters.py @@ -145,7 +145,6 @@ class CssAbsolutizingTestCase(TestCase): 'hash1': self.hashing_func(os.path.join(settings.COMPRESS_ROOT, 'img/python.png')), 'hash2': self.hashing_func(os.path.join(settings.COMPRESS_ROOT, 'img/add.png')), } - hunks = [h for m, h in self.css_node.hunks()] self.assertEqual([u"""\ p { background: url('/media/img/python.png?%(hash1)s'); } p { background: url('/media/img/python.png?%(hash1)s'); } @@ -157,7 +156,7 @@ p { background: url('/media/img/add.png?%(hash2)s'); } p { background: url('/media/img/add.png?%(hash2)s'); } p { background: url('/media/img/add.png?%(hash2)s'); } p { background: url('/media/img/add.png?%(hash2)s'); } -""" % hash_dict], hunks) +""" % hash_dict], list(self.css_node.hunks())) def test_guess_filename(self): for base_url in ('/media/', 'http://media.example.com/'): @@ -199,5 +198,4 @@ class CssDataUriTestCase(TestCase): 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] - hunks = [h for m, h in self.css_node.hunks()] - self.assertEqual(out, hunks) + self.assertEqual(out, list(self.css_node.hunks()))