a  zeG@sdZddgZddlmZddlZddlZddlZddlZddlZddl Z ej dkr`ddl Z dZ n ddl Z dZ ejejBZd Ze rd Znd Zd d ZGdddZdZGdddZdS)zProvides shared memory for direct access across processes. The API of this package is currently provisional. Refer to the documentation for details. SharedMemory ShareableList)partialNntFTz/psm_Zwnsm_cCs"tttd}tt|}|S)z6Create a random filename for the shared memory object.)_SHM_SAFE_NAME_LENGTHlen_SHM_NAME_PREFIXsecretsZ token_hex)nbytesnamerQ/opt/bitninja-python-dojo/embedded/lib/python3.9/multiprocessing/shared_memory.py_make_filename'src@seZdZdZdZdZdZdZej Z dZ e r.dndZ ddd Zd d Zd d ZddZeddZeddZeddZddZddZdS)raCreates a new shared memory block or attaches to an existing shared memory block. Every shared memory block is assigned a unique name. This enables one process to create a shared memory block with a particular name so that a different process can attach to that same shared memory block using that same name. As a resource for sharing data across processes, shared memory blocks may outlive the original process that created them. When one process no longer needs access to a shared memory block that might still be needed by other processes, the close() method should be called. When a shared memory block is no longer needed by any process, the unlink() method should be called to ensure proper cleanup.NiTFrc Cs|dkstd|r0ttjB|_|dkr0td|durL|jtj@sLtdtrD|durt}ztj ||j|j d|_ Wnt yYqZYn0||_ qqZn.|jrd|n|}tj ||j|j d|_ ||_ z<|r|rt|j |t|j }|j}t|j ||_Wnty&|Yn0ddlm}||j d n*|r |durZtn|}ttjtjtj|d ?d @|d @|}zjt}|tjkr|durt tj t!tj |tjnWt"|qJtjd ||d |_Wt"|n t"|0||_ qnqJnb||_ t#tj$d|}z"t%|tj$ddd} Wt"|n t"|0t&| }tjd ||d |_||_'t(|j|_)dS)Nrz!'size' must be a positive integerz4'size' must be a positive number different from zeroz&'name' can only be None if create=True)mode/)register shared_memory lr)ZtagnameF)* ValueError_O_CREXosO_RDWR_flagsO_EXCL _USE_POSIXr _posixshmemZshm_open_mode_fdFileExistsError_name_prepend_leading_slash ftruncatefstatst_sizemmap_mmapOSErrorunlinkresource_trackerr_winapiZCreateFileMappingZINVALID_HANDLE_VALUEZNULLZPAGE_READWRITEZ GetLastErrorZERROR_ALREADY_EXISTSerrnoEEXISTstrerrorZ CloseHandleZOpenFileMappingZ FILE_MAP_READZ MapViewOfFileZVirtualQuerySize_size memoryview_buf) selfr createsizeZstatsrZ temp_nameZh_mapZlast_error_codeZp_bufrrr__init__Js             zSharedMemory.__init__cCs$z |WntyYn0dSN)closer*r4rrr__del__s  zSharedMemory.__del__cCs|j|jd|jffS)NF) __class__r r6r:rrr __reduce__s zSharedMemory.__reduce__cCs|jjd|jd|jdS)N(z, size=))r<__name__r r6r:rrr__repr__szSharedMemory.__repr__cCs|jS)z4A memoryview of contents of the shared memory block.)r3r:rrrbufszSharedMemory.bufcCs.|j}tr*|jr*|jdr*|jdd}|S)z4Unique name that identifies the shared memory block.rrN)r#rr$ startswith)r4Z reported_namerrrr s   zSharedMemory.namecCs|jS)zSize in bytes.)r1r:rrrr6szSharedMemory.sizecCsX|jdur|jd|_|jdur4|jd|_trT|jdkrTt|jd|_dS)zkCloses access to the shared memory from this instance but does not destroy the shared memory block.Nrr)r3releaser)r9rr!rr:rrrr9s     zSharedMemory.closecCs2tr.|jr.ddlm}t|j||jddS)zRequests that the underlying shared memory block be destroyed. In order to ensure proper cleanup of resources, unlink should be called once (and only once) across all processes which have access to the shared memory block.r) unregisterrN)rr#r,rErZ shm_unlink)r4rErrrr+s   zSharedMemory.unlink)NFr)r@ __module__ __qualname____doc__r#r!r)r3rrrr rr$r7r;r=rApropertyrBr r6r9r+rrrrr1s(  l     utf8c @seZdZdZedededededdj diZ dZ d d d d d d d d dZ e ddZd6ddddZddZddZddZddZddZddZd d!Zd"d#Zed$d%Zed&d'Zed(d)Zed*d+Zed,d-Zed.d/Zed0d1Zd2d3Z d4d5Z!e"e#j$Z%dS)7raPattern for a mutable list-like object shareable via a shared memory block. It differs from the built-in list type in that these lists can not change their overall length (i.e. no append, insert, etc.) Because values are packed into a memoryview as bytes, the struct packing format for any storable value must require no more than 8 characters to describe its format.qdzxxxxxxx?z%dsNzxxxxxx?xcCs|Sr8rvaluerrrzShareableList.cCs|dtSN)rstripdecode _encodingrNrrrrPrQcCs |dSrR)rTrNrrrrPrQcCsdSr8r)_valuerrrrPrQ)rrrcCs:t|ttdjfsdSt|tr$dSt|tr2dSdSdS)zUsed in concert with _back_transforms_mapping to convert values into the appropriate Python objects when retrieving them from the list as well as when storing them.NrrrrX) isinstancestrbytesr<rNrrr_extract_recreation_codes  z&ShareableList._extract_recreation_coder cs|dus|dur|pd}fdd|D}t|_d}dg_|D]6}||ddkr\jnt|dd7}j|qDfdd|D}tdjd |j j }t |d |d _ n t |_ |durttjdjj jdjgjRtjd |j jjgfd d |DRtjj j jjgfdd |DRtjj j jjg|Rn$t_ttjj jd_dS)NrcsPg|]H}t|ttfs$jt|n&jt|jt|jdfqS)r)rYrZr[_types_mappingtype _alignmentr .0itemr:rr +s   z*ShareableList.__init__..rrscsg|]}|qSr)r\rar:rrrd=srKT)r5r6c3s&|]}t|tr|n|VqdSr8)rYrZencoderbv_encrr XrQz)ShareableList.__init__..c3s|]}|VqdSr8)rgrhrjrrrl^rQrM)r _list_len_allocated_offsetsr`intappendstructcalcsize_format_size_metainfojoin_format_packing_metainfo_format_back_transform_codesrshmrV pack_intorB_offset_data_start_offset_packing_formats_offset_back_transform_codeslist unpack_from)r4Zsequencer Z_formatsoffsetfmtZ_recreation_codesZrequested_sizer)rkr4rr7(s  &     zShareableList.__init__cCsj|dkr |n||j}||jks*|jdkr2tdtd|jj|j|dd}|d}|t }|S)z>Gets the packing format for a single value stored in the list.r Requested position out of range.8srMrS) rm IndexErrorrqr}rwrBrzrTrUrV)r4positionrir fmt_as_strrrr_get_packing_formatqs   z!ShareableList._get_packing_formatcCsF||jks|jdkrtdtd|jj|j|d}|j|}|S)z9Gets the back transformation function for a single value.rrb)rmrrqr}rwrBr{_back_transforms_mapping)r4rtransform_codeZtransform_functionrrr_get_back_transforms z!ShareableList._get_back_transformcCsh||jks|jdkrtdtd|jj|j|d|t| |}td|jj|j ||dS)zvSets the packing format and back transformation code for a single value in the list at the specified position.rrrrMrN) rmrrqrxrwrBrzrgrVr\r{)r4rrrOrrrr!_set_packing_format_and_transforms  z/ShareableList._set_packing_format_and_transformcCsv|dkr |n||j}z.|j|j|}t|||jj|\}Wnty^tdYn0| |}||}|S)Nrzindex out of range) rmryrnrqr}rrwrBrr)r4rr~riZback_transformrrr __getitem__s   zShareableList.__getitem__c Cs|dkr |n||j}z"|j|}|j|}||}WntyRtdYn0t|ttfsv|jt |}|}n`|j|d|}t|tr| t n|}t ||krt d|ddkr|}n|jt|f}||||t||jj||dS)Nrzassignment index out of rangerz(bytes/str item exceeds available storagerre)rmrnryrrrYrZr[r^r_rgrVr rrrqrxrwrB) r4rrOZ item_offsetr~Zcurrent_formatZ new_formatZ encoded_valueZallocated_lengthrrr __setitem__s8      zShareableList.__setitem__cCst|j|jjddfS)Nr]r)rr<rwr r:rrrr=szShareableList.__reduce__cCstd|jjddS)NrKr)rqr}rwrBr:rrr__len__szShareableList.__len__cCs"|jjdt|d|jjdS)Nr>z, name=r?)r<r@r|rwr r:rrrrAszShareableList.__repr__csdfddtjDS)z=The struct packing format used by all currently stored items.rfc3s|]}|VqdSr8)r)rbir:rrrlsz'ShareableList.format..)rtrangermr:rr:rformatszShareableList.formatcCsd|jdS)z>The struct packing format used for the items' storage offsets.rKrrmr:rrrrssz#ShareableList._format_size_metainfocCs d|jS)z>The struct packing format used for the items' packing formats.rrr:rrrrusz&ShareableList._format_packing_metainfocCs d|jS)z>The struct packing format used for the items' back transforms.rrr:rrrrvsz*ShareableList._format_back_transform_codescCs|jddS)NrrMrr:rrrrysz ShareableList._offset_data_startcCs|j|jdS)Nr)ryrnr:rrrrzsz%ShareableList._offset_packing_formatscCs|j|jdS)NrM)rzrmr:rrrr{sz*ShareableList._offset_back_transform_codescstfdd|DS)zCL.count(value) -> integer -- return number of occurrences of value.c3s|]}|kVqdSr8r)rbentryrNrrrlrQz&ShareableList.count..)sum)r4rOrrNrcountszShareableList.countcCs4t|D]\}}||kr|Sqt|ddS)zpL.index(value) -> integer -- return first index of value. Raises ValueError if the value is not present.z not in this containerN) enumerater)r4rOrrrrrindex s zShareableList.index)N)&r@rFrGrHrofloatboolrZr[r<r^r`r staticmethodr\r7rrrrrr=rrArIrrsrurvryrzr{rr classmethodtypes GenericAlias__class_getitem__rrrrrsT I!        )rH__all__ functoolsrr(rr.rqr rr r-rrO_CREATrrrr rrrVrrrrrs.    E