diff options
| author | Adrian Holovaty <adrian@holovaty.com> | 2006-06-20 04:47:07 +0000 |
|---|---|---|
| committer | Adrian Holovaty <adrian@holovaty.com> | 2006-06-20 04:47:07 +0000 |
| commit | a4b11826a73e50e3d7d7dfa5d086e409be2b05dc (patch) | |
| tree | 1847035e6173e14bc066eb27074b7c2a1f2c7824 | |
| parent | fb1c01b1038cbba421aaaf5b53da5bb507cc9b48 (diff) | |
Tightened up code in django.contrib.contenttypes.models.ContentTypeManager.get_for_model() to use get_or_create()
git-svn-id: http://code.djangoproject.com/svn/django/trunk@3173 bcc190cf-cafb-0310-a4f2-bffc1f526a37
| -rw-r--r-- | django/contrib/contenttypes/models.py | 15 |
1 files changed, 5 insertions, 10 deletions
diff --git a/django/contrib/contenttypes/models.py b/django/contrib/contenttypes/models.py index 87316ae523..a95748a9a1 100644 --- a/django/contrib/contenttypes/models.py +++ b/django/contrib/contenttypes/models.py @@ -8,16 +8,11 @@ class ContentTypeManager(models.Manager): ContentType if necessary. """ opts = model._meta - try: - return self.model._default_manager.get(app_label=opts.app_label, - model=opts.object_name.lower()) - except self.model.DoesNotExist: - # The str() is needed around opts.verbose_name because it's a - # django.utils.functional.__proxy__ object. - ct = self.model(name=str(opts.verbose_name), - app_label=opts.app_label, model=opts.object_name.lower()) - ct.save() - return ct + # The str() is needed around opts.verbose_name because it's a + # django.utils.functional.__proxy__ object. + ct, created = self.model._default_manager.get_or_create(app_label=opts.app_label, + model=opts.object_name.lower(), defaults={'name': str(opts.verbose_name)}) + return ct class ContentType(models.Model): name = models.CharField(maxlength=100) |
