Fixed #18389 -- Fixed the way contribute_to_class is called

Now this method is only called only if the object is an instance.
This allows to have field classes as model class attributes.
This commit is contained in:
Vlad Starostin 2014-05-16 14:25:45 +02:00 committed by Tim Graham
parent ddd52b221c
commit 1be03aff5c
2 changed files with 14 additions and 2 deletions

View File

@ -1,6 +1,7 @@
from __future__ import unicode_literals from __future__ import unicode_literals
import copy import copy
import inspect
import sys import sys
from functools import update_wrapper from functools import update_wrapper
import warnings import warnings
@ -299,7 +300,8 @@ class ModelBase(type):
cls.add_to_class(mgr_name, new_manager) cls.add_to_class(mgr_name, new_manager)
def add_to_class(cls, name, value): def add_to_class(cls, name, value):
if hasattr(value, 'contribute_to_class'): # We should call the contirbute_to_class method only if it's bound
if not inspect.isclass(value) and hasattr(value, 'contribute_to_class'):
value.contribute_to_class(cls, name) value.contribute_to_class(cls, name)
else: else:
setattr(cls, name, value) setattr(cls, name, value)

View File

@ -145,12 +145,22 @@ class VerboseNameField(models.Model):
field22 = models.URLField("verbose field22") field22 = models.URLField("verbose field22")
# This model isn't used in any test, just here to ensure it validates successfully. ###############################################################################
# These models aren't used in any test, just here to ensure they validate
# successfully.
# See ticket #16570. # See ticket #16570.
class DecimalLessThanOne(models.Model): class DecimalLessThanOne(models.Model):
d = models.DecimalField(max_digits=3, decimal_places=3) d = models.DecimalField(max_digits=3, decimal_places=3)
# See ticket #18389.
class FieldClassAttributeModel(models.Model):
field_class = models.CharField
###############################################################################
class DataModel(models.Model): class DataModel(models.Model):
short_data = models.BinaryField(max_length=10, default=b'\x08') short_data = models.BinaryField(max_length=10, default=b'\x08')
data = models.BinaryField() data = models.BinaryField()