HEX
Server: Apache
System: Linux pdx1-shared-a1-38 6.6.104-grsec-jammy+ #3 SMP Tue Sep 16 00:28:11 UTC 2025 x86_64
User: mmickelson (3396398)
PHP: 8.1.31
Disabled: NONE
Upload Files
File: //lib/python3/dist-packages/django/contrib/gis/geos/__pycache__/geometry.cpython-310.pyc
o

�a�c�@sdZddlZddlmZmZmZddlmZddlm	Z	m
Z
mZddlm
ZddlmZddlmZdd	lmZdd
lmZddlmZddlmZdd
lmZmZmZmZm Z ddl!m"Z"ddl#m$Z$m%Z%Gdd�de�Z&Gdd�d�Z'e"Gdd�de&e��Z(dS)zh
 This module contains the 'base' GEOSGeometry object -- all GEOS Geometries
 inherit from this object.
�N)�	addressof�byref�c_double)�gdal)�	hex_regex�
json_regex�	wkt_regex)�
prototypes)�GEOSBase)�GEOSCoordSeq)�
GEOSException)�GEOM_PTR)�	ListMixin��PreparedGeometry)�ewkb_w�wkb_r�wkb_w�wkt_r�wkt_w)�deconstructible)�force_bytes�	force_strc@sVeZdZdZeZejZdZ	dd�Z
dd�Zdd�Zd	d
�Z
dd�Zd
d�Zdd�Zdd�Zdd�Zdd�Zedd��Zedd��Zedd��Zedd��Zdd �Zd!d"�Zd#d$�Zd%d&�Zd'd(�Zd)d*�Ze d+d,��Z!e d-d.��Z"e d/d0��Z#e d1d2��Z$e d3d4��Z%e d5d6��Z&e d7d8��Z'd9d:�Z(e d;d<��Z)e d=d>��Z*e d?d@��Z+e dAdB��Z,e dCdD��Z-e dEdF��Z.dGdH�Z/dIdJ�Z0dKdL�Z1dMdN�Z2dOdP�Z3d�dRdS�Z4dTdU�Z5dVdW�Z6dXdY�Z7dZd[�Z8d\d]�Z9e d^d_��Z:e:j;d`d_��Z:e dadb��Z<e dcdd��Z=e dedf��Z>e dgdh��Z?e didj��Z@e@ZAe dkdl��ZBe dmdn��ZCe dodp��ZDe dqdr��ZEdsdt�ZFe dudv��ZGe dwdx��ZHe dydz��ZId�d{d|�ZJd}d~�ZKe dd���ZLd�d�d��ZMd�d�d��ZNe d�d���ZOe d�d���ZPd�d��ZQe d�d���ZRd�d��ZSe d�d���ZTd�d��ZUd�d�d��ZVd�d��ZWe d�d���ZXd�d��ZYe d�d���ZZd�d��Z[e d�d���Z\e d�d���Z]d�d��Z^dS)��GEOSGeometryBaseNFc	Cs�||_t|�ttfvrI|durFtjdur@ddlm}m}m}m	}ddl
m}m}ddl
m}	ddlm}
|	|||
||||d�t_tj|j}||_|��dS)N�)�GeometryCollection�MultiLineString�
MultiPoint�MultiPolygon)�
LinearRing�
LineString��Point)�Polygon)rr������)�_ptr�typer�GEOSGeometry�
_GEOS_CLASSES�collectionsrrrr�
linestringrr �pointr"�polygonr#�geom_typeid�	__class__�
_post_init)�self�ptr�clsrrrrrr r"r#�r8�B/usr/lib/python3/dist-packages/django/contrib/gis/geos/geometry.py�__init__ s(
�
zGEOSGeometryBase.__init__cCs*|jrtt�|j�|j�|_dSd|_dS)z"Perform post-initialization setup.N)�has_csr�capi�get_csr6�hasz�_cs�r5r8r8r9r4=s*zGEOSGeometryBase._post_initcC�|��S)z�
        Return a clone because the copy of a GEOSGeometry may contain an
        invalid pointer location if the original is garbage collected.
        ��cloner@r8r8r9�__copy__C�zGEOSGeometryBase.__copy__cCrA)z�
        The `deepcopy` routine is used by the `Node` class of django.utils.tree;
        thus, the protocol routine needs to be implemented to return correct
        copies (clones) of these GEOS objects, which use C pointers.
        rB)r5�memodictr8r8r9�__deepcopy__J�zGEOSGeometryBase.__deepcopy__cC�|jS)z+EWKT is used for the string representation.)�ewktr@r8r8r9�__str__RszGEOSGeometryBase.__str__cCsd|jtt|j��fS)z8Short-hand representation because WKT may be very large.z<%s object at %s>)�	geom_type�hexrr6r@r8r8r9�__repr__VszGEOSGeometryBase.__repr__cCs
t|j�S�N)�bytes�wkbr@r8r8r9�_to_pickle_wkb[s
zGEOSGeometryBase._to_pickle_wkbcCst��t|��SrO)r�read�
memoryview)r5rQr8r8r9�_from_pickle_wkb^�z!GEOSGeometryBase._from_pickle_wkbcCs|��|jfSrO)rR�sridr@r8r8r9�__getstate__aszGEOSGeometryBase.__getstate__cCs6|\}}|�|�}|std��||_|��||_dS)Nz+Invalid Geometry loaded from pickled state.)rUrr6r4rW)r5�staterQrWr6r8r8r9�__setstate__fs

zGEOSGeometryBase.__setstate__cCst��|�SrO)rrS)r7rQr8r8r9�	_from_wkbp�zGEOSGeometryBase._from_wkbcCstt|�}d}|�dd�}t|�dkr)|\}}t�d|�}|s"td��t|d�}n|}|s1td��tt�|�|d�S)	N�;rr$sSRID=(?P<srid>\-?\d+)zEWKT has invalid SRID part.rWz%Expected WKT but got an empty string.�rW)	r�split�len�re�match�
ValueError�intr,�	_from_wkt)rJrW�parts�	srid_part�wktrbr8r8r9�	from_ewkttszGEOSGeometryBase.from_ewktcCst��|�SrO)rrS)rhr8r8r9re�r\zGEOSGeometryBase._from_wktcCstj�|�jSrO)r�OGRGeometry�from_gml�geos)r7�
gml_stringr8r8r9rk��zGEOSGeometryBase.from_gmlc	CsRt|t�rzt�|�}WnttfyYdSwt|t�o(|j|jko(|�|�S)zz
        Equivalence testing, a Geometry may be compared with another Geometry
        or an EWKT representation.
        F)�
isinstance�strr,rircrrW�equals_exact�r5�otherr8r8r9�__eq__�s
� zGEOSGeometryBase.__eq__cCst|j|jf�SrO)�hashrWrhr@r8r8r9�__hash__�rVzGEOSGeometryBase.__hash__cC�
|�|�S)z0Return the union of this Geometry and the other.)�unionrrr8r8r9�__or__��
zGEOSGeometryBase.__or__cCrw)z7Return the intersection of this Geometry and the other.)�intersectionrrr8r8r9�__and__�rzzGEOSGeometryBase.__and__cCrw)z2Return the difference this Geometry and the other.)�
differencerrr8r8r9�__sub__�rzzGEOSGeometryBase.__sub__cCrw)z?Return the symmetric difference of this Geometry and the other.)�sym_differencerrr8r8r9�__xor__�rzzGEOSGeometryBase.__xor__cCs|jr|j��SdS)z<Return a clone of the coordinate sequence for this Geometry.N)r;r?rCr@r8r8r9�	coord_seq�s
�zGEOSGeometryBase.coord_seqcC�t�|j���S)z>Return a string representing the Geometry type, e.g. 'Polygon')r<�	geos_typer6�decoder@r8r8r9rL�szGEOSGeometryBase.geom_typecC�t�|j�S)z1Return an integer representing the Geometry type.)r<�geos_typeidr6r@r8r8r9r2��zGEOSGeometryBase.geom_typeidcCr�)z0Return the number of geometries in the Geometry.)r<�
get_num_geomsr6r@r8r8r9�num_geom�r�zGEOSGeometryBase.num_geomcCr�)z1Return the number of coordinates in the Geometry.)r<�get_num_coordsr6r@r8r8r9�
num_coords�r�zGEOSGeometryBase.num_coordscCrI)z:Return the number points, or coordinates, in the Geometry.)r�r@r8r8r9�
num_points��zGEOSGeometryBase.num_pointscCr�)zCReturn the dimension of this Geometry (0=point, 1=line, 2=surface).)r<�get_dimsr6r@r8r8r9�dims�r�zGEOSGeometryBase.dimscCst�|j�dS)z9Convert this Geometry to normal form (or canonical form).N)r<�geos_normalizer6r@r8r8r9�	normalize��zGEOSGeometryBase.normalizecCr�)zk
        Return a boolean indicating whether the set of points in this Geometry
        are empty.
        )r<�geos_isemptyr6r@r8r8r9�empty�szGEOSGeometryBase.emptycCr�)z/Return whether the geometry has a 3D dimension.)r<�	geos_haszr6r@r8r8r9r>�r�zGEOSGeometryBase.haszcCr�)z-Return whether or not the geometry is a ring.)r<�geos_isringr6r@r8r8r9�ring�r�zGEOSGeometryBase.ringcCr�)z*Return false if the Geometry isn't simple.)r<�
geos_issimpler6r@r8r8r9�simple�r�zGEOSGeometryBase.simplecCr�)z#Test the validity of this Geometry.)r<�geos_isvalidr6r@r8r8r9�valid�r�zGEOSGeometryBase.validcCr�)zK
        Return a string containing the reason for any invalidity.
        )r<�geos_isvalidreasonr6r�r@r8r8r9�valid_reason��zGEOSGeometryBase.valid_reasoncC�t�|j|j�S)z/Return true if other.within(this) returns true.)r<�
geos_containsr6rrr8r8r9�containsr�zGEOSGeometryBase.containscCr�)z�
        Return True if the DE-9IM Intersection Matrix for the two geometries is
        T*****FF*, *T****FF*, ***T**FF*, or ****T*FF*. If either geometry is
        empty, return False.
        )r<�geos_coversr6rrr8r8r9�covers�zGEOSGeometryBase.coverscCr�)z�
        Return true if the DE-9IM intersection matrix for the two Geometries
        is T*T****** (for a point and a curve,a point and an area or a line and
        an area) 0******** (for two curves).
        )r<�geos_crossesr6rrr8r8r9�crossesr�zGEOSGeometryBase.crossescCr�)zl
        Return true if the DE-9IM intersection matrix for the two Geometries
        is FF*FF****.
        )r<�
geos_disjointr6rrr8r8r9�disjointr�zGEOSGeometryBase.disjointcCr�)zl
        Return true if the DE-9IM intersection matrix for the two Geometries
        is T*F**FFF*.
        )r<�geos_equalsr6rrr8r8r9�equalsr�zGEOSGeometryBase.equalsrcCst�|j|jt|��S)zk
        Return true if the two Geometries are exactly equal, up to a
        specified tolerance.
        )r<�geos_equalsexactr6�float)r5rs�	tolerancer8r8r9rq%�zGEOSGeometryBase.equals_exactcCr�)z%Return true if disjoint return false.)r<�geos_intersectsr6rrr8r8r9�
intersects,r�zGEOSGeometryBase.intersectscCr�)z�
        Return true if the DE-9IM intersection matrix for the two Geometries
        is T*T***T** (for two points or two surfaces) 1*T***T** (for two curves).
        )r<�
geos_overlapsr6rrr8r8r9�overlaps0r�zGEOSGeometryBase.overlapscCs4t|t�rt|�dkrtd��t�|j|jt|��S)z�
        Return true if the elements in the DE-9IM intersection matrix for the
        two Geometries match the elements in pattern.
        �	z#invalid intersection matrix pattern)rorpr`rr<�geos_relatepatternr6r)r5rs�patternr8r8r9�relate_pattern7szGEOSGeometryBase.relate_patterncCr�)z�
        Return true if the DE-9IM intersection matrix for the two Geometries
        is FT*******, F**T***** or F***T****.
        )r<�geos_touchesr6rrr8r8r9�touches@r�zGEOSGeometryBase.touchescCr�)zl
        Return true if the DE-9IM intersection matrix for the two Geometries
        is T*F**F***.
        )r<�geos_withinr6rrr8r8r9�withinGr�zGEOSGeometryBase.withincCst�|j�}|dkrdS|S)z=Get the SRID for the geometry. Return None if no SRID is set.rN)r<�
geos_get_sridr6)r5�sr8r8r9rWOszGEOSGeometryBase.sridcCs$t�|j|dur
d�dS|�dS)zSet the SRID for the geometry.Nr)r<�
geos_set_sridr6�r5rWr8r8r9rWXs$cCs|j}|rd||jfS|jS)z?
        Return the EWKT (SRID + WKT) of the Geometry.
        z
SRID=%s;%s)rWrhr�r8r8r9rJ^szGEOSGeometryBase.ewktcCs t|jrdnddd��|���S)zAReturn the WKT (Well-Known Text) representation of this Geometry.r%r$T)�dim�trim)rr>�writer�r@r8r8r9rhfs zGEOSGeometryBase.wktcC�t|jrdndd��|�S)z�
        Return the WKB of this Geometry in hexadecimal form. Please note
        that the SRID is not included in this representation because it is not
        a part of the OGC specification (use the `hexewkb` property instead).
        r%r$�r�)rr>�	write_hexr@r8r8r9rMks	zGEOSGeometryBase.hexcCr�)z�
        Return the EWKB of this Geometry in hexadecimal form. This is an
        extension of the WKB specification that includes SRID value that are
        a part of this geometry.
        r%r$r�)rr>r�r@r8r8r9�hexewkbvszGEOSGeometryBase.hexewkbcCs|jjS)zA
        Return GeoJSON representation of this Geometry.
        )�ogr�jsonr@r8r8r9r�rEzGEOSGeometryBase.jsoncC�t|jrdnd��|�S)z�
        Return the WKB (Well-Known Binary) representation of this Geometry
        as a Python buffer.  SRID and Z values are not included, use the
        `ewkb` property instead.
        r%r$)rr>r�r@r8r8r9rQ��zGEOSGeometryBase.wkbcCr�)z�
        Return the EWKB representation of this Geometry as a Python buffer.
        This is an extension of the WKB specification that includes any SRID
        value that are a part of this geometry.
        r%r$)rr>r�r@r8r8r9�ewkb�r�zGEOSGeometryBase.ewkbcCs|j}d||jj|fS)z/Return the KML representation of this Geometry.z<%s>%s</%s>)rLr��kml)r5�gtyper8r8r9r��szGEOSGeometryBase.kmlcCst|�S)z�
        Return a PreparedGeometry corresponding to this geometry -- it is
        optimized for the contains, intersects, and covers operations.
        rr@r8r8r9�prepared�rHzGEOSGeometryBase.preparedcCstj�|j�SrO)rrjr[rQr@r8r8r9�_ogr_ptr�szGEOSGeometryBase._ogr_ptrcCst�|��|j�S)z*Return the OGR Geometry for this Geometry.)rrjr��srsr@r8r8r9r���zGEOSGeometryBase.ogrc	Cs6|jrzt�|j�WStjtjfyYdSwdS)z:Return the OSR SpatialReference for SRID of this Geometry.N)rWr�SpatialReference�
GDALException�SRSExceptionr@r8r8r9r��s�zGEOSGeometryBase.srscCrI)zAlias for `srs` property.)r�r@r8r8r9�crs�r�zGEOSGeometryBase.crscCs�|j}||kr|r
|��SdSt|tj�rd}n|dus |dkr$td��t�|��|�}|�|�|�	�}|r>t
||jd�S|rSt�|j
�||_
|��|j|_dStd��)ad
        Requires GDAL. Transform the geometry according to the given
        transformation object, which may be an integer SRID, and WKT or
        PROJ string. By default, transform the geometry in-place and return
        nothing. However if the `clone` keyword is set, don't modify the
        geometry and return a transformed clone instead.
        Nrz5Calling transform() with no SRID set is not supportedr^zTransformed WKB was invalid.)rWrCror�CoordTransformrrjr��	transform�	_geos_ptrr,r<�destroy_geomr6r4)r5�ctrCrW�gr6r8r8r9r��s(
zGEOSGeometryBase.transformcCst||jd�S)z'Return Geometry from the given pointer.r^)r,rW)r5�gptrr8r8r9�	_topology�rnzGEOSGeometryBase._topologycC�|�t�|j��S)z9Return the boundary as a newly allocated Geometry object.)r�r<�
geos_boundaryr6r@r8r8r9�boundary�r�zGEOSGeometryBase.boundary�cCs|�t�|j||��S)a�
        Return a geometry that represents all points whose distance from this
        Geometry is less than or equal to distance. Calculations are in the
        Spatial Reference System of this Geometry. The optional third parameter sets
        the number of segment used to approximate a quarter circle (defaults to 8).
        (Text from PostGIS documentation at ch. 6.1.3)
        )r�r<�geos_bufferr6)r5�width�quadsegsr8r8r9�buffer�szGEOSGeometryBase.bufferr�@c
Cs|�t�|j|||||��S)a

        Same as buffer() but allows customizing the style of the buffer.

        End cap style can be round (1), flat (2), or square (3).
        Join style can be round (1), mitre (2), or bevel (3).
        Mitre ratio limit only affects mitered join style.
        )r�r<�geos_bufferwithstyler6)r5r�r��
end_cap_style�
join_style�mitre_limitr8r8r9�buffer_with_style�s�z"GEOSGeometryBase.buffer_with_stylecCr�)z�
        The centroid is equal to the centroid of the set of component Geometries
        of highest dimension (since the lower-dimension geometries contribute zero
        "weight" to the centroid).
        )r�r<�
geos_centroidr6r@r8r8r9�centroid	szGEOSGeometryBase.centroidcCr�)zj
        Return the smallest convex Polygon that contains all the points
        in the Geometry.
        )r�r<�geos_convexhullr6r@r8r8r9�convex_hullszGEOSGeometryBase.convex_hullcC�|�t�|j|j��S)zv
        Return a Geometry representing the points making up this Geometry
        that do not make up other.
        )r�r<�geos_differencer6rrr8r8r9r}r�zGEOSGeometryBase.differencecCr�)z2Return the envelope for this geometry (a polygon).)r�r<�
geos_enveloper6r@r8r8r9�envelope!r�zGEOSGeometryBase.envelopecCr�)zLReturn a Geometry representing the points shared by this Geometry and other.)r�r<�geos_intersectionr6rrr8r8r9r{&�zGEOSGeometryBase.intersectioncCr�)z+Compute an interior point of this Geometry.)r�r<�geos_pointonsurfacer6r@r8r8r9�point_on_surface*r�z!GEOSGeometryBase.point_on_surfacecCst�|j|j���S)zFReturn the DE-9IM intersection matrix for this Geometry and the other.)r<�geos_relater6r�rrr8r8r9�relate/szGEOSGeometryBase.relate�cCs,|r|�t�|j|��S|�t�|j|��S)a"
        Return the Geometry, simplified using the Douglas-Peucker algorithm
        to the specified tolerance (higher tolerance => less points).  If no
        tolerance provided, defaults to 0.

        By default, don't preserve topology - e.g. polygons can be split,
        collapse to lines or disappear holes can be created or disappear, and
        lines can cross. By specifying preserve_topology=True, the result will
        have the same dimension and number of components as the input. This is
        significantly slower.
        )r�r<�geos_preservesimplifyr6�
geos_simplify)r5r��preserve_topologyr8r8r9�simplify3szGEOSGeometryBase.simplifycCr�)z�
        Return a set combining the points in this Geometry not in other,
        and the points in other not in this Geometry.
        )r�r<�geos_symdifferencer6rrr8r8r9rDr�zGEOSGeometryBase.sym_differencecCr�)z6Return the union of all the elements of this geometry.)r�r<�geos_unary_unionr6r@r8r8r9�unary_unionKr�zGEOSGeometryBase.unary_unioncCr�)zIReturn a Geometry representing all the points in this Geometry and other.)r�r<�
geos_unionr6rrr8r8r9rxPr�zGEOSGeometryBase.unioncC�t�|jtt���S)z Return the area of the Geometry.)r<�	geos_arear6rrr@r8r8r9�areaUszGEOSGeometryBase.areacCs*t|t�s	td��t�|j|jtt���S)z�
        Return the distance between the closest points on this Geometry
        and the other. Units will be in those of the coordinate system of
        the Geometry.
        z/distance() works only on other GEOS Geometries.)ror,�	TypeErrorr<�
geos_distancer6rrrrr8r8r9�distanceZs
zGEOSGeometryBase.distancecCs^ddlm}|j}t||�r|j\}}||}}n|dd\}}|dd\}}||||fS)zr
        Return the extent of this geometry as a 4-tuple, consisting of
        (xmin, ymin, xmax, ymax).
        rr!rr$)r0r"r�ro�tuple)r5r"�env�xmin�ymin�xmax�ymaxr8r8r9�extentds

zGEOSGeometryBase.extentcCr)zt
        Return the length of this Geometry (e.g., 0 for point, or the
        circumference of a Polygon).
        )r<�geos_lengthr6rrr@r8r8r9�lengthtszGEOSGeometryBase.lengthcCstt�|j��S)zClone this Geometry.)r,r<�
geom_cloner6r@r8r8r9rC|r�zGEOSGeometryBase.clone)r)F)r�)r�rrr�)r�F)_�__name__�
__module__�__qualname__r-r
�ptr_typer<r��
destructorr;r:r4rDrGrKrNrRrUrXrZ�classmethodr[�staticmethodrirerkrtrvryr|r~r��propertyr�rLr2r�r�r�r�r�r�r>r�r�r�r�r�r�r�r�r�rqr�r�r�r�r�rW�setterrJrhrMr�r��geojsonrQr�r�r�r�r�r�r�r�r�r�r�r�r�r�r}r�r{r�r�r�rrrxrrrrrCr8r8r8r9rs�


















	













	

+













rc@sHeZdZdZdd�Zdd�Zdd�Zdd	�Zed
d��Z	edd
��Z
dS)�LinearGeometryMixinz2
    Used for LineString and MultiLineString.
    cC�|�t�|j|��SrO)r�r<�geos_interpolater6�r5rr8r8r9�interpolate��zLinearGeometryMixin.interpolatecCrrO)r�r<�geos_interpolate_normalizedr6rr8r8r9�interpolate_normalized�r!z*LinearGeometryMixin.interpolate_normalizedcC�.ddlm}t||�std��t�|j|j�S�Nrr!z%locate_point argument must be a Point)r0r"rorr<�geos_projectr6�r5r0r"r8r8r9�project��
zLinearGeometryMixin.projectcCr$r%)r0r"rorr<�geos_project_normalizedr6r'r8r8r9�project_normalized�r)z&LinearGeometryMixin.project_normalizedcCr�)z9
        Return the line merge of this Geometry.
        )r�r<�geos_linemerger6r@r8r8r9�merged�szLinearGeometryMixin.mergedcCr�)z@
        Return whether or not this Geometry is closed.
        )r<�
geos_isclosedr6r@r8r8r9�closed�szLinearGeometryMixin.closedN)rrr�__doc__r r#r(r+rr-r/r8r8r8r9r�s
rcs"eZdZdZd�fdd�	Z�ZS)r,z6A class that, generally, encapsulates a GEOS geometry.Ncs`d}t|t�rt|�}t|t�rPt�|�}|r+|dr!t|d�}|�t|d��}nMt	�|�r9t
��t|��}n?t�|�rLt
j�|�}|��}|j}n,td��t|t�rX|}n t|t�rdt
��|�}nt|t�rpt�|j�}ntdt|���|s~td��|p�t�|�p�d}|r�|r�||kr�td|��t��|d�|p�|}|r�t|t�r�||_dSdSdS)a�
        The base constructor for GEOS geometry objects. It may take the
        following inputs:

         * strings:
            - WKT
            - HEXEWKB (a PostGIS-specific canonical form)
            - GeoJSON (requires GDAL)
         * buffer:
            - WKB

        The `srid` keyword specifies the Source Reference Identifier (SRID)
        number for this Geometry. If not provided, it defaults to None.
        NrWrhz3String input unrecognized as WKT EWKT, and HEXEWKB.z Improper geometry input type: %sz4Could not initialize GEOS Geometry with given input.z$Input geometry already has SRID: %d.)rorPrrprrbrdrerrrrSrrrj�	from_jsonr�rWrcr
rTr,r<rr6rr+rr��superr:)r5�	geo_inputrW�
input_srid�wkt_mr�r��r3r8r9r:�sB








�zGEOSGeometry.__init__rO)rrrr0r:�
__classcell__r8r8r6r9r,�sr,))r0ra�ctypesrrr�django.contrib.gisr�django.contrib.gis.geometryrrr�django.contrib.gis.geosr	r<�django.contrib.gis.geos.baser
� django.contrib.gis.geos.coordseqr�django.contrib.gis.geos.errorr�django.contrib.gis.geos.libgeosr
�$django.contrib.gis.geos.mutable_listr� django.contrib.gis.geos.preparedr�%django.contrib.gis.geos.prototypes.iorrrrr�django.utils.deconstructr�django.utils.encodingrrrrr,r8r8r8r9�<module>s.m%