mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	Corrected a regression in validation of admin fieldsets with nested definitions from r11744. Thanks to Davor Lučić for the report.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@11752 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -219,19 +219,24 @@ def validate_base(cls, model): | ||||
|                 raise ImproperlyConfigured("'fields' key is required in " | ||||
|                         "%s.fieldsets[%d][1] field options dict." | ||||
|                         % (cls.__name__, idx)) | ||||
|             for field in fieldset[1]['fields']: | ||||
|                 check_formfield(cls, model, opts, "fieldsets[%d][1]['fields']" % idx, field) | ||||
|                 try: | ||||
|                     f = opts.get_field(field) | ||||
|                     if isinstance(f, models.ManyToManyField) and not f.rel.through._meta.auto_created: | ||||
|                         raise ImproperlyConfigured("'%s.fieldsets[%d][1]['fields']' " | ||||
|                             "can't include the ManyToManyField field '%s' because " | ||||
|                             "'%s' manually specifies a 'through' model." % ( | ||||
|                                 cls.__name__, idx, field, field)) | ||||
|                 except models.FieldDoesNotExist: | ||||
|                     # If we can't find a field on the model that matches, | ||||
|                     # it could be an extra field on the form. | ||||
|                     pass | ||||
|             for fields in fieldset[1]['fields']: | ||||
|                 # The entry in fields might be a tuple. If it is a standalone | ||||
|                 # field, make it into a tuple to make processing easier. | ||||
|                 if type(fields) != tuple: | ||||
|                     fields = (fields,) | ||||
|                 for field in fields: | ||||
|                     check_formfield(cls, model, opts, "fieldsets[%d][1]['fields']" % idx, field) | ||||
|                     try: | ||||
|                         f = opts.get_field(field) | ||||
|                         if isinstance(f, models.ManyToManyField) and not f.rel.through._meta.auto_created: | ||||
|                             raise ImproperlyConfigured("'%s.fieldsets[%d][1]['fields']' " | ||||
|                                 "can't include the ManyToManyField field '%s' because " | ||||
|                                 "'%s' manually specifies a 'through' model." % ( | ||||
|                                     cls.__name__, idx, field, field)) | ||||
|                     except models.FieldDoesNotExist: | ||||
|                         # If we can't find a field on the model that matches, | ||||
|                         # it could be an extra field on the form. | ||||
|                         pass | ||||
|         flattened_fieldsets = flatten_fieldsets(cls.fieldsets) | ||||
|         if len(flattened_fieldsets) > len(set(flattened_fieldsets)): | ||||
|             raise ImproperlyConfigured('There are duplicate field(s) in %s.fieldsets' % cls.__name__) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user