rdobuilder f03bbc
From 72b33ddbcdc41eb5af42b86329d81d96894a9d10 Mon Sep 17 00:00:00 2001
rdobuilder f03bbc
From: Carlton Gibson <carlton.gibson@noumenal.co.uk>
rdobuilder f03bbc
Date: Tue, 10 Mar 2015 20:04:07 +0100
rdobuilder f03bbc
Subject: [PATCH] Make `compress` command (at least) run through on 1.8
rdobuilder f03bbc
rdobuilder f03bbc
FAILED (failures=15, errors=15, skipped=1)
rdobuilder f03bbc
rdobuilder f03bbc
AssertionError: 2 != 12
rdobuilder f03bbc
OfflineGenerationError: ... key "XYZ" missing ...
rdobuilder f03bbc
---
rdobuilder f03bbc
 compressor/management/commands/compress.py | 41 +++++++++++++++++-------------
rdobuilder f03bbc
 compressor/offline/django.py               | 27 ++++++++++++++------
rdobuilder f03bbc
 2 files changed, 43 insertions(+), 25 deletions(-)
rdobuilder f03bbc
rdobuilder f03bbc
diff --git a/compressor/management/commands/compress.py b/compressor/management/commands/compress.py
rdobuilder f03bbc
index 6be215e..0bc436a 100644
rdobuilder f03bbc
--- a/compressor/management/commands/compress.py
rdobuilder f03bbc
+++ b/compressor/management/commands/compress.py
rdobuilder f03bbc
@@ -5,6 +5,7 @@
rdobuilder f03bbc
 from fnmatch import fnmatch
rdobuilder f03bbc
 from optparse import make_option
rdobuilder f03bbc
 
rdobuilder f03bbc
+import django
rdobuilder f03bbc
 from django.core.management.base import NoArgsCommand, CommandError
rdobuilder f03bbc
 import django.template
rdobuilder f03bbc
 from django.template import Context
rdobuilder f03bbc
@@ -53,24 +54,30 @@ class Command(NoArgsCommand):
rdobuilder f03bbc
     requires_model_validation = False
rdobuilder f03bbc
 
rdobuilder f03bbc
     def get_loaders(self):
rdobuilder f03bbc
-        from django.template.loader import template_source_loaders
rdobuilder f03bbc
-        if template_source_loaders is None:
rdobuilder f03bbc
-            try:
rdobuilder f03bbc
-                from django.template.loader import (
rdobuilder f03bbc
-                    find_template as finder_func)
rdobuilder f03bbc
-            except ImportError:
rdobuilder f03bbc
-                from django.template.loader import (
rdobuilder f03bbc
-                    find_template_source as finder_func)  # noqa
rdobuilder f03bbc
-            try:
rdobuilder f03bbc
-                # Force django to calculate template_source_loaders from
rdobuilder f03bbc
-                # TEMPLATE_LOADERS settings, by asking to find a dummy template
rdobuilder f03bbc
-                source, name = finder_func('test')
rdobuilder f03bbc
-            except django.template.TemplateDoesNotExist:
rdobuilder f03bbc
-                pass
rdobuilder f03bbc
-            # Reload template_source_loaders now that it has been calculated ;
rdobuilder f03bbc
-            # it should contain the list of valid, instanciated template loaders
rdobuilder f03bbc
-            # to use.
rdobuilder f03bbc
+        if django.VERSION < (1, 8):
rdobuilder f03bbc
             from django.template.loader import template_source_loaders
rdobuilder f03bbc
+            if template_source_loaders is None:
rdobuilder f03bbc
+                try:
rdobuilder f03bbc
+                    from django.template.loader import (
rdobuilder f03bbc
+                        find_template as finder_func)
rdobuilder f03bbc
+                except ImportError:
rdobuilder f03bbc
+                    from django.template.loader import (
rdobuilder f03bbc
+                        find_template_source as finder_func)  # noqa
rdobuilder f03bbc
+                try:
rdobuilder f03bbc
+                    # Force django to calculate template_source_loaders from
rdobuilder f03bbc
+                    # TEMPLATE_LOADERS settings, by asking to find a dummy template
rdobuilder f03bbc
+                    source, name = finder_func('test')
rdobuilder f03bbc
+                except django.template.TemplateDoesNotExist:
rdobuilder f03bbc
+                    pass
rdobuilder f03bbc
+                # Reload template_source_loaders now that it has been calculated ;
rdobuilder f03bbc
+                # it should contain the list of valid, instanciated template loaders
rdobuilder f03bbc
+                # to use.
rdobuilder f03bbc
+                from django.template.loader import template_source_loaders
rdobuilder f03bbc
+        else:
rdobuilder f03bbc
+            from django.template import engines
rdobuilder f03bbc
+            template_source_loaders = []
rdobuilder f03bbc
+            for e in engines.all():
rdobuilder f03bbc
+                template_source_loaders.extend(e.engine.get_template_loaders(e.engine.loaders))
rdobuilder f03bbc
         loaders = []
rdobuilder f03bbc
         # If template loader is CachedTemplateLoader, return the loaders
rdobuilder f03bbc
         # that it wraps around. So if we have
rdobuilder f03bbc
diff --git a/compressor/offline/django.py b/compressor/offline/django.py
rdobuilder f03bbc
index b326093..107c6e4 100644
rdobuilder f03bbc
--- a/compressor/offline/django.py
rdobuilder f03bbc
+++ b/compressor/offline/django.py
rdobuilder f03bbc
@@ -1,6 +1,7 @@
rdobuilder f03bbc
 from __future__ import absolute_import
rdobuilder f03bbc
 from copy import copy
rdobuilder f03bbc
 
rdobuilder f03bbc
+import django
rdobuilder f03bbc
 from django import template
rdobuilder f03bbc
 from django.conf import settings
rdobuilder f03bbc
 from django.template import Context
rdobuilder f03bbc
@@ -14,7 +15,7 @@
rdobuilder f03bbc
 from compressor.templatetags.compress import CompressorNode
rdobuilder f03bbc
 
rdobuilder f03bbc
 
rdobuilder f03bbc
-def handle_extendsnode(extendsnode, block_context=None):
rdobuilder f03bbc
+def handle_extendsnode(extendsnode, block_context=None, original=None):
rdobuilder f03bbc
     """Create a copy of Node tree of a derived template replacing
rdobuilder f03bbc
     all blocks tags with the nodes of appropriate blocks.
rdobuilder f03bbc
     Also handles {{ block.super }} tags.
rdobuilder f03bbc
@@ -26,6 +27,9 @@ def handle_extendsnode(extendsnode, block_context=None):
rdobuilder f03bbc
     block_context.add_blocks(blocks)
rdobuilder f03bbc
 
rdobuilder f03bbc
     context = Context(settings.COMPRESS_OFFLINE_CONTEXT)
rdobuilder f03bbc
+    if original is not None:
rdobuilder f03bbc
+        context.template = original
rdobuilder f03bbc
+
rdobuilder f03bbc
     compiled_parent = extendsnode.get_parent(context)
rdobuilder f03bbc
     parent_nodelist = compiled_parent.nodelist
rdobuilder f03bbc
     # If the parent template has an ExtendsNode it is not the root.
rdobuilder f03bbc
@@ -33,7 +37,7 @@ def handle_extendsnode(extendsnode, block_context=None):
rdobuilder f03bbc
         # The ExtendsNode has to be the first non-text node.
rdobuilder f03bbc
         if not isinstance(node, TextNode):
rdobuilder f03bbc
             if isinstance(node, ExtendsNode):
rdobuilder f03bbc
-                return handle_extendsnode(node, block_context)
rdobuilder f03bbc
+                return handle_extendsnode(node, block_context, original)
rdobuilder f03bbc
             break
rdobuilder f03bbc
     # Add blocks of the root template to block context.
rdobuilder f03bbc
     blocks = dict((n.name, n) for n in
rdobuilder f03bbc
@@ -95,7 +99,10 @@ def __init__(self, charset):
rdobuilder f03bbc
 
rdobuilder f03bbc
     def parse(self, template_name):
rdobuilder f03bbc
         try:
rdobuilder f03bbc
-            return get_template(template_name)
rdobuilder f03bbc
+            if django.VERSION < (1, 8):
rdobuilder f03bbc
+                return get_template(template_name)
rdobuilder f03bbc
+            else:
rdobuilder f03bbc
+                return get_template(template_name).template
rdobuilder f03bbc
         except template.TemplateSyntaxError as e:
rdobuilder f03bbc
             raise TemplateSyntaxError(str(e))
rdobuilder f03bbc
         except template.TemplateDoesNotExist as e:
rdobuilder f03bbc
@@ -111,15 +118,17 @@ def process_node(self, template, context, node):
rdobuilder f03bbc
         pass
rdobuilder f03bbc
 
rdobuilder f03bbc
     def render_nodelist(self, template, context, node):
rdobuilder f03bbc
+        if django.VERSION >= (1, 8):
rdobuilder f03bbc
+            context.template = template
rdobuilder f03bbc
         return node.nodelist.render(context)
rdobuilder f03bbc
 
rdobuilder f03bbc
     def render_node(self, template, context, node):
rdobuilder f03bbc
         return node.render(context, forced=True)
rdobuilder f03bbc
 
rdobuilder f03bbc
-    def get_nodelist(self, node):
rdobuilder f03bbc
+    def get_nodelist(self, node, original=None):
rdobuilder f03bbc
         if isinstance(node, ExtendsNode):
rdobuilder f03bbc
             try:
rdobuilder f03bbc
-                return handle_extendsnode(node)
rdobuilder f03bbc
+                return handle_extendsnode(node, block_context=None, original=original)
rdobuilder f03bbc
             except template.TemplateSyntaxError as e:
rdobuilder f03bbc
                 raise TemplateSyntaxError(str(e))
rdobuilder f03bbc
             except template.TemplateDoesNotExist as e:
rdobuilder f03bbc
@@ -134,10 +143,12 @@ def get_nodelist(self, node):
rdobuilder f03bbc
             nodelist = getattr(node, 'nodelist', [])
rdobuilder f03bbc
         return nodelist
rdobuilder f03bbc
 
rdobuilder f03bbc
-    def walk_nodes(self, node):
rdobuilder f03bbc
-        for node in self.get_nodelist(node):
rdobuilder f03bbc
+    def walk_nodes(self, node, original=None):
rdobuilder f03bbc
+        if django.VERSION >= (1, 8) and original is None:
rdobuilder f03bbc
+            original = node
rdobuilder f03bbc
+        for node in self.get_nodelist(node, original):
rdobuilder f03bbc
             if isinstance(node, CompressorNode) and node.is_offline_compression_enabled(forced=True):
rdobuilder f03bbc
                 yield node
rdobuilder f03bbc
             else:
rdobuilder f03bbc
-                for node in self.walk_nodes(node):
rdobuilder f03bbc
+                for node in self.walk_nodes(node, original):
rdobuilder f03bbc
                     yield node