o
    Fhi%                     @   sn   d Z ddlZG dd dZdd Zdd Zd	d
 Zdd Zdd Zdd Z	dd Z
dd Zdd Zdd ZdS )a  
Functions to interact with Arrow memory allocated by Arrow Java.

These functions convert the objects holding the metadata, the actual
data is not copied at all.

This will only work with a JVM running in the same process such as provided
through jpype. Modules that talk to a remote JVM like py4j will not work as the
memory addresses reported by them are not reachable in the python process.
    Nc                   @   s$   e Zd ZdZdZdd Zdd ZdS )_JvmBufferNannyz`
    An object that keeps a org.apache.arrow.memory.ArrowBuf's underlying
    memory alive.
    Nc                 C   s   |  }|  || _d S N)getReferenceManagerretainref_manager)selfjvm_bufr    r	   L/var/www/html/Persson_Maskin/env/lib/python3.10/site-packages/pyarrow/jvm.py__init__&   s   
z_JvmBufferNanny.__init__c                 C   s   | j d ur| j   d S d S r   )r   release)r   r	   r	   r
   __del__.   s   
z_JvmBufferNanny.__del__)__name__
__module____qualname____doc__r   r   r   r	   r	   r	   r
   r      s
    r   c                 C   s(   t | }|  }|  }tj|||dS )a)  
    Construct an Arrow buffer from org.apache.arrow.memory.ArrowBuf

    Parameters
    ----------

    jvm_buf: org.apache.arrow.memory.ArrowBuf
        Arrow Buffer representation on the JVM.

    Returns
    -------
    pyarrow.Buffer
        Python Buffer that references the JVM memory.
    )base)r   memoryAddresscapacitypaforeign_buffer)r   nannyaddresssizer	   r	   r
   
jvm_buffer3   s   r   c                 C   s   |   }|  r*|dkrt S |dkrt S |dkr t S |dkr(t S dS |dkr2t S |dkr:t S |dkrBt	 S |dkrJt
 S dS )z
    Convert a JVM int type to its Python equivalent.

    Parameters
    ----------
    jvm_type : org.apache.arrow.vector.types.pojo.ArrowType$Int

    Returns
    -------
    typ : pyarrow.DataType
              @   N)getBitWidthgetIsSignedr   int8int16int32int64uint8uint16uint32uint64)jvm_type	bit_widthr	   r	   r
   _from_jvm_int_typeH   s(   r+   c                 C   s@   |    }|dkrt S |dkrt S |dkrt S dS )z
    Convert a JVM float type to its Python equivalent.

    Parameters
    ----------
    jvm_type: org.apache.arrow.vector.types.pojo.ArrowType$FloatingPoint

    Returns
    -------
    typ: pyarrow.DataType
    HALFSINGLEDOUBLEN)getPrecisiontoStringr   float16float32float64)r)   	precisionr	   r	   r
   _from_jvm_float_typej   s   r5   c                 C   s   |    }|dkr|  dksJ tdS |dkr(|  dks#J tdS |dkr9|  dks4J tdS |d	krJ|  dksEJ td
S dS )z
    Convert a JVM time type to its Python equivalent.

    Parameters
    ----------
    jvm_type: org.apache.arrow.vector.types.pojo.ArrowType$Time

    Returns
    -------
    typ: pyarrow.DataType
    SECONDr   sMILLISECONDmsMICROSECONDr   us
NANOSECONDnsN)getUnitr0   r   r   time32time64)r)   	time_unitr	   r	   r
   _from_jvm_time_type   s   



rB   c                 C   s   |    }|  }|durt|}|dkrtjd|dS |dkr(tjd|dS |dkr3tjd|dS |d	kr>tjd
|dS dS )z
    Convert a JVM timestamp type to its Python equivalent.

    Parameters
    ----------
    jvm_type: org.apache.arrow.vector.types.pojo.ArrowType$Timestamp

    Returns
    -------
    typ: pyarrow.DataType
    Nr6   r7   )tzr8   r9   r:   r;   r<   r=   )r>   r0   getTimezonestrr   	timestamp)r)   rA   timezoner	   r	   r
   _from_jvm_timestamp_type   s   rH   c                 C   s0   |    }|dkrt S |dkrt S dS )z
    Convert a JVM date type to its Python equivalent

    Parameters
    ----------
    jvm_type: org.apache.arrow.vector.types.pojo.ArrowType$Date

    Returns
    -------
    typ: pyarrow.DataType
    DAYr8   N)r>   r0   r   date32date64)r)   day_unitr	   r	   r
   _from_jvm_date_type   s   rM   c                 C   sZ  t |  }|  }d}| s|  }|dkrt }nn|dkr(t|}ne|dkr1t	|}n\|dkr:t
 }nS|dkrCt }nJ|dkrOt| }n>|dkrXt }n5|d	krat|}n,|d
krjt|}n#|dkrst|}n|dkrt| | }ntd| td|  }|  }| rd}n	dd | D }t||||S )z
    Construct a Field from a org.apache.arrow.vector.types.pojo.Field
    instance.

    Parameters
    ----------
    jvm_field: org.apache.arrow.vector.types.pojo.Field

    Returns
    -------
    pyarrow.Field
    NNullIntFloatingPointUtf8BinaryFixedSizeBinaryBoolTime	TimestampDateDecimalzUnsupported JVM type: z:JVM field conversion only implemented for primitive types.c                 S   "   i | ]}t | t | qS r	   rE   getKeygetValue.0entryr	   r	   r
   
<dictcomp>       zfield.<locals>.<dictcomp>)rE   getNamegetType	isComplex	getTypeIDr0   r   nullr+   r5   stringbinarygetByteWidthbool_rB   rH   rM   
decimal128r/   getScaleNotImplementedError
isNullablegetMetadataisEmptyentrySetfield)	jvm_fieldnamer)   typtype_strnullablejvm_metadatametadatar	   r	   r
   rr      sR   








rr   c                 C   sJ   |   }dd |D }|  }| rd}n	dd | D }t||S )z
    Construct a Schema from a org.apache.arrow.vector.types.pojo.Schema
    instance.

    Parameters
    ----------
    jvm_schema: org.apache.arrow.vector.types.pojo.Schema

    Returns
    -------
    pyarrow.Schema
    c                 S      g | ]}t |qS r	   )rr   )r^   fr	   r	   r
   
<listcomp>  s    zschema.<locals>.<listcomp>Nc                 S   rY   r	   rZ   r]   r	   r	   r
   r`     ra   zschema.<locals>.<dictcomp>)	getFieldsgetCustomMetadatarp   rq   r   schema)
jvm_schemafieldsrx   ry   r	   r	   r
   r     s   r   c                 C   s   |     r|   }td| dt|   j}dd t| 	dD }t
|dkr6tjg |dS |  }|  }tj||||S )z
    Construct an (Python) Array from its JVM equivalent.

    Parameters
    ----------
    jvm_array : org.apache.arrow.vector.ValueVector

    Returns
    -------
    array : Array
    z'Cannot convert JVM Arrow array of type z$, complex types not yet implemented.c                 S   rz   r	   )r   )r^   bufr	   r	   r
   r|   -  s    zarray.<locals>.<listcomp>Fr   )type)getFieldrc   rd   getMinorTyper0   rm   rr   r   list
getBufferslenr   arraygetValueCountgetNullCountArrayfrom_buffers)	jvm_arrayminor_type_strdtypebufferslength
null_countr	   r	   r
   r     s   
r   c                 C   sF   t |  }g }|jD ]}|t| | qtjj||j|j	dS )z
    Construct a (Python) RecordBatch from a JVM VectorSchemaRoot

    Parameters
    ----------
    jvm_vector_schema_root : org.apache.arrow.vector.VectorSchemaRoot

    Returns
    -------
    record_batch: pyarrow.RecordBatch
    )ry   )
r   	getSchemanamesappendr   	getVectorr   RecordBatchfrom_arraysry   )jvm_vector_schema_root	pa_schemaarraysrt   r	   r	   r
   record_batch9  s   
r   )r   pyarrowr   r   r   r+   r5   rB   rH   rM   rr   r   r   r   r	   r	   r	   r
   <module>   s   "<