Add gis deconstruct() method (this does not make schema work)

This commit is contained in:
Andrew Godwin 2013-11-27 12:56:33 +00:00
parent 96dd48c83f
commit 4fcfc31865
2 changed files with 14 additions and 1 deletions

View File

@ -105,6 +105,19 @@ class GeometryField(Field):
super(GeometryField, self).__init__(**kwargs) super(GeometryField, self).__init__(**kwargs)
def deconstruct(self):
name, path, args, kwargs = super(GeometryField, self).deconstruct()
# Always include SRID for less fragility; include others if they're
# not the default values.
kwargs['srid'] = self.srid
if self.dim != 2:
kwargs['dim'] = self.dim
if self.spatial_index != True:
kwargs['spatial_index'] = self.spatial_index
if self.geography != False:
kwargs['geography'] = self.geography
return name, path, args, kwargs
# The following functions are used to get the units, their name, and # The following functions are used to get the units, their name, and
# the spheroid corresponding to the SRID of the GeometryField. # the spheroid corresponding to the SRID of the GeometryField.
def _get_srid_info(self, connection): def _get_srid_info(self, connection):

View File

@ -110,7 +110,7 @@ class BaseDatabaseSchemaEditor(object):
params = [] params = []
# Check for fields that aren't actually columns (e.g. M2M) # Check for fields that aren't actually columns (e.g. M2M)
if sql is None: if sql is None:
return None return None, None
# Work out nullability # Work out nullability
null = field.null null = field.null
# If we were told to include a default value, do so # If we were told to include a default value, do so