mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Applied Black's 2025 stable style.
https://github.com/psf/black/releases/tag/25.1.0
This commit is contained in:
		| @@ -1,11 +1,11 @@ | |||||||
| """ | """ | ||||||
|  The GeometryColumns and SpatialRefSys models for the Oracle spatial | The GeometryColumns and SpatialRefSys models for the Oracle spatial | ||||||
|  backend. | backend. | ||||||
|  |  | ||||||
|  It should be noted that Oracle Spatial does not have database tables | It should be noted that Oracle Spatial does not have database tables | ||||||
|  named according to the OGC standard, so the closest analogs are used. | named according to the OGC standard, so the closest analogs are used. | ||||||
|  For example, the `USER_SDO_GEOM_METADATA` is used for the GeometryColumns | For example, the `USER_SDO_GEOM_METADATA` is used for the GeometryColumns | ||||||
|  model and the `SDO_COORD_REF_SYS` is used for the SpatialRefSys model. | model and the `SDO_COORD_REF_SYS` is used for the SpatialRefSys model. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from django.contrib.gis.db import models | from django.contrib.gis.db import models | ||||||
| @@ -14,6 +14,7 @@ from django.contrib.gis.db.backends.base.models import SpatialRefSysMixin | |||||||
|  |  | ||||||
| class OracleGeometryColumns(models.Model): | class OracleGeometryColumns(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) | ||||||
|     column_name = models.CharField(max_length=1024) |     column_name = models.CharField(max_length=1024) | ||||||
|     srid = models.IntegerField(primary_key=True) |     srid = models.IntegerField(primary_key=True) | ||||||
| @@ -46,6 +47,7 @@ class OracleGeometryColumns(models.Model): | |||||||
|  |  | ||||||
| class OracleSpatialRefSys(models.Model, SpatialRefSysMixin): | class OracleSpatialRefSys(models.Model, SpatialRefSysMixin): | ||||||
|     "Maps to the Oracle MDSYS.CS_SRS table." |     "Maps to the Oracle MDSYS.CS_SRS table." | ||||||
|  |  | ||||||
|     cs_name = models.CharField(max_length=68) |     cs_name = models.CharField(max_length=68) | ||||||
|     srid = models.IntegerField(primary_key=True) |     srid = models.IntegerField(primary_key=True) | ||||||
|     auth_srid = models.IntegerField() |     auth_srid = models.IntegerField() | ||||||
|   | |||||||
| @@ -1,11 +1,11 @@ | |||||||
| """ | """ | ||||||
|  This module contains the spatial lookup types, and the `get_geo_where_clause` | This module contains the spatial lookup types, and the `get_geo_where_clause` | ||||||
|  routine for Oracle Spatial. | routine for Oracle Spatial. | ||||||
|  |  | ||||||
|  Please note that WKT support is broken on the XE version, and thus | Please note that WKT support is broken on the XE version, and thus | ||||||
|  this backend will not work on such platforms.  Specifically, XE lacks | this backend will not work on such platforms.  Specifically, XE lacks | ||||||
|  support for an internal JVM, and Java libraries are required to use | support for an internal JVM, and Java libraries are required to use | ||||||
|  the WKT constructors. | the WKT constructors. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| import re | import re | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| """ | """ | ||||||
|  This object provides quoting for GEOS geometries into PostgreSQL/PostGIS. | This object provides quoting for GEOS geometries into PostgreSQL/PostGIS. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from django.contrib.gis.db.backends.postgis.pgraster import to_pgraster | from django.contrib.gis.db.backends.postgis.pgraster import to_pgraster | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| """ | """ | ||||||
|  The GeometryColumns and SpatialRefSys models for the PostGIS backend. | The GeometryColumns and SpatialRefSys models for the PostGIS backend. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from django.contrib.gis.db.backends.base.models import SpatialRefSysMixin | from django.contrib.gis.db.backends.base.models import SpatialRefSysMixin | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| """ | """ | ||||||
|  The GeometryColumns and SpatialRefSys models for the SpatiaLite backend. | The GeometryColumns and SpatialRefSys models for the SpatiaLite backend. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from django.contrib.gis.db.backends.base.models import SpatialRefSysMixin | from django.contrib.gis.db.backends.base.models import SpatialRefSysMixin | ||||||
|   | |||||||
| @@ -1,29 +1,29 @@ | |||||||
| """ | """ | ||||||
|  This module houses ctypes interfaces for GDAL objects.  The following GDAL | This module houses ctypes interfaces for GDAL objects.  The following GDAL | ||||||
|  objects are supported: | objects are supported: | ||||||
|  |  | ||||||
|  CoordTransform: Used for coordinate transformations from one spatial | CoordTransform: Used for coordinate transformations from one spatial | ||||||
|   reference system to another. |  reference system to another. | ||||||
|  |  | ||||||
|  Driver: Wraps an OGR data source driver. | Driver: Wraps an OGR data source driver. | ||||||
|  |  | ||||||
|  DataSource: Wrapper for the OGR data source object, supports | DataSource: Wrapper for the OGR data source object, supports | ||||||
|   OGR-supported data sources. |  OGR-supported data sources. | ||||||
|  |  | ||||||
|  Envelope: A ctypes structure for bounding boxes (GDAL library | Envelope: A ctypes structure for bounding boxes (GDAL library | ||||||
|   not required). |  not required). | ||||||
|  |  | ||||||
|  OGRGeometry: Object for accessing OGR Geometry functionality. | OGRGeometry: Object for accessing OGR Geometry functionality. | ||||||
|  |  | ||||||
|  OGRGeomType: A class for representing the different OGR Geometry | OGRGeomType: A class for representing the different OGR Geometry | ||||||
|   types (GDAL library not required). |  types (GDAL library not required). | ||||||
|  |  | ||||||
|  SpatialReference: Represents OSR Spatial Reference objects. | SpatialReference: Represents OSR Spatial Reference objects. | ||||||
|  |  | ||||||
|  The GDAL library will be imported from the system path using the default | The GDAL library will be imported from the system path using the default | ||||||
|  library name for the current OS. The default library path may be overridden | library name for the current OS. The default library path may be overridden | ||||||
|  by setting `GDAL_LIBRARY_PATH` in your settings with the path to the GDAL C | by setting `GDAL_LIBRARY_PATH` in your settings with the path to the GDAL C | ||||||
|  library on your system. | library on your system. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from django.contrib.gis.gdal.datasource import DataSource | from django.contrib.gis.gdal.datasource import DataSource | ||||||
|   | |||||||
| @@ -1,37 +1,37 @@ | |||||||
| """ | """ | ||||||
|  DataSource is a wrapper for the OGR Data Source object, which provides | DataSource is a wrapper for the OGR Data Source object, which provides | ||||||
|  an interface for reading vector geometry data from many different file | an interface for reading vector geometry data from many different file | ||||||
|  formats (including ESRI shapefiles). | formats (including ESRI shapefiles). | ||||||
|  |  | ||||||
|  When instantiating a DataSource object, use the filename of a | When instantiating a DataSource object, use the filename of a | ||||||
|  GDAL-supported data source.  For example, a SHP file or a | GDAL-supported data source.  For example, a SHP file or a | ||||||
|  TIGER/Line file from the government. | TIGER/Line file from the government. | ||||||
|  |  | ||||||
|  The ds_driver keyword is used internally when a ctypes pointer | The ds_driver keyword is used internally when a ctypes pointer | ||||||
|  is passed in directly. | is passed in directly. | ||||||
|  |  | ||||||
|  Example: | Example: | ||||||
|   ds = DataSource('/home/foo/bar.shp') |  ds = DataSource('/home/foo/bar.shp') | ||||||
|   for layer in ds: |  for layer in ds: | ||||||
|       for feature in layer: |      for feature in layer: | ||||||
|           # Getting the geometry for the feature. |          # Getting the geometry for the feature. | ||||||
|           g = feature.geom |          g = feature.geom | ||||||
|  |  | ||||||
|           # Getting the 'description' field for the feature. |          # Getting the 'description' field for the feature. | ||||||
|           desc = feature['description'] |          desc = feature['description'] | ||||||
|  |  | ||||||
|           # We can also increment through all of the fields |          # We can also increment through all of the fields | ||||||
|           #  attached to this feature. |          #  attached to this feature. | ||||||
|           for field in feature: |          for field in feature: | ||||||
|               # Get the name of the field (e.g. 'description') |              # Get the name of the field (e.g. 'description') | ||||||
|               nm = field.name |              nm = field.name | ||||||
|  |  | ||||||
|               # Get the type (integer) of the field, e.g. 0 => OFTInteger |              # Get the type (integer) of the field, e.g. 0 => OFTInteger | ||||||
|               t = field.type |              t = field.type | ||||||
|  |  | ||||||
|               # Returns the value the field; OFTIntegers return ints, |              # Returns the value the field; OFTIntegers return ints, | ||||||
|               #  OFTReal returns floats, all else returns string. |              #  OFTReal returns floats, all else returns string. | ||||||
|               val = field.value |              val = field.value | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from pathlib import Path | from pathlib import Path | ||||||
| @@ -50,6 +50,7 @@ from django.utils.encoding import force_bytes, force_str | |||||||
| # The OGR_DS_* routines are relevant here. | # The OGR_DS_* routines are relevant here. | ||||||
| class DataSource(GDALBase): | class DataSource(GDALBase): | ||||||
|     "Wraps an OGR Data Source object." |     "Wraps an OGR Data Source object." | ||||||
|  |  | ||||||
|     destructor = capi.destroy_ds |     destructor = capi.destroy_ds | ||||||
|  |  | ||||||
|     def __init__(self, ds_input, ds_driver=False, write=False, encoding="utf-8"): |     def __init__(self, ds_input, ds_driver=False, write=False, encoding="utf-8"): | ||||||
|   | |||||||
| @@ -1,14 +1,14 @@ | |||||||
| """ | """ | ||||||
|  The GDAL/OGR library uses an Envelope structure to hold the bounding | The GDAL/OGR library uses an Envelope structure to hold the bounding | ||||||
|  box information for a geometry.  The envelope (bounding box) contains | box information for a geometry.  The envelope (bounding box) contains | ||||||
|  two pairs of coordinates, one for the lower left coordinate and one | two pairs of coordinates, one for the lower left coordinate and one | ||||||
|  for the upper right coordinate: | for the upper right coordinate: | ||||||
|  |  | ||||||
|                            +----------o Upper right; (max_x, max_y) |                           +----------o Upper right; (max_x, max_y) | ||||||
|                            |          | |                           |          | | ||||||
|                            |          | |                           |          | | ||||||
|                            |          | |                           |          | | ||||||
|  Lower left (min_x, min_y) o----------+ | Lower left (min_x, min_y) o----------+ | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import Structure, c_double | from ctypes import Structure, c_double | ||||||
| @@ -21,6 +21,7 @@ from django.contrib.gis.gdal.error import GDALException | |||||||
| #   https://gdal.org/doxygen/ogr__core_8h_source.html | #   https://gdal.org/doxygen/ogr__core_8h_source.html | ||||||
| class OGREnvelope(Structure): | class OGREnvelope(Structure): | ||||||
|     "Represent the OGREnvelope C Structure." |     "Represent the OGREnvelope C Structure." | ||||||
|  |  | ||||||
|     _fields_ = [ |     _fields_ = [ | ||||||
|         ("MinX", c_double), |         ("MinX", c_double), | ||||||
|         ("MaxX", c_double), |         ("MaxX", c_double), | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| """ | """ | ||||||
|  This module houses the GDAL & SRS Exception objects, and the | This module houses the GDAL & SRS Exception objects, and the | ||||||
|  check_err() routine which checks the status code returned by | check_err() routine which checks the status code returned by | ||||||
|  GDAL/OGR methods. | GDAL/OGR methods. | ||||||
| """ | """ | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,42 +1,42 @@ | |||||||
| """ | """ | ||||||
|  The OGRGeometry is a wrapper for using the OGR Geometry class | The OGRGeometry is a wrapper for using the OGR Geometry class | ||||||
|  (see https://gdal.org/api/ogrgeometry_cpp.html#_CPPv411OGRGeometry). | (see https://gdal.org/api/ogrgeometry_cpp.html#_CPPv411OGRGeometry). | ||||||
|  OGRGeometry may be instantiated when reading geometries from OGR Data Sources | OGRGeometry may be instantiated when reading geometries from OGR Data Sources | ||||||
|  (e.g. SHP files), or when given OGC WKT (a string). | (e.g. SHP files), or when given OGC WKT (a string). | ||||||
|  |  | ||||||
|  While the 'full' API is not present yet, the API is "pythonic" unlike | While the 'full' API is not present yet, the API is "pythonic" unlike | ||||||
|  the traditional and "next-generation" OGR Python bindings.  One major | the traditional and "next-generation" OGR Python bindings.  One major | ||||||
|  advantage OGR Geometries have over their GEOS counterparts is support | advantage OGR Geometries have over their GEOS counterparts is support | ||||||
|  for spatial reference systems and their transformation. | for spatial reference systems and their transformation. | ||||||
|  |  | ||||||
|  Example: | Example: | ||||||
|   >>> from django.contrib.gis.gdal import OGRGeometry, OGRGeomType, SpatialReference |  >>> from django.contrib.gis.gdal import OGRGeometry, OGRGeomType, SpatialReference | ||||||
|   >>> wkt1, wkt2 = 'POINT(-90 30)', 'POLYGON((0 0, 5 0, 5 5, 0 5)' |  >>> wkt1, wkt2 = 'POINT(-90 30)', 'POLYGON((0 0, 5 0, 5 5, 0 5)' | ||||||
|   >>> pnt = OGRGeometry(wkt1) |  >>> pnt = OGRGeometry(wkt1) | ||||||
|   >>> print(pnt) |  >>> print(pnt) | ||||||
|   POINT (-90 30) |  POINT (-90 30) | ||||||
|   >>> mpnt = OGRGeometry(OGRGeomType('MultiPoint'), SpatialReference('WGS84')) |  >>> mpnt = OGRGeometry(OGRGeomType('MultiPoint'), SpatialReference('WGS84')) | ||||||
|   >>> mpnt.add(wkt1) |  >>> mpnt.add(wkt1) | ||||||
|   >>> mpnt.add(wkt1) |  >>> mpnt.add(wkt1) | ||||||
|   >>> print(mpnt) |  >>> print(mpnt) | ||||||
|   MULTIPOINT (-90 30,-90 30) |  MULTIPOINT (-90 30,-90 30) | ||||||
|   >>> print(mpnt.srs.name) |  >>> print(mpnt.srs.name) | ||||||
|   WGS 84 |  WGS 84 | ||||||
|   >>> print(mpnt.srs.proj) |  >>> print(mpnt.srs.proj) | ||||||
|   +proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs |  +proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs | ||||||
|   >>> mpnt.transform(SpatialReference('NAD27')) |  >>> mpnt.transform(SpatialReference('NAD27')) | ||||||
|   >>> print(mpnt.proj) |  >>> print(mpnt.proj) | ||||||
|   +proj=longlat +ellps=clrk66 +datum=NAD27 +no_defs |  +proj=longlat +ellps=clrk66 +datum=NAD27 +no_defs | ||||||
|   >>> print(mpnt) |  >>> print(mpnt) | ||||||
|   MULTIPOINT (-89.99993037860248 29.99979788655764,-89.99993037860248 29.99979788655764) |  MULTIPOINT (-89.99993037860248 29.99979788655764,-89.99993037860248 29.99979788655764) | ||||||
|  |  | ||||||
|   The OGRGeomType class is to make it easy to specify an OGR geometry type: |  The OGRGeomType class is to make it easy to specify an OGR geometry type: | ||||||
|   >>> from django.contrib.gis.gdal import OGRGeomType |  >>> from django.contrib.gis.gdal import OGRGeomType | ||||||
|   >>> gt1 = OGRGeomType(3) # Using an integer for the type |  >>> gt1 = OGRGeomType(3) # Using an integer for the type | ||||||
|   >>> gt2 = OGRGeomType('Polygon') # Using a string |  >>> gt2 = OGRGeomType('Polygon') # Using a string | ||||||
|   >>> gt3 = OGRGeomType('POLYGON') # It's case-insensitive |  >>> gt3 = OGRGeomType('POLYGON') # It's case-insensitive | ||||||
|   >>> print(gt1 == 3, gt1 == 'Polygon') # Equivalence works w/non-OGRGeomType objects |  >>> print(gt1 == 3, gt1 == 'Polygon') # Equivalence works w/non-OGRGeomType objects | ||||||
|   True True |  True True | ||||||
| """ | """ | ||||||
|  |  | ||||||
| import sys | import sys | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| """ | """ | ||||||
|  This module houses the ctypes function prototypes for OGR DataSource | This module houses the ctypes function prototypes for OGR DataSource | ||||||
|  related data structures. OGR_Dr_*, OGR_DS_*, OGR_L_*, OGR_F_*, | related data structures. OGR_Dr_*, OGR_DS_*, OGR_L_*, OGR_F_*, | ||||||
|  OGR_Fld_* routines are relevant here. | OGR_Fld_* routines are relevant here. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import POINTER, c_char_p, c_double, c_int, c_long, c_uint, c_void_p | from ctypes import POINTER, c_char_p, c_double, c_int, c_long, c_uint, c_void_p | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| """ | """ | ||||||
|  This module houses the error-checking routines used by the GDAL | This module houses the error-checking routines used by the GDAL | ||||||
|  ctypes prototypes. | ctypes prototypes. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import c_void_p, string_at | from ctypes import c_void_p, string_at | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| """ | """ | ||||||
|  This module contains functions that generate ctypes prototypes for the | This module contains functions that generate ctypes prototypes for the | ||||||
|  GDAL routines. | GDAL routines. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import POINTER, c_bool, c_char_p, c_double, c_int, c_int64, c_void_p | from ctypes import POINTER, c_bool, c_char_p, c_double, c_int, c_int64, c_void_p | ||||||
|   | |||||||
| @@ -1,30 +1,30 @@ | |||||||
| """ | """ | ||||||
|   The Spatial Reference class, represents OGR Spatial Reference objects. | The Spatial Reference class, represents OGR Spatial Reference objects. | ||||||
|  |  | ||||||
|   Example: | Example: | ||||||
|   >>> from django.contrib.gis.gdal import SpatialReference | >>> from django.contrib.gis.gdal import SpatialReference | ||||||
|   >>> srs = SpatialReference('WGS84') | >>> srs = SpatialReference('WGS84') | ||||||
|   >>> print(srs) | >>> print(srs) | ||||||
|   GEOGCS["WGS 84", | GEOGCS["WGS 84", | ||||||
|       DATUM["WGS_1984", |     DATUM["WGS_1984", | ||||||
|           SPHEROID["WGS 84",6378137,298.257223563, |         SPHEROID["WGS 84",6378137,298.257223563, | ||||||
|               AUTHORITY["EPSG","7030"]], |             AUTHORITY["EPSG","7030"]], | ||||||
|           TOWGS84[0,0,0,0,0,0,0], |         TOWGS84[0,0,0,0,0,0,0], | ||||||
|           AUTHORITY["EPSG","6326"]], |         AUTHORITY["EPSG","6326"]], | ||||||
|       PRIMEM["Greenwich",0, |     PRIMEM["Greenwich",0, | ||||||
|           AUTHORITY["EPSG","8901"]], |         AUTHORITY["EPSG","8901"]], | ||||||
|       UNIT["degree",0.01745329251994328, |     UNIT["degree",0.01745329251994328, | ||||||
|           AUTHORITY["EPSG","9122"]], |         AUTHORITY["EPSG","9122"]], | ||||||
|       AUTHORITY["EPSG","4326"]] |     AUTHORITY["EPSG","4326"]] | ||||||
|   >>> print(srs.proj) | >>> print(srs.proj) | ||||||
|   +proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs | +proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs | ||||||
|   >>> print(srs.ellipsoid) | >>> print(srs.ellipsoid) | ||||||
|   (6378137.0, 6356752.3142451793, 298.25722356300003) | (6378137.0, 6356752.3142451793, 298.25722356300003) | ||||||
|   >>> print(srs.projected, srs.geographic) | >>> print(srs.projected, srs.geographic) | ||||||
|   False True | False True | ||||||
|   >>> srs.import_epsg(32140) | >>> srs.import_epsg(32140) | ||||||
|   >>> print(srs.name) | >>> print(srs.name) | ||||||
|   NAD83 / Texas South Central | NAD83 / Texas South Central | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import byref, c_char_p, c_int | from ctypes import byref, c_char_p, c_int | ||||||
| @@ -345,6 +345,7 @@ class SpatialReference(GDALBase): | |||||||
|  |  | ||||||
| class CoordTransform(GDALBase): | class CoordTransform(GDALBase): | ||||||
|     "The coordinate system transformation object." |     "The coordinate system transformation object." | ||||||
|  |  | ||||||
|     destructor = capi.destroy_ct |     destructor = capi.destroy_ct | ||||||
|  |  | ||||||
|     def __init__(self, source, target): |     def __init__(self, source, target): | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| """ | """ | ||||||
|  This module houses the Geometry Collection objects: | This module houses the Geometry Collection objects: | ||||||
|  GeometryCollection, MultiPoint, MultiLineString, and MultiPolygon | GeometryCollection, MultiPoint, MultiLineString, and MultiPolygon | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from django.contrib.gis.geos import prototypes as capi | from django.contrib.gis.geos import prototypes as capi | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| """ | """ | ||||||
|  This module houses the GEOSCoordSeq object, which is used internally | This module houses the GEOSCoordSeq object, which is used internally | ||||||
|  by GEOSGeometry to house the actual coordinates of the Point, | by GEOSGeometry to house the actual coordinates of the Point, | ||||||
|  LineString, and LinearRing geometries. | LineString, and LinearRing geometries. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import byref, c_byte, c_double, c_uint | from ctypes import byref, c_byte, c_double, c_uint | ||||||
|   | |||||||
| @@ -1,3 +1,4 @@ | |||||||
| class GEOSException(Exception): | class GEOSException(Exception): | ||||||
|     "The base GEOS exception, indicates a GEOS-related error." |     "The base GEOS exception, indicates a GEOS-related error." | ||||||
|  |  | ||||||
|     pass |     pass | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| """ | """ | ||||||
|  This module contains the 'base' GEOSGeometry object -- all GEOS Geometries | This module contains the 'base' GEOSGeometry object -- all GEOS Geometries | ||||||
|  inherit from this object. | inherit from this object. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| import re | import re | ||||||
|   | |||||||
| @@ -1,10 +1,10 @@ | |||||||
| """ | """ | ||||||
|  This module houses the ctypes initialization procedures, as well | This module houses the ctypes initialization procedures, as well | ||||||
|  as the notice and error handler function callbacks (get called | as the notice and error handler function callbacks (get called | ||||||
|  when an error occurs in GEOS). | when an error occurs in GEOS). | ||||||
|  |  | ||||||
|  This module also houses GEOS Pointer utilities, including | This module also houses GEOS Pointer utilities, including | ||||||
|  get_pointer_arr(), and GEOM_PTR. | get_pointer_arr(), and GEOM_PTR. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| import logging | import logging | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| """ | """ | ||||||
|  This module contains all of the GEOS ctypes function prototypes. Each | This module contains all of the GEOS ctypes function prototypes. Each | ||||||
|  prototype handles the interaction between the GEOS library and Python | prototype handles the interaction between the GEOS library and Python | ||||||
|  via ctypes. | via ctypes. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from django.contrib.gis.geos.prototypes.coordseq import (  # NOQA | from django.contrib.gis.geos.prototypes.coordseq import (  # NOQA | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ def check_cs_get(result, func, cargs): | |||||||
| # ## Coordinate sequence prototype factory classes. ## | # ## Coordinate sequence prototype factory classes. ## | ||||||
| class CsInt(GEOSFuncFactory): | class CsInt(GEOSFuncFactory): | ||||||
|     "For coordinate sequence routines that return an integer." |     "For coordinate sequence routines that return an integer." | ||||||
|  |  | ||||||
|     argtypes = [CS_PTR, POINTER(c_uint)] |     argtypes = [CS_PTR, POINTER(c_uint)] | ||||||
|     restype = c_int |     restype = c_int | ||||||
|     errcheck = staticmethod(check_cs_get) |     errcheck = staticmethod(check_cs_get) | ||||||
| @@ -30,6 +31,7 @@ class CsInt(GEOSFuncFactory): | |||||||
|  |  | ||||||
| class CsOperation(GEOSFuncFactory): | class CsOperation(GEOSFuncFactory): | ||||||
|     "For coordinate sequence operations." |     "For coordinate sequence operations." | ||||||
|  |  | ||||||
|     restype = c_int |     restype = c_int | ||||||
|  |  | ||||||
|     def __init__(self, *args, ordinate=False, get=False, **kwargs): |     def __init__(self, *args, ordinate=False, get=False, **kwargs): | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| """ | """ | ||||||
|  Error checking functions for GEOS ctypes prototype functions. | Error checking functions for GEOS ctypes prototype functions. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import c_void_p, string_at | from ctypes import c_void_p, string_at | ||||||
|   | |||||||
| @@ -25,12 +25,14 @@ class geos_char_p(c_char_p): | |||||||
| # ### ctypes factory classes ### | # ### ctypes factory classes ### | ||||||
| class GeomOutput(GEOSFuncFactory): | class GeomOutput(GEOSFuncFactory): | ||||||
|     "For GEOS routines that return a geometry." |     "For GEOS routines that return a geometry." | ||||||
|  |  | ||||||
|     restype = GEOM_PTR |     restype = GEOM_PTR | ||||||
|     errcheck = staticmethod(check_geom) |     errcheck = staticmethod(check_geom) | ||||||
|  |  | ||||||
|  |  | ||||||
| class IntFromGeom(GEOSFuncFactory): | class IntFromGeom(GEOSFuncFactory): | ||||||
|     "Argument is a geometry, return type is an integer." |     "Argument is a geometry, return type is an integer." | ||||||
|  |  | ||||||
|     argtypes = [GEOM_PTR] |     argtypes = [GEOM_PTR] | ||||||
|     restype = c_int |     restype = c_int | ||||||
|     errcheck = staticmethod(check_minus_one) |     errcheck = staticmethod(check_minus_one) | ||||||
| @@ -38,6 +40,7 @@ class IntFromGeom(GEOSFuncFactory): | |||||||
|  |  | ||||||
| class StringFromGeom(GEOSFuncFactory): | class StringFromGeom(GEOSFuncFactory): | ||||||
|     "Argument is a Geometry, return type is a string." |     "Argument is a Geometry, return type is a string." | ||||||
|  |  | ||||||
|     argtypes = [GEOM_PTR] |     argtypes = [GEOM_PTR] | ||||||
|     restype = geos_char_p |     restype = geos_char_p | ||||||
|     errcheck = staticmethod(check_string) |     errcheck = staticmethod(check_string) | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| """ | """ | ||||||
|  This module is for the miscellaneous GEOS routines, particularly the | This module is for the miscellaneous GEOS routines, particularly the | ||||||
|  ones that return the area, distance, and length. | ones that return the area, distance, and length. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import POINTER, c_double, c_int | from ctypes import POINTER, c_double, c_int | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| """ | """ | ||||||
|  This module houses the GEOS ctypes prototype functions for the | This module houses the GEOS ctypes prototype functions for the | ||||||
|  unary and binary predicate operations on geometries. | unary and binary predicate operations on geometries. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import c_byte, c_char_p, c_double | from ctypes import c_byte, c_char_p, c_double | ||||||
| @@ -12,6 +12,7 @@ from django.contrib.gis.geos.prototypes.errcheck import check_predicate | |||||||
| # ## Binary & unary predicate factories ## | # ## Binary & unary predicate factories ## | ||||||
| class UnaryPredicate(GEOSFuncFactory): | class UnaryPredicate(GEOSFuncFactory): | ||||||
|     "For GEOS unary predicate functions." |     "For GEOS unary predicate functions." | ||||||
|  |  | ||||||
|     argtypes = [GEOM_PTR] |     argtypes = [GEOM_PTR] | ||||||
|     restype = c_byte |     restype = c_byte | ||||||
|     errcheck = staticmethod(check_predicate) |     errcheck = staticmethod(check_predicate) | ||||||
| @@ -19,6 +20,7 @@ class UnaryPredicate(GEOSFuncFactory): | |||||||
|  |  | ||||||
| class BinaryPredicate(UnaryPredicate): | class BinaryPredicate(UnaryPredicate): | ||||||
|     "For GEOS binary predicate functions." |     "For GEOS binary predicate functions." | ||||||
|  |  | ||||||
|     argtypes = [GEOM_PTR, GEOM_PTR] |     argtypes = [GEOM_PTR, GEOM_PTR] | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| """ | """ | ||||||
|  This module houses the GEOS ctypes prototype functions for the | This module houses the GEOS ctypes prototype functions for the | ||||||
|  topological operations on geometries. | topological operations on geometries. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from ctypes import c_double, c_int | from ctypes import c_double, c_int | ||||||
| @@ -16,6 +16,7 @@ from django.contrib.gis.geos.prototypes.geom import geos_char_p | |||||||
|  |  | ||||||
| class Topology(GEOSFuncFactory): | class Topology(GEOSFuncFactory): | ||||||
|     "For GEOS unary topology functions." |     "For GEOS unary topology functions." | ||||||
|  |  | ||||||
|     argtypes = [GEOM_PTR] |     argtypes = [GEOM_PTR] | ||||||
|     restype = GEOM_PTR |     restype = GEOM_PTR | ||||||
|     errcheck = staticmethod(check_geom) |     errcheck = staticmethod(check_geom) | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| """ | """ | ||||||
|  This module contains useful utilities for GeoDjango. | This module contains useful utilities for GeoDjango. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from django.contrib.gis.utils.ogrinfo import ogrinfo | from django.contrib.gis.utils.ogrinfo import ogrinfo | ||||||
|   | |||||||
| @@ -1,10 +1,10 @@ | |||||||
| # LayerMapping -- A Django Model/OGR Layer Mapping Utility | # LayerMapping -- A Django Model/OGR Layer Mapping Utility | ||||||
| """ | """ | ||||||
|  The LayerMapping class provides a way to map the contents of OGR | The LayerMapping class provides a way to map the contents of OGR | ||||||
|  vector files (e.g. SHP files) to Geographic-enabled Django models. | vector files (e.g. SHP files) to Geographic-enabled Django models. | ||||||
|  |  | ||||||
|  For more information, please consult the GeoDjango documentation: | For more information, please consult the GeoDjango documentation: | ||||||
|    https://docs.djangoproject.com/en/dev/ref/contrib/gis/layermapping/ |   https://docs.djangoproject.com/en/dev/ref/contrib/gis/layermapping/ | ||||||
| """ | """ | ||||||
| import sys | import sys | ||||||
| from decimal import Decimal | from decimal import Decimal | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								django/core/cache/backends/base.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								django/core/cache/backends/base.py
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,5 @@ | |||||||
| "Base Cache class." | "Base Cache class." | ||||||
|  |  | ||||||
| import time | import time | ||||||
| import warnings | import warnings | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								django/core/cache/backends/db.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								django/core/cache/backends/db.py
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,5 @@ | |||||||
| "Database cache backend." | "Database cache backend." | ||||||
|  |  | ||||||
| import base64 | import base64 | ||||||
| import pickle | import pickle | ||||||
| from datetime import UTC, datetime | from datetime import UTC, datetime | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								django/core/cache/backends/filebased.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								django/core/cache/backends/filebased.py
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,5 @@ | |||||||
| "File-based cache backend" | "File-based cache backend" | ||||||
|  |  | ||||||
| import glob | import glob | ||||||
| import os | import os | ||||||
| import pickle | import pickle | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								django/core/cache/backends/locmem.py
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								django/core/cache/backends/locmem.py
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,5 @@ | |||||||
| "Thread-safe in-memory cache backend." | "Thread-safe in-memory cache backend." | ||||||
|  |  | ||||||
| import pickle | import pickle | ||||||
| import time | import time | ||||||
| from collections import OrderedDict | from collections import OrderedDict | ||||||
|   | |||||||
| @@ -431,6 +431,7 @@ class BaseForm(RenderableFormMixin): | |||||||
|  |  | ||||||
| class Form(BaseForm, metaclass=DeclarativeFieldsMetaclass): | class Form(BaseForm, metaclass=DeclarativeFieldsMetaclass): | ||||||
|     "A collection of Fields, plus their associated data." |     "A collection of Fields, plus their associated data." | ||||||
|  |  | ||||||
|     # This is a separate class from BaseForm in order to abstract the way |     # This is a separate class from BaseForm in order to abstract the way | ||||||
|     # self.fields is specified. This class (Form) is the one that does the |     # self.fields is specified. This class (Form) is the one that does the | ||||||
|     # fancy metaclass stuff purely for the semantic sugar -- it allows one |     # fancy metaclass stuff purely for the semantic sugar -- it allows one | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ _builtin_context_processors = ("django.template.context_processors.csrf",) | |||||||
|  |  | ||||||
| class ContextPopException(Exception): | class ContextPopException(Exception): | ||||||
|     "pop() has been called more times than push()" |     "pop() has been called more times than push()" | ||||||
|  |  | ||||||
|     pass |     pass | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -546,6 +546,7 @@ class SuperVillain(Villain): | |||||||
|  |  | ||||||
| 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) | ||||||
|     content_type = models.ForeignKey(ContentType, models.CASCADE) |     content_type = models.ForeignKey(ContentType, models.CASCADE) | ||||||
|     object_id = models.PositiveIntegerField() |     object_id = models.PositiveIntegerField() | ||||||
|   | |||||||
| @@ -7158,7 +7158,7 @@ class ReadonlyTest(AdminFieldExtractionMixin, TestCase): | |||||||
|         url = reverse("admin:admin_views_pizza_change", args=(pizza.pk,)) |         url = reverse("admin:admin_views_pizza_change", args=(pizza.pk,)) | ||||||
|         with self.settings(LANGUAGE_CODE="fr"): |         with self.settings(LANGUAGE_CODE="fr"): | ||||||
|             response = self.client.get(url) |             response = self.client.get(url) | ||||||
|         self.assertContains(response, "<label>Toppings\u00A0:</label>", html=True) |         self.assertContains(response, "<label>Toppings\u00a0:</label>", html=True) | ||||||
|  |  | ||||||
|  |  | ||||||
| @override_settings(ROOT_URLCONF="admin_views.urls") | @override_settings(ROOT_URLCONF="admin_views.urls") | ||||||
|   | |||||||
| @@ -350,10 +350,10 @@ class UsernameValidatorsTests(SimpleTestCase): | |||||||
|         invalid_usernames = [ |         invalid_usernames = [ | ||||||
|             "o'connell", |             "o'connell", | ||||||
|             "عبد ال", |             "عبد ال", | ||||||
|             "zerowidth\u200Bspace", |             "zerowidth\u200bspace", | ||||||
|             "nonbreaking\u00A0space", |             "nonbreaking\u00a0space", | ||||||
|             "en\u2013dash", |             "en\u2013dash", | ||||||
|             "trailingnewline\u000A", |             "trailingnewline\u000a", | ||||||
|         ] |         ] | ||||||
|         v = validators.UnicodeUsernameValidator() |         v = validators.UnicodeUsernameValidator() | ||||||
|         for valid in valid_usernames: |         for valid in valid_usernames: | ||||||
|   | |||||||
| @@ -95,7 +95,7 @@ class LastExecutedQueryTest(TestCase): | |||||||
|  |  | ||||||
|     def test_query_encoding(self): |     def test_query_encoding(self): | ||||||
|         """last_executed_query() returns a string.""" |         """last_executed_query() returns a string.""" | ||||||
|         data = RawData.objects.filter(raw_data=b"\x00\x46  \xFE").extra( |         data = RawData.objects.filter(raw_data=b"\x00\x46  \xfe").extra( | ||||||
|             select={"föö": 1} |             select={"föö": 1} | ||||||
|         ) |         ) | ||||||
|         sql, params = data.query.sql_with_params() |         sql, params = data.query.sql_with_params() | ||||||
|   | |||||||
| @@ -73,7 +73,7 @@ class FormsUtilsTestCase(SimpleTestCase): | |||||||
|         ) |         ) | ||||||
|         # Can take a Unicode string. |         # Can take a Unicode string. | ||||||
|         self.assertHTMLEqual( |         self.assertHTMLEqual( | ||||||
|             str(ErrorList(ValidationError("Not \u03C0.").messages)), |             str(ErrorList(ValidationError("Not \u03c0.").messages)), | ||||||
|             '<ul class="errorlist"><li>Not π.</li></ul>', |             '<ul class="errorlist"><li>Not π.</li></ul>', | ||||||
|         ) |         ) | ||||||
|         # Can take a lazy string. |         # Can take a lazy string. | ||||||
| @@ -107,7 +107,7 @@ class FormsUtilsTestCase(SimpleTestCase): | |||||||
|                         ValidationError( |                         ValidationError( | ||||||
|                             [ |                             [ | ||||||
|                                 "1. First error.", |                                 "1. First error.", | ||||||
|                                 "2. Not \u03C0.", |                                 "2. Not \u03c0.", | ||||||
|                                 gettext_lazy("3. Error."), |                                 gettext_lazy("3. Error."), | ||||||
|                                 { |                                 { | ||||||
|                                     "error_1": "4. First dict error.", |                                     "error_1": "4. First dict error.", | ||||||
|   | |||||||
| @@ -15,17 +15,20 @@ class NamedModel(models.Model): | |||||||
|  |  | ||||||
| class SouthTexasCity(NamedModel): | class SouthTexasCity(NamedModel): | ||||||
|     "City model on projected coordinate system for South Texas." |     "City model on projected coordinate system for South Texas." | ||||||
|  |  | ||||||
|     point = models.PointField(srid=32140) |     point = models.PointField(srid=32140) | ||||||
|     radius = models.IntegerField(default=10000) |     radius = models.IntegerField(default=10000) | ||||||
|  |  | ||||||
|  |  | ||||||
| class SouthTexasCityFt(NamedModel): | class SouthTexasCityFt(NamedModel): | ||||||
|     "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." | ||||||
|  |  | ||||||
|     point = models.PointField(srid=2278) |     point = models.PointField(srid=2278) | ||||||
|  |  | ||||||
|  |  | ||||||
| class AustraliaCity(NamedModel): | class AustraliaCity(NamedModel): | ||||||
|     "City model for Australia, using WGS84." |     "City model for Australia, using WGS84." | ||||||
|  |  | ||||||
|     point = models.PointField() |     point = models.PointField() | ||||||
|     radius = models.IntegerField(default=10000) |     radius = models.IntegerField(default=10000) | ||||||
|     allowed_distance = models.FloatField(default=0.5) |     allowed_distance = models.FloatField(default=0.5) | ||||||
| @@ -34,19 +37,23 @@ class AustraliaCity(NamedModel): | |||||||
|  |  | ||||||
| class CensusZipcode(NamedModel): | class CensusZipcode(NamedModel): | ||||||
|     "Model for a few South Texas ZIP codes (in original Census NAD83)." |     "Model for a few South Texas ZIP codes (in original Census NAD83)." | ||||||
|  |  | ||||||
|     poly = models.PolygonField(srid=4269) |     poly = models.PolygonField(srid=4269) | ||||||
|  |  | ||||||
|  |  | ||||||
| class SouthTexasZipcode(NamedModel): | class SouthTexasZipcode(NamedModel): | ||||||
|     "Model for a few South Texas ZIP codes." |     "Model for a few South Texas ZIP codes." | ||||||
|  |  | ||||||
|     poly = models.PolygonField(srid=32140, null=gisfield_may_be_null) |     poly = models.PolygonField(srid=32140, null=gisfield_may_be_null) | ||||||
|  |  | ||||||
|  |  | ||||||
| class Interstate(NamedModel): | class Interstate(NamedModel): | ||||||
|     "Geodetic model for U.S. Interstates." |     "Geodetic model for U.S. Interstates." | ||||||
|  |  | ||||||
|     path = models.LineStringField() |     path = models.LineStringField() | ||||||
|  |  | ||||||
|  |  | ||||||
| class SouthTexasInterstate(NamedModel): | class SouthTexasInterstate(NamedModel): | ||||||
|     "Projected model for South Texas Interstates." |     "Projected model for South Texas Interstates." | ||||||
|  |  | ||||||
|     path = models.LineStringField(srid=32140) |     path = models.LineStringField(srid=32140) | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ from .models import DataModel | |||||||
|  |  | ||||||
|  |  | ||||||
| class BinaryFieldTests(TestCase): | class BinaryFieldTests(TestCase): | ||||||
|     binary_data = b"\x00\x46\xFE" |     binary_data = b"\x00\x46\xfe" | ||||||
|  |  | ||||||
|     def test_set_and_retrieve(self): |     def test_set_and_retrieve(self): | ||||||
|         data_set = ( |         data_set = ( | ||||||
|   | |||||||
| @@ -309,7 +309,7 @@ class ExclusionConstraintTests(PostgreSQLTestCase): | |||||||
|  |  | ||||||
|     def test_invalid_expressions(self): |     def test_invalid_expressions(self): | ||||||
|         msg = "The expressions must be a list of 2-tuples." |         msg = "The expressions must be a list of 2-tuples." | ||||||
|         for expressions in (["foo"], [("foo")], [("foo_1", "foo_2", "foo_3")]): |         for expressions in (["foo"], ["foo"], [("foo_1", "foo_2", "foo_3")]): | ||||||
|             with self.subTest(expressions), self.assertRaisesMessage(ValueError, msg): |             with self.subTest(expressions), self.assertRaisesMessage(ValueError, msg): | ||||||
|                 ExclusionConstraint( |                 ExclusionConstraint( | ||||||
|                     index_type="GIST", |                     index_type="GIST", | ||||||
|   | |||||||
| @@ -257,7 +257,7 @@ uuid_obj = uuid.uuid4() | |||||||
|  |  | ||||||
| test_data = [ | test_data = [ | ||||||
|     # Format: (test helper, PK value, Model Class, data) |     # Format: (test helper, PK value, Model Class, data) | ||||||
|     (data_obj, 1, BinaryData, memoryview(b"\x05\xFD\x00")), |     (data_obj, 1, BinaryData, memoryview(b"\x05\xfd\x00")), | ||||||
|     (data_obj, 5, BooleanData, True), |     (data_obj, 5, BooleanData, True), | ||||||
|     (data_obj, 6, BooleanData, False), |     (data_obj, 6, BooleanData, False), | ||||||
|     (data_obj, 7, BooleanData, None), |     (data_obj, 7, BooleanData, None), | ||||||
|   | |||||||
| @@ -70,7 +70,7 @@ class XmlSerializerTestCase(SerializersTestBase, TestCase): | |||||||
|         msg = "Article.headline (pk:%s) contains unserializable characters" % self.a1.pk |         msg = "Article.headline (pk:%s) contains unserializable characters" % self.a1.pk | ||||||
|         with self.assertRaisesMessage(ValueError, msg): |         with self.assertRaisesMessage(ValueError, msg): | ||||||
|             serializers.serialize(self.serializer_name, [self.a1]) |             serializers.serialize(self.serializer_name, [self.a1]) | ||||||
|         self.a1.headline = "HT \u0009, LF \u000A, and CR \u000D are allowed" |         self.a1.headline = "HT \u0009, LF \u000a, and CR \u000d are allowed" | ||||||
|         self.assertIn( |         self.assertIn( | ||||||
|             "HT \t, LF \n, and CR \r are allowed", |             "HT \t, LF \n, and CR \r are allowed", | ||||||
|             serializers.serialize(self.serializer_name, [self.a1]), |             serializers.serialize(self.serializer_name, [self.a1]), | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ from django.utils.functional import lazystr | |||||||
| from django.utils.text import format_lazy | from django.utils.text import format_lazy | ||||||
| from django.utils.translation import gettext_lazy, override | from django.utils.translation import gettext_lazy, override | ||||||
|  |  | ||||||
| IS_WIDE_BUILD = len("\U0001F4A9") == 1 | IS_WIDE_BUILD = len("\U0001f4a9") == 1 | ||||||
|  |  | ||||||
|  |  | ||||||
| class TestUtilsText(SimpleTestCase): | class TestUtilsText(SimpleTestCase): | ||||||
| @@ -76,16 +76,16 @@ class TestUtilsText(SimpleTestCase): | |||||||
|         # Ensure the final length is calculated correctly when there are |         # Ensure the final length is calculated correctly when there are | ||||||
|         # combining characters with no precomposed form, and that combining |         # combining characters with no precomposed form, and that combining | ||||||
|         # characters are not split up. |         # characters are not split up. | ||||||
|         truncator = text.Truncator("-B\u030AB\u030A----8") |         truncator = text.Truncator("-B\u030aB\u030a----8") | ||||||
|         self.assertEqual("-B\u030A…", truncator.chars(3)) |         self.assertEqual("-B\u030a…", truncator.chars(3)) | ||||||
|         self.assertEqual("-B\u030AB\u030A-…", truncator.chars(5)) |         self.assertEqual("-B\u030aB\u030a-…", truncator.chars(5)) | ||||||
|         self.assertEqual("-B\u030AB\u030A----8", truncator.chars(8)) |         self.assertEqual("-B\u030aB\u030a----8", truncator.chars(8)) | ||||||
|  |  | ||||||
|         # Ensure the length of the end text is correctly calculated when it |         # Ensure the length of the end text is correctly calculated when it | ||||||
|         # contains combining characters with no precomposed form. |         # contains combining characters with no precomposed form. | ||||||
|         truncator = text.Truncator("-----") |         truncator = text.Truncator("-----") | ||||||
|         self.assertEqual("---B\u030A", truncator.chars(4, "B\u030A")) |         self.assertEqual("---B\u030a", truncator.chars(4, "B\u030a")) | ||||||
|         self.assertEqual("-----", truncator.chars(5, "B\u030A")) |         self.assertEqual("-----", truncator.chars(5, "B\u030a")) | ||||||
|  |  | ||||||
|         # Make a best effort to shorten to the desired length, but requesting |         # Make a best effort to shorten to the desired length, but requesting | ||||||
|         # a length shorter than the ellipsis shouldn't break |         # a length shorter than the ellipsis shouldn't break | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user