diff options
| author | Rudraksha Dwivedi <146867502+Rudraksha-007@users.noreply.github.com> | 2026-01-13 00:04:14 +0530 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2026-01-12 13:34:14 -0500 |
| commit | 21ceaf2fd75bb994b7a0e3b691171d6b34ffc913 (patch) | |
| tree | 4b57515830d4ba5d946262b4231c47f05fb850a6 /django/contrib/admin/options.py | |
| parent | 64ac4385c75b12a4065055b3d8d60bd5e0e61f04 (diff) | |
Fixed #36708 -- Initialized formset to None in ChangeList.__init__().
Thanks Antoliny for the review.
Diffstat (limited to 'django/contrib/admin/options.py')
| -rw-r--r-- | django/contrib/admin/options.py | 19 |
1 files changed, 6 insertions, 13 deletions
diff --git a/django/contrib/admin/options.py b/django/contrib/admin/options.py index 6c202c8e61..2de07fde7e 100644 --- a/django/contrib/admin/options.py +++ b/django/contrib/admin/options.py @@ -2050,11 +2050,6 @@ class ModelAdmin(BaseModelAdmin): # me back" button on the action confirmation page. return HttpResponseRedirect(request.get_full_path()) - # If we're allowing changelist editing, we need to construct a formset - # for the changelist given all the fields to be edited. Then we'll - # use the formset to validate/process POSTed data. - formset = cl.formset = None - # Handle POSTed bulk-edit data. if request.method == "POST" and cl.list_editable and "_save" in request.POST: if not self.has_change_permission(request): @@ -2063,13 +2058,11 @@ class ModelAdmin(BaseModelAdmin): modified_objects = self._get_list_editable_queryset( request, FormSet.get_default_prefix() ) - formset = cl.formset = FormSet( - request.POST, request.FILES, queryset=modified_objects - ) - if formset.is_valid(): + cl.formset = FormSet(request.POST, request.FILES, queryset=modified_objects) + if cl.formset.is_valid(): changecount = 0 with transaction.atomic(using=router.db_for_write(self.model)): - for form in formset.forms: + for form in cl.formset.forms: if form.has_changed(): obj = self.save_form(request, form, change=True) self.save_model(request, obj, form, change=True) @@ -2095,11 +2088,11 @@ class ModelAdmin(BaseModelAdmin): # Handle GET -- construct a formset for display. elif cl.list_editable and self.has_change_permission(request): FormSet = self.get_changelist_formset(request) - formset = cl.formset = FormSet(queryset=cl.result_list) + cl.formset = FormSet(queryset=cl.result_list) # Build the list of media to be used by the formset. - if formset: - media = self.media + formset.media + if cl.formset: + media = self.media + cl.formset.media else: media = self.media |
