[py3] Refactored __unicode__ to __str__.
* Renamed the __unicode__ methods * Applied the python_2_unicode_compatible decorator * Removed the StrAndUnicode mix-in that is superseded by python_2_unicode_compatible * Kept the __unicode__ methods in classes that specifically test it under Python 2
This commit is contained in:
parent
79d62a7175
commit
d4a0b27838
|
@ -6,6 +6,7 @@ from django.contrib.auth.models import User
|
||||||
from django.contrib.admin.util import quote
|
from django.contrib.admin.util import quote
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
from django.utils.encoding import smart_text
|
from django.utils.encoding import smart_text
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
ADDITION = 1
|
ADDITION = 1
|
||||||
CHANGE = 2
|
CHANGE = 2
|
||||||
|
@ -16,6 +17,7 @@ class LogEntryManager(models.Manager):
|
||||||
e = self.model(None, None, user_id, content_type_id, smart_text(object_id), object_repr[:200], action_flag, change_message)
|
e = self.model(None, None, user_id, content_type_id, smart_text(object_id), object_repr[:200], action_flag, change_message)
|
||||||
e.save()
|
e.save()
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class LogEntry(models.Model):
|
class LogEntry(models.Model):
|
||||||
action_time = models.DateTimeField(_('action time'), auto_now=True)
|
action_time = models.DateTimeField(_('action time'), auto_now=True)
|
||||||
user = models.ForeignKey(User)
|
user = models.ForeignKey(User)
|
||||||
|
@ -36,7 +38,7 @@ class LogEntry(models.Model):
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return smart_text(self.action_time)
|
return smart_text(self.action_time)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
if self.action_flag == ADDITION:
|
if self.action_flag == ADDITION:
|
||||||
return _('Added "%(object)s".') % {'object': self.object_repr}
|
return _('Added "%(object)s".') % {'object': self.object_repr}
|
||||||
elif self.action_flag == CHANGE:
|
elif self.action_flag == CHANGE:
|
||||||
|
|
|
@ -16,6 +16,7 @@ from django.contrib.auth.hashers import (
|
||||||
check_password, make_password, is_password_usable, UNUSABLE_PASSWORD)
|
check_password, make_password, is_password_usable, UNUSABLE_PASSWORD)
|
||||||
from django.contrib.auth.signals import user_logged_in
|
from django.contrib.auth.signals import user_logged_in
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
def update_last_login(sender, user, **kwargs):
|
def update_last_login(sender, user, **kwargs):
|
||||||
|
@ -41,6 +42,7 @@ class PermissionManager(models.Manager):
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Permission(models.Model):
|
class Permission(models.Model):
|
||||||
"""
|
"""
|
||||||
The permissions system provides a way to assign permissions to specific
|
The permissions system provides a way to assign permissions to specific
|
||||||
|
@ -76,7 +78,7 @@ class Permission(models.Model):
|
||||||
ordering = ('content_type__app_label', 'content_type__model',
|
ordering = ('content_type__app_label', 'content_type__model',
|
||||||
'codename')
|
'codename')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s | %s | %s" % (
|
return "%s | %s | %s" % (
|
||||||
six.text_type(self.content_type.app_label),
|
six.text_type(self.content_type.app_label),
|
||||||
six.text_type(self.content_type),
|
six.text_type(self.content_type),
|
||||||
|
@ -94,6 +96,7 @@ class GroupManager(models.Manager):
|
||||||
def get_by_natural_key(self, name):
|
def get_by_natural_key(self, name):
|
||||||
return self.get(name=name)
|
return self.get(name=name)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Group(models.Model):
|
class Group(models.Model):
|
||||||
"""
|
"""
|
||||||
Groups are a generic way of categorizing users to apply permissions, or
|
Groups are a generic way of categorizing users to apply permissions, or
|
||||||
|
@ -121,7 +124,7 @@ class Group(models.Model):
|
||||||
verbose_name = _('group')
|
verbose_name = _('group')
|
||||||
verbose_name_plural = _('groups')
|
verbose_name_plural = _('groups')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
def natural_key(self):
|
def natural_key(self):
|
||||||
|
@ -221,6 +224,7 @@ def _user_has_module_perms(user, app_label):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class User(models.Model):
|
class User(models.Model):
|
||||||
"""
|
"""
|
||||||
Users within the Django authentication system are represented by this
|
Users within the Django authentication system are represented by this
|
||||||
|
@ -259,7 +263,7 @@ class User(models.Model):
|
||||||
verbose_name = _('user')
|
verbose_name = _('user')
|
||||||
verbose_name_plural = _('users')
|
verbose_name_plural = _('users')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.username
|
return self.username
|
||||||
|
|
||||||
def natural_key(self):
|
def natural_key(self):
|
||||||
|
@ -403,6 +407,7 @@ class User(models.Model):
|
||||||
return self._profile_cache
|
return self._profile_cache
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class AnonymousUser(object):
|
class AnonymousUser(object):
|
||||||
id = None
|
id = None
|
||||||
pk = None
|
pk = None
|
||||||
|
@ -416,7 +421,7 @@ class AnonymousUser(object):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return 'AnonymousUser'
|
return 'AnonymousUser'
|
||||||
|
|
||||||
def __eq__(self, other):
|
def __eq__(self, other):
|
||||||
|
|
|
@ -8,6 +8,7 @@ from django.core import urlresolvers
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
COMMENT_MAX_LENGTH = getattr(settings,'COMMENT_MAX_LENGTH',3000)
|
COMMENT_MAX_LENGTH = getattr(settings,'COMMENT_MAX_LENGTH',3000)
|
||||||
|
|
||||||
|
@ -39,6 +40,7 @@ class BaseCommentAbstractModel(models.Model):
|
||||||
args=(self.content_type_id, self.object_pk)
|
args=(self.content_type_id, self.object_pk)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Comment(BaseCommentAbstractModel):
|
class Comment(BaseCommentAbstractModel):
|
||||||
"""
|
"""
|
||||||
A user comment about some object.
|
A user comment about some object.
|
||||||
|
@ -76,7 +78,7 @@ class Comment(BaseCommentAbstractModel):
|
||||||
verbose_name = _('comment')
|
verbose_name = _('comment')
|
||||||
verbose_name_plural = _('comments')
|
verbose_name_plural = _('comments')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s: %s..." % (self.name, self.comment[:50])
|
return "%s: %s..." % (self.name, self.comment[:50])
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
|
@ -153,6 +155,7 @@ class Comment(BaseCommentAbstractModel):
|
||||||
}
|
}
|
||||||
return _('Posted by %(user)s at %(date)s\n\n%(comment)s\n\nhttp://%(domain)s%(url)s') % d
|
return _('Posted by %(user)s at %(date)s\n\n%(comment)s\n\nhttp://%(domain)s%(url)s') % d
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class CommentFlag(models.Model):
|
class CommentFlag(models.Model):
|
||||||
"""
|
"""
|
||||||
Records a flag on a comment. This is intentionally flexible; right now, a
|
Records a flag on a comment. This is intentionally flexible; right now, a
|
||||||
|
@ -182,7 +185,7 @@ class CommentFlag(models.Model):
|
||||||
verbose_name = _('comment flag')
|
verbose_name = _('comment flag')
|
||||||
verbose_name_plural = _('comment flags')
|
verbose_name_plural = _('comment flags')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s flag of comment ID %s by %s" % \
|
return "%s flag of comment ID %s by %s" % \
|
||||||
(self.flag, self.comment_id, self.user.username)
|
(self.flag, self.comment_id, self.user.username)
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
from django.utils.encoding import smart_text, force_text
|
from django.utils.encoding import smart_text, force_text
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
class ContentTypeManager(models.Manager):
|
class ContentTypeManager(models.Manager):
|
||||||
|
|
||||||
|
@ -122,6 +123,7 @@ class ContentTypeManager(models.Manager):
|
||||||
self.__class__._cache.setdefault(using, {})[key] = ct
|
self.__class__._cache.setdefault(using, {})[key] = ct
|
||||||
self.__class__._cache.setdefault(using, {})[ct.id] = ct
|
self.__class__._cache.setdefault(using, {})[ct.id] = ct
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ContentType(models.Model):
|
class ContentType(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
app_label = models.CharField(max_length=100)
|
app_label = models.CharField(max_length=100)
|
||||||
|
@ -135,7 +137,7 @@ class ContentType(models.Model):
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
unique_together = (('app_label', 'model'),)
|
unique_together = (('app_label', 'model'),)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
# self.name is deprecated in favor of using model's verbose_name, which
|
# self.name is deprecated in favor of using model's verbose_name, which
|
||||||
# can be translated. Formal deprecation is delayed until we have DB
|
# can be translated. Formal deprecation is delayed until we have DB
|
||||||
# migration to be able to remove the field from the database along with
|
# migration to be able to remove the field from the database along with
|
||||||
|
|
|
@ -8,6 +8,7 @@ from django.http import HttpRequest, Http404
|
||||||
from django.test import TestCase
|
from django.test import TestCase
|
||||||
from django.utils.http import urlquote
|
from django.utils.http import urlquote
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class ConcreteModel(models.Model):
|
class ConcreteModel(models.Model):
|
||||||
|
@ -17,13 +18,14 @@ class ProxyModel(ConcreteModel):
|
||||||
class Meta:
|
class Meta:
|
||||||
proxy = True
|
proxy = True
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class FooWithoutUrl(models.Model):
|
class FooWithoutUrl(models.Model):
|
||||||
"""
|
"""
|
||||||
Fake model not defining ``get_absolute_url`` for
|
Fake model not defining ``get_absolute_url`` for
|
||||||
:meth:`ContentTypesTests.test_shortcut_view_without_get_absolute_url`"""
|
:meth:`ContentTypesTests.test_shortcut_view_without_get_absolute_url`"""
|
||||||
name = models.CharField(max_length=30, unique=True)
|
name = models.CharField(max_length=30, unique=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,7 @@ from django.utils import formats
|
||||||
from django.utils.text import capfirst
|
from django.utils.text import capfirst
|
||||||
from django.utils.encoding import smart_text, smart_bytes, iri_to_uri
|
from django.utils.encoding import smart_text, smart_bytes, iri_to_uri
|
||||||
from django.db.models.query import QuerySet
|
from django.db.models.query import QuerySet
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
EMPTY_VALUE = '(None)'
|
EMPTY_VALUE = '(None)'
|
||||||
DISPLAY_SIZE = 100
|
DISPLAY_SIZE = 100
|
||||||
|
@ -84,6 +85,7 @@ class EasyChoice(object):
|
||||||
def url(self):
|
def url(self):
|
||||||
return '%s%s/%s/%s/%s/' % (self.model.site.root_url, self.model.model._meta.app_label, self.model.model._meta.module_name, self.field.field.name, iri_to_uri(self.value))
|
return '%s%s/%s/%s/%s/' % (self.model.site.root_url, self.model.model._meta.app_label, self.model.model._meta.module_name, self.field.field.name, iri_to_uri(self.value))
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class EasyInstance(object):
|
class EasyInstance(object):
|
||||||
def __init__(self, easy_model, instance):
|
def __init__(self, easy_model, instance):
|
||||||
self.model, self.instance = easy_model, instance
|
self.model, self.instance = easy_model, instance
|
||||||
|
@ -91,7 +93,7 @@ class EasyInstance(object):
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return smart_bytes('<EasyInstance for %s (%s)>' % (self.model.model._meta.object_name, self.instance._get_pk_val()))
|
return smart_bytes('<EasyInstance for %s (%s)>' % (self.model.model._meta.object_name, self.instance._get_pk_val()))
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
val = smart_text(self.instance)
|
val = smart_text(self.instance)
|
||||||
if len(val) > DISPLAY_SIZE:
|
if len(val) > DISPLAY_SIZE:
|
||||||
return val[:DISPLAY_SIZE] + '...'
|
return val[:DISPLAY_SIZE] + '...'
|
||||||
|
|
|
@ -1,26 +1,30 @@
|
||||||
from django.contrib import databrowse
|
from django.contrib import databrowse
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.test import TestCase
|
from django.test import TestCase
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SomeModel(models.Model):
|
class SomeModel(models.Model):
|
||||||
some_field = models.CharField(max_length=50)
|
some_field = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.some_field
|
return self.some_field
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SomeOtherModel(models.Model):
|
class SomeOtherModel(models.Model):
|
||||||
some_other_field = models.CharField(max_length=50)
|
some_other_field = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.some_other_field
|
return self.some_other_field
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class YetAnotherModel(models.Model):
|
class YetAnotherModel(models.Model):
|
||||||
yet_another_field = models.CharField(max_length=50)
|
yet_another_field = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.yet_another_field
|
return self.yet_another_field
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -3,8 +3,10 @@ from __future__ import unicode_literals
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.contrib.sites.models import Site
|
from django.contrib.sites.models import Site
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class FlatPage(models.Model):
|
class FlatPage(models.Model):
|
||||||
url = models.CharField(_('URL'), max_length=100, db_index=True)
|
url = models.CharField(_('URL'), max_length=100, db_index=True)
|
||||||
title = models.CharField(_('title'), max_length=200)
|
title = models.CharField(_('title'), max_length=200)
|
||||||
|
@ -21,7 +23,7 @@ class FlatPage(models.Model):
|
||||||
verbose_name_plural = _('flat pages')
|
verbose_name_plural = _('flat pages')
|
||||||
ordering = ('url',)
|
ordering = ('url',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s -- %s" % (self.url, self.title)
|
return "%s -- %s" % (self.url, self.title)
|
||||||
|
|
||||||
def get_absolute_url(self):
|
def get_absolute_url(self):
|
||||||
|
|
|
@ -5,6 +5,7 @@ Base/mixin classes for the spatial backend database operations and the
|
||||||
import re
|
import re
|
||||||
from django.contrib.gis import gdal
|
from django.contrib.gis import gdal
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
class BaseSpatialOperations(object):
|
class BaseSpatialOperations(object):
|
||||||
"""
|
"""
|
||||||
|
@ -131,6 +132,7 @@ class BaseSpatialOperations(object):
|
||||||
def spatial_ref_sys(self):
|
def spatial_ref_sys(self):
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SpatialRefSysMixin(object):
|
class SpatialRefSysMixin(object):
|
||||||
"""
|
"""
|
||||||
The SpatialRefSysMixin is a class used by the database-dependent
|
The SpatialRefSysMixin is a class used by the database-dependent
|
||||||
|
@ -325,7 +327,7 @@ class SpatialRefSysMixin(object):
|
||||||
radius, flattening = sphere_params
|
radius, flattening = sphere_params
|
||||||
return 'SPHEROID["%s",%s,%s]' % (sphere_name, radius, flattening)
|
return 'SPHEROID["%s",%s,%s]' % (sphere_name, radius, flattening)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
"""
|
"""
|
||||||
Returns the string representation. If GDAL is installed,
|
Returns the string representation. If GDAL is installed,
|
||||||
it will be 'pretty' OGC WKT.
|
it will be 'pretty' OGC WKT.
|
||||||
|
|
|
@ -9,7 +9,9 @@
|
||||||
"""
|
"""
|
||||||
from django.contrib.gis.db import models
|
from django.contrib.gis.db import models
|
||||||
from django.contrib.gis.db.backends.base import SpatialRefSysMixin
|
from django.contrib.gis.db.backends.base import SpatialRefSysMixin
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class GeometryColumns(models.Model):
|
class GeometryColumns(models.Model):
|
||||||
"Maps to the Oracle USER_SDO_GEOM_METADATA table."
|
"Maps to the Oracle USER_SDO_GEOM_METADATA table."
|
||||||
table_name = models.CharField(max_length=32)
|
table_name = models.CharField(max_length=32)
|
||||||
|
@ -36,7 +38,7 @@ class GeometryColumns(models.Model):
|
||||||
"""
|
"""
|
||||||
return 'column_name'
|
return 'column_name'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s - %s (SRID: %s)' % (self.table_name, self.column_name, self.srid)
|
return '%s - %s (SRID: %s)' % (self.table_name, self.column_name, self.srid)
|
||||||
|
|
||||||
class SpatialRefSys(models.Model, SpatialRefSysMixin):
|
class SpatialRefSys(models.Model, SpatialRefSysMixin):
|
||||||
|
|
|
@ -3,7 +3,9 @@
|
||||||
"""
|
"""
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.contrib.gis.db.backends.base import SpatialRefSysMixin
|
from django.contrib.gis.db.backends.base import SpatialRefSysMixin
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class GeometryColumns(models.Model):
|
class GeometryColumns(models.Model):
|
||||||
"""
|
"""
|
||||||
The 'geometry_columns' table from the PostGIS. See the PostGIS
|
The 'geometry_columns' table from the PostGIS. See the PostGIS
|
||||||
|
@ -37,7 +39,7 @@ class GeometryColumns(models.Model):
|
||||||
"""
|
"""
|
||||||
return 'f_geometry_column'
|
return 'f_geometry_column'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s.%s - %dD %s field (SRID: %d)" % \
|
return "%s.%s - %dD %s field (SRID: %d)" % \
|
||||||
(self.f_table_name, self.f_geometry_column,
|
(self.f_table_name, self.f_geometry_column,
|
||||||
self.coord_dimension, self.type, self.srid)
|
self.coord_dimension, self.type, self.srid)
|
||||||
|
|
|
@ -3,7 +3,9 @@
|
||||||
"""
|
"""
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.contrib.gis.db.backends.base import SpatialRefSysMixin
|
from django.contrib.gis.db.backends.base import SpatialRefSysMixin
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class GeometryColumns(models.Model):
|
class GeometryColumns(models.Model):
|
||||||
"""
|
"""
|
||||||
The 'geometry_columns' table from SpatiaLite.
|
The 'geometry_columns' table from SpatiaLite.
|
||||||
|
@ -35,7 +37,7 @@ class GeometryColumns(models.Model):
|
||||||
"""
|
"""
|
||||||
return 'f_geometry_column'
|
return 'f_geometry_column'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s.%s - %dD %s field (SRID: %d)" % \
|
return "%s.%s - %dD %s field (SRID: %d)" % \
|
||||||
(self.f_table_name, self.f_geometry_column,
|
(self.f_table_name, self.f_geometry_column,
|
||||||
self.coord_dimension, self.type, self.srid)
|
self.coord_dimension, self.type, self.srid)
|
||||||
|
|
|
@ -2,8 +2,10 @@ from django.contrib.gis.geos import fromstr, Point, LineString, LinearRing, Poly
|
||||||
from django.utils.functional import total_ordering
|
from django.utils.functional import total_ordering
|
||||||
from django.utils.safestring import mark_safe
|
from django.utils.safestring import mark_safe
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class GEvent(object):
|
class GEvent(object):
|
||||||
"""
|
"""
|
||||||
A Python wrapper for the Google GEvent object.
|
A Python wrapper for the Google GEvent object.
|
||||||
|
@ -48,10 +50,11 @@ class GEvent(object):
|
||||||
self.event = event
|
self.event = event
|
||||||
self.action = action
|
self.action = action
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
"Returns the parameter part of a GEvent."
|
"Returns the parameter part of a GEvent."
|
||||||
return mark_safe('"%s", %s' %(self.event, self.action))
|
return mark_safe('"%s", %s' %(self.event, self.action))
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class GOverlayBase(object):
|
class GOverlayBase(object):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.events = []
|
self.events = []
|
||||||
|
@ -64,7 +67,7 @@ class GOverlayBase(object):
|
||||||
"Attaches a GEvent to the overlay object."
|
"Attaches a GEvent to the overlay object."
|
||||||
self.events.append(event)
|
self.events.append(event)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
"The string representation is the JavaScript API call."
|
"The string representation is the JavaScript API call."
|
||||||
return mark_safe('%s(%s)' % (self.__class__.__name__, self.js_params))
|
return mark_safe('%s(%s)' % (self.__class__.__name__, self.js_params))
|
||||||
|
|
||||||
|
|
|
@ -1,50 +1,58 @@
|
||||||
from django.contrib.gis.db import models
|
from django.contrib.gis.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SouthTexasCity(models.Model):
|
class SouthTexasCity(models.Model):
|
||||||
"City model on projected coordinate system for South Texas."
|
"City model on projected coordinate system for South Texas."
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
point = models.PointField(srid=32140)
|
point = models.PointField(srid=32140)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SouthTexasCityFt(models.Model):
|
class SouthTexasCityFt(models.Model):
|
||||||
"Same City model as above, but U.S. survey feet are the units."
|
"Same City model as above, but U.S. survey feet are the units."
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
point = models.PointField(srid=2278)
|
point = models.PointField(srid=2278)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class AustraliaCity(models.Model):
|
class AustraliaCity(models.Model):
|
||||||
"City model for Australia, using WGS84."
|
"City model for Australia, using WGS84."
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
point = models.PointField()
|
point = models.PointField()
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class CensusZipcode(models.Model):
|
class CensusZipcode(models.Model):
|
||||||
"Model for a few South Texas ZIP codes (in original Census NAD83)."
|
"Model for a few South Texas ZIP codes (in original Census NAD83)."
|
||||||
name = models.CharField(max_length=5)
|
name = models.CharField(max_length=5)
|
||||||
poly = models.PolygonField(srid=4269)
|
poly = models.PolygonField(srid=4269)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SouthTexasZipcode(models.Model):
|
class SouthTexasZipcode(models.Model):
|
||||||
"Model for a few South Texas ZIP codes."
|
"Model for a few South Texas ZIP codes."
|
||||||
name = models.CharField(max_length=5)
|
name = models.CharField(max_length=5)
|
||||||
poly = models.PolygonField(srid=32140, null=True)
|
poly = models.PolygonField(srid=32140, null=True)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Interstate(models.Model):
|
class Interstate(models.Model):
|
||||||
"Geodetic model for U.S. Interstates."
|
"Geodetic model for U.S. Interstates."
|
||||||
name = models.CharField(max_length=10)
|
name = models.CharField(max_length=10)
|
||||||
path = models.LineStringField()
|
path = models.LineStringField()
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SouthTexasInterstate(models.Model):
|
class SouthTexasInterstate(models.Model):
|
||||||
"Projected model for South Texas Interstates."
|
"Projected model for South Texas Interstates."
|
||||||
name = models.CharField(max_length=10)
|
name = models.CharField(max_length=10)
|
||||||
path = models.LineStringField(srid=32140)
|
path = models.LineStringField(srid=32140)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
|
@ -1,59 +1,67 @@
|
||||||
from django.contrib.gis.db import models
|
from django.contrib.gis.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class City3D(models.Model):
|
class City3D(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
point = models.PointField(dim=3)
|
point = models.PointField(dim=3)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Interstate2D(models.Model):
|
class Interstate2D(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
line = models.LineStringField(srid=4269)
|
line = models.LineStringField(srid=4269)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Interstate3D(models.Model):
|
class Interstate3D(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
line = models.LineStringField(dim=3, srid=4269)
|
line = models.LineStringField(dim=3, srid=4269)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class InterstateProj2D(models.Model):
|
class InterstateProj2D(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
line = models.LineStringField(srid=32140)
|
line = models.LineStringField(srid=32140)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class InterstateProj3D(models.Model):
|
class InterstateProj3D(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
line = models.LineStringField(dim=3, srid=32140)
|
line = models.LineStringField(dim=3, srid=32140)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Polygon2D(models.Model):
|
class Polygon2D(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
poly = models.PolygonField(srid=32140)
|
poly = models.PolygonField(srid=32140)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Polygon3D(models.Model):
|
class Polygon3D(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
poly = models.PolygonField(dim=3, srid=32140)
|
poly = models.PolygonField(dim=3, srid=32140)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Point2D(models.Model):
|
class Point2D(models.Model):
|
||||||
|
|
|
@ -1,10 +1,12 @@
|
||||||
from django.contrib.gis.db import models
|
from django.contrib.gis.db import models
|
||||||
from django.contrib.gis import admin
|
from django.contrib.gis import admin
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class City(models.Model):
|
class City(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
point = models.PointField()
|
point = models.PointField()
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
admin.site.register(City, admin.OSMGeoAdmin)
|
admin.site.register(City, admin.OSMGeoAdmin)
|
||||||
|
|
|
@ -1,20 +1,23 @@
|
||||||
from django.contrib.gis.db import models
|
from django.contrib.gis.db import models
|
||||||
from django.contrib.gis.tests.utils import mysql, spatialite
|
from django.contrib.gis.tests.utils import mysql, spatialite
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
# MySQL spatial indices can't handle NULL geometries.
|
# MySQL spatial indices can't handle NULL geometries.
|
||||||
null_flag = not mysql
|
null_flag = not mysql
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Country(models.Model):
|
class Country(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
mpoly = models.MultiPolygonField() # SRID, by default, is 4326
|
mpoly = models.MultiPolygonField() # SRID, by default, is 4326
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class City(models.Model):
|
class City(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
point = models.PointField()
|
point = models.PointField()
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
# This is an inherited model from City
|
# This is an inherited model from City
|
||||||
class PennsylvaniaCity(City):
|
class PennsylvaniaCity(City):
|
||||||
|
@ -22,28 +25,31 @@ class PennsylvaniaCity(City):
|
||||||
founded = models.DateTimeField(null=True)
|
founded = models.DateTimeField(null=True)
|
||||||
objects = models.GeoManager() # TODO: This should be implicitly inherited.
|
objects = models.GeoManager() # TODO: This should be implicitly inherited.
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class State(models.Model):
|
class State(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
poly = models.PolygonField(null=null_flag) # Allowing NULL geometries here.
|
poly = models.PolygonField(null=null_flag) # Allowing NULL geometries here.
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Track(models.Model):
|
class Track(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
line = models.LineStringField()
|
line = models.LineStringField()
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
class Truth(models.Model):
|
class Truth(models.Model):
|
||||||
val = models.BooleanField()
|
val = models.BooleanField()
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
if not spatialite:
|
if not spatialite:
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Feature(models.Model):
|
class Feature(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
geom = models.GeometryField()
|
geom = models.GeometryField()
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
class MinusOneSRID(models.Model):
|
class MinusOneSRID(models.Model):
|
||||||
geom = models.PointField(srid=-1) # Minus one SRID.
|
geom = models.PointField(srid=-1) # Minus one SRID.
|
||||||
|
|
|
@ -1,20 +1,24 @@
|
||||||
from django.contrib.gis.db import models
|
from django.contrib.gis.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class City(models.Model):
|
class City(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
point = models.PointField(geography=True)
|
point = models.PointField(geography=True)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Zipcode(models.Model):
|
class Zipcode(models.Model):
|
||||||
code = models.CharField(max_length=10)
|
code = models.CharField(max_length=10)
|
||||||
poly = models.PolygonField(geography=True)
|
poly = models.PolygonField(geography=True)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.code
|
def __str__(self): return self.code
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class County(models.Model):
|
class County(models.Model):
|
||||||
name = models.CharField(max_length=25)
|
name = models.CharField(max_length=25)
|
||||||
state = models.CharField(max_length=20)
|
state = models.CharField(max_length=20)
|
||||||
mpoly = models.MultiPolygonField(geography=True)
|
mpoly = models.MultiPolygonField(geography=True)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return ' County, '.join([self.name, self.state])
|
def __str__(self): return ' County, '.join([self.name, self.state])
|
||||||
|
|
|
@ -1,37 +1,41 @@
|
||||||
from django.contrib.gis.db import models
|
from django.contrib.gis.db import models
|
||||||
from django.contrib.localflavor.us.models import USStateField
|
from django.contrib.localflavor.us.models import USStateField
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Location(models.Model):
|
class Location(models.Model):
|
||||||
point = models.PointField()
|
point = models.PointField()
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.point.wkt
|
def __str__(self): return self.point.wkt
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class City(models.Model):
|
class City(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
state = USStateField()
|
state = USStateField()
|
||||||
location = models.ForeignKey(Location)
|
location = models.ForeignKey(Location)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
class AugmentedLocation(Location):
|
class AugmentedLocation(Location):
|
||||||
extra_text = models.TextField(blank=True)
|
extra_text = models.TextField(blank=True)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
class DirectoryEntry(models.Model):
|
class DirectoryEntry(models.Model):
|
||||||
listing_text = models.CharField(max_length=50)
|
listing_text = models.CharField(max_length=50)
|
||||||
location = models.ForeignKey(AugmentedLocation)
|
location = models.ForeignKey(AugmentedLocation)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Parcel(models.Model):
|
class Parcel(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
city = models.ForeignKey(City)
|
city = models.ForeignKey(City)
|
||||||
center1 = models.PointField()
|
center1 = models.PointField()
|
||||||
# Throwing a curveball w/`db_column` here.
|
# Throwing a curveball w/`db_column` here.
|
||||||
center2 = models.PointField(srid=2276, db_column='mycenter')
|
center2 = models.PointField(srid=2276, db_column='mycenter')
|
||||||
border1 = models.PolygonField()
|
border1 = models.PolygonField()
|
||||||
border2 = models.PolygonField(srid=2276)
|
border2 = models.PolygonField(srid=2276)
|
||||||
objects = models.GeoManager()
|
objects = models.GeoManager()
|
||||||
def __unicode__(self): return self.name
|
def __str__(self): return self.name
|
||||||
|
|
||||||
# These use the GeoManager but do not have any geographic fields.
|
# These use the GeoManager but do not have any geographic fields.
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
|
|
|
@ -223,4 +223,4 @@ def _ogrinspect(data_source, model_name, geom_name='geom', layer_key=0, srid=Non
|
||||||
|
|
||||||
if name_field:
|
if name_field:
|
||||||
yield ''
|
yield ''
|
||||||
yield ' def __unicode__(self): return self.%s' % name_field
|
yield ' def __str__(self): return self.%s' % name_field
|
||||||
|
|
|
@ -1,14 +1,15 @@
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.utils.encoding import force_text, StrAndUnicode
|
from django.utils.encoding import force_text, python_2_unicode_compatible
|
||||||
from django.contrib.messages import constants, utils
|
from django.contrib.messages import constants, utils
|
||||||
|
|
||||||
|
|
||||||
LEVEL_TAGS = utils.get_level_tags()
|
LEVEL_TAGS = utils.get_level_tags()
|
||||||
|
|
||||||
|
|
||||||
class Message(StrAndUnicode):
|
@python_2_unicode_compatible
|
||||||
|
class Message(object):
|
||||||
"""
|
"""
|
||||||
Represents an actual message that can be stored in any of the supported
|
Represents an actual message that can be stored in any of the supported
|
||||||
storage classes (typically session- or cookie-based) and rendered in a view
|
storage classes (typically session- or cookie-based) and rendered in a view
|
||||||
|
@ -35,7 +36,7 @@ class Message(StrAndUnicode):
|
||||||
return isinstance(other, Message) and self.level == other.level and \
|
return isinstance(other, Message) and self.level == other.level and \
|
||||||
self.message == other.message
|
self.message == other.message
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return force_text(self.message)
|
return force_text(self.message)
|
||||||
|
|
||||||
def _get_tags(self):
|
def _get_tags(self):
|
||||||
|
|
|
@ -1,7 +1,9 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.contrib.sites.models import Site
|
from django.contrib.sites.models import Site
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Redirect(models.Model):
|
class Redirect(models.Model):
|
||||||
site = models.ForeignKey(Site)
|
site = models.ForeignKey(Site)
|
||||||
old_path = models.CharField(_('redirect from'), max_length=200, db_index=True,
|
old_path = models.CharField(_('redirect from'), max_length=200, db_index=True,
|
||||||
|
@ -15,6 +17,6 @@ class Redirect(models.Model):
|
||||||
db_table = 'django_redirect'
|
db_table = 'django_redirect'
|
||||||
unique_together=(('site', 'old_path'),)
|
unique_together=(('site', 'old_path'),)
|
||||||
ordering = ('old_path',)
|
ordering = ('old_path',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s ---> %s" % (self.old_path, self.new_path)
|
return "%s ---> %s" % (self.old_path, self.new_path)
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
SITE_CACHE = {}
|
SITE_CACHE = {}
|
||||||
|
@ -32,6 +33,7 @@ class SiteManager(models.Manager):
|
||||||
SITE_CACHE = {}
|
SITE_CACHE = {}
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Site(models.Model):
|
class Site(models.Model):
|
||||||
|
|
||||||
domain = models.CharField(_('domain name'), max_length=100)
|
domain = models.CharField(_('domain name'), max_length=100)
|
||||||
|
@ -44,7 +46,7 @@ class Site(models.Model):
|
||||||
verbose_name_plural = _('sites')
|
verbose_name_plural = _('sites')
|
||||||
ordering = ('domain',)
|
ordering = ('domain',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.domain
|
return self.domain
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
|
@ -62,6 +64,7 @@ class Site(models.Model):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class RequestSite(object):
|
class RequestSite(object):
|
||||||
"""
|
"""
|
||||||
A class that shares the primary interface of Site (i.e., it has
|
A class that shares the primary interface of Site (i.e., it has
|
||||||
|
@ -73,7 +76,7 @@ class RequestSite(object):
|
||||||
def __init__(self, request):
|
def __init__(self, request):
|
||||||
self.domain = self.name = request.get_host()
|
self.domain = self.name = request.get_host()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.domain
|
return self.domain
|
||||||
|
|
||||||
def save(self, force_insert=False, force_update=False):
|
def save(self, force_insert=False, force_update=False):
|
||||||
|
|
|
@ -5,7 +5,9 @@ from io import BytesIO
|
||||||
|
|
||||||
from django.utils.encoding import smart_bytes, smart_text
|
from django.utils.encoding import smart_bytes, smart_text
|
||||||
from django.core.files.utils import FileProxyMixin
|
from django.core.files.utils import FileProxyMixin
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class File(FileProxyMixin):
|
class File(FileProxyMixin):
|
||||||
DEFAULT_CHUNK_SIZE = 64 * 2**10
|
DEFAULT_CHUNK_SIZE = 64 * 2**10
|
||||||
|
|
||||||
|
@ -17,7 +19,7 @@ class File(FileProxyMixin):
|
||||||
if hasattr(file, 'mode'):
|
if hasattr(file, 'mode'):
|
||||||
self.mode = file.mode
|
self.mode = file.mode
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return smart_text(self.name or '')
|
return smart_text(self.name or '')
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
|
@ -121,6 +123,7 @@ class File(FileProxyMixin):
|
||||||
def close(self):
|
def close(self):
|
||||||
self.file.close()
|
self.file.close()
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ContentFile(File):
|
class ContentFile(File):
|
||||||
"""
|
"""
|
||||||
A File-like object that takes just raw content, rather than an actual file.
|
A File-like object that takes just raw content, rather than an actual file.
|
||||||
|
@ -130,7 +133,7 @@ class ContentFile(File):
|
||||||
super(ContentFile, self).__init__(BytesIO(content), name=name)
|
super(ContentFile, self).__init__(BytesIO(content), name=name)
|
||||||
self.size = len(content)
|
self.size = len(content)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return 'Raw content'
|
return 'Raw content'
|
||||||
|
|
||||||
def __bool__(self):
|
def __bool__(self):
|
||||||
|
|
|
@ -10,6 +10,7 @@ from django.conf import settings
|
||||||
from django.core.exceptions import ImproperlyConfigured
|
from django.core.exceptions import ImproperlyConfigured
|
||||||
from django.core.files.uploadedfile import TemporaryUploadedFile, InMemoryUploadedFile
|
from django.core.files.uploadedfile import TemporaryUploadedFile, InMemoryUploadedFile
|
||||||
from django.utils import importlib
|
from django.utils import importlib
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
__all__ = ['UploadFileException','StopUpload', 'SkipFile', 'FileUploadHandler',
|
__all__ = ['UploadFileException','StopUpload', 'SkipFile', 'FileUploadHandler',
|
||||||
'TemporaryFileUploadHandler', 'MemoryFileUploadHandler',
|
'TemporaryFileUploadHandler', 'MemoryFileUploadHandler',
|
||||||
|
@ -21,6 +22,7 @@ class UploadFileException(Exception):
|
||||||
"""
|
"""
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class StopUpload(UploadFileException):
|
class StopUpload(UploadFileException):
|
||||||
"""
|
"""
|
||||||
This exception is raised when an upload must abort.
|
This exception is raised when an upload must abort.
|
||||||
|
@ -33,7 +35,7 @@ class StopUpload(UploadFileException):
|
||||||
"""
|
"""
|
||||||
self.connection_reset = connection_reset
|
self.connection_reset = connection_reset
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
if self.connection_reset:
|
if self.connection_reset:
|
||||||
return 'StopUpload: Halt current upload.'
|
return 'StopUpload: Halt current upload.'
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -13,6 +13,7 @@ from django.utils.translation import activate, deactivate_all, get_language, str
|
||||||
from django.utils.encoding import force_text, smart_text
|
from django.utils.encoding import force_text, smart_text
|
||||||
from django.utils.datastructures import SortedDict
|
from django.utils.datastructures import SortedDict
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
# Calculate the verbose_name by converting from InitialCaps to "lowercase with spaces".
|
# Calculate the verbose_name by converting from InitialCaps to "lowercase with spaces".
|
||||||
get_verbose_name = lambda class_name: re.sub('(((?<=[a-z])[A-Z])|([A-Z](?![A-Z]|$)))', ' \\1', class_name).lower().strip()
|
get_verbose_name = lambda class_name: re.sub('(((?<=[a-z])[A-Z])|([A-Z](?![A-Z]|$)))', ' \\1', class_name).lower().strip()
|
||||||
|
@ -22,6 +23,7 @@ DEFAULT_NAMES = ('verbose_name', 'verbose_name_plural', 'db_table', 'ordering',
|
||||||
'order_with_respect_to', 'app_label', 'db_tablespace',
|
'order_with_respect_to', 'app_label', 'db_tablespace',
|
||||||
'abstract', 'managed', 'proxy', 'auto_created')
|
'abstract', 'managed', 'proxy', 'auto_created')
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Options(object):
|
class Options(object):
|
||||||
def __init__(self, meta, app_label=None):
|
def __init__(self, meta, app_label=None):
|
||||||
self.local_fields, self.local_many_to_many = [], []
|
self.local_fields, self.local_many_to_many = [], []
|
||||||
|
@ -200,7 +202,7 @@ class Options(object):
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return '<Options for %s>' % self.object_name
|
return '<Options for %s>' % self.object_name
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s.%s" % (smart_text(self.app_label), smart_text(self.module_name))
|
return "%s.%s" % (smart_text(self.app_label), smart_text(self.module_name))
|
||||||
|
|
||||||
def verbose_name_raw(self):
|
def verbose_name_raw(self):
|
||||||
|
|
|
@ -12,7 +12,7 @@ from django.forms.util import flatatt, ErrorDict, ErrorList
|
||||||
from django.forms.widgets import Media, media_property, TextInput, Textarea
|
from django.forms.widgets import Media, media_property, TextInput, Textarea
|
||||||
from django.utils.datastructures import SortedDict
|
from django.utils.datastructures import SortedDict
|
||||||
from django.utils.html import conditional_escape, format_html
|
from django.utils.html import conditional_escape, format_html
|
||||||
from django.utils.encoding import StrAndUnicode, smart_text, force_text
|
from django.utils.encoding import smart_text, force_text, python_2_unicode_compatible
|
||||||
from django.utils.safestring import mark_safe
|
from django.utils.safestring import mark_safe
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
|
||||||
|
@ -68,7 +68,8 @@ class DeclarativeFieldsMetaclass(type):
|
||||||
new_class.media = media_property(new_class)
|
new_class.media = media_property(new_class)
|
||||||
return new_class
|
return new_class
|
||||||
|
|
||||||
class BaseForm(StrAndUnicode):
|
@python_2_unicode_compatible
|
||||||
|
class BaseForm(object):
|
||||||
# This is the main implementation of all the Form logic. Note that this
|
# This is the main implementation of all the Form logic. Note that this
|
||||||
# class is different than Form. See the comments by the Form class for more
|
# class is different than Form. See the comments by the Form class for more
|
||||||
# information. Any improvements to the form API should be made to *this*
|
# information. Any improvements to the form API should be made to *this*
|
||||||
|
@ -95,7 +96,7 @@ class BaseForm(StrAndUnicode):
|
||||||
# self.base_fields.
|
# self.base_fields.
|
||||||
self.fields = copy.deepcopy(self.base_fields)
|
self.fields = copy.deepcopy(self.base_fields)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.as_table()
|
return self.as_table()
|
||||||
|
|
||||||
def __iter__(self):
|
def __iter__(self):
|
||||||
|
@ -387,7 +388,8 @@ class Form(six.with_metaclass(DeclarativeFieldsMetaclass, BaseForm)):
|
||||||
# to define a form using declarative syntax.
|
# to define a form using declarative syntax.
|
||||||
# BaseForm itself has no way of designating self.fields.
|
# BaseForm itself has no way of designating self.fields.
|
||||||
|
|
||||||
class BoundField(StrAndUnicode):
|
@python_2_unicode_compatible
|
||||||
|
class BoundField(object):
|
||||||
"A Field plus data"
|
"A Field plus data"
|
||||||
def __init__(self, form, field, name):
|
def __init__(self, form, field, name):
|
||||||
self.form = form
|
self.form = form
|
||||||
|
@ -402,7 +404,7 @@ class BoundField(StrAndUnicode):
|
||||||
self.label = self.field.label
|
self.label = self.field.label
|
||||||
self.help_text = field.help_text or ''
|
self.help_text = field.help_text or ''
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
"""Renders this field as an HTML widget."""
|
"""Renders this field as an HTML widget."""
|
||||||
if self.field.show_hidden_initial:
|
if self.field.show_hidden_initial:
|
||||||
return self.as_widget() + self.as_hidden(only_initial=True)
|
return self.as_widget() + self.as_hidden(only_initial=True)
|
||||||
|
|
|
@ -5,7 +5,7 @@ from django.forms import Form
|
||||||
from django.forms.fields import IntegerField, BooleanField
|
from django.forms.fields import IntegerField, BooleanField
|
||||||
from django.forms.util import ErrorList
|
from django.forms.util import ErrorList
|
||||||
from django.forms.widgets import Media, HiddenInput
|
from django.forms.widgets import Media, HiddenInput
|
||||||
from django.utils.encoding import StrAndUnicode
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
from django.utils.safestring import mark_safe
|
from django.utils.safestring import mark_safe
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
from django.utils.six.moves import xrange
|
from django.utils.six.moves import xrange
|
||||||
|
@ -33,7 +33,8 @@ class ManagementForm(Form):
|
||||||
self.base_fields[MAX_NUM_FORM_COUNT] = IntegerField(required=False, widget=HiddenInput)
|
self.base_fields[MAX_NUM_FORM_COUNT] = IntegerField(required=False, widget=HiddenInput)
|
||||||
super(ManagementForm, self).__init__(*args, **kwargs)
|
super(ManagementForm, self).__init__(*args, **kwargs)
|
||||||
|
|
||||||
class BaseFormSet(StrAndUnicode):
|
@python_2_unicode_compatible
|
||||||
|
class BaseFormSet(object):
|
||||||
"""
|
"""
|
||||||
A collection of instances of the same Form class.
|
A collection of instances of the same Form class.
|
||||||
"""
|
"""
|
||||||
|
@ -51,7 +52,7 @@ class BaseFormSet(StrAndUnicode):
|
||||||
# construct the forms in the formset
|
# construct the forms in the formset
|
||||||
self._construct_forms()
|
self._construct_forms()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.as_table()
|
return self.as_table()
|
||||||
|
|
||||||
def __iter__(self):
|
def __iter__(self):
|
||||||
|
|
|
@ -2,7 +2,7 @@ from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.utils.html import format_html, format_html_join
|
from django.utils.html import format_html, format_html_join
|
||||||
from django.utils.encoding import StrAndUnicode, force_text
|
from django.utils.encoding import force_text, python_2_unicode_compatible
|
||||||
from django.utils.safestring import mark_safe
|
from django.utils.safestring import mark_safe
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
@ -22,13 +22,14 @@ def flatatt(attrs):
|
||||||
"""
|
"""
|
||||||
return format_html_join('', ' {0}="{1}"', attrs.items())
|
return format_html_join('', ' {0}="{1}"', attrs.items())
|
||||||
|
|
||||||
class ErrorDict(dict, StrAndUnicode):
|
@python_2_unicode_compatible
|
||||||
|
class ErrorDict(dict):
|
||||||
"""
|
"""
|
||||||
A collection of errors that knows how to display itself in various formats.
|
A collection of errors that knows how to display itself in various formats.
|
||||||
|
|
||||||
The dictionary keys are the field names, and the values are the errors.
|
The dictionary keys are the field names, and the values are the errors.
|
||||||
"""
|
"""
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.as_ul()
|
return self.as_ul()
|
||||||
|
|
||||||
def as_ul(self):
|
def as_ul(self):
|
||||||
|
@ -42,11 +43,12 @@ class ErrorDict(dict, StrAndUnicode):
|
||||||
def as_text(self):
|
def as_text(self):
|
||||||
return '\n'.join(['* %s\n%s' % (k, '\n'.join([' * %s' % force_text(i) for i in v])) for k, v in self.items()])
|
return '\n'.join(['* %s\n%s' % (k, '\n'.join([' * %s' % force_text(i) for i in v])) for k, v in self.items()])
|
||||||
|
|
||||||
class ErrorList(list, StrAndUnicode):
|
@python_2_unicode_compatible
|
||||||
|
class ErrorList(list):
|
||||||
"""
|
"""
|
||||||
A collection of errors that knows how to display itself in various formats.
|
A collection of errors that knows how to display itself in various formats.
|
||||||
"""
|
"""
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.as_ul()
|
return self.as_ul()
|
||||||
|
|
||||||
def as_ul(self):
|
def as_ul(self):
|
||||||
|
|
|
@ -17,7 +17,7 @@ from django.forms.util import flatatt, to_current_timezone
|
||||||
from django.utils.datastructures import MultiValueDict, MergeDict
|
from django.utils.datastructures import MultiValueDict, MergeDict
|
||||||
from django.utils.html import conditional_escape, format_html, format_html_join
|
from django.utils.html import conditional_escape, format_html, format_html_join
|
||||||
from django.utils.translation import ugettext, ugettext_lazy
|
from django.utils.translation import ugettext, ugettext_lazy
|
||||||
from django.utils.encoding import StrAndUnicode, force_text
|
from django.utils.encoding import force_text, python_2_unicode_compatible
|
||||||
from django.utils.safestring import mark_safe
|
from django.utils.safestring import mark_safe
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
from django.utils import datetime_safe, formats
|
from django.utils import datetime_safe, formats
|
||||||
|
@ -34,7 +34,8 @@ __all__ = (
|
||||||
|
|
||||||
MEDIA_TYPES = ('css','js')
|
MEDIA_TYPES = ('css','js')
|
||||||
|
|
||||||
class Media(StrAndUnicode):
|
@python_2_unicode_compatible
|
||||||
|
class Media(object):
|
||||||
def __init__(self, media=None, **kwargs):
|
def __init__(self, media=None, **kwargs):
|
||||||
if media:
|
if media:
|
||||||
media_attrs = media.__dict__
|
media_attrs = media.__dict__
|
||||||
|
@ -51,7 +52,7 @@ class Media(StrAndUnicode):
|
||||||
# if media_attrs != {}:
|
# if media_attrs != {}:
|
||||||
# raise TypeError("'class Media' has invalid attribute(s): %s" % ','.join(media_attrs.keys()))
|
# raise TypeError("'class Media' has invalid attribute(s): %s" % ','.join(media_attrs.keys()))
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.render()
|
return self.render()
|
||||||
|
|
||||||
def render(self):
|
def render(self):
|
||||||
|
@ -142,7 +143,8 @@ class MediaDefiningClass(type):
|
||||||
new_class.media = media_property(new_class)
|
new_class.media = media_property(new_class)
|
||||||
return new_class
|
return new_class
|
||||||
|
|
||||||
class SubWidget(StrAndUnicode):
|
@python_2_unicode_compatible
|
||||||
|
class SubWidget(object):
|
||||||
"""
|
"""
|
||||||
Some widgets are made of multiple HTML elements -- namely, RadioSelect.
|
Some widgets are made of multiple HTML elements -- namely, RadioSelect.
|
||||||
This is a class that represents the "inner" HTML element of a widget.
|
This is a class that represents the "inner" HTML element of a widget.
|
||||||
|
@ -152,7 +154,7 @@ class SubWidget(StrAndUnicode):
|
||||||
self.name, self.value = name, value
|
self.name, self.value = name, value
|
||||||
self.attrs, self.choices = attrs, choices
|
self.attrs, self.choices = attrs, choices
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
args = [self.name, self.value, self.attrs]
|
args = [self.name, self.value, self.attrs]
|
||||||
if self.choices:
|
if self.choices:
|
||||||
args.append(self.choices)
|
args.append(self.choices)
|
||||||
|
@ -647,6 +649,7 @@ class SelectMultiple(Select):
|
||||||
data_set = set([force_text(value) for value in data])
|
data_set = set([force_text(value) for value in data])
|
||||||
return data_set != initial_set
|
return data_set != initial_set
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class RadioInput(SubWidget):
|
class RadioInput(SubWidget):
|
||||||
"""
|
"""
|
||||||
An object used by RadioFieldRenderer that represents a single
|
An object used by RadioFieldRenderer that represents a single
|
||||||
|
@ -660,7 +663,7 @@ class RadioInput(SubWidget):
|
||||||
self.choice_label = force_text(choice[1])
|
self.choice_label = force_text(choice[1])
|
||||||
self.index = index
|
self.index = index
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.render()
|
return self.render()
|
||||||
|
|
||||||
def render(self, name=None, value=None, attrs=None, choices=()):
|
def render(self, name=None, value=None, attrs=None, choices=()):
|
||||||
|
@ -685,7 +688,8 @@ class RadioInput(SubWidget):
|
||||||
final_attrs['checked'] = 'checked'
|
final_attrs['checked'] = 'checked'
|
||||||
return format_html('<input{0} />', flatatt(final_attrs))
|
return format_html('<input{0} />', flatatt(final_attrs))
|
||||||
|
|
||||||
class RadioFieldRenderer(StrAndUnicode):
|
@python_2_unicode_compatible
|
||||||
|
class RadioFieldRenderer(object):
|
||||||
"""
|
"""
|
||||||
An object used by RadioSelect to enable customization of radio widgets.
|
An object used by RadioSelect to enable customization of radio widgets.
|
||||||
"""
|
"""
|
||||||
|
@ -702,7 +706,7 @@ class RadioFieldRenderer(StrAndUnicode):
|
||||||
choice = self.choices[idx] # Let the IndexError propogate
|
choice = self.choices[idx] # Let the IndexError propogate
|
||||||
return RadioInput(self.name, self.value, self.attrs.copy(), choice, idx)
|
return RadioInput(self.name, self.value, self.attrs.copy(), choice, idx)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.render()
|
return self.render()
|
||||||
|
|
||||||
def render(self):
|
def render(self):
|
||||||
|
|
|
@ -20,6 +20,7 @@ from django.utils.html import escape
|
||||||
from django.utils.module_loading import module_has_submodule
|
from django.utils.module_loading import module_has_submodule
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
from django.utils.timezone import template_localtime
|
from django.utils.timezone import template_localtime
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
TOKEN_TEXT = 0
|
TOKEN_TEXT = 0
|
||||||
|
@ -79,13 +80,14 @@ class TemplateDoesNotExist(Exception):
|
||||||
class TemplateEncodingError(Exception):
|
class TemplateEncodingError(Exception):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class VariableDoesNotExist(Exception):
|
class VariableDoesNotExist(Exception):
|
||||||
|
|
||||||
def __init__(self, msg, params=()):
|
def __init__(self, msg, params=()):
|
||||||
self.msg = msg
|
self.msg = msg
|
||||||
self.params = params
|
self.params = params
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.msg % tuple([force_text(p, errors='replace')
|
return self.msg % tuple([force_text(p, errors='replace')
|
||||||
for p in self.params])
|
for p in self.params])
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,7 @@ import re
|
||||||
from django.utils.encoding import force_text
|
from django.utils.encoding import force_text
|
||||||
from django.utils.html_parser import HTMLParser, HTMLParseError
|
from django.utils.html_parser import HTMLParser, HTMLParseError
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
WHITESPACE = re.compile('\s+')
|
WHITESPACE = re.compile('\s+')
|
||||||
|
@ -17,6 +18,7 @@ def normalize_whitespace(string):
|
||||||
return WHITESPACE.sub(' ', string)
|
return WHITESPACE.sub(' ', string)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Element(object):
|
class Element(object):
|
||||||
def __init__(self, name, attributes):
|
def __init__(self, name, attributes):
|
||||||
self.name = name
|
self.name = name
|
||||||
|
@ -117,7 +119,7 @@ class Element(object):
|
||||||
def __getitem__(self, key):
|
def __getitem__(self, key):
|
||||||
return self.children[key]
|
return self.children[key]
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
output = '<%s' % self.name
|
output = '<%s' % self.name
|
||||||
for key, value in self.attributes:
|
for key, value in self.attributes:
|
||||||
if value:
|
if value:
|
||||||
|
@ -136,11 +138,12 @@ class Element(object):
|
||||||
return six.text_type(self)
|
return six.text_type(self)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class RootElement(Element):
|
class RootElement(Element):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
super(RootElement, self).__init__(None, ())
|
super(RootElement, self).__init__(None, ())
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return ''.join(six.text_type(c) for c in self.children)
|
return ''.join(six.text_type(c) for c in self.children)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,22 +1,26 @@
|
||||||
# coding: utf-8
|
# coding: utf-8
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
age = models.IntegerField()
|
age = models.IntegerField()
|
||||||
friends = models.ManyToManyField('self', blank=True)
|
friends = models.ManyToManyField('self', blank=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Publisher(models.Model):
|
class Publisher(models.Model):
|
||||||
name = models.CharField(max_length=255)
|
name = models.CharField(max_length=255)
|
||||||
num_awards = models.IntegerField()
|
num_awards = models.IntegerField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
isbn = models.CharField(max_length=9)
|
isbn = models.CharField(max_length=9)
|
||||||
name = models.CharField(max_length=255)
|
name = models.CharField(max_length=255)
|
||||||
|
@ -28,15 +32,16 @@ class Book(models.Model):
|
||||||
publisher = models.ForeignKey(Publisher)
|
publisher = models.ForeignKey(Publisher)
|
||||||
pubdate = models.DateField()
|
pubdate = models.DateField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Store(models.Model):
|
class Store(models.Model):
|
||||||
name = models.CharField(max_length=255)
|
name = models.CharField(max_length=255)
|
||||||
books = models.ManyToManyField(Book)
|
books = models.ManyToManyField(Book)
|
||||||
original_opening = models.DateTimeField()
|
original_opening = models.DateTimeField()
|
||||||
friday_night_closing = models.TimeField()
|
friday_night_closing = models.TimeField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
|
@ -5,8 +5,10 @@
|
||||||
This is a basic model with only two non-primary-key fields.
|
This is a basic model with only two non-primary-key fields.
|
||||||
"""
|
"""
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100, default='Default headline')
|
headline = models.CharField(max_length=100, default='Default headline')
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
|
@ -14,5 +16,5 @@ class Article(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('pub_date','headline')
|
ordering = ('pub_date','headline')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
|
@ -10,6 +10,7 @@ field. This method returns the "human-readable" value of the field.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
GENDER_CHOICES = (
|
GENDER_CHOICES = (
|
||||||
|
@ -17,9 +18,10 @@ GENDER_CHOICES = (
|
||||||
('F', 'Female'),
|
('F', 'Female'),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
gender = models.CharField(max_length=1, choices=GENDER_CHOICES)
|
gender = models.CharField(max_length=1, choices=GENDER_CHOICES)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -18,24 +18,27 @@ from the default generated name, use the ``db_table`` parameter on the
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
first_name = models.CharField(max_length=30, db_column='firstname')
|
first_name = models.CharField(max_length=30, db_column='firstname')
|
||||||
last_name = models.CharField(max_length=30, db_column='last')
|
last_name = models.CharField(max_length=30, db_column='last')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s %s' % (self.first_name, self.last_name)
|
return '%s %s' % (self.first_name, self.last_name)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
db_table = 'my_author_table'
|
db_table = 'my_author_table'
|
||||||
ordering = ('last_name','first_name')
|
ordering = ('last_name','first_name')
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
authors = models.ManyToManyField(Author, db_table='my_m2m_table')
|
authors = models.ManyToManyField(Author, db_table='my_m2m_table')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
|
@ -12,6 +12,7 @@ returns.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
# An example of a custom manager called "objects".
|
# An example of a custom manager called "objects".
|
||||||
|
|
||||||
|
@ -19,13 +20,14 @@ class PersonManager(models.Manager):
|
||||||
def get_fun_people(self):
|
def get_fun_people(self):
|
||||||
return self.filter(fun=True)
|
return self.filter(fun=True)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
first_name = models.CharField(max_length=30)
|
first_name = models.CharField(max_length=30)
|
||||||
last_name = models.CharField(max_length=30)
|
last_name = models.CharField(max_length=30)
|
||||||
fun = models.BooleanField()
|
fun = models.BooleanField()
|
||||||
objects = PersonManager()
|
objects = PersonManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.first_name, self.last_name)
|
return "%s %s" % (self.first_name, self.last_name)
|
||||||
|
|
||||||
# An example of a custom manager that sets get_query_set().
|
# An example of a custom manager that sets get_query_set().
|
||||||
|
@ -34,6 +36,7 @@ class PublishedBookManager(models.Manager):
|
||||||
def get_query_set(self):
|
def get_query_set(self):
|
||||||
return super(PublishedBookManager, self).get_query_set().filter(is_published=True)
|
return super(PublishedBookManager, self).get_query_set().filter(is_published=True)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
title = models.CharField(max_length=50)
|
title = models.CharField(max_length=50)
|
||||||
author = models.CharField(max_length=30)
|
author = models.CharField(max_length=30)
|
||||||
|
@ -41,7 +44,7 @@ class Book(models.Model):
|
||||||
published_objects = PublishedBookManager()
|
published_objects = PublishedBookManager()
|
||||||
authors = models.ManyToManyField(Person, related_name='books')
|
authors = models.ManyToManyField(Person, related_name='books')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
# An example of providing multiple custom managers.
|
# An example of providing multiple custom managers.
|
||||||
|
@ -50,6 +53,7 @@ class FastCarManager(models.Manager):
|
||||||
def get_query_set(self):
|
def get_query_set(self):
|
||||||
return super(FastCarManager, self).get_query_set().filter(top_speed__gt=150)
|
return super(FastCarManager, self).get_query_set().filter(top_speed__gt=150)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Car(models.Model):
|
class Car(models.Model):
|
||||||
name = models.CharField(max_length=10)
|
name = models.CharField(max_length=10)
|
||||||
mileage = models.IntegerField()
|
mileage = models.IntegerField()
|
||||||
|
@ -57,5 +61,5 @@ class Car(models.Model):
|
||||||
cars = models.Manager()
|
cars = models.Manager()
|
||||||
fast_cars = FastCarManager()
|
fast_cars = FastCarManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -7,13 +7,15 @@ Any method you add to a model will be available to instances.
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
pub_date = models.DateField()
|
pub_date = models.DateField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
def was_published_today(self):
|
def was_published_today(self):
|
||||||
|
|
|
@ -3,8 +3,10 @@ import string
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class MyWrapper(object):
|
class MyWrapper(object):
|
||||||
def __init__(self, value):
|
def __init__(self, value):
|
||||||
self.value = value
|
self.value = value
|
||||||
|
@ -12,7 +14,7 @@ class MyWrapper(object):
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return "<%s: %s>" % (self.__class__.__name__, self.value)
|
return "<%s: %s>" % (self.__class__.__name__, self.value)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.value
|
return self.value
|
||||||
|
|
||||||
def __eq__(self, other):
|
def __eq__(self, other):
|
||||||
|
|
|
@ -11,8 +11,10 @@ from __future__ import absolute_import, unicode_literals
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
|
||||||
from .fields import MyAutoField
|
from .fields import MyAutoField
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Employee(models.Model):
|
class Employee(models.Model):
|
||||||
employee_code = models.IntegerField(primary_key=True, db_column = 'code')
|
employee_code = models.IntegerField(primary_key=True, db_column = 'code')
|
||||||
first_name = models.CharField(max_length=20)
|
first_name = models.CharField(max_length=20)
|
||||||
|
@ -20,22 +22,24 @@ class Employee(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('last_name', 'first_name')
|
ordering = ('last_name', 'first_name')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.first_name, self.last_name)
|
return "%s %s" % (self.first_name, self.last_name)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Business(models.Model):
|
class Business(models.Model):
|
||||||
name = models.CharField(max_length=20, primary_key=True)
|
name = models.CharField(max_length=20, primary_key=True)
|
||||||
employees = models.ManyToManyField(Employee)
|
employees = models.ManyToManyField(Employee)
|
||||||
class Meta:
|
class Meta:
|
||||||
verbose_name_plural = 'businesses'
|
verbose_name_plural = 'businesses'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Bar(models.Model):
|
class Bar(models.Model):
|
||||||
id = MyAutoField(primary_key=True, db_index=True)
|
id = MyAutoField(primary_key=True, db_index=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return repr(self.pk)
|
return repr(self.pk)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -3,18 +3,20 @@ Tests for defer() and only().
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class Secondary(models.Model):
|
class Secondary(models.Model):
|
||||||
first = models.CharField(max_length=50)
|
first = models.CharField(max_length=50)
|
||||||
second = models.CharField(max_length=50)
|
second = models.CharField(max_length=50)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Primary(models.Model):
|
class Primary(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
value = models.CharField(max_length=50)
|
value = models.CharField(max_length=50)
|
||||||
related = models.ForeignKey(Secondary)
|
related = models.ForeignKey(Secondary)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Child(Primary):
|
class Child(Primary):
|
||||||
|
|
|
@ -1,12 +1,14 @@
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class R(models.Model):
|
class R(models.Model):
|
||||||
is_default = models.BooleanField(default=False)
|
is_default = models.BooleanField(default=False)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s" % self.pk
|
return "%s" % self.pk
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,9 @@
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Tag(models.Model):
|
class Tag(models.Model):
|
||||||
name = models.CharField(max_length=10)
|
name = models.CharField(max_length=10)
|
||||||
parent = models.ForeignKey('self', blank=True, null=True,
|
parent = models.ForeignKey('self', blank=True, null=True,
|
||||||
|
@ -10,19 +12,21 @@ class Tag(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ['name']
|
ordering = ['name']
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Celebrity(models.Model):
|
class Celebrity(models.Model):
|
||||||
name = models.CharField("Name", max_length=20)
|
name = models.CharField("Name", max_length=20)
|
||||||
greatest_fan = models.ForeignKey("Fan", null=True, unique=True)
|
greatest_fan = models.ForeignKey("Fan", null=True, unique=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Fan(models.Model):
|
class Fan(models.Model):
|
||||||
fan_of = models.ForeignKey(Celebrity)
|
fan_of = models.ForeignKey(Celebrity)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Staff(models.Model):
|
class Staff(models.Model):
|
||||||
id = models.IntegerField(primary_key=True)
|
id = models.IntegerField(primary_key=True)
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
|
@ -30,12 +34,13 @@ class Staff(models.Model):
|
||||||
tags = models.ManyToManyField(Tag, through='StaffTag')
|
tags = models.ManyToManyField(Tag, through='StaffTag')
|
||||||
coworkers = models.ManyToManyField('self')
|
coworkers = models.ManyToManyField('self')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class StaffTag(models.Model):
|
class StaffTag(models.Model):
|
||||||
staff = models.ForeignKey(Staff)
|
staff = models.ForeignKey(Staff)
|
||||||
tag = models.ForeignKey(Tag)
|
tag = models.ForeignKey(Tag)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s -> %s" % (self.tag, self.staff)
|
return "%s -> %s" % (self.tag, self.staff)
|
||||||
|
|
|
@ -4,15 +4,18 @@ Tests for F() query expression syntax.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Employee(models.Model):
|
class Employee(models.Model):
|
||||||
firstname = models.CharField(max_length=50)
|
firstname = models.CharField(max_length=50)
|
||||||
lastname = models.CharField(max_length=50)
|
lastname = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s %s' % (self.firstname, self.lastname)
|
return '%s %s' % (self.firstname, self.lastname)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Company(models.Model):
|
class Company(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
num_employees = models.PositiveIntegerField()
|
num_employees = models.PositiveIntegerField()
|
||||||
|
@ -25,5 +28,5 @@ class Company(models.Model):
|
||||||
related_name='company_point_of_contact_set',
|
related_name='company_point_of_contact_set',
|
||||||
null=True)
|
null=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -13,11 +13,13 @@ field.
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100, default='Default headline')
|
headline = models.CharField(max_length=100, default='Default headline')
|
||||||
pub_date = models.DateTimeField(default=datetime.now)
|
pub_date = models.DateTimeField(default=datetime.now)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
|
@ -5,8 +5,10 @@ import json
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils.encoding import force_text
|
from django.utils.encoding import force_text
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Small(object):
|
class Small(object):
|
||||||
"""
|
"""
|
||||||
A simple class to show that non-trivial Python objects can be used as
|
A simple class to show that non-trivial Python objects can be used as
|
||||||
|
@ -15,7 +17,7 @@ class Small(object):
|
||||||
def __init__(self, first, second):
|
def __init__(self, first, second):
|
||||||
self.first, self.second = first, second
|
self.first, self.second = first, second
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s%s' % (force_text(self.first), force_text(self.second))
|
return '%s%s' % (force_text(self.first), force_text(self.second))
|
||||||
|
|
||||||
class SmallField(models.Field):
|
class SmallField(models.Field):
|
||||||
|
|
|
@ -8,13 +8,15 @@ from django.db import models
|
||||||
from django.utils.encoding import force_text
|
from django.utils.encoding import force_text
|
||||||
|
|
||||||
from .fields import SmallField, SmallerField, JSONField
|
from .fields import SmallField, SmallerField, JSONField
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class MyModel(models.Model):
|
class MyModel(models.Model):
|
||||||
name = models.CharField(max_length=10)
|
name = models.CharField(max_length=10)
|
||||||
data = SmallField('small field')
|
data = SmallField('small field')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return force_text(self.name)
|
return force_text(self.name)
|
||||||
|
|
||||||
class OtherModel(models.Model):
|
class OtherModel(models.Model):
|
||||||
|
|
|
@ -12,38 +12,43 @@ from django.contrib.auth.models import Permission
|
||||||
from django.contrib.contenttypes import generic
|
from django.contrib.contenttypes import generic
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Category(models.Model):
|
class Category(models.Model):
|
||||||
title = models.CharField(max_length=100)
|
title = models.CharField(max_length=100)
|
||||||
description = models.TextField()
|
description = models.TextField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('title',)
|
ordering = ('title',)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100, default='Default headline')
|
headline = models.CharField(max_length=100, default='Default headline')
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('-pub_date', 'headline')
|
ordering = ('-pub_date', 'headline')
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Blog(models.Model):
|
class Blog(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
featured = models.ForeignKey(Article, related_name='fixtures_featured_set')
|
featured = models.ForeignKey(Article, related_name='fixtures_featured_set')
|
||||||
articles = models.ManyToManyField(Article, blank=True,
|
articles = models.ManyToManyField(Article, blank=True,
|
||||||
related_name='fixtures_articles_set')
|
related_name='fixtures_articles_set')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Tag(models.Model):
|
class Tag(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
tagged_type = models.ForeignKey(ContentType, related_name="fixtures_tag_set")
|
tagged_type = models.ForeignKey(ContentType, related_name="fixtures_tag_set")
|
||||||
|
@ -51,7 +56,7 @@ class Tag(models.Model):
|
||||||
tagged = generic.GenericForeignKey(ct_field='tagged_type',
|
tagged = generic.GenericForeignKey(ct_field='tagged_type',
|
||||||
fk_field='tagged_id')
|
fk_field='tagged_id')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '<%s: %s> tagged "%s"' % (self.tagged.__class__.__name__,
|
return '<%s: %s> tagged "%s"' % (self.tagged.__class__.__name__,
|
||||||
self.tagged, self.name)
|
self.tagged, self.name)
|
||||||
|
|
||||||
|
@ -59,10 +64,11 @@ class PersonManager(models.Manager):
|
||||||
def get_by_natural_key(self, name):
|
def get_by_natural_key(self, name):
|
||||||
return self.get(name=name)
|
return self.get(name=name)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
objects = PersonManager()
|
objects = PersonManager()
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -79,19 +85,21 @@ class Spy(Person):
|
||||||
objects = SpyManager()
|
objects = SpyManager()
|
||||||
cover_blown = models.BooleanField(default=False)
|
cover_blown = models.BooleanField(default=False)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Visa(models.Model):
|
class Visa(models.Model):
|
||||||
person = models.ForeignKey(Person)
|
person = models.ForeignKey(Person)
|
||||||
permissions = models.ManyToManyField(Permission, blank=True)
|
permissions = models.ManyToManyField(Permission, blank=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s %s' % (self.person.name,
|
return '%s %s' % (self.person.name,
|
||||||
', '.join(p.name for p in self.permissions.all()))
|
', '.join(p.name for p in self.permissions.all()))
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
authors = models.ManyToManyField(Person)
|
authors = models.ManyToManyField(Person)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
authors = ' and '.join(a.name for a in self.authors.all())
|
authors = ' and '.join(a.name for a in self.authors.all())
|
||||||
return '%s by %s' % (self.name, authors) if authors else self.name
|
return '%s by %s' % (self.name, authors) if authors else self.name
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100, default='Default headline')
|
headline = models.CharField(max_length=100, default='Default headline')
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
|
@ -14,8 +14,10 @@ from __future__ import unicode_literals
|
||||||
from django.contrib.contenttypes import generic
|
from django.contrib.contenttypes import generic
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class TaggedItem(models.Model):
|
class TaggedItem(models.Model):
|
||||||
"""A tag on an item."""
|
"""A tag on an item."""
|
||||||
tag = models.SlugField()
|
tag = models.SlugField()
|
||||||
|
@ -27,12 +29,13 @@ class TaggedItem(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ["tag", "content_type__name"]
|
ordering = ["tag", "content_type__name"]
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.tag
|
return self.tag
|
||||||
|
|
||||||
class ValuableTaggedItem(TaggedItem):
|
class ValuableTaggedItem(TaggedItem):
|
||||||
value = models.PositiveIntegerField()
|
value = models.PositiveIntegerField()
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Comparison(models.Model):
|
class Comparison(models.Model):
|
||||||
"""
|
"""
|
||||||
A model that tests having multiple GenericForeignKeys
|
A model that tests having multiple GenericForeignKeys
|
||||||
|
@ -48,9 +51,10 @@ class Comparison(models.Model):
|
||||||
first_obj = generic.GenericForeignKey(ct_field="content_type1", fk_field="object_id1")
|
first_obj = generic.GenericForeignKey(ct_field="content_type1", fk_field="object_id1")
|
||||||
other_obj = generic.GenericForeignKey(ct_field="content_type2", fk_field="object_id2")
|
other_obj = generic.GenericForeignKey(ct_field="content_type2", fk_field="object_id2")
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s is %s than %s" % (self.first_obj, self.comparative, self.other_obj)
|
return "%s is %s than %s" % (self.first_obj, self.comparative, self.other_obj)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Animal(models.Model):
|
class Animal(models.Model):
|
||||||
common_name = models.CharField(max_length=150)
|
common_name = models.CharField(max_length=150)
|
||||||
latin_name = models.CharField(max_length=150)
|
latin_name = models.CharField(max_length=150)
|
||||||
|
@ -60,25 +64,27 @@ class Animal(models.Model):
|
||||||
object_id_field="object_id1",
|
object_id_field="object_id1",
|
||||||
content_type_field="content_type1")
|
content_type_field="content_type1")
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.common_name
|
return self.common_name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Vegetable(models.Model):
|
class Vegetable(models.Model):
|
||||||
name = models.CharField(max_length=150)
|
name = models.CharField(max_length=150)
|
||||||
is_yucky = models.BooleanField(default=True)
|
is_yucky = models.BooleanField(default=True)
|
||||||
|
|
||||||
tags = generic.GenericRelation(TaggedItem)
|
tags = generic.GenericRelation(TaggedItem)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Mineral(models.Model):
|
class Mineral(models.Model):
|
||||||
name = models.CharField(max_length=150)
|
name = models.CharField(max_length=150)
|
||||||
hardness = models.PositiveSmallIntegerField()
|
hardness = models.PositiveSmallIntegerField()
|
||||||
|
|
||||||
# note the lack of an explicit GenericRelation here...
|
# note the lack of an explicit GenericRelation here...
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class GeckoManager(models.Manager):
|
class GeckoManager(models.Manager):
|
||||||
|
|
|
@ -9,8 +9,10 @@ farthest into the future."
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
pub_date = models.DateField()
|
pub_date = models.DateField()
|
||||||
|
@ -18,14 +20,15 @@ class Article(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
get_latest_by = 'pub_date'
|
get_latest_by = 'pub_date'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
birthday = models.DateField()
|
birthday = models.DateField()
|
||||||
|
|
||||||
# Note that this model doesn't have "get_latest_by" set.
|
# Note that this model doesn't have "get_latest_by" set.
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -11,23 +11,26 @@ performing a ``filter()`` lookup and raising a ``Http404`` exception if a
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class ArticleManager(models.Manager):
|
class ArticleManager(models.Manager):
|
||||||
def get_query_set(self):
|
def get_query_set(self):
|
||||||
return super(ArticleManager, self).get_query_set().filter(authors__name__icontains='sir')
|
return super(ArticleManager, self).get_query_set().filter(authors__name__icontains='sir')
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
authors = models.ManyToManyField(Author)
|
authors = models.ManyToManyField(Author)
|
||||||
title = models.CharField(max_length=50)
|
title = models.CharField(max_length=50)
|
||||||
objects = models.Manager()
|
objects = models.Manager()
|
||||||
by_a_sir = ArticleManager()
|
by_a_sir = ArticleManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
|
@ -9,14 +9,16 @@ parameters.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
first_name = models.CharField(max_length=100)
|
first_name = models.CharField(max_length=100)
|
||||||
last_name = models.CharField(max_length=100)
|
last_name = models.CharField(max_length=100)
|
||||||
birthday = models.DateField()
|
birthday = models.DateField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s %s' % (self.first_name, self.last_name)
|
return '%s %s' % (self.first_name, self.last_name)
|
||||||
|
|
||||||
class ManualPrimaryKeyTest(models.Model):
|
class ManualPrimaryKeyTest(models.Model):
|
||||||
|
|
|
@ -8,6 +8,7 @@ from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
|
@ -15,6 +16,7 @@ class Author(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name', )
|
ordering = ('name', )
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
|
@ -22,7 +24,7 @@ class Article(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('-pub_date', 'headline')
|
ordering = ('-pub_date', 'headline')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
class Tag(models.Model):
|
class Tag(models.Model):
|
||||||
|
@ -31,24 +33,27 @@ class Tag(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name', )
|
ordering = ('name', )
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Season(models.Model):
|
class Season(models.Model):
|
||||||
year = models.PositiveSmallIntegerField()
|
year = models.PositiveSmallIntegerField()
|
||||||
gt = models.IntegerField(null=True, blank=True)
|
gt = models.IntegerField(null=True, blank=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return six.text_type(self.year)
|
return six.text_type(self.year)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Game(models.Model):
|
class Game(models.Model):
|
||||||
season = models.ForeignKey(Season, related_name='games')
|
season = models.ForeignKey(Season, related_name='games')
|
||||||
home = models.CharField(max_length=100)
|
home = models.CharField(max_length=100)
|
||||||
away = models.CharField(max_length=100)
|
away = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s at %s" % (self.away, self.home)
|
return "%s at %s" % (self.away, self.home)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Player(models.Model):
|
class Player(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
games = models.ManyToManyField(Game, related_name='players')
|
games = models.ManyToManyField(Game, related_name='players')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -7,17 +7,19 @@ from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class User(models.Model):
|
class User(models.Model):
|
||||||
username = models.CharField(max_length=20)
|
username = models.CharField(max_length=20)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Issue(models.Model):
|
class Issue(models.Model):
|
||||||
num = models.IntegerField()
|
num = models.IntegerField()
|
||||||
cc = models.ManyToManyField(User, blank=True, related_name='test_issue_cc')
|
cc = models.ManyToManyField(User, blank=True, related_name='test_issue_cc')
|
||||||
client = models.ForeignKey(User, related_name='test_issue_client')
|
client = models.ForeignKey(User, related_name='test_issue_client')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return six.text_type(self.num)
|
return six.text_type(self.num)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
|
@ -12,27 +12,31 @@ field, which specifies the ``Reporter``'s position for the given article
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Reporter(models.Model):
|
class Reporter(models.Model):
|
||||||
first_name = models.CharField(max_length=30)
|
first_name = models.CharField(max_length=30)
|
||||||
last_name = models.CharField(max_length=30)
|
last_name = models.CharField(max_length=30)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.first_name, self.last_name)
|
return "%s %s" % (self.first_name, self.last_name)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
pub_date = models.DateField()
|
pub_date = models.DateField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Writer(models.Model):
|
class Writer(models.Model):
|
||||||
reporter = models.ForeignKey(Reporter)
|
reporter = models.ForeignKey(Reporter)
|
||||||
article = models.ForeignKey(Article)
|
article = models.ForeignKey(Article)
|
||||||
position = models.CharField(max_length=100)
|
position = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s (%s)' % (self.reporter, self.position)
|
return '%s (%s)' % (self.reporter, self.position)
|
||||||
|
|
||||||
|
|
|
@ -8,16 +8,19 @@ Set ``related_name`` to designate what the reverse relationship is called.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Category(models.Model):
|
class Category(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=50)
|
headline = models.CharField(max_length=50)
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
|
@ -26,6 +29,6 @@ class Article(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('pub_date',)
|
ordering = ('pub_date',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
|
|
|
@ -17,12 +17,14 @@ appropriate.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
friends = models.ManyToManyField('self')
|
friends = models.ManyToManyField('self')
|
||||||
idols = models.ManyToManyField('self', symmetrical=False, related_name='stalkers')
|
idols = models.ManyToManyField('self', symmetrical=False, related_name='stalkers')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -1,15 +1,18 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Part(models.Model):
|
class Part(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Car(models.Model):
|
class Car(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
default_parts = models.ManyToManyField(Part)
|
default_parts = models.ManyToManyField(Part)
|
||||||
|
@ -18,12 +21,13 @@ class Car(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class SportsCar(Car):
|
class SportsCar(Car):
|
||||||
price = models.IntegerField()
|
price = models.IntegerField()
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
fans = models.ManyToManyField('self', related_name='idols', symmetrical=False)
|
fans = models.ManyToManyField('self', related_name='idols', symmetrical=False)
|
||||||
|
@ -32,5 +36,5 @@ class Person(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -1,18 +1,21 @@
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
# M2M described on one of the models
|
# M2M described on one of the models
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
name = models.CharField(max_length=128)
|
name = models.CharField(max_length=128)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Group(models.Model):
|
class Group(models.Model):
|
||||||
name = models.CharField(max_length=128)
|
name = models.CharField(max_length=128)
|
||||||
members = models.ManyToManyField(Person, through='Membership')
|
members = models.ManyToManyField(Person, through='Membership')
|
||||||
|
@ -22,9 +25,10 @@ class Group(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Membership(models.Model):
|
class Membership(models.Model):
|
||||||
person = models.ForeignKey(Person)
|
person = models.ForeignKey(Person)
|
||||||
group = models.ForeignKey(Group)
|
group = models.ForeignKey(Group)
|
||||||
|
@ -34,16 +38,17 @@ class Membership(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('date_joined', 'invite_reason', 'group')
|
ordering = ('date_joined', 'invite_reason', 'group')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s is a member of %s" % (self.person.name, self.group.name)
|
return "%s is a member of %s" % (self.person.name, self.group.name)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class CustomMembership(models.Model):
|
class CustomMembership(models.Model):
|
||||||
person = models.ForeignKey(Person, db_column="custom_person_column", related_name="custom_person_related_name")
|
person = models.ForeignKey(Person, db_column="custom_person_column", related_name="custom_person_related_name")
|
||||||
group = models.ForeignKey(Group)
|
group = models.ForeignKey(Group)
|
||||||
weird_fk = models.ForeignKey(Membership, null=True)
|
weird_fk = models.ForeignKey(Membership, null=True)
|
||||||
date_joined = models.DateTimeField(default=datetime.now)
|
date_joined = models.DateTimeField(default=datetime.now)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s is a member of %s" % (self.person.name, self.group.name)
|
return "%s is a member of %s" % (self.person.name, self.group.name)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -54,11 +59,12 @@ class TestNoDefaultsOrNulls(models.Model):
|
||||||
group = models.ForeignKey(Group)
|
group = models.ForeignKey(Group)
|
||||||
nodefaultnonull = models.CharField(max_length=5)
|
nodefaultnonull = models.CharField(max_length=5)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class PersonSelfRefM2M(models.Model):
|
class PersonSelfRefM2M(models.Model):
|
||||||
name = models.CharField(max_length=5)
|
name = models.CharField(max_length=5)
|
||||||
friends = models.ManyToManyField('self', through="Friendship", symmetrical=False)
|
friends = models.ManyToManyField('self', through="Friendship", symmetrical=False)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Friendship(models.Model):
|
class Friendship(models.Model):
|
||||||
|
|
|
@ -11,19 +11,22 @@ Set ``related_name`` to designate what the reverse relationship is called.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Category(models.Model):
|
class Category(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
parent = models.ForeignKey('self', blank=True, null=True, related_name='child_set')
|
parent = models.ForeignKey('self', blank=True, null=True, related_name='child_set')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
full_name = models.CharField(max_length=20)
|
full_name = models.CharField(max_length=20)
|
||||||
mother = models.ForeignKey('self', null=True, related_name='mothers_child_set')
|
mother = models.ForeignKey('self', null=True, related_name='mothers_child_set')
|
||||||
father = models.ForeignKey('self', null=True, related_name='fathers_child_set')
|
father = models.ForeignKey('self', null=True, related_name='fathers_child_set')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.full_name
|
return self.full_name
|
||||||
|
|
|
@ -8,22 +8,25 @@ objects, and a ``Publication`` has multiple ``Article`` objects.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Publication(models.Model):
|
class Publication(models.Model):
|
||||||
title = models.CharField(max_length=30)
|
title = models.CharField(max_length=30)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('title',)
|
ordering = ('title',)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
publications = models.ManyToManyField(Publication)
|
publications = models.ManyToManyField(Publication)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
|
@ -6,22 +6,25 @@ To define a many-to-one relationship, use ``ForeignKey()``.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Reporter(models.Model):
|
class Reporter(models.Model):
|
||||||
first_name = models.CharField(max_length=30)
|
first_name = models.CharField(max_length=30)
|
||||||
last_name = models.CharField(max_length=30)
|
last_name = models.CharField(max_length=30)
|
||||||
email = models.EmailField()
|
email = models.EmailField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.first_name, self.last_name)
|
return "%s %s" % (self.first_name, self.last_name)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
pub_date = models.DateField()
|
pub_date = models.DateField()
|
||||||
reporter = models.ForeignKey(Reporter)
|
reporter = models.ForeignKey(Reporter)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
|
@ -6,14 +6,17 @@ To define a many-to-one relationship that can have a null foreign key, use
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Reporter(models.Model):
|
class Reporter(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
reporter = models.ForeignKey(Reporter, null=True)
|
reporter = models.ForeignKey(Reporter, null=True)
|
||||||
|
@ -21,5 +24,5 @@ class Article(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('headline',)
|
ordering = ('headline',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
|
@ -14,6 +14,7 @@ import tempfile
|
||||||
from django.core.files.storage import FileSystemStorage
|
from django.core.files.storage import FileSystemStorage
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
temp_storage_dir = tempfile.mkdtemp(dir=os.environ['DJANGO_TEST_TEMP_DIR'])
|
temp_storage_dir = tempfile.mkdtemp(dir=os.environ['DJANGO_TEST_TEMP_DIR'])
|
||||||
|
@ -31,23 +32,26 @@ ARTICLE_STATUS_CHAR = (
|
||||||
('l', 'Live'),
|
('l', 'Live'),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Category(models.Model):
|
class Category(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
slug = models.SlugField(max_length=20)
|
slug = models.SlugField(max_length=20)
|
||||||
url = models.CharField('The URL', max_length=40)
|
url = models.CharField('The URL', max_length=40)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Writer(models.Model):
|
class Writer(models.Model):
|
||||||
name = models.CharField(max_length=50, help_text='Use both first and last names.')
|
name = models.CharField(max_length=50, help_text='Use both first and last names.')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=50)
|
headline = models.CharField(max_length=50)
|
||||||
slug = models.SlugField()
|
slug = models.SlugField()
|
||||||
|
@ -64,7 +68,7 @@ class Article(models.Model):
|
||||||
self.created = datetime.date.today()
|
self.created = datetime.date.today()
|
||||||
return super(Article, self).save()
|
return super(Article, self).save()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
class ImprovedArticle(models.Model):
|
class ImprovedArticle(models.Model):
|
||||||
|
@ -76,26 +80,29 @@ class ImprovedArticleWithParentLink(models.Model):
|
||||||
class BetterWriter(Writer):
|
class BetterWriter(Writer):
|
||||||
score = models.IntegerField()
|
score = models.IntegerField()
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class WriterProfile(models.Model):
|
class WriterProfile(models.Model):
|
||||||
writer = models.OneToOneField(Writer, primary_key=True)
|
writer = models.OneToOneField(Writer, primary_key=True)
|
||||||
age = models.PositiveIntegerField()
|
age = models.PositiveIntegerField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s is %s" % (self.writer, self.age)
|
return "%s is %s" % (self.writer, self.age)
|
||||||
|
|
||||||
from django.contrib.localflavor.us.models import PhoneNumberField
|
from django.contrib.localflavor.us.models import PhoneNumberField
|
||||||
|
@python_2_unicode_compatible
|
||||||
class PhoneNumber(models.Model):
|
class PhoneNumber(models.Model):
|
||||||
phone = PhoneNumberField()
|
phone = PhoneNumberField()
|
||||||
description = models.CharField(max_length=20)
|
description = models.CharField(max_length=20)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.phone
|
return self.phone
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class TextFile(models.Model):
|
class TextFile(models.Model):
|
||||||
description = models.CharField(max_length=20)
|
description = models.CharField(max_length=20)
|
||||||
file = models.FileField(storage=temp_storage, upload_to='tests', max_length=15)
|
file = models.FileField(storage=temp_storage, upload_to='tests', max_length=15)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.description
|
return self.description
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -110,6 +117,7 @@ try:
|
||||||
|
|
||||||
test_images = True
|
test_images = True
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ImageFile(models.Model):
|
class ImageFile(models.Model):
|
||||||
def custom_upload_path(self, filename):
|
def custom_upload_path(self, filename):
|
||||||
path = self.path or 'tests'
|
path = self.path or 'tests'
|
||||||
|
@ -125,9 +133,10 @@ try:
|
||||||
width_field='width', height_field='height')
|
width_field='width', height_field='height')
|
||||||
path = models.CharField(max_length=16, blank=True, default='')
|
path = models.CharField(max_length=16, blank=True, default='')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.description
|
return self.description
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class OptionalImageFile(models.Model):
|
class OptionalImageFile(models.Model):
|
||||||
def custom_upload_path(self, filename):
|
def custom_upload_path(self, filename):
|
||||||
path = self.path or 'tests'
|
path = self.path or 'tests'
|
||||||
|
@ -141,28 +150,31 @@ try:
|
||||||
height = models.IntegerField(editable=False, null=True)
|
height = models.IntegerField(editable=False, null=True)
|
||||||
path = models.CharField(max_length=16, blank=True, default='')
|
path = models.CharField(max_length=16, blank=True, default='')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.description
|
return self.description
|
||||||
except ImportError:
|
except ImportError:
|
||||||
test_images = False
|
test_images = False
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class CommaSeparatedInteger(models.Model):
|
class CommaSeparatedInteger(models.Model):
|
||||||
field = models.CommaSeparatedIntegerField(max_length=20)
|
field = models.CommaSeparatedIntegerField(max_length=20)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.field
|
return self.field
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Product(models.Model):
|
class Product(models.Model):
|
||||||
slug = models.SlugField(unique=True)
|
slug = models.SlugField(unique=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.slug
|
return self.slug
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Price(models.Model):
|
class Price(models.Model):
|
||||||
price = models.DecimalField(max_digits=10, decimal_places=2)
|
price = models.DecimalField(max_digits=10, decimal_places=2)
|
||||||
quantity = models.PositiveIntegerField()
|
quantity = models.PositiveIntegerField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s for %s" % (self.quantity, self.price)
|
return "%s for %s" % (self.quantity, self.price)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -171,6 +183,7 @@ class Price(models.Model):
|
||||||
class ArticleStatus(models.Model):
|
class ArticleStatus(models.Model):
|
||||||
status = models.CharField(max_length=2, choices=ARTICLE_STATUS_CHAR, blank=True, null=True)
|
status = models.CharField(max_length=2, choices=ARTICLE_STATUS_CHAR, blank=True, null=True)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Inventory(models.Model):
|
class Inventory(models.Model):
|
||||||
barcode = models.PositiveIntegerField(unique=True)
|
barcode = models.PositiveIntegerField(unique=True)
|
||||||
parent = models.ForeignKey('self', to_field='barcode', blank=True, null=True)
|
parent = models.ForeignKey('self', to_field='barcode', blank=True, null=True)
|
||||||
|
@ -179,7 +192,7 @@ class Inventory(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
|
@ -202,31 +215,34 @@ class BookXtra(models.Model):
|
||||||
class DerivedBook(Book, BookXtra):
|
class DerivedBook(Book, BookXtra):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ExplicitPK(models.Model):
|
class ExplicitPK(models.Model):
|
||||||
key = models.CharField(max_length=20, primary_key=True)
|
key = models.CharField(max_length=20, primary_key=True)
|
||||||
desc = models.CharField(max_length=20, blank=True, unique=True)
|
desc = models.CharField(max_length=20, blank=True, unique=True)
|
||||||
class Meta:
|
class Meta:
|
||||||
unique_together = ('key', 'desc')
|
unique_together = ('key', 'desc')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.key
|
return self.key
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Post(models.Model):
|
class Post(models.Model):
|
||||||
title = models.CharField(max_length=50, unique_for_date='posted', blank=True)
|
title = models.CharField(max_length=50, unique_for_date='posted', blank=True)
|
||||||
slug = models.CharField(max_length=50, unique_for_year='posted', blank=True)
|
slug = models.CharField(max_length=50, unique_for_year='posted', blank=True)
|
||||||
subtitle = models.CharField(max_length=50, unique_for_month='posted', blank=True)
|
subtitle = models.CharField(max_length=50, unique_for_month='posted', blank=True)
|
||||||
posted = models.DateField()
|
posted = models.DateField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class DerivedPost(Post):
|
class DerivedPost(Post):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class BigInt(models.Model):
|
class BigInt(models.Model):
|
||||||
biggie = models.BigIntegerField()
|
biggie = models.BigIntegerField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return six.text_type(self.biggie)
|
return six.text_type(self.biggie)
|
||||||
|
|
||||||
class MarkupField(models.CharField):
|
class MarkupField(models.CharField):
|
||||||
|
|
|
@ -4,20 +4,23 @@ import datetime
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class BetterAuthor(Author):
|
class BetterAuthor(Author):
|
||||||
write_speed = models.IntegerField()
|
write_speed = models.IntegerField()
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
author = models.ForeignKey(Author)
|
author = models.ForeignKey(Author)
|
||||||
title = models.CharField(max_length=100)
|
title = models.CharField(max_length=100)
|
||||||
|
@ -28,20 +31,22 @@ class Book(models.Model):
|
||||||
)
|
)
|
||||||
ordering = ['id']
|
ordering = ['id']
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class BookWithCustomPK(models.Model):
|
class BookWithCustomPK(models.Model):
|
||||||
my_pk = models.DecimalField(max_digits=5, decimal_places=0, primary_key=True)
|
my_pk = models.DecimalField(max_digits=5, decimal_places=0, primary_key=True)
|
||||||
author = models.ForeignKey(Author)
|
author = models.ForeignKey(Author)
|
||||||
title = models.CharField(max_length=100)
|
title = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s: %s' % (self.my_pk, self.title)
|
return '%s: %s' % (self.my_pk, self.title)
|
||||||
|
|
||||||
class Editor(models.Model):
|
class Editor(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class BookWithOptionalAltEditor(models.Model):
|
class BookWithOptionalAltEditor(models.Model):
|
||||||
author = models.ForeignKey(Author)
|
author = models.ForeignKey(Author)
|
||||||
# Optional secondary author
|
# Optional secondary author
|
||||||
|
@ -53,21 +58,23 @@ class BookWithOptionalAltEditor(models.Model):
|
||||||
('author', 'title', 'alt_editor'),
|
('author', 'title', 'alt_editor'),
|
||||||
)
|
)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class AlternateBook(Book):
|
class AlternateBook(Book):
|
||||||
notes = models.CharField(max_length=100)
|
notes = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s - %s' % (self.title, self.notes)
|
return '%s - %s' % (self.title, self.notes)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class AuthorMeeting(models.Model):
|
class AuthorMeeting(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
authors = models.ManyToManyField(Author)
|
authors = models.ManyToManyField(Author)
|
||||||
created = models.DateField(editable=False)
|
created = models.DateField(editable=False)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class CustomPrimaryKey(models.Model):
|
class CustomPrimaryKey(models.Model):
|
||||||
|
@ -77,19 +84,21 @@ class CustomPrimaryKey(models.Model):
|
||||||
|
|
||||||
# models for inheritance tests.
|
# models for inheritance tests.
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Place(models.Model):
|
class Place(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
city = models.CharField(max_length=50)
|
city = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Owner(models.Model):
|
class Owner(models.Model):
|
||||||
auto_id = models.AutoField(primary_key=True)
|
auto_id = models.AutoField(primary_key=True)
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
place = models.ForeignKey(Place)
|
place = models.ForeignKey(Place)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s at %s" % (self.name, self.place)
|
return "%s at %s" % (self.name, self.place)
|
||||||
|
|
||||||
class Location(models.Model):
|
class Location(models.Model):
|
||||||
|
@ -98,30 +107,34 @@ class Location(models.Model):
|
||||||
lat = models.CharField(max_length=100)
|
lat = models.CharField(max_length=100)
|
||||||
lon = models.CharField(max_length=100)
|
lon = models.CharField(max_length=100)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class OwnerProfile(models.Model):
|
class OwnerProfile(models.Model):
|
||||||
owner = models.OneToOneField(Owner, primary_key=True)
|
owner = models.OneToOneField(Owner, primary_key=True)
|
||||||
age = models.PositiveIntegerField()
|
age = models.PositiveIntegerField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s is %d" % (self.owner.name, self.age)
|
return "%s is %d" % (self.owner.name, self.age)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Restaurant(Place):
|
class Restaurant(Place):
|
||||||
serves_pizza = models.BooleanField()
|
serves_pizza = models.BooleanField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Product(models.Model):
|
class Product(models.Model):
|
||||||
slug = models.SlugField(unique=True)
|
slug = models.SlugField(unique=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.slug
|
return self.slug
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Price(models.Model):
|
class Price(models.Model):
|
||||||
price = models.DecimalField(max_digits=10, decimal_places=2)
|
price = models.DecimalField(max_digits=10, decimal_places=2)
|
||||||
quantity = models.PositiveIntegerField()
|
quantity = models.PositiveIntegerField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s for %s" % (self.quantity, self.price)
|
return "%s for %s" % (self.quantity, self.price)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -136,12 +149,14 @@ class ClassyMexicanRestaurant(MexicanRestaurant):
|
||||||
|
|
||||||
# models for testing unique_together validation when a fk is involved and
|
# models for testing unique_together validation when a fk is involved and
|
||||||
# using inlineformset_factory.
|
# using inlineformset_factory.
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Repository(models.Model):
|
class Repository(models.Model):
|
||||||
name = models.CharField(max_length=25)
|
name = models.CharField(max_length=25)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Revision(models.Model):
|
class Revision(models.Model):
|
||||||
repository = models.ForeignKey(Repository)
|
repository = models.ForeignKey(Repository)
|
||||||
revision = models.CharField(max_length=40)
|
revision = models.CharField(max_length=40)
|
||||||
|
@ -149,7 +164,7 @@ class Revision(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
unique_together = (("repository", "revision"),)
|
unique_together = (("repository", "revision"),)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s (%s)" % (self.revision, six.text_type(self.repository))
|
return "%s (%s)" % (self.revision, six.text_type(self.repository))
|
||||||
|
|
||||||
# models for testing callable defaults (see bug #7975). If you define a model
|
# models for testing callable defaults (see bug #7975). If you define a model
|
||||||
|
@ -167,32 +182,36 @@ class Membership(models.Model):
|
||||||
class Team(models.Model):
|
class Team(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Player(models.Model):
|
class Player(models.Model):
|
||||||
team = models.ForeignKey(Team, null=True)
|
team = models.ForeignKey(Team, null=True)
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
# Models for testing custom ModelForm save methods in formsets and inline formsets
|
# Models for testing custom ModelForm save methods in formsets and inline formsets
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Poet(models.Model):
|
class Poet(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Poem(models.Model):
|
class Poem(models.Model):
|
||||||
poet = models.ForeignKey(Poet)
|
poet = models.ForeignKey(Poet)
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Post(models.Model):
|
class Post(models.Model):
|
||||||
title = models.CharField(max_length=50, unique_for_date='posted', blank=True)
|
title = models.CharField(max_length=50, unique_for_date='posted', blank=True)
|
||||||
slug = models.CharField(max_length=50, unique_for_year='posted', blank=True)
|
slug = models.CharField(max_length=50, unique_for_year='posted', blank=True)
|
||||||
subtitle = models.CharField(max_length=50, unique_for_month='posted', blank=True)
|
subtitle = models.CharField(max_length=50, unique_for_month='posted', blank=True)
|
||||||
posted = models.DateField()
|
posted = models.DateField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -14,11 +14,13 @@ Both styles are demonstrated here.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
#
|
#
|
||||||
# Abstract base classes
|
# Abstract base classes
|
||||||
#
|
#
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class CommonInfo(models.Model):
|
class CommonInfo(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
age = models.PositiveIntegerField()
|
age = models.PositiveIntegerField()
|
||||||
|
@ -27,7 +29,7 @@ class CommonInfo(models.Model):
|
||||||
abstract = True
|
abstract = True
|
||||||
ordering = ['name']
|
ordering = ['name']
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s %s' % (self.__class__.__name__, self.name)
|
return '%s %s' % (self.__class__.__name__, self.name)
|
||||||
|
|
||||||
class Worker(CommonInfo):
|
class Worker(CommonInfo):
|
||||||
|
@ -49,6 +51,7 @@ class StudentWorker(Student, Worker):
|
||||||
class Post(models.Model):
|
class Post(models.Model):
|
||||||
title = models.CharField(max_length=50)
|
title = models.CharField(max_length=50)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Attachment(models.Model):
|
class Attachment(models.Model):
|
||||||
post = models.ForeignKey(Post, related_name='attached_%(class)s_set')
|
post = models.ForeignKey(Post, related_name='attached_%(class)s_set')
|
||||||
content = models.TextField()
|
content = models.TextField()
|
||||||
|
@ -56,7 +59,7 @@ class Attachment(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
abstract = True
|
abstract = True
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.content
|
return self.content
|
||||||
|
|
||||||
class Comment(Attachment):
|
class Comment(Attachment):
|
||||||
|
@ -69,17 +72,19 @@ class Link(Attachment):
|
||||||
# Multi-table inheritance
|
# Multi-table inheritance
|
||||||
#
|
#
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Chef(models.Model):
|
class Chef(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s the chef" % self.name
|
return "%s the chef" % self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Place(models.Model):
|
class Place(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
address = models.CharField(max_length=80)
|
address = models.CharField(max_length=80)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s the place" % self.name
|
return "%s the place" % self.name
|
||||||
|
|
||||||
class Rating(models.Model):
|
class Rating(models.Model):
|
||||||
|
@ -89,6 +94,7 @@ class Rating(models.Model):
|
||||||
abstract = True
|
abstract = True
|
||||||
ordering = ['-rating']
|
ordering = ['-rating']
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Restaurant(Place, Rating):
|
class Restaurant(Place, Rating):
|
||||||
serves_hot_dogs = models.BooleanField()
|
serves_hot_dogs = models.BooleanField()
|
||||||
serves_pizza = models.BooleanField()
|
serves_pizza = models.BooleanField()
|
||||||
|
@ -97,27 +103,30 @@ class Restaurant(Place, Rating):
|
||||||
class Meta(Rating.Meta):
|
class Meta(Rating.Meta):
|
||||||
db_table = 'my_restaurant'
|
db_table = 'my_restaurant'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s the restaurant" % self.name
|
return "%s the restaurant" % self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ItalianRestaurant(Restaurant):
|
class ItalianRestaurant(Restaurant):
|
||||||
serves_gnocchi = models.BooleanField()
|
serves_gnocchi = models.BooleanField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s the italian restaurant" % self.name
|
return "%s the italian restaurant" % self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Supplier(Place):
|
class Supplier(Place):
|
||||||
customers = models.ManyToManyField(Restaurant, related_name='provider')
|
customers = models.ManyToManyField(Restaurant, related_name='provider')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s the supplier" % self.name
|
return "%s the supplier" % self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ParkingLot(Place):
|
class ParkingLot(Place):
|
||||||
# An explicit link to the parent (we can control the attribute name).
|
# An explicit link to the parent (we can control the attribute name).
|
||||||
parent = models.OneToOneField(Place, primary_key=True, parent_link=True)
|
parent = models.OneToOneField(Place, primary_key=True, parent_link=True)
|
||||||
main_site = models.ForeignKey(Place, related_name='lot')
|
main_site = models.ForeignKey(Place, related_name='lot')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s the parking lot" % self.name
|
return "%s the parking lot" % self.name
|
||||||
|
|
||||||
#
|
#
|
||||||
|
@ -139,10 +148,11 @@ class NamedURL(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
abstract = True
|
abstract = True
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Copy(NamedURL):
|
class Copy(NamedURL):
|
||||||
content = models.TextField()
|
content = models.TextField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.content
|
return self.content
|
||||||
|
|
||||||
class Mixin(object):
|
class Mixin(object):
|
||||||
|
|
|
@ -11,12 +11,14 @@ from __future__ import absolute_import
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
|
||||||
from ..model_inheritance.models import NamedURL
|
from ..model_inheritance.models import NamedURL
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
#
|
#
|
||||||
# Abstract base classes with related models
|
# Abstract base classes with related models
|
||||||
#
|
#
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Copy(NamedURL):
|
class Copy(NamedURL):
|
||||||
content = models.TextField()
|
content = models.TextField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.content
|
return self.content
|
||||||
|
|
|
@ -8,28 +8,32 @@ In this example, a ``Place`` optionally can be a ``Restaurant``.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Place(models.Model):
|
class Place(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
address = models.CharField(max_length=80)
|
address = models.CharField(max_length=80)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s the place" % self.name
|
return "%s the place" % self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Restaurant(models.Model):
|
class Restaurant(models.Model):
|
||||||
place = models.OneToOneField(Place, primary_key=True)
|
place = models.OneToOneField(Place, primary_key=True)
|
||||||
serves_hot_dogs = models.BooleanField()
|
serves_hot_dogs = models.BooleanField()
|
||||||
serves_pizza = models.BooleanField()
|
serves_pizza = models.BooleanField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s the restaurant" % self.place.name
|
return "%s the restaurant" % self.place.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Waiter(models.Model):
|
class Waiter(models.Model):
|
||||||
restaurant = models.ForeignKey(Restaurant)
|
restaurant = models.ForeignKey(Restaurant)
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s the waiter at %s" % (self.name, self.restaurant)
|
return "%s the waiter at %s" % (self.name, self.restaurant)
|
||||||
|
|
||||||
class ManualPrimaryKey(models.Model):
|
class ManualPrimaryKey(models.Model):
|
||||||
|
@ -40,10 +44,11 @@ class RelatedModel(models.Model):
|
||||||
link = models.OneToOneField(ManualPrimaryKey)
|
link = models.OneToOneField(ManualPrimaryKey)
|
||||||
name = models.CharField(max_length = 50)
|
name = models.CharField(max_length = 50)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class MultiModel(models.Model):
|
class MultiModel(models.Model):
|
||||||
link1 = models.OneToOneField(Place)
|
link1 = models.OneToOneField(Place)
|
||||||
link2 = models.OneToOneField(ManualPrimaryKey)
|
link2 = models.OneToOneField(ManualPrimaryKey)
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "Multimodel %s" % self.name
|
return "Multimodel %s" % self.name
|
||||||
|
|
|
@ -10,8 +10,10 @@ clauses using the variable ``django.db.models.Q`` (or any object with an
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=50)
|
headline = models.CharField(max_length=50)
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
|
@ -19,5 +21,5 @@ class Article(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('pub_date',)
|
ordering = ('pub_date',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
|
@ -4,11 +4,13 @@ Tests for the order_with_respect_to Meta attribute.
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class Question(models.Model):
|
class Question(models.Model):
|
||||||
text = models.CharField(max_length=200)
|
text = models.CharField(max_length=200)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Answer(models.Model):
|
class Answer(models.Model):
|
||||||
text = models.CharField(max_length=200)
|
text = models.CharField(max_length=200)
|
||||||
question = models.ForeignKey(Question)
|
question = models.ForeignKey(Question)
|
||||||
|
@ -16,9 +18,10 @@ class Answer(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
order_with_respect_to = 'question'
|
order_with_respect_to = 'question'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return six.text_type(self.text)
|
return six.text_type(self.text)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Post(models.Model):
|
class Post(models.Model):
|
||||||
title = models.CharField(max_length=200)
|
title = models.CharField(max_length=200)
|
||||||
parent = models.ForeignKey("self", related_name="children", null=True)
|
parent = models.ForeignKey("self", related_name="children", null=True)
|
||||||
|
@ -26,5 +29,5 @@ class Post(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
order_with_respect_to = "parent"
|
order_with_respect_to = "parent"
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
|
@ -14,22 +14,25 @@ undefined -- not random, just undefined.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('-pub_date', 'headline')
|
ordering = ('-pub_date', 'headline')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ArticlePKOrdering(models.Model):
|
class ArticlePKOrdering(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('-pk',)
|
ordering = ('-pk',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
|
@ -7,11 +7,13 @@ objects into easily readable pages.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100, default='Default headline')
|
headline = models.CharField(max_length=100, default='Default headline')
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
|
@ -1,16 +1,18 @@
|
||||||
from django.contrib.contenttypes import generic
|
from django.contrib.contenttypes import generic
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
## Basic tests
|
## Basic tests
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
name = models.CharField(max_length=50, unique=True)
|
name = models.CharField(max_length=50, unique=True)
|
||||||
first_book = models.ForeignKey('Book', related_name='first_time_authors')
|
first_book = models.ForeignKey('Book', related_name='first_time_authors')
|
||||||
favorite_authors = models.ManyToManyField(
|
favorite_authors = models.ManyToManyField(
|
||||||
'self', through='FavoriteAuthors', symmetrical=False, related_name='favors_me')
|
'self', through='FavoriteAuthors', symmetrical=False, related_name='favors_me')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -30,6 +32,7 @@ class FavoriteAuthors(models.Model):
|
||||||
ordering = ['id']
|
ordering = ['id']
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class AuthorAddress(models.Model):
|
class AuthorAddress(models.Model):
|
||||||
author = models.ForeignKey(Author, to_field='name', related_name='addresses')
|
author = models.ForeignKey(Author, to_field='name', related_name='addresses')
|
||||||
address = models.TextField()
|
address = models.TextField()
|
||||||
|
@ -37,15 +40,16 @@ class AuthorAddress(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ['id']
|
ordering = ['id']
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.address
|
return self.address
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
title = models.CharField(max_length=255)
|
title = models.CharField(max_length=255)
|
||||||
authors = models.ManyToManyField(Author, related_name='books')
|
authors = models.ManyToManyField(Author, related_name='books')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -58,11 +62,12 @@ class BookWithYear(Book):
|
||||||
AuthorWithAge, related_name='books_with_year')
|
AuthorWithAge, related_name='books_with_year')
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Reader(models.Model):
|
class Reader(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
books_read = models.ManyToManyField(Book, related_name='read_by')
|
books_read = models.ManyToManyField(Book, related_name='read_by')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -86,13 +91,14 @@ class TeacherManager(models.Manager):
|
||||||
return super(TeacherManager, self).get_query_set().prefetch_related('qualifications')
|
return super(TeacherManager, self).get_query_set().prefetch_related('qualifications')
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Teacher(models.Model):
|
class Teacher(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
qualifications = models.ManyToManyField(Qualification)
|
qualifications = models.ManyToManyField(Qualification)
|
||||||
|
|
||||||
objects = TeacherManager()
|
objects = TeacherManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s (%s)" % (self.name, ", ".join(q.name for q in self.qualifications.all()))
|
return "%s (%s)" % (self.name, ", ".join(q.name for q in self.qualifications.all()))
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -109,6 +115,7 @@ class Department(models.Model):
|
||||||
|
|
||||||
## GenericRelation/GenericForeignKey tests
|
## GenericRelation/GenericForeignKey tests
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class TaggedItem(models.Model):
|
class TaggedItem(models.Model):
|
||||||
tag = models.SlugField()
|
tag = models.SlugField()
|
||||||
content_type = models.ForeignKey(ContentType, related_name="taggeditem_set2")
|
content_type = models.ForeignKey(ContentType, related_name="taggeditem_set2")
|
||||||
|
@ -119,7 +126,7 @@ class TaggedItem(models.Model):
|
||||||
created_by_fkey = models.PositiveIntegerField(null=True)
|
created_by_fkey = models.PositiveIntegerField(null=True)
|
||||||
created_by = generic.GenericForeignKey('created_by_ct', 'created_by_fkey',)
|
created_by = generic.GenericForeignKey('created_by_ct', 'created_by_fkey',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.tag
|
return self.tag
|
||||||
|
|
||||||
|
|
||||||
|
@ -169,12 +176,13 @@ class Person(models.Model):
|
||||||
|
|
||||||
## Models for nullable FK tests
|
## Models for nullable FK tests
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Employee(models.Model):
|
class Employee(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
boss = models.ForeignKey('self', null=True,
|
boss = models.ForeignKey('self', null=True,
|
||||||
related_name='serfs')
|
related_name='serfs')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
|
@ -5,6 +5,7 @@ than using a new table of their own. This allows them to act as simple proxies,
|
||||||
providing a modified interface to the data from the base class.
|
providing a modified interface to the data from the base class.
|
||||||
"""
|
"""
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
# A couple of managers for testing managing overriding in proxy model cases.
|
# A couple of managers for testing managing overriding in proxy model cases.
|
||||||
|
|
||||||
|
@ -16,6 +17,7 @@ class SubManager(models.Manager):
|
||||||
def get_query_set(self):
|
def get_query_set(self):
|
||||||
return super(SubManager, self).get_query_set().exclude(name="wilma")
|
return super(SubManager, self).get_query_set().exclude(name="wilma")
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
"""
|
"""
|
||||||
A simple concrete base class.
|
A simple concrete base class.
|
||||||
|
@ -24,7 +26,7 @@ class Person(models.Model):
|
||||||
|
|
||||||
objects = PersonManager()
|
objects = PersonManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Abstract(models.Model):
|
class Abstract(models.Model):
|
||||||
|
@ -82,10 +84,11 @@ class MyPersonProxy(MyPerson):
|
||||||
class LowerStatusPerson(MyPersonProxy):
|
class LowerStatusPerson(MyPersonProxy):
|
||||||
status = models.CharField(max_length=80)
|
status = models.CharField(max_length=80)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class User(models.Model):
|
class User(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class UserProxy(User):
|
class UserProxy(User):
|
||||||
|
@ -100,11 +103,12 @@ class UserProxyProxy(UserProxy):
|
||||||
class Country(models.Model):
|
class Country(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class State(models.Model):
|
class State(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
country = models.ForeignKey(Country)
|
country = models.ForeignKey(Country)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class StateProxy(State):
|
class StateProxy(State):
|
||||||
|
@ -124,11 +128,12 @@ class ProxyTrackerUser(TrackerUser):
|
||||||
proxy = True
|
proxy = True
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Issue(models.Model):
|
class Issue(models.Model):
|
||||||
summary = models.CharField(max_length=255)
|
summary = models.CharField(max_length=255)
|
||||||
assignee = models.ForeignKey(TrackerUser)
|
assignee = models.ForeignKey(TrackerUser)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return ':'.join((self.__class__.__name__,self.summary,))
|
return ':'.join((self.__class__.__name__,self.summary,))
|
||||||
|
|
||||||
class Bug(Issue):
|
class Bug(Issue):
|
||||||
|
|
|
@ -8,8 +8,10 @@ reserved-name usage.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Thing(models.Model):
|
class Thing(models.Model):
|
||||||
when = models.CharField(max_length=1, primary_key=True)
|
when = models.CharField(max_length=1, primary_key=True)
|
||||||
join = models.CharField(max_length=1)
|
join = models.CharField(max_length=1)
|
||||||
|
@ -22,5 +24,5 @@ class Thing(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
db_table = 'select'
|
db_table = 'select'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.when
|
return self.when
|
||||||
|
|
|
@ -5,25 +5,29 @@ This demonstrates the reverse lookup features of the database API.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class User(models.Model):
|
class User(models.Model):
|
||||||
name = models.CharField(max_length=200)
|
name = models.CharField(max_length=200)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Poll(models.Model):
|
class Poll(models.Model):
|
||||||
question = models.CharField(max_length=200)
|
question = models.CharField(max_length=200)
|
||||||
creator = models.ForeignKey(User)
|
creator = models.ForeignKey(User)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.question
|
return self.question
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Choice(models.Model):
|
class Choice(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
poll = models.ForeignKey(Poll, related_name="poll_choice")
|
poll = models.ForeignKey(Poll, related_name="poll_choice")
|
||||||
related_poll = models.ForeignKey(Poll, related_name="related_choice")
|
related_poll = models.ForeignKey(Poll, related_name="related_choice")
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -7,8 +7,10 @@ the methods.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
first_name = models.CharField(max_length=20)
|
first_name = models.CharField(max_length=20)
|
||||||
last_name = models.CharField(max_length=20)
|
last_name = models.CharField(max_length=20)
|
||||||
|
@ -17,7 +19,7 @@ class Person(models.Model):
|
||||||
super(Person, self).__init__(*args, **kwargs)
|
super(Person, self).__init__(*args, **kwargs)
|
||||||
self.data = []
|
self.data = []
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.first_name, self.last_name)
|
return "%s %s" % (self.first_name, self.last_name)
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
|
|
|
@ -8,52 +8,61 @@ the select-related behavior will traverse.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
# Who remembers high school biology?
|
# Who remembers high school biology?
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Domain(models.Model):
|
class Domain(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Kingdom(models.Model):
|
class Kingdom(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
domain = models.ForeignKey(Domain)
|
domain = models.ForeignKey(Domain)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Phylum(models.Model):
|
class Phylum(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
kingdom = models.ForeignKey(Kingdom)
|
kingdom = models.ForeignKey(Kingdom)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Klass(models.Model):
|
class Klass(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
phylum = models.ForeignKey(Phylum)
|
phylum = models.ForeignKey(Phylum)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Order(models.Model):
|
class Order(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
klass = models.ForeignKey(Klass)
|
klass = models.ForeignKey(Klass)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Family(models.Model):
|
class Family(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
order = models.ForeignKey(Order)
|
order = models.ForeignKey(Order)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Genus(models.Model):
|
class Genus(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
family = models.ForeignKey(Family)
|
family = models.ForeignKey(Family)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Species(models.Model):
|
class Species(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
genus = models.ForeignKey(Genus)
|
genus = models.ForeignKey(Genus)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -11,28 +11,32 @@ from decimal import Decimal
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Category(models.Model):
|
class Category(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
author = models.ForeignKey(Author)
|
author = models.ForeignKey(Author)
|
||||||
headline = models.CharField(max_length=50)
|
headline = models.CharField(max_length=50)
|
||||||
|
@ -42,28 +46,31 @@ class Article(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('pub_date',)
|
ordering = ('pub_date',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class AuthorProfile(models.Model):
|
class AuthorProfile(models.Model):
|
||||||
author = models.OneToOneField(Author, primary_key=True)
|
author = models.OneToOneField(Author, primary_key=True)
|
||||||
date_of_birth = models.DateField()
|
date_of_birth = models.DateField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "Profile of %s" % self.author
|
return "Profile of %s" % self.author
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Actor(models.Model):
|
class Actor(models.Model):
|
||||||
name = models.CharField(max_length=20, primary_key=True)
|
name = models.CharField(max_length=20, primary_key=True)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Movie(models.Model):
|
class Movie(models.Model):
|
||||||
actor = models.ForeignKey(Actor)
|
actor = models.ForeignKey(Actor)
|
||||||
title = models.CharField(max_length=50)
|
title = models.CharField(max_length=50)
|
||||||
|
@ -72,7 +79,7 @@ class Movie(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('title',)
|
ordering = ('title',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
@ -80,11 +87,12 @@ class Score(models.Model):
|
||||||
score = models.FloatField()
|
score = models.FloatField()
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Team(object):
|
class Team(object):
|
||||||
def __init__(self, title):
|
def __init__(self, title):
|
||||||
self.title = title
|
self.title = title
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
raise NotImplementedError("Not so simple")
|
raise NotImplementedError("Not so simple")
|
||||||
|
|
||||||
def to_string(self):
|
def to_string(self):
|
||||||
|
@ -109,10 +117,11 @@ class TeamField(models.CharField):
|
||||||
return self._get_val_from_obj(obj).to_string()
|
return self._get_val_from_obj(obj).to_string()
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Player(models.Model):
|
class Player(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
rank = models.IntegerField()
|
rank = models.IntegerField()
|
||||||
team = TeamField()
|
team = TeamField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s (%d) playing for %s' % (self.name, self.rank, self.team.to_string())
|
return '%s (%d) playing for %s' % (self.name, self.rank, self.team.to_string())
|
||||||
|
|
|
@ -4,18 +4,21 @@ Testing signals before/after saving and deleting.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
first_name = models.CharField(max_length=20)
|
first_name = models.CharField(max_length=20)
|
||||||
last_name = models.CharField(max_length=20)
|
last_name = models.CharField(max_length=20)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.first_name, self.last_name)
|
return "%s %s" % (self.first_name, self.last_name)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Car(models.Model):
|
class Car(models.Model):
|
||||||
make = models.CharField(max_length=20)
|
make = models.CharField(max_length=20)
|
||||||
model = models.CharField(max_length=20)
|
model = models.CharField(max_length=20)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.make, self.model)
|
return "%s %s" % (self.make, self.model)
|
||||||
|
|
|
@ -15,6 +15,7 @@ if you prefer. You must be careful to encode the results correctly, though.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
|
@ -26,9 +27,10 @@ class Article(models.Model):
|
||||||
# in ASCII.
|
# in ASCII.
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class InternationalArticle(models.Model):
|
class InternationalArticle(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
|
@ -9,8 +9,10 @@ manually.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Reporter(models.Model):
|
class Reporter(models.Model):
|
||||||
first_name = models.CharField(max_length=30)
|
first_name = models.CharField(max_length=30)
|
||||||
last_name = models.CharField(max_length=30)
|
last_name = models.CharField(max_length=30)
|
||||||
|
@ -19,5 +21,5 @@ class Reporter(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('first_name', 'last_name')
|
ordering = ('first_name', 'last_name')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.first_name, self.last_name)
|
return "%s %s" % (self.first_name, self.last_name)
|
||||||
|
|
|
@ -4,9 +4,11 @@ is generated for the table on various manage.py operations.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
# All of these models are created in the database by Django.
|
# All of these models are created in the database by Django.
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class A01(models.Model):
|
class A01(models.Model):
|
||||||
f_a = models.CharField(max_length=10, db_index=True)
|
f_a = models.CharField(max_length=10, db_index=True)
|
||||||
f_b = models.IntegerField()
|
f_b = models.IntegerField()
|
||||||
|
@ -14,9 +16,10 @@ class A01(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
db_table = 'a01'
|
db_table = 'a01'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.f_a
|
return self.f_a
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class B01(models.Model):
|
class B01(models.Model):
|
||||||
fk_a = models.ForeignKey(A01)
|
fk_a = models.ForeignKey(A01)
|
||||||
f_a = models.CharField(max_length=10, db_index=True)
|
f_a = models.CharField(max_length=10, db_index=True)
|
||||||
|
@ -27,9 +30,10 @@ class B01(models.Model):
|
||||||
# 'managed' is True by default. This tests we can set it explicitly.
|
# 'managed' is True by default. This tests we can set it explicitly.
|
||||||
managed = True
|
managed = True
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.f_a
|
return self.f_a
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class C01(models.Model):
|
class C01(models.Model):
|
||||||
mm_a = models.ManyToManyField(A01, db_table='d01')
|
mm_a = models.ManyToManyField(A01, db_table='d01')
|
||||||
f_a = models.CharField(max_length=10, db_index=True)
|
f_a = models.CharField(max_length=10, db_index=True)
|
||||||
|
@ -38,13 +42,14 @@ class C01(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
db_table = 'c01'
|
db_table = 'c01'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.f_a
|
return self.f_a
|
||||||
|
|
||||||
# All of these models use the same tables as the previous set (they are shadows
|
# All of these models use the same tables as the previous set (they are shadows
|
||||||
# of possibly a subset of the columns). There should be no creation errors,
|
# of possibly a subset of the columns). There should be no creation errors,
|
||||||
# since we have told Django they aren't managed by Django.
|
# since we have told Django they aren't managed by Django.
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class A02(models.Model):
|
class A02(models.Model):
|
||||||
f_a = models.CharField(max_length=10, db_index=True)
|
f_a = models.CharField(max_length=10, db_index=True)
|
||||||
|
|
||||||
|
@ -52,9 +57,10 @@ class A02(models.Model):
|
||||||
db_table = 'a01'
|
db_table = 'a01'
|
||||||
managed = False
|
managed = False
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.f_a
|
return self.f_a
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class B02(models.Model):
|
class B02(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
db_table = 'b01'
|
db_table = 'b01'
|
||||||
|
@ -64,11 +70,12 @@ class B02(models.Model):
|
||||||
f_a = models.CharField(max_length=10, db_index=True)
|
f_a = models.CharField(max_length=10, db_index=True)
|
||||||
f_b = models.IntegerField()
|
f_b = models.IntegerField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.f_a
|
return self.f_a
|
||||||
|
|
||||||
# To re-use the many-to-many intermediate table, we need to manually set up
|
# To re-use the many-to-many intermediate table, we need to manually set up
|
||||||
# things up.
|
# things up.
|
||||||
|
@python_2_unicode_compatible
|
||||||
class C02(models.Model):
|
class C02(models.Model):
|
||||||
mm_a = models.ManyToManyField(A02, through="Intermediate")
|
mm_a = models.ManyToManyField(A02, through="Intermediate")
|
||||||
f_a = models.CharField(max_length=10, db_index=True)
|
f_a = models.CharField(max_length=10, db_index=True)
|
||||||
|
@ -78,7 +85,7 @@ class C02(models.Model):
|
||||||
db_table = 'c01'
|
db_table = 'c01'
|
||||||
managed = False
|
managed = False
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.f_a
|
return self.f_a
|
||||||
|
|
||||||
class Intermediate(models.Model):
|
class Intermediate(models.Model):
|
||||||
|
|
|
@ -5,21 +5,24 @@ updates.
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class DataPoint(models.Model):
|
class DataPoint(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
value = models.CharField(max_length=20)
|
value = models.CharField(max_length=20)
|
||||||
another_value = models.CharField(max_length=20, blank=True)
|
another_value = models.CharField(max_length=20, blank=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return six.text_type(self.name)
|
return six.text_type(self.name)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class RelatedPoint(models.Model):
|
class RelatedPoint(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
data = models.ForeignKey(DataPoint)
|
data = models.ForeignKey(DataPoint)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return six.text_type(self.name)
|
return six.text_type(self.name)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
GENDER_CHOICES = (
|
GENDER_CHOICES = (
|
||||||
('M', 'Male'),
|
('M', 'Male'),
|
||||||
|
@ -10,11 +11,12 @@ class Account(models.Model):
|
||||||
num = models.IntegerField()
|
num = models.IntegerField()
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
name = models.CharField(max_length=20)
|
name = models.CharField(max_length=20)
|
||||||
gender = models.CharField(max_length=1, choices=GENDER_CHOICES)
|
gender = models.CharField(max_length=1, choices=GENDER_CHOICES)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@ -24,11 +26,12 @@ class Employee(Person):
|
||||||
accounts = models.ManyToManyField('Account', related_name='employees', blank=True, null=True)
|
accounts = models.ManyToManyField('Account', related_name='employees', blank=True, null=True)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Profile(models.Model):
|
class Profile(models.Model):
|
||||||
name = models.CharField(max_length=200)
|
name = models.CharField(max_length=200)
|
||||||
salary = models.FloatField(default=1000.0)
|
salary = models.FloatField(default=1000.0)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,7 @@ from datetime import datetime
|
||||||
|
|
||||||
from django.core.exceptions import ValidationError
|
from django.core.exceptions import ValidationError
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
def validate_answer_to_universe(value):
|
def validate_answer_to_universe(value):
|
||||||
|
@ -66,13 +67,14 @@ class Article(models.Model):
|
||||||
if self.pub_date is None:
|
if self.pub_date is None:
|
||||||
self.pub_date = datetime.now()
|
self.pub_date = datetime.now()
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Post(models.Model):
|
class Post(models.Model):
|
||||||
title = models.CharField(max_length=50, unique_for_date='posted', blank=True)
|
title = models.CharField(max_length=50, unique_for_date='posted', blank=True)
|
||||||
slug = models.CharField(max_length=50, unique_for_year='posted', blank=True)
|
slug = models.CharField(max_length=50, unique_for_year='posted', blank=True)
|
||||||
subtitle = models.CharField(max_length=50, unique_for_month='posted', blank=True)
|
subtitle = models.CharField(max_length=50, unique_for_month='posted', blank=True)
|
||||||
posted = models.DateField()
|
posted = models.DateField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class FlexibleDatePost(models.Model):
|
class FlexibleDatePost(models.Model):
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
class Event(models.Model):
|
class Event(models.Model):
|
||||||
# Oracle can have problems with a column named "date"
|
# Oracle can have problems with a column named "date"
|
||||||
|
@ -20,17 +21,19 @@ class Band(models.Model):
|
||||||
nr_of_members = models.PositiveIntegerField()
|
nr_of_members = models.PositiveIntegerField()
|
||||||
genres = models.ManyToManyField(Genre)
|
genres = models.ManyToManyField(Genre)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Musician(models.Model):
|
class Musician(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Group(models.Model):
|
class Group(models.Model):
|
||||||
name = models.CharField(max_length=30)
|
name = models.CharField(max_length=30)
|
||||||
members = models.ManyToManyField(Musician, through='Membership')
|
members = models.ManyToManyField(Musician, through='Membership')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Membership(models.Model):
|
class Membership(models.Model):
|
||||||
|
|
|
@ -2,13 +2,15 @@ from functools import update_wrapper
|
||||||
|
|
||||||
from django.contrib import admin
|
from django.contrib import admin
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Action(models.Model):
|
class Action(models.Model):
|
||||||
name = models.CharField(max_length=50, primary_key=True)
|
name = models.CharField(max_length=50, primary_key=True)
|
||||||
description = models.CharField(max_length=70)
|
description = models.CharField(max_length=70)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,8 +2,10 @@ from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
title = models.CharField(max_length=50)
|
title = models.CharField(max_length=50)
|
||||||
year = models.PositiveIntegerField(null=True, blank=True)
|
year = models.PositiveIntegerField(null=True, blank=True)
|
||||||
|
@ -13,20 +15,22 @@ class Book(models.Model):
|
||||||
date_registered = models.DateField(null=True)
|
date_registered = models.DateField(null=True)
|
||||||
no = models.IntegerField(verbose_name='number', blank=True, null=True) # This field is intentionally 2 characters long. See #16080.
|
no = models.IntegerField(verbose_name='number', blank=True, null=True) # This field is intentionally 2 characters long. See #16080.
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Department(models.Model):
|
class Department(models.Model):
|
||||||
code = models.CharField(max_length=4, unique=True)
|
code = models.CharField(max_length=4, unique=True)
|
||||||
description = models.CharField(max_length=50, blank=True, null=True)
|
description = models.CharField(max_length=50, blank=True, null=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.description
|
return self.description
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Employee(models.Model):
|
class Employee(models.Model):
|
||||||
department = models.ForeignKey(Department, to_field="code")
|
department = models.ForeignKey(Department, to_field="code")
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -7,22 +7,26 @@ from __future__ import unicode_literals
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.contrib.contenttypes import generic
|
from django.contrib.contenttypes import generic
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Parent(models.Model):
|
class Parent(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Teacher(models.Model):
|
class Teacher(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Child(models.Model):
|
class Child(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
teacher = models.ForeignKey(Teacher)
|
teacher = models.ForeignKey(Teacher)
|
||||||
|
@ -31,7 +35,7 @@ class Child(models.Model):
|
||||||
object_id = models.PositiveIntegerField()
|
object_id = models.PositiveIntegerField()
|
||||||
parent = generic.GenericForeignKey()
|
parent = generic.GenericForeignKey()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return 'I am %s, a child of %s' % (self.name, self.parent)
|
return 'I am %s, a child of %s' % (self.name, self.parent)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100, default='Default headline')
|
headline = models.CharField(max_length=100, default='Default headline')
|
||||||
pub_date = models.DateTimeField()
|
pub_date = models.DateTimeField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
|
@ -18,11 +19,12 @@ class Article(models.Model):
|
||||||
return "nothing"
|
return "nothing"
|
||||||
test_from_model_with_override.short_description = "not What you Expect"
|
test_from_model_with_override.short_description = "not What you Expect"
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Count(models.Model):
|
class Count(models.Model):
|
||||||
num = models.PositiveSmallIntegerField()
|
num = models.PositiveSmallIntegerField()
|
||||||
parent = models.ForeignKey('self', null=True)
|
parent = models.ForeignKey('self', null=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return six.text_type(self.num)
|
return six.text_type(self.num)
|
||||||
|
|
||||||
class Event(models.Model):
|
class Event(models.Model):
|
||||||
|
|
|
@ -3,12 +3,14 @@ Tests of ModelAdmin validation logic.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class Album(models.Model):
|
class Album(models.Model):
|
||||||
title = models.CharField(max_length=150)
|
title = models.CharField(max_length=150)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Song(models.Model):
|
class Song(models.Model):
|
||||||
title = models.CharField(max_length=150)
|
title = models.CharField(max_length=150)
|
||||||
album = models.ForeignKey(Album)
|
album = models.ForeignKey(Album)
|
||||||
|
@ -17,7 +19,7 @@ class Song(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('title',)
|
ordering = ('title',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
def readonly_method_on_model(self):
|
def readonly_method_on_model(self):
|
||||||
|
|
|
@ -10,6 +10,7 @@ from django.contrib.contenttypes import generic
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.core.files.storage import FileSystemStorage
|
from django.core.files.storage import FileSystemStorage
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class Section(models.Model):
|
class Section(models.Model):
|
||||||
|
@ -20,6 +21,7 @@ class Section(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
"""
|
"""
|
||||||
A simple article to test admin views. Test backwards compatibility.
|
A simple article to test admin views. Test backwards compatibility.
|
||||||
|
@ -29,7 +31,7 @@ class Article(models.Model):
|
||||||
date = models.DateTimeField()
|
date = models.DateTimeField()
|
||||||
section = models.ForeignKey(Section, null=True, blank=True)
|
section = models.ForeignKey(Section, null=True, blank=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
def model_year(self):
|
def model_year(self):
|
||||||
|
@ -38,30 +40,33 @@ class Article(models.Model):
|
||||||
model_year.short_description = ''
|
model_year.short_description = ''
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
"""
|
"""
|
||||||
A simple book that has chapters.
|
A simple book that has chapters.
|
||||||
"""
|
"""
|
||||||
name = models.CharField(max_length=100, verbose_name='¿Name?')
|
name = models.CharField(max_length=100, verbose_name='¿Name?')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Promo(models.Model):
|
class Promo(models.Model):
|
||||||
name = models.CharField(max_length=100, verbose_name='¿Name?')
|
name = models.CharField(max_length=100, verbose_name='¿Name?')
|
||||||
book = models.ForeignKey(Book)
|
book = models.ForeignKey(Book)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Chapter(models.Model):
|
class Chapter(models.Model):
|
||||||
title = models.CharField(max_length=100, verbose_name='¿Title?')
|
title = models.CharField(max_length=100, verbose_name='¿Title?')
|
||||||
content = models.TextField()
|
content = models.TextField()
|
||||||
book = models.ForeignKey(Book)
|
book = models.ForeignKey(Book)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -69,19 +74,21 @@ class Chapter(models.Model):
|
||||||
verbose_name = '¿Chapter?'
|
verbose_name = '¿Chapter?'
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ChapterXtra1(models.Model):
|
class ChapterXtra1(models.Model):
|
||||||
chap = models.OneToOneField(Chapter, verbose_name='¿Chap?')
|
chap = models.OneToOneField(Chapter, verbose_name='¿Chap?')
|
||||||
xtra = models.CharField(max_length=100, verbose_name='¿Xtra?')
|
xtra = models.CharField(max_length=100, verbose_name='¿Xtra?')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '¿Xtra1: %s' % self.xtra
|
return '¿Xtra1: %s' % self.xtra
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ChapterXtra2(models.Model):
|
class ChapterXtra2(models.Model):
|
||||||
chap = models.OneToOneField(Chapter, verbose_name='¿Chap?')
|
chap = models.OneToOneField(Chapter, verbose_name='¿Chap?')
|
||||||
xtra = models.CharField(max_length=100, verbose_name='¿Xtra?')
|
xtra = models.CharField(max_length=100, verbose_name='¿Xtra?')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '¿Xtra2: %s' % self.xtra
|
return '¿Xtra2: %s' % self.xtra
|
||||||
|
|
||||||
|
|
||||||
|
@ -94,20 +101,22 @@ class CustomArticle(models.Model):
|
||||||
date = models.DateTimeField()
|
date = models.DateTimeField()
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class ModelWithStringPrimaryKey(models.Model):
|
class ModelWithStringPrimaryKey(models.Model):
|
||||||
string_pk = models.CharField(max_length=255, primary_key=True)
|
string_pk = models.CharField(max_length=255, primary_key=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.string_pk
|
return self.string_pk
|
||||||
|
|
||||||
def get_absolute_url(self):
|
def get_absolute_url(self):
|
||||||
return '/dummy/%s/' % self.string_pk
|
return '/dummy/%s/' % self.string_pk
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Color(models.Model):
|
class Color(models.Model):
|
||||||
value = models.CharField(max_length=10)
|
value = models.CharField(max_length=10)
|
||||||
warm = models.BooleanField()
|
warm = models.BooleanField()
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.value
|
return self.value
|
||||||
|
|
||||||
# we replicate Color to register with another ModelAdmin
|
# we replicate Color to register with another ModelAdmin
|
||||||
|
@ -115,29 +124,33 @@ class Color2(Color):
|
||||||
class Meta:
|
class Meta:
|
||||||
proxy = True
|
proxy = True
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Thing(models.Model):
|
class Thing(models.Model):
|
||||||
title = models.CharField(max_length=20)
|
title = models.CharField(max_length=20)
|
||||||
color = models.ForeignKey(Color, limit_choices_to={'warm': True})
|
color = models.ForeignKey(Color, limit_choices_to={'warm': True})
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Actor(models.Model):
|
class Actor(models.Model):
|
||||||
name = models.CharField(max_length=50)
|
name = models.CharField(max_length=50)
|
||||||
age = models.IntegerField()
|
age = models.IntegerField()
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Inquisition(models.Model):
|
class Inquisition(models.Model):
|
||||||
expected = models.BooleanField()
|
expected = models.BooleanField()
|
||||||
leader = models.ForeignKey(Actor)
|
leader = models.ForeignKey(Actor)
|
||||||
country = models.CharField(max_length=20)
|
country = models.CharField(max_length=20)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "by %s from %s" % (self.leader, self.country)
|
return "by %s from %s" % (self.leader, self.country)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Sketch(models.Model):
|
class Sketch(models.Model):
|
||||||
title = models.CharField(max_length=100)
|
title = models.CharField(max_length=100)
|
||||||
inquisition = models.ForeignKey(Inquisition, limit_choices_to={'leader__name': 'Palin',
|
inquisition = models.ForeignKey(Inquisition, limit_choices_to={'leader__name': 'Palin',
|
||||||
|
@ -145,7 +158,7 @@ class Sketch(models.Model):
|
||||||
'expected': False,
|
'expected': False,
|
||||||
})
|
})
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
@ -161,6 +174,7 @@ class Fabric(models.Model):
|
||||||
surface = models.CharField(max_length=20, choices=NG_CHOICES)
|
surface = models.CharField(max_length=20, choices=NG_CHOICES)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
GENDER_CHOICES = (
|
GENDER_CHOICES = (
|
||||||
(1, "Male"),
|
(1, "Male"),
|
||||||
|
@ -171,20 +185,22 @@ class Person(models.Model):
|
||||||
age = models.IntegerField(default=21)
|
age = models.IntegerField(default=21)
|
||||||
alive = models.BooleanField()
|
alive = models.BooleanField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Persona(models.Model):
|
class Persona(models.Model):
|
||||||
"""
|
"""
|
||||||
A simple persona associated with accounts, to test inlining of related
|
A simple persona associated with accounts, to test inlining of related
|
||||||
accounts which inherit from a common accounts class.
|
accounts which inherit from a common accounts class.
|
||||||
"""
|
"""
|
||||||
name = models.CharField(blank=False, max_length=80)
|
name = models.CharField(blank=False, max_length=80)
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Account(models.Model):
|
class Account(models.Model):
|
||||||
"""
|
"""
|
||||||
A simple, generic account encapsulating the information shared by all
|
A simple, generic account encapsulating the information shared by all
|
||||||
|
@ -194,7 +210,7 @@ class Account(models.Model):
|
||||||
persona = models.ForeignKey(Persona, related_name="accounts")
|
persona = models.ForeignKey(Persona, related_name="accounts")
|
||||||
servicename = 'generic service'
|
servicename = 'generic service'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s: %s" % (self.servicename, self.username)
|
return "%s: %s" % (self.servicename, self.username)
|
||||||
|
|
||||||
|
|
||||||
|
@ -208,11 +224,12 @@ class BarAccount(Account):
|
||||||
servicename = 'bar'
|
servicename = 'bar'
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Subscriber(models.Model):
|
class Subscriber(models.Model):
|
||||||
name = models.CharField(blank=False, max_length=80)
|
name = models.CharField(blank=False, max_length=80)
|
||||||
email = models.EmailField(blank=False, max_length=175)
|
email = models.EmailField(blank=False, max_length=175)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s (%s)" % (self.name, self.email)
|
return "%s (%s)" % (self.name, self.email)
|
||||||
|
|
||||||
|
|
||||||
|
@ -249,8 +266,9 @@ class Child(models.Model):
|
||||||
name = models.CharField(max_length=30, blank=True)
|
name = models.CharField(max_length=30, blank=True)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class EmptyModel(models.Model):
|
class EmptyModel(models.Model):
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "Primary key = %s" % self.id
|
return "Primary key = %s" % self.id
|
||||||
|
|
||||||
|
|
||||||
|
@ -332,6 +350,7 @@ class FancyDoodad(Doodad):
|
||||||
expensive = models.BooleanField(default=True)
|
expensive = models.BooleanField(default=True)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Category(models.Model):
|
class Category(models.Model):
|
||||||
collector = models.ForeignKey(Collector)
|
collector = models.ForeignKey(Collector)
|
||||||
order = models.PositiveIntegerField()
|
order = models.PositiveIntegerField()
|
||||||
|
@ -339,7 +358,7 @@ class Category(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('order',)
|
ordering = ('order',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s:o%s' % (self.id, self.order)
|
return '%s:o%s' % (self.id, self.order)
|
||||||
|
|
||||||
|
|
||||||
|
@ -376,17 +395,19 @@ class Post(models.Model):
|
||||||
return "Very awesome."
|
return "Very awesome."
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Gadget(models.Model):
|
class Gadget(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Villain(models.Model):
|
class Villain(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@ -394,6 +415,7 @@ class SuperVillain(Villain):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class FunkyTag(models.Model):
|
class FunkyTag(models.Model):
|
||||||
"Because we all know there's only one real use case for GFKs."
|
"Because we all know there's only one real use case for GFKs."
|
||||||
name = models.CharField(max_length=25)
|
name = models.CharField(max_length=25)
|
||||||
|
@ -401,59 +423,65 @@ class FunkyTag(models.Model):
|
||||||
object_id = models.PositiveIntegerField()
|
object_id = models.PositiveIntegerField()
|
||||||
content_object = generic.GenericForeignKey('content_type', 'object_id')
|
content_object = generic.GenericForeignKey('content_type', 'object_id')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Plot(models.Model):
|
class Plot(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
team_leader = models.ForeignKey(Villain, related_name='lead_plots')
|
team_leader = models.ForeignKey(Villain, related_name='lead_plots')
|
||||||
contact = models.ForeignKey(Villain, related_name='contact_plots')
|
contact = models.ForeignKey(Villain, related_name='contact_plots')
|
||||||
tags = generic.GenericRelation(FunkyTag)
|
tags = generic.GenericRelation(FunkyTag)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class PlotDetails(models.Model):
|
class PlotDetails(models.Model):
|
||||||
details = models.CharField(max_length=100)
|
details = models.CharField(max_length=100)
|
||||||
plot = models.OneToOneField(Plot)
|
plot = models.OneToOneField(Plot)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.details
|
return self.details
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SecretHideout(models.Model):
|
class SecretHideout(models.Model):
|
||||||
""" Secret! Not registered with the admin! """
|
""" Secret! Not registered with the admin! """
|
||||||
location = models.CharField(max_length=100)
|
location = models.CharField(max_length=100)
|
||||||
villain = models.ForeignKey(Villain)
|
villain = models.ForeignKey(Villain)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.location
|
return self.location
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SuperSecretHideout(models.Model):
|
class SuperSecretHideout(models.Model):
|
||||||
""" Secret! Not registered with the admin! """
|
""" Secret! Not registered with the admin! """
|
||||||
location = models.CharField(max_length=100)
|
location = models.CharField(max_length=100)
|
||||||
supervillain = models.ForeignKey(SuperVillain)
|
supervillain = models.ForeignKey(SuperVillain)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.location
|
return self.location
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class CyclicOne(models.Model):
|
class CyclicOne(models.Model):
|
||||||
name = models.CharField(max_length=25)
|
name = models.CharField(max_length=25)
|
||||||
two = models.ForeignKey('CyclicTwo')
|
two = models.ForeignKey('CyclicTwo')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class CyclicTwo(models.Model):
|
class CyclicTwo(models.Model):
|
||||||
name = models.CharField(max_length=25)
|
name = models.CharField(max_length=25)
|
||||||
one = models.ForeignKey(CyclicOne)
|
one = models.ForeignKey(CyclicOne)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@ -484,11 +512,12 @@ class Question(models.Model):
|
||||||
question = models.CharField(max_length=20)
|
question = models.CharField(max_length=20)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Answer(models.Model):
|
class Answer(models.Model):
|
||||||
question = models.ForeignKey(Question, on_delete=models.PROTECT)
|
question = models.ForeignKey(Question, on_delete=models.PROTECT)
|
||||||
answer = models.CharField(max_length=20)
|
answer = models.CharField(max_length=20)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.answer
|
return self.answer
|
||||||
|
|
||||||
|
|
||||||
|
@ -523,11 +552,12 @@ class Paper(models.Model):
|
||||||
author = models.CharField(max_length=30, blank=True, null=True)
|
author = models.CharField(max_length=30, blank=True, null=True)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class CoverLetter(models.Model):
|
class CoverLetter(models.Model):
|
||||||
author = models.CharField(max_length=30)
|
author = models.CharField(max_length=30)
|
||||||
date_written = models.DateField(null=True, blank=True)
|
date_written = models.DateField(null=True, blank=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.author
|
return self.author
|
||||||
|
|
||||||
|
|
||||||
|
@ -575,10 +605,11 @@ class AdminOrderedCallable(models.Model):
|
||||||
order = models.IntegerField()
|
order = models.IntegerField()
|
||||||
stuff = models.CharField(max_length=200)
|
stuff = models.CharField(max_length=200)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Report(models.Model):
|
class Report(models.Model):
|
||||||
title = models.CharField(max_length=100)
|
title = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,39 +2,44 @@ from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
class MyFileField(models.FileField):
|
class MyFileField(models.FileField):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Member(models.Model):
|
class Member(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
birthdate = models.DateTimeField(blank=True, null=True)
|
birthdate = models.DateTimeField(blank=True, null=True)
|
||||||
gender = models.CharField(max_length=1, blank=True, choices=[('M','Male'), ('F', 'Female')])
|
gender = models.CharField(max_length=1, blank=True, choices=[('M','Male'), ('F', 'Female')])
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Band(models.Model):
|
class Band(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
members = models.ManyToManyField(Member)
|
members = models.ManyToManyField(Member)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Album(models.Model):
|
class Album(models.Model):
|
||||||
band = models.ForeignKey(Band)
|
band = models.ForeignKey(Band)
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
cover_art = models.FileField(upload_to='albums')
|
cover_art = models.FileField(upload_to='albums')
|
||||||
backside_art = MyFileField(upload_to='albums_back', null=True)
|
backside_art = MyFileField(upload_to='albums_back', null=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class HiddenInventoryManager(models.Manager):
|
class HiddenInventoryManager(models.Manager):
|
||||||
def get_query_set(self):
|
def get_query_set(self):
|
||||||
return super(HiddenInventoryManager, self).get_query_set().filter(hidden=False)
|
return super(HiddenInventoryManager, self).get_query_set().filter(hidden=False)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Inventory(models.Model):
|
class Inventory(models.Model):
|
||||||
barcode = models.PositiveIntegerField(unique=True)
|
barcode = models.PositiveIntegerField(unique=True)
|
||||||
parent = models.ForeignKey('self', to_field='barcode', blank=True, null=True)
|
parent = models.ForeignKey('self', to_field='barcode', blank=True, null=True)
|
||||||
|
@ -45,7 +50,7 @@ class Inventory(models.Model):
|
||||||
default_manager = models.Manager()
|
default_manager = models.Manager()
|
||||||
objects = HiddenInventoryManager()
|
objects = HiddenInventoryManager()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Event(models.Model):
|
class Event(models.Model):
|
||||||
|
@ -56,12 +61,13 @@ class Event(models.Model):
|
||||||
link = models.URLField(blank=True)
|
link = models.URLField(blank=True)
|
||||||
min_age = models.IntegerField(blank=True, null=True)
|
min_age = models.IntegerField(blank=True, null=True)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Car(models.Model):
|
class Car(models.Model):
|
||||||
owner = models.ForeignKey(User)
|
owner = models.ForeignKey(User)
|
||||||
make = models.CharField(max_length=30)
|
make = models.CharField(max_length=30)
|
||||||
model = models.CharField(max_length=30)
|
model = models.CharField(max_length=30)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.make, self.model)
|
return "%s %s" % (self.make, self.model)
|
||||||
|
|
||||||
class CarTire(models.Model):
|
class CarTire(models.Model):
|
||||||
|
@ -103,19 +109,21 @@ class Advisor(models.Model):
|
||||||
companies = models.ManyToManyField(Company)
|
companies = models.ManyToManyField(Company)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Student(models.Model):
|
class Student(models.Model):
|
||||||
name = models.CharField(max_length=255)
|
name = models.CharField(max_length=255)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class School(models.Model):
|
class School(models.Model):
|
||||||
name = models.CharField(max_length=255)
|
name = models.CharField(max_length=255)
|
||||||
students = models.ManyToManyField(Student, related_name='current_schools')
|
students = models.ManyToManyField(Student, related_name='current_schools')
|
||||||
alumni = models.ManyToManyField(Student, related_name='previous_schools')
|
alumni = models.ManyToManyField(Student, related_name='previous_schools')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
|
@ -1,24 +1,28 @@
|
||||||
# coding: utf-8
|
# coding: utf-8
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
name = models.CharField(max_length=100)
|
name = models.CharField(max_length=100)
|
||||||
age = models.IntegerField()
|
age = models.IntegerField()
|
||||||
friends = models.ManyToManyField('self', blank=True)
|
friends = models.ManyToManyField('self', blank=True)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Publisher(models.Model):
|
class Publisher(models.Model):
|
||||||
name = models.CharField(max_length=255)
|
name = models.CharField(max_length=255)
|
||||||
num_awards = models.IntegerField()
|
num_awards = models.IntegerField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
isbn = models.CharField(max_length=9)
|
isbn = models.CharField(max_length=9)
|
||||||
name = models.CharField(max_length=255)
|
name = models.CharField(max_length=255)
|
||||||
|
@ -33,17 +37,18 @@ class Book(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Store(models.Model):
|
class Store(models.Model):
|
||||||
name = models.CharField(max_length=255)
|
name = models.CharField(max_length=255)
|
||||||
books = models.ManyToManyField(Book)
|
books = models.ManyToManyField(Book)
|
||||||
original_opening = models.DateTimeField()
|
original_opening = models.DateTimeField()
|
||||||
friday_night_closing = models.TimeField()
|
friday_night_closing = models.TimeField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
class Entries(models.Model):
|
class Entries(models.Model):
|
||||||
|
@ -58,8 +63,9 @@ class Clues(models.Model):
|
||||||
Clue = models.CharField(max_length=150)
|
Clue = models.CharField(max_length=150)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class HardbackBook(Book):
|
class HardbackBook(Book):
|
||||||
weight = models.FloatField()
|
weight = models.FloatField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s (hardback): %s" % (self.name, self.weight)
|
return "%s (hardback): %s" % (self.name, self.weight)
|
||||||
|
|
|
@ -3,21 +3,24 @@ from __future__ import unicode_literals
|
||||||
from django.contrib.contenttypes import generic
|
from django.contrib.contenttypes import generic
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.db import models, connection
|
from django.db import models, connection
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Square(models.Model):
|
class Square(models.Model):
|
||||||
root = models.IntegerField()
|
root = models.IntegerField()
|
||||||
square = models.PositiveIntegerField()
|
square = models.PositiveIntegerField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s ** 2 == %s" % (self.root, self.square)
|
return "%s ** 2 == %s" % (self.root, self.square)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(models.Model):
|
class Person(models.Model):
|
||||||
first_name = models.CharField(max_length=20)
|
first_name = models.CharField(max_length=20)
|
||||||
last_name = models.CharField(max_length=20)
|
last_name = models.CharField(max_length=20)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s %s' % (self.first_name, self.last_name)
|
return '%s %s' % (self.first_name, self.last_name)
|
||||||
|
|
||||||
|
|
||||||
|
@ -55,18 +58,20 @@ class Post(models.Model):
|
||||||
db_table = 'CaseSensitive_Post'
|
db_table = 'CaseSensitive_Post'
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Reporter(models.Model):
|
class Reporter(models.Model):
|
||||||
first_name = models.CharField(max_length=30)
|
first_name = models.CharField(max_length=30)
|
||||||
last_name = models.CharField(max_length=30)
|
last_name = models.CharField(max_length=30)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return "%s %s" % (self.first_name, self.last_name)
|
return "%s %s" % (self.first_name, self.last_name)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
pub_date = models.DateField()
|
pub_date = models.DateField()
|
||||||
reporter = models.ForeignKey(Reporter)
|
reporter = models.ForeignKey(Reporter)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
|
@ -6,29 +6,33 @@ more information.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
first_name = models.CharField(max_length=30)
|
first_name = models.CharField(max_length=30)
|
||||||
last_name = models.CharField(max_length=30)
|
last_name = models.CharField(max_length=30)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s %s' % (self.first_name, self.last_name)
|
return '%s %s' % (self.first_name, self.last_name)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
author = models.ForeignKey(Author)
|
author = models.ForeignKey(Author)
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Entry(models.Model):
|
class Entry(models.Model):
|
||||||
title = models.CharField(max_length=250)
|
title = models.CharField(max_length=250)
|
||||||
body = models.TextField()
|
body = models.TextField()
|
||||||
pub_date = models.DateField()
|
pub_date = models.DateField()
|
||||||
enable_comments = models.BooleanField()
|
enable_comments = models.BooleanField()
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
class Book(models.Model):
|
class Book(models.Model):
|
||||||
|
|
|
@ -8,26 +8,29 @@ table creation or queries.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Article(models.Model):
|
class Article(models.Model):
|
||||||
Article_ID = models.AutoField(primary_key=True, db_column='Article ID')
|
Article_ID = models.AutoField(primary_key=True, db_column='Article ID')
|
||||||
headline = models.CharField(max_length=100)
|
headline = models.CharField(max_length=100)
|
||||||
authors = models.ManyToManyField('Author', db_table='my m2m table')
|
authors = models.ManyToManyField('Author', db_table='my m2m table')
|
||||||
primary_author = models.ForeignKey('Author', db_column='Author ID', related_name='primary_set')
|
primary_author = models.ForeignKey('Author', db_column='Author ID', related_name='primary_set')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.headline
|
return self.headline
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('headline',)
|
ordering = ('headline',)
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Author(models.Model):
|
class Author(models.Model):
|
||||||
Author_ID = models.AutoField(primary_key=True, db_column='Author ID')
|
Author_ID = models.AutoField(primary_key=True, db_column='Author ID')
|
||||||
first_name = models.CharField(max_length=30, db_column='first name')
|
first_name = models.CharField(max_length=30, db_column='first name')
|
||||||
last_name = models.CharField(max_length=30, db_column='last name')
|
last_name = models.CharField(max_length=30, db_column='last name')
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '%s %s' % (self.first_name, self.last_name)
|
return '%s %s' % (self.first_name, self.last_name)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue