Skip to content

Commit

Permalink
Fixed #1683 -- Permit initialising models using settable properties a…
Browse files Browse the repository at this point in the history
…s well as

field names.


git-svn-id: http://code.djangoproject.com/svn/django/trunk@3145 bcc190cf-cafb-0310-a4f2-bffc1f526a37
  • Loading branch information
malcolmt committed Jun 19, 2006
1 parent 214d88c commit 1fc3b32
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 0 deletions.
6 changes: 6 additions & 0 deletions django/db/models/base.py
Expand Up @@ -107,6 +107,12 @@ def __init__(self, *args, **kwargs):
else:
val = kwargs.pop(f.attname, f.get_default())
setattr(self, f.attname, val)
for prop in kwargs.keys():
try:
if isinstance(getattr(self.__class__, prop), property):
setattr(self, prop, kwargs.pop(prop))
except AttributeError:
pass
if kwargs:
raise TypeError, "'%s' is an invalid keyword argument for this function" % kwargs.keys()[0]
for i, arg in enumerate(args):
Expand Down
12 changes: 12 additions & 0 deletions tests/modeltests/properties/models.py
Expand Up @@ -12,8 +12,14 @@ class Person(models.Model):

def _get_full_name(self):
return "%s %s" % (self.first_name, self.last_name)

def _set_full_name(self, combined_name):
self.first_name, self.last_name = combined_name.split(' ', 1)

full_name = property(_get_full_name)

full_name_2 = property(_get_full_name, _set_full_name)

API_TESTS = """
>>> a = Person(first_name='John', last_name='Lennon')
>>> a.save()
Expand All @@ -25,4 +31,10 @@ def _get_full_name(self):
Traceback (most recent call last):
...
AttributeError: can't set attribute
# But "full_name_2" has, and it can be used to initialise the class.
>>> a2 = Person(full_name_2 = 'Paul McCartney')
>>> a2.save()
>>> a2.first_name
'Paul'
"""

0 comments on commit 1fc3b32

Please sign in to comment.