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__/coordseq.cpython-310.pyc
o

�a@�@spdZddlmZmZmZmZddlmZddl	m
Z
ddlmZddl
mZmZddlmZGdd	�d	e
�Zd
S)z�
 This module houses the GEOSCoordSeq object, which is used internally
 by GEOSGeometry to house the actual coordinates of the Point,
 LineString, and LinearRing geometries.
�)�byref�c_byte�c_double�c_uint)�
prototypes)�GEOSBase��
GEOSException)�CS_PTR�geos_version_tuple)�numpyc@sBeZdZdZeZdHdd�Zdd�Zdd�Zd	d
�Z	dd�Z
d
d�Zdd�Zdd�Z
dd�Zdd�Zdd�Zdd�Zdd�Zdd�Zedd ��Zd!d"�Zd#d$�Zd%d&�Zd'd(�Zd)d*�Zd+d,�Zd-d.�Zd/d0�Zd1d2�Zd3d4�Zd5d6�Z d7d8�Z!ed9d:��Z"ed;d<��Z#ed=d>��Z$d?d@�Z%edAdB��Z&edCdD��Z'edEdF��Z(dGS)I�GEOSCoordSeqzGThe internal representation of a list of coordinates inside a Geometry.FcCs"t|t�s	td��||_||_dS)zInitialize from a GEOS pointer.z4Coordinate sequence should initialize with a CS_PTR.N)�
isinstancer
�	TypeError�_ptr�_z)�self�ptr�z�r�B/usr/lib/python3/dist-packages/django/contrib/gis/geos/coordseq.py�__init__s

zGEOSCoordSeq.__init__ccs �t|j�D]}||VqdS)z3Iterate over each point in the coordinate sequence.N)�range�size)r�irrr�__iter__s��zGEOSCoordSeq.__iter__cC�|jS)z7Return the number of points in the coordinate sequence.)r�rrrr�__len__ szGEOSCoordSeq.__len__cCs
t|j�S)z<Return the string representation of the coordinate sequence.)�str�tuplerrrr�__str__$s
zGEOSCoordSeq.__str__cCs|�|�|�|�S)z8Return the coordinate sequence value at the given index.)�_checkindex�
_point_getter�r�indexrrr�__getitem__(s

zGEOSCoordSeq.__getitem__cCs|t|ttf�rn
trt|tj�rntd��|jdkr#|jr#d}|j}nd}|j	}t
|�|kr2td��|�|�|||�dS)z5Set the coordinate sequence value at the given index.zBMust set coordinate with a sequence (list, tuple, or numpy array).��z"Dimension of value does not match.N)r�listr r�ndarrayr�dimsr�
_set_point_3d�
_set_point_2d�lenr")rr%�value�n_args�point_setterrrr�__setitem__-s
zGEOSCoordSeq.__setitem__cCs(d|kr|jksntd|��dS)zCheck the given index.rzinvalid GEOS Geometry index: %sN)r�
IndexErrorr$rrrr"Cs�zGEOSCoordSeq._checkindexcCs |dks|dkrtd|��dS)zCheck the given dimension.rr(zinvalid ordinate dimension "%d"Nr)r�dimrrr�	_checkdimHs�zGEOSCoordSeq._checkdimcC�t�|j|tt���S�N)�capi�cs_getxrrrr$rrr�_get_xM�zGEOSCoordSeq._get_xcCr6r7)r8�cs_getyrrrr$rrr�_get_yPr;zGEOSCoordSeq._get_ycCr6r7)r8�cs_getzrrrr$rrr�_get_zSr;zGEOSCoordSeq._get_zcC�t�|j||�dSr7)r8�cs_setxr�rr%r/rrr�_set_xV�zGEOSCoordSeq._set_xcCr@r7)r8�cs_setyrrBrrr�_set_yYrDzGEOSCoordSeq._set_ycCr@r7)r8�cs_setzrrBrrr�_set_z\rDzGEOSCoordSeq._set_zcCs|jdkr|jr|jS|jS)Nr')r+r�
_get_point_3d�
_get_point_2drrrrr#_szGEOSCoordSeq._point_gettercCs|�|�|�|�fSr7)r:r=r$rrrrJcrDzGEOSCoordSeq._get_point_2dcCs|�|�|�|�|�|�fSr7)r:r=r?r$rrrrIfszGEOSCoordSeq._get_point_3dcCs$|\}}|�||�|�||�dSr7)rCrF)rr%r/�x�yrrrr-iszGEOSCoordSeq._set_point_2dcCs2|\}}}|�||�|�||�|�||�dSr7)rCrFrH)rr%r/rKrLrrrrr,ns
zGEOSCoordSeq._set_point_3dcCs,|�|�|�|�t�|j||tt���S)z3Return the value for the given dimension and index.)r"r5r8�cs_getordinaterrr)r�	dimensionr%rrr�getOrdinateus

zGEOSCoordSeq.getOrdinatecCs*|�|�|�|�t�|j|||�dS)z0Set the value for the given dimension and index.N)r"r5r8�cs_setordinater)rrNr%r/rrr�setOrdinate{s

zGEOSCoordSeq.setOrdinatecC�|�d|�S)zGet the X value at the index.r�rOr$rrr�getX��zGEOSCoordSeq.getXcC�|�d||�dS)z(Set X with the value at the given index.rN�rQrBrrr�setX��zGEOSCoordSeq.setXcCrR)z#Get the Y value at the given index.�rSr$rrr�getY�rUzGEOSCoordSeq.getYcCrV)z(Set Y with the value at the given index.rZNrWrBrrr�setY�rYzGEOSCoordSeq.setYcCrR)z(Get Z with the value at the given index.r(rSr$rrr�getZ�rUzGEOSCoordSeq.getZcCrV)z(Set Z with the value at the given index.r(NrWrBrrr�setZ�rYzGEOSCoordSeq.setZcC�t�|jtt���S)z,Return the size of this coordinate sequence.)r8�
cs_getsizerrrrrrrr��zGEOSCoordSeq.sizecCr_)z2Return the dimensions of this coordinate sequence.)r8�
cs_getdimsrrrrrrrr+�razGEOSCoordSeq.dimscCr)z�
        Return whether this coordinate sequence is 3D. This property value is
        inherited from the parent Geometry.
        )rrrrr�hasz�szGEOSCoordSeq.haszcCstt�|j�|j�S)zClone this coordinate sequence.)r
r8�cs_clonerrcrrrr�clone�szGEOSCoordSeq.clonecs:�jrd�nd�dd���fdd�tt���D����S)z2Return the KML representation for the coordinates.z	%s,%s,%s z%s,%s,0 z<coordinates>%s</coordinates>�c3s�|]	}��|VqdSr7r��.0r�r�substrrr�	<genexpr>�s�z#GEOSCoordSeq.kml.<locals>.<genexpr>)rc�joinrr.�striprrrir�kml�s$�zGEOSCoordSeq.kmlcs6|j}|j�|dkr�d�St�fdd�t|�D��S)z3Return a tuple version of this coordinate sequence.rZrc3s�|]}�|�VqdSr7rrg��	get_pointrrrk�s�z%GEOSCoordSeq.tuple.<locals>.<genexpr>)rr#r r)r�nrrorr �s
zGEOSCoordSeq.tuplecCs�t�dkr8d}t|�}t|�D]$}|d|}|||d||d7}|||d||d8}q|dkSt�}t�|jt|��sLtdtjj	��|j
dkS)z<Return whether this coordinate sequence is counterclockwise.)r'�grZrz*Error encountered in GEOS C function "%s".)rr.rrr8�	cs_is_ccwrrr	�	func_namer/)r�arearqr�j�retrrr�is_counterclockwise�s

�
z GEOSCoordSeq.is_counterclockwiseN)F))�__name__�
__module__�__qualname__�__doc__r
�ptr_typerrrr!r&r2r"r5r:r=r?rCrFrH�propertyr#rJrIr-r,rOrQrTrXr[r\r]r^rr+rcrernr rxrrrrr
sX






r
N)r|�ctypesrrrr�django.contrib.gis.geosrr8�django.contrib.gis.geos.baser�django.contrib.gis.geos.errorr	�django.contrib.gis.geos.libgeosr
r�django.contrib.gis.shortcutsrr
rrrr�<module>s