Author: Alex
Date: 2010-10-08 18:55:38 -0500 (Fri, 08 Oct 2010)
New Revision: 14046

Modified:
   django/branches/releases/1.2.X/AUTHORS
   django/branches/releases/1.2.X/django/db/models/base.py
   
django/branches/releases/1.2.X/tests/modeltests/order_with_respect_to/models.py
   
django/branches/releases/1.2.X/tests/modeltests/order_with_respect_to/tests.py
Log:
[1.2.X] Fixed #13241.  order_with_respect_to now works with ForeignKeys who 
refer to their model lazily (i.e. with a string).  Thanks to Gabriel Grant for 
the patch.  This is a backport of [14045].

Modified: django/branches/releases/1.2.X/AUTHORS
===================================================================
--- django/branches/releases/1.2.X/AUTHORS      2010-10-08 23:54:43 UTC (rev 
14045)
+++ django/branches/releases/1.2.X/AUTHORS      2010-10-08 23:55:38 UTC (rev 
14046)
@@ -197,6 +197,7 @@
     David Gouldin <dgoul...@gmail.com>
     pradeep.go...@gmail.com
     Collin Grady <col...@collingrady.com>
+    Gabriel Grant <g...@briel.ca>
     Simon Greenhill <d...@simon.net.nz>
     Owen Griffiths
     Espen Grindhaug <http://grindhaug.org/>

Modified: django/branches/releases/1.2.X/django/db/models/base.py
===================================================================
--- django/branches/releases/1.2.X/django/db/models/base.py     2010-10-08 
23:54:43 UTC (rev 14045)
+++ django/branches/releases/1.2.X/django/db/models/base.py     2010-10-08 
23:55:38 UTC (rev 14046)
@@ -5,7 +5,8 @@
 from django.core.exceptions import ObjectDoesNotExist, 
MultipleObjectsReturned, FieldError, ValidationError, NON_FIELD_ERRORS
 from django.core import validators
 from django.db.models.fields import AutoField, FieldDoesNotExist
-from django.db.models.fields.related import OneToOneRel, ManyToOneRel, 
OneToOneField
+from django.db.models.fields.related import (OneToOneRel, ManyToOneRel,
+    OneToOneField, add_lazy_relation)
 from django.db.models.query import delete_objects, Q
 from django.db.models.query_utils import CollectedObjects, DeferredAttribute
 from django.db.models.options import Options
@@ -223,8 +224,25 @@
         if opts.order_with_respect_to:
             cls.get_next_in_order = curry(cls._get_next_or_previous_in_order, 
is_next=True)
             cls.get_previous_in_order = 
curry(cls._get_next_or_previous_in_order, is_next=False)
-            setattr(opts.order_with_respect_to.rel.to, 'get_%s_order' % 
cls.__name__.lower(), curry(method_get_order, cls))
-            setattr(opts.order_with_respect_to.rel.to, 'set_%s_order' % 
cls.__name__.lower(), curry(method_set_order, cls))
+            # defer creating accessors on the foreign class until we are
+            # certain it has been created
+            def make_foreign_order_accessors(field, model, cls):
+                setattr(
+                    field.rel.to,
+                    'get_%s_order' % cls.__name__.lower(),
+                    curry(method_get_order, cls)
+                )
+                setattr(
+                    field.rel.to,
+                    'set_%s_order' % cls.__name__.lower(),
+                    curry(method_set_order, cls)
+                )
+            add_lazy_relation(
+                cls,
+                opts.order_with_respect_to,
+                opts.order_with_respect_to.rel.to,
+                make_foreign_order_accessors
+            )
 
         # Give the class a docstring -- its definition.
         if cls.__doc__ is None:

Modified: 
django/branches/releases/1.2.X/tests/modeltests/order_with_respect_to/models.py
===================================================================
--- 
django/branches/releases/1.2.X/tests/modeltests/order_with_respect_to/models.py 
    2010-10-08 23:54:43 UTC (rev 14045)
+++ 
django/branches/releases/1.2.X/tests/modeltests/order_with_respect_to/models.py 
    2010-10-08 23:55:38 UTC (rev 14046)
@@ -17,3 +17,13 @@
 
     def __unicode__(self):
         return unicode(self.text)
+
+class Post(models.Model):
+    title = models.CharField(max_length=200)
+    parent = models.ForeignKey("self", related_name="children", null=True)
+
+    class Meta:
+        order_with_respect_to = "parent"
+
+    def __unicode__(self):
+        return self.title

Modified: 
django/branches/releases/1.2.X/tests/modeltests/order_with_respect_to/tests.py
===================================================================
--- 
django/branches/releases/1.2.X/tests/modeltests/order_with_respect_to/tests.py  
    2010-10-08 23:54:43 UTC (rev 14045)
+++ 
django/branches/releases/1.2.X/tests/modeltests/order_with_respect_to/tests.py  
    2010-10-08 23:55:38 UTC (rev 14046)
@@ -2,7 +2,7 @@
 
 from django.test import TestCase
 
-from models import Question, Answer
+from models import Post, Question, Answer
 
 
 class OrderWithRespectToTests(TestCase):
@@ -60,3 +60,12 @@
             ],
             attrgetter("text")
         )
+
+    def test_recursive_ordering(self):
+        p1 = Post.objects.create(title='1')
+        p2 = Post.objects.create(title='2')
+        p1_1 = Post.objects.create(title="1.1", parent=p1)
+        p1_2 = Post.objects.create(title="1.2", parent=p1)
+        p2_1 = Post.objects.create(title="2.1", parent=p2)
+        p1_3 = Post.objects.create(title="1.3", parent=p1)
+        self.assertEqual(p1.get_post_order(), [p1_1.pk, p1_2.pk, p1_3.pk])

-- 
You received this message because you are subscribed to the Google Groups 
"Django updates" group.
To post to this group, send email to django-upda...@googlegroups.com.
To unsubscribe from this group, send email to 
django-updates+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/django-updates?hl=en.

Reply via email to