summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdrian Holovaty <adrian@holovaty.com>2006-06-20 04:47:07 +0000
committerAdrian Holovaty <adrian@holovaty.com>2006-06-20 04:47:07 +0000
commita4b11826a73e50e3d7d7dfa5d086e409be2b05dc (patch)
tree1847035e6173e14bc066eb27074b7c2a1f2c7824
parentfb1c01b1038cbba421aaaf5b53da5bb507cc9b48 (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.py15
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)