mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Make `Formset.__getitem__ O(1), rather than O(n). If you override __iter__ you now need to also override __getitem__` for consistant behavior. Thanks to Carl and Russ for the review.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@16770 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
@@ -55,7 +55,7 @@ class BaseFormSet(StrAndUnicode):
|
||||
|
||||
def __getitem__(self, index):
|
||||
"""Returns the form at the given index, based on the rendering order"""
|
||||
return list(self)[index]
|
||||
return self.forms[index]
|
||||
|
||||
def __len__(self):
|
||||
return len(self.forms)
|
||||
|
||||
@@ -49,6 +49,10 @@ they were created. The default formset iterator also renders the forms
|
||||
in this order, but you can change this order by providing an alternate
|
||||
implementation for the :meth:`__iter__()` method.
|
||||
|
||||
Formsets can also be indexed into, which returns the corresponding form. If you
|
||||
override ``__iter__``, you will need to also override ``__getitem__`` to have
|
||||
matching behavior.
|
||||
|
||||
Using initial data with a formset
|
||||
---------------------------------
|
||||
|
||||
|
||||
@@ -793,8 +793,10 @@ class FormsFormsetTestCase(TestCase):
|
||||
# Formets can override the default iteration order
|
||||
class BaseReverseFormSet(BaseFormSet):
|
||||
def __iter__(self):
|
||||
for form in reversed(self.forms):
|
||||
yield form
|
||||
return reversed(self.forms)
|
||||
|
||||
def __getitem__(self, idx):
|
||||
return super(BaseReverseFormSet, self).__getitem__(len(self) - idx - 1)
|
||||
|
||||
ReverseChoiceFormset = formset_factory(Choice, BaseReverseFormSet, extra=3)
|
||||
reverse_formset = ReverseChoiceFormset()
|
||||
|
||||
Reference in New Issue
Block a user