mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Changed ModelForms to allow inheritance as long as their model attributes are the same.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@6917 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -245,14 +245,14 @@ class ModelFormMetaclass(type): | |||||||
|  |  | ||||||
|         # If a model is defined, extract form fields from it and add them to base_fields |         # If a model is defined, extract form fields from it and add them to base_fields | ||||||
|         if attrs['_meta'].model is not None: |         if attrs['_meta'].model is not None: | ||||||
|             # Don't allow a subclass to define a Meta model if a parent class has. |             # Don't allow a subclass to define a different Meta model than a | ||||||
|             # Technically the right fields would be generated, but the save  |             # parent class has. Technically the right fields would be generated, | ||||||
|             # method will not deal with more than one model. |             # but the save method will not deal with more than one model. | ||||||
|             for base in bases: |             for base in bases: | ||||||
|                 base_opts = getattr(base, '_meta', None) |                 base_opts = getattr(base, '_meta', None) | ||||||
|                 base_model = getattr(base_opts, 'model', None) |                 base_model = getattr(base_opts, 'model', None) | ||||||
|                 if base_model is not None: |                 if base_model and base_model is not opts.model: | ||||||
|                     raise ImproperlyConfigured('%s defines more than one model.' % name) |                     raise ImproperlyConfigured('%s defines a different model than its parent.' % name) | ||||||
|             model_fields = fields_for_model(opts.model, opts.fields, opts.exclude) |             model_fields = fields_for_model(opts.model, opts.fields, opts.exclude) | ||||||
|             # fields declared in base classes override fields from the model |             # fields declared in base classes override fields from the model | ||||||
|             model_fields.update(declared_fields) |             model_fields.update(declared_fields) | ||||||
|   | |||||||
| @@ -143,7 +143,7 @@ familiar with the mechanics. | |||||||
| ...         model = Article | ...         model = Article | ||||||
| Traceback (most recent call last): | Traceback (most recent call last): | ||||||
| ... | ... | ||||||
| ImproperlyConfigured: BadForm defines more than one model. | ImproperlyConfigured: BadForm defines a different model than its parent. | ||||||
|  |  | ||||||
| >>> class ArticleForm(ModelForm): | >>> class ArticleForm(ModelForm): | ||||||
| ...     class Meta: | ...     class Meta: | ||||||
| @@ -155,6 +155,12 @@ Traceback (most recent call last): | |||||||
| ... | ... | ||||||
| ImproperlyConfigured: BadForm's base classes define more than one model. | ImproperlyConfigured: BadForm's base classes define more than one model. | ||||||
|  |  | ||||||
|  | This one is OK since the subclass specifies the same model as the parent. | ||||||
|  |  | ||||||
|  | >>> class SubCategoryForm(CategoryForm): | ||||||
|  | ...     class Meta: | ||||||
|  | ...         model = Category | ||||||
|  |  | ||||||
|  |  | ||||||
| # Old form_for_x tests ####################################################### | # Old form_for_x tests ####################################################### | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user