U \k^K@sjddlZddlZddlZddlZddlZddlZddlZddlZddlm Z ddl m Z m Z m Z mZmZddlmZddlmZmZmZmZmZmZmZddlmZdZejdkrddlZe dd d krdd lm!Z!qd ZdZ!ndZd dddddgZ"e e eefZ#dZ$ddZ%ddZ&Gddde'Z(Gddde(Z)Gddde(Z*e)Z+e*Z,GdddZ-Gd d!d!e-Z.e.Z/d"d#Z0e1ed$re2e0Z0Gd%d&d&Z3Gd'd(d(Z4Gd)d*d*e3Z5Gd+d,d,e3Z6Gd-d.d.e3Z7Gd/d0d0e Z8Gd1d d e'Z9ej:;e9Gd2dde9ZGd5dde>e<Z?Gd6dde>e=Z@dS)7N)Sequence)EINVALENOENTENOTDIREBADFELOOP) attrgetter)S_ISDIRS_ISLNKS_ISREGS_ISSOCKS_ISBLKS_ISCHRS_ISFIFO)quote_from_bytesTnt)r)_getfinalpathnameFPurePath PurePosixPathPureWindowsPathPath PosixPath WindowsPath)icCs t|ddtkpt|ddtkS)NerrnoZwinerror)getattr_IGNORED_ERROS_IGNORED_WINERRORS)Z exceptionr /usr/lib/python3.8/pathlib.py _ignore_error-sr"cCsd|kpd|kpd|kS)N*?[r )patr r r!_is_wildcard_pattern2sr'c@s(eZdZdZddZddZddZdS) _FlavourzPA flavour implements a particular (platform-specific) set of path semantics.cCs|jj|_dSN)sepjoinselfr r r!__init__<sz_Flavour.__init__c Csg}|j}|j}d}}t|}|D]}|s.q$|r>|||}||\}}} || krt| |D] } | rd| dkrd|t| qdn| r| dkr|t| |s|r$|s|D]0}|sq|r|||}||d}|rqqqq$|s|r|||| |||fS)N.r) r*altsepreversedreplace splitrootsplitappendsysinternreverse) r-partsZparsedr*r1drvrootitpartZrelxr r r! parse_parts?s@     z_Flavour.parse_partscCsz|r*|sp|rp||||g|ddfSnF|rb||ksJ||||krp||||ddfSn||||fS|||fS)z Join the two paths represented by the respective (drive, root, parts) tuples. Return a new (drive, root, parts) tuple. N)casefold)r-r;r<r:Zdrv2Zroot2Zparts2r r r!join_parsed_partsesz_Flavour.join_parsed_partsN)__name__ __module__ __qualname____doc__r.r@rCr r r r!r(8s&r(c@seZdZdZdZdZeZej dkZ e dZ dZ ddd d hd d ed dDBdd ed dDBZefddZddZddZddZd&ddZe fddZddZdd Zd!d"Zd#d$Zd%S)'_WindowsFlavour\/TrZ4abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZz\\?\ZCONZPRNZAUXZNULcCsh|] }d|qS)zCOM%dr .0ir r r! sz_WindowsFlavour.rA cCsh|] }d|qS)zLPT%dr rKr r r!rNsc Cs\|dd}|dd}||krP||krP||\}}|dd}|dd}nd}|dd}||kr||kr||kr||d}|dkr|||d}||dkr|dkrt|}|r||d||||ddfS|d||||ddfSd} } |dkr6||jkr6|dd} |dd}|}||krN|} ||}|| | |fS)NrrArr/:)_split_extended_pathfindlen drive_letterslstrip) r-r>r*firstsecondprefixZthirdindexZindex2r;r<r r r!r4s6      "    z_WindowsFlavour.splitrootcCs|Sr)lowerr-sr r r!rBsz_WindowsFlavour.casefoldcCsdd|DS)NcSsg|] }|qSr r\)rLpr r r! sz2_WindowsFlavour.casefold_parts..r r-r:r r r!casefold_partssz_WindowsFlavour.casefold_partscCstt|tjjSr))recompilefnmatch translate IGNORECASE fullmatchr-patternr r r!compile_patternsz_WindowsFlavour.compile_patternFcCst|}|stSd}tdk r|r2|t|Sg}z|t|}WnBtk r|}tj|\}}||||kr|YSYq6Xtjj |ft |Sq6dSr)) strosgetcwdr_ext_to_normalFileNotFoundErrorpathr5r6r+r2)r-rrstrictr_Z previous_sZ tail_partstailr r r!resolves$ z_WindowsFlavour.resolvecCsXd}||rP|dd}|dd}|drP||dd7}d|dd}||fS)Nr/zUNC\rPrI) startswith)r-r_Z ext_prefixrZr r r!rSs    z$_WindowsFlavour._split_extended_pathcCs||dSNrA)rSr^r r r!rpsz_WindowsFlavour._ext_to_normalcCs6|sdS|ddrdS|ddd|jkS)NFrz\\rQr0)rw partitionupperreserved_namesrbr r r! is_reserveds z_WindowsFlavour.is_reservedcCsd|j}t|dkrJ|ddkrJ|ddd}d|t|dfSdt|dSdS)NrrArRrJz file:///%s/%szutf-8zfile:)driverUas_posixrWurlquote_from_bytesencode)r-rrr}restr r r!make_uris z_WindowsFlavour.make_uricCsdtjkrtjd}nJdtjkrXztjd}Wntk rFd}YnX|tjd}ntd|rtjd|kr||f\}}}|dtjdkrtd|||d<|s|r||||d d}n ||}|S) NZ USERPROFILEZHOMEPATHZ HOMEDRIVEr/zCan't determine home directoryZUSERNAMErQ%Can't determine home directory for %rrA)rnenvironKeyError RuntimeErrorr@r+)r-usernameuserhomer;r<r:r r r! gethomedirs*     z_WindowsFlavour.gethomedirN)F)rDrErFr*r1has_drvntpathpathmodrnname is_supportedsetrVZext_namespace_prefixranger{r4rBrcrlrurSrpr|rrr r r r!rHws.   '    rHc@sleZdZdZdZdZeZej dkZ efddZ ddZ d d Z d d Zdd dZddZddZddZdS) _PosixFlavourrJr/FrcCsV|rH|d|krH||}t|t|dkrr*Z stripped_partr r r!r4$s   z_PosixFlavour.splitrootcCs|Sr)r r^r r r!rB3sz_PosixFlavour.casefoldcCs|Sr)r rbr r r!rc6sz_PosixFlavour.casefold_partscCstt|jSr))rdrerfrgrirjr r r!rl9sz_PosixFlavour.compile_patterncsJ|j|jifdd|r0dnt}|t|pHS)Nc s|rd}|D]}|r|dkr*q|dkrD|\}}}q||}|krv|}|dk rjqtd|z|}Wn6tk r}z|jtkrr|}W5d}~XYqXd|<||}||<q|S)Nr/r0..zSymlink loop from %r)rwr5 rpartitionrreadlinkOSErrorrr)rrrr_newpathtargete_resolveZaccessorseenr*rsr r!r@s0      z'_PosixFlavour.resolve.._resolver/)r* _accessor is_absoluternrorm)r-rrrsbaser rr!ru<s &z_PosixFlavour.resolvecCsdSNFr rbr r r!r|isz_PosixFlavour.is_reservedcCst|}dt|S)Nzfile://)bytesr)r-rrZbpathr r r!rlsz_PosixFlavour.make_uricCs||s@z tjdWStk r<ddl}|tjYSXn8ddl}z||jWStk rvtd|YnXdS)NHOMErr) rnrrpwdgetpwuidgetuidpw_dirgetpwnamr)r-rrr r r!rrs z_PosixFlavour.gethomedirN)F)rDrErFr*r1r posixpathrrnrrr4rBrcrlrur|rrr r r r!rs   -rc@seZdZdZdS) _AccessorzjAn accessor implements a particular (system-specific or not) way of accessing paths on the filesystem.N)rDrErFrGr r r r!rsrc@seZdZejZejZejZejZejZej Z e edr>ej Z nddZ ej Z ej Z e edrdejZn eddZejZejZejZererejZqddZn ed dZejZd d Zd S) _NormalAccessorlchmodcCs tddS)Nz%lchmod() not available on this systemNotImplementedError)r-Zpathobjmoder r r!rsz_NormalAccessor.lchmodlinkcCs tddS)Nz&os.link() not available on this systemrr-rr r r!link_tosz_NormalAccessor.link_tocCs tddS)Nz&symlink() not available on this systemrabtarget_is_directoryr r r!symlinksz_NormalAccessor.symlinkcCs t||Sr))rnrrr r r!rscCs t|Sr))rnrr-rrr r r!rsz_NormalAccessor.readlinkN)rDrErFrnstatlstatopenlistdirscandirchmodhasattrrmkdirunlinkrr staticmethodrmdirrenamer3rsupports_symlinksrutimerr r r r!rs4     rcCsR|d}|dd}|dkr"t}n$d|kr4tdnt|rBt}nt}||||S)NrrA**z:Invalid pattern: '**' can only be an entire path component)_RecursiveWildcardSelector ValueErrorr'_WildcardSelector_PreciseSelector) pattern_partsflavourr& child_partsclsr r r!_make_selectors  r lru_cachec@s eZdZdZddZddZdS) _SelectorzYA selector matches a specific glob pattern part against the children of a given path.cCs0||_|rt|||_d|_nt|_d|_dS)NTF)rr successordironly_TerminatingSelector)r-rrr r r!r.s  z_Selector.__init__cCs<t|}|j}|j}|jj}||s,tgS|||||S)zuIterate over all child paths of `parent_path` matched by this selector. This can contain parent_path itself.)typeis_direxistsrriter _select_from)r- parent_pathZpath_clsrrrr r r! select_fromsz_Selector.select_fromN)rDrErFrGr.rr r r r!rs rc@seZdZddZdS)rccs |VdSr)r )r-rrrrr r r!rsz!_TerminatingSelector._select_fromN)rDrErFrr r r r!rsrc@seZdZddZddZdS)rcCs||_t|||dSr))rrr.)r-rrrr r r!r.sz_PreciseSelector.__init__ccs\z@||j}|jr|n||r>|j||||D] }|Vq2Wntk rVYdSXdSr))_make_child_relpathrrrrPermissionError)r-rrrrrrr`r r r!rs  z_PreciseSelector._select_fromNrDrErFr.rr r r r!rsrc@seZdZddZddZdS)rcCs|||_t|||dSr))rlmatchrr.r-r&rrr r r!r. s z_WildcardSelector.__init__c cszt||}|D]}d}z |}Wn,tk rR}zt|sBW5d}~XYnX|jr^|r|j} || r|| } |j | |||D] } | VqqWnt k rYdSXdSr) listrrr"rrrrrrr) r-rrrrentriesentry entry_is_dirrrrrr`r r r!rs"     z_WildcardSelector._select_fromNrr r r r!r src@s$eZdZddZddZddZdS)rcCst|||dSr))rr.rr r r!r.'sz#_RecursiveWildcardSelector.__init__c cs|Vzt||}|D]t}d}z |}Wn,tk rX}zt|sHW5d}~XYnX|r|s||j}||||D] } | VqqWntk rYdSXdSr) rrrr" is_symlinkrr_iterate_directoriesr) r-rrrrrrrrrr`r r r!r*s     z/_RecursiveWildcardSelector._iterate_directoriesc cs~zbt}zL|jj}||||D]0}|||||D]}||kr2|V||q2q W5|XWntk rxYdSXdSr))rclearrrraddr) r-rrrrZyieldedZsuccessor_selectZstarting_pointr`r r r!r<sz'_RecursiveWildcardSelector._select_fromN)rDrErFr.rrr r r r!r%src@s4eZdZdZdZddZddZddZd d Zd S) _PathParentszvThis object provides sequence-like access to the logical ancestors of a path. Don't try to construct it yourself.)_pathcls_drv_root_partscCs&t||_|j|_|j|_|j|_dSr))rrrrrrr r r!r.Us z_PathParents.__init__cCs(|js |jrt|jdSt|jSdSrx)rrrUrr,r r r!__len__\s z_PathParents.__len__cCs@|dks|t|krt||j|j|j|jd| dS)NrrA)rU IndexErrorr_from_parsed_partsrrr)r-idxr r r! __getitem__bs z_PathParents.__getitem__cCsd|jjS)Nz <{}.parents>)formatrrDr,r r r!__repr__hsz_PathParents.__repr__N) rDrErFrG __slots__r.rrrr r r r!rPs rc@seZdZdZdZddZddZeddZedVd d Z edWd d Z eddZ ddZ ddZ ddZddZddZddZddZddZed d!Zd"d#Zd$d%Zd&d'Zd(d)Zd*d+Zd,d-Zeed.d/d0Zeed1d2d0Zed3d4Zed5d6Z ed7d8Z!ed9d:Z"ed;d<Z#d=d>Z$d?d@Z%dAdBZ&edCdDZ'dEdFZ(dGdHZ)dIdJZ*edKdLZ+edMdNZ,dOdPZ-dQdRZ.dSdTZ/dUS)Xra|Base class for manipulating paths without I/O. PurePath represents a filesystem path and offers operations which don't imply any actual filesystem I/O. Depending on your system, instantiating a PurePath will return either a PurePosixPath or a PureWindowsPath object. You can also instantiate either of these classes directly, regardless of your system. )rrr_str_hash_pparts_cached_cpartscGs$|tkrtjdkrtnt}||S)zConstruct a PurePath from one or several strings and or existing PurePath objects. The strings and path objects are combined so as to yield a canonicalized path, which is incorporated into the new PurePath object. r)rrnrrr _from_parts)rargsr r r!__new__zszPurePath.__new__cCs|jt|jfSr)) __class__tuplerr,r r r! __reduce__szPurePath.__reduce__cCsdg}|D]N}t|tr"||j7}qt|}t|trF|t|qtdt|q|j |S)NzNargument should be a str object or an os.PathLike object returning str, not %r) isinstancerrrnfspathrmr6 TypeErrorr_flavourr@)rrr:rr r r! _parse_argss    zPurePath._parse_argsTcCs<t|}||\}}}||_||_||_|r8||Sr))objectrrrrr_init)rrinitr-r;r<r:r r r!rs zPurePath._from_partscCs,t|}||_||_||_|r(||Sr))rrrrrr)rr;r<r:rr-r r r!rs zPurePath._from_parsed_partscCs4|s|r$|||j|ddS|j|SdSrx)rr+)rr;r<r:r r r!_format_parsed_partsszPurePath._format_parsed_partscCsdSr)r r,r r r!rszPurePath._initcCs@||\}}}|j|j|j|j|||\}}}||||Sr))rrrCrrrr)r-rr;r<r:r r r! _make_childs zPurePath._make_childcCsBz|jWStk r<||j|j|jp.d|_|jYSXdS)z[Return the string representation of the path, suitable for passing to system calls.r0N)rAttributeErrorrrrrr,r r r!__str__s zPurePath.__str__cCst|Sr))rmr,r r r! __fspath__szPurePath.__fspath__cCs|j}t||jdS)zNReturn the string representation of the path with forward (/) slashes.rJ)rrmr3r*r-fr r r!r~szPurePath.as_posixcCs t|S)zaReturn the bytes representation of the path. This is only recommended to use under Unix.)rnfsencoder,r r r! __bytes__szPurePath.__bytes__cCsd|jj|S)Nz{}({!r}))rrrDr~r,r r r!rszPurePath.__repr__cCs|std|j|S)z Return the path as a 'file' URI.z.relative path can't be expressed as a file URI)rrrrr,r r r!as_uriszPurePath.as_uricCs8z|jWStk r2|j|j|_|jYSXdSr))rr rrcrr,r r r!_cpartss zPurePath._cpartscCs&t|tstS|j|jko$|j|jkSr))rrNotImplementedrrr-otherr r r!__eq__s zPurePath.__eq__cCs8z|jWStk r2tt|j|_|jYSXdSr))rr hashrrr,r r r!__hash__s zPurePath.__hash__cCs&t|tr|j|jk rtS|j|jkSr)rrrrrrr r r!__lt__szPurePath.__lt__cCs&t|tr|j|jk rtS|j|jkSr)rrr r r!__le__szPurePath.__le__cCs&t|tr|j|jk rtS|j|jkSr)rrr r r!__gt__szPurePath.__gt__cCs&t|tr|j|jk rtS|j|jkSr)rrr r r!__ge__ szPurePath.__ge__rz.The drive prefix (letter or UNC path), if any.)docrzThe root of the path, if any.cCs|j|j}|S)z/The concatenation of the drive and root, or ''.)rr)r-anchorr r r!rs zPurePath.anchorcCs.|j}t||js|jrdndkr&dS|dS)z!The final path component, if any.rArr/rQ)rrUrrrbr r r!rsz PurePath.namecCsD|j}|d}d|kr,t|dkr.rAN)rendswithrWr5r-rr r r!suffixes1s   zPurePath.suffixescCsD|j}|d}d|kr,t|dkrs    z PurePath.stemcCs|jstd|f|j|f\}}}|rX|d|jj|jjfksX|sX|sXt|dkrdtd|||j|j |j dd|gS)z-Return a new path with the file name changed.%r has an empty namerQrAzInvalid name %rN) rrrr@r*r1rUrrrr)r-rr;r<r:r r r! with_nameHs   zPurePath.with_namecCs|j}|j|ks |jr.|j|kr.td|f|r<|drD|dkrPtd||j}|shtd|f|j}|s|||}n|dt| |}||j |j |j dd|gS)zReturn a new path with the file suffix changed. If the path has no suffix, add given suffix. If the given suffix is an empty string, remove the suffix from the path. zInvalid suffix %rr0r(NrQ) rr*r1rrwrr#rUrrrr)r-r#rrZ old_suffixr r r! with_suffixSs   zPurePath.with_suffixc Gs|s td|j}|j}|j}|r8||g|dd}n|}||\}}}|rf||g|dd} n|} t| } |jj} | dkr|s|rn| |d| | | kr||||} t d t |t | | d| dkr|nd|| dS)zReturn the relative path to another path identified by the passed arguments. If the operation is not possible (because this is not a subpath of the other path), raise ValueError. zneed at least one argumentrANrz{!r} does not start with {!r}r/) rrrrrrUrrcrrrrmr) r-rr:r;r<Z abs_partsZto_drvZto_rootZto_partsZ to_abs_partsncfZ formattedr r r! relative_tohs. * zPurePath.relative_tocCs4z|jWStk r.t|j|_|jYSXdS)zZAn object providing sequence-like access to the components in the filesystem path.N)rr rrr,r r r!r:s  zPurePath.partscGs ||S)zCombine this path with one or several arguments, and return a new path representing either a subpath (if all arguments are relative paths) or a totally different path (if one of the arguments is anchored). )r )r-rr r r!joinpathszPurePath.joinpathcCs,z||fWStk r&tYSXdSr))r rrr-keyr r r! __truediv__szPurePath.__truediv__cCs2z||g|jWStk r,tYSXdSr))rrrrr/r r r! __rtruediv__szPurePath.__rtruediv__cCs@|j}|j}|j}t|dkr*|s&|r*|S||||ddS)zThe logical parent of the path.rANrQ)rrrrUr)r-r;r<r:r r r!parents zPurePath.parentcCst|S)z*A sequence of this path's logical parents.)rr,r r r!parentsszPurePath.parentscCs|js dS|jj pt|jS)zSTrue if the path is absolute (has both a root and, if applicable, a drive).F)rrrboolrr,r r r!rszPurePath.is_absolutecCs|j|jS)zaReturn True if the path contains one of the special names reserved by the system, if any.)rr|rr,r r r!r|szPurePath.is_reservedc Cs|jj}||}|j|f\}}}|s0td|rF|||jkrFdS|r\|||jkr\dS|j}|sj|rt|t|kr~dS|dd}nt|t|krdStt |t |D]\}}t ||sdSqdS)zE Return True if this path matches the given pattern. z empty patternFrANT) rrBr@rrrrrUzipr2rfZ fnmatchcase) r-Z path_patternr,r;r<Z pat_partsr:r>r&r r r!rs( zPurePath.matchN)T)T)0rDrErFrGrrr classmethodrrrrrr r r r~rrrpropertyrrrrrrrrr}r<rrr#r&r'r)r*r-r:r.r1r2r3r4rr|rr r r r!rlsv                 c@seZdZdZeZdZdS)rzPurePath subclass for non-Windows systems. On a POSIX system, instantiating a PurePath should return this object. However, you can also instantiate it directly on any system. r N)rDrErFrG_posix_flavourrrr r r r!rsc@seZdZdZeZdZdS)rzPurePath subclass for Windows systems. On a Windows system, instantiating a PurePath should return this object. However, you can also instantiate it directly on any system. r N)rDrErFrG_windows_flavourrrr r r r!rsc@seZdZdZdZddZddddZdd Zd d Zd d Z ddZ deddZ dfddZ e ddZe ddZddZddZddZd d!Zd"d#Zdgd%d&Zd'd(Zd)d*Zd+d,Zdhd/d0Zd1d2Zdid3d4Zd5d6Zdjd7d8Zdkd:d;Zdldd?Z d@dAZ!dmdBdCZ"dDdEZ#dFdGZ$dHdIZ%dJdKZ&dLdMZ'dndNdOZ(dPdQZ)dRdSZ*dTdUZ+dVdWZ,dXdYZ-dZd[Z.d\d]Z/d^d_Z0d`daZ1dbdcZ2dS)oraPurePath subclass that can make system calls. Path represents a filesystem path but unlike PurePath, also offers methods to do system calls on path objects. Depending on your system, instantiating a Path will return either a PosixPath or a WindowsPath object. You can also instantiate a PosixPath or WindowsPath directly, but cannot instantiate a WindowsPath on a POSIX system or vice versa. )r_closedcOsL|tkrtjdkrtnt}|j|dd}|jjs@td|j f| |S)NrFrz$cannot instantiate %r on your system) rrnrrrrrrrrDr)rrkwargsr-r r r!rsz Path.__new__NcCs"d|_|dk r|j|_nt|_dSr)r;r_normal_accessor)r-templater r r!rs z Path._initcCs|j|g}||j|j|Sr))rrrr)r-r>r:r r r!rs zPath._make_child_relpathcCs|jr||Sr))r; _raise_closedr,r r r! __enter__ szPath.__enter__cCs d|_dS)NT)r;)r-tvtbr r r!__exit__%sz Path.__exit__cCs tddS)NzI/O operation on closed path)rr,r r r!r@(szPath._raise_closedcCs|j|||Sr))rr)r-rflagsrr r r!_opener+sz Path._openercCs|jr||j|||S)zm Open the file pointed by this path and return a file descriptor, as os.open() does. )r;r@rr)r-rGrr r r! _raw_open/szPath._raw_opencCs |tS)zjReturn a new path pointing to the current working directory (as returned by os.getcwd()). )rnrorr r r!cwd:szPath.cwdcCs||jdS)zrReturn a new path pointing to the user's home directory (as returned by os.path.expanduser('~')). N)rrrKr r r!homeAsz Path.homecCsB|}z |}Wntk r2t|}YnXtj||S)zoReturn whether other_path is the same or not as this file (as returned by os.path.samefile()). )rr rnrrsamestat)r-Z other_pathstZother_str r r!samefileHs  z Path.samefileccsH|jr||j|D](}|dkr(q||V|jr|qdS)zyIterate over the files in this directory. Does not yield any result for the special paths '.' and '..'. >rr0N)r;r@rrrr%r r r!iterdirSs z Path.iterdirccs`|std||j|f\}}}|s.|r6tdtt||j}||D] }|VqPdS)zIterate over this subtree and yield all existing files (of any kind, including directories) matching the given relative pattern. zUnacceptable pattern: {!r}%Non-relative patterns are unsupportedN)rrrr@rrrrr-rkr;r<rZselectorr`r r r!globasz Path.globccsR|j|f\}}}|s|r$tdtdt||j}||D] }|VqBdS)zRecursively yield all existing files (of any kind, including directories) matching the given relative pattern, anywhere in this subtree. rR)rN)rr@rrrrrSr r r!rglobns z Path.rglobcCsD|jr||r|S|jtg|jdd}|j|d|S)aReturn an absolute version of this path. This function works even if the path doesn't point to anything. No normalization is done, i.e. all '.' and '..' will be kept along. Use resolve() to get the canonical path to a file. Fr<r?)r;r@rrrnrorr)r-objr r r!absolutezs z Path.absoluteFcCsh|jr||jj||d}|dkr:|t|}|jj|}|j |fdd}|j |d|S)z Make the path absolute, resolving all symlinks on the way and also normalizing it (for example turning slashes into backslashes under Windows). )rsNFr<rV) r;r@rrurrmrXrnormpathrr)r-rsr_ZnormedrWr r r!rus  z Path.resolvecCs |j|S)zh Return the result of the stat() system call on this path, like os.stat() does. )rrr,r r r!rsz Path.statcCsddl}||jjS)z: Return the login name of the file owner. rN)rrrst_uidZpw_name)r-rr r r!ownersz Path.ownercCsddl}||jjS)z8 Return the group name of the file gid. rN)grpZgetgrgidrst_gidZgr_name)r-r\r r r!groupsz Path.grouprrQc Cs(|jr|tj|||||||jdS)z| Open the file pointed by this path and return a file object, as the built-in open() function does. )Zopener)r;r@iorrH)r-r bufferingencodingerrorsnewliner r r!rs z Path.openc Cs,|jdd}|W5QRSQRXdS)zK Open the file in bytes mode, read it, and close the file. rbrNrreadr r r r! read_bytesszPath.read_bytesc Cs0|jd||d}|W5QRSQRXdS)zJ Open the file in text mode, read it, and close the file. r_rrbrcNrg)r-rbrcrr r r! read_textszPath.read_textc Cs6t|}|jdd}||W5QRSQRXdS)zO Open the file in bytes mode, write to it, and close the file. wbrfN) memoryviewrwrite)r-dataZviewrr r r! write_bytesszPath.write_bytesc CsLt|tstd|jj|jd||d}||W5QRSQRXdS)zN Open the file in text mode, write to it, and close the file. zdata must be str, not %swrjN)rrmrrrDrrn)r-rorbrcrr r r! write_texts  zPath.write_textTcCsr|jr||r>z|j|dWntk r8YnXdStjtjB}|sX|tjO}| ||}t |dS)zS Create this file with the given access mode, if it doesn't exist. N) r;r@rrrrnO_CREATO_WRONLYO_EXCLrJclose)r-rexist_okrGfdr r r!touchs   z Path.touchcCs|jr|z|j||Wndtk rd|r>|j|kr@|jjddd|j|d|dYn"tk r|r~|sYnXdS)z< Create a new directory at this given path. T)r4rwFN)r;r@rrrqr3rr)r-rr4rwr r r!rs z Path.mkdircCs |jr||j||dS)zF Change the permissions of the path, like os.chmod(). N)r;r@rrr-rr r r!r sz Path.chmodcCs |jr||j||dS)z Like chmod(), except if the path points to a symlink, the symlink's permissions are changed, rather than its target's. N)r;r@rrrzr r r!rsz Path.lchmodcCs>|jr|z|j|Wntk r8|s4YnXdS)zd Remove this file or link. If the path is a directory, use rmdir() instead. N)r;r@rrrq)r-Z missing_okr r r!rsz Path.unlinkcCs|jr||j|dS)zF Remove this directory. The directory must be empty. N)r;r@rrr,r r r!r)sz Path.rmdircCs|jr||j|S)z Like stat(), except if the path points to a symlink, the symlink's status information is returned, rather than its target's. )r;r@rrr,r r r!r1sz Path.lstatcCs |jr||j||dS)zE Create a hard link pointing to a path named target. N)r;r@rrrr r r!r:sz Path.link_tocCs&|jr||j||||S)zx Rename this path to the given path, and return a new Path instance pointing to the given path. )r;r@rrrrr r r!rBsz Path.renamecCs&|jr||j||||S)z Rename this path to the given path, clobbering the existing destination if it exists, and return a new Path instance pointing to the given path. )r;r@rr3rrr r r!r3Lsz Path.replacecCs"|jr||j|||dS)z Make this path a symlink pointing to the given path. Note the order of arguments (self, target) is the reverse of os.symlink's. N)r;r@rr)r-rrr r r! symlink_toWszPath.symlink_toc CsXz |WnFtk r>}zt|s(WYdSd}~XYntk rRYdSXdS)z+ Whether this path exists. FNT)rrr"rr-rr r r!rbs z Path.existsc Cs\zt|jWStk rB}zt|s,WYdSd}~XYntk rVYdSXdS)z3 Whether this path is a directory. FN)r rst_moderr"rr|r r r!rqsz Path.is_dirc Cs\zt|jWStk rB}zt|s,WYdSd}~XYntk rVYdSXdS)zq Whether this path is a regular file (also True for symlinks pointing to regular files). FN)r rr}rr"rr|r r r!is_filesz Path.is_filecCsv|r|sdSt|j}z|j}Wntk rBYdSX|j}||krZdS|j}|j}||kS)z; Check if this path is a POSIX mount point FT)rrrr3rst_devrst_ino)r-r3Z parent_devZdevZinoZ parent_inor r r!is_mounts    z Path.is_mountc Cs\zt|jWStk rB}zt|s,WYdSd}~XYntk rVYdSXdS)z7 Whether this path is a symbolic link. FN)r rr}rr"rr|r r r!rszPath.is_symlinkc Cs\zt|jWStk rB}zt|s,WYdSd}~XYntk rVYdSXdS)z6 Whether this path is a block device. FN)r rr}rr"rr|r r r!is_block_deviceszPath.is_block_devicec Cs\zt|jWStk rB}zt|s,WYdSd}~XYntk rVYdSXdS)z: Whether this path is a character device. FN)rrr}rr"rr|r r r!is_char_deviceszPath.is_char_devicec Cs\zt|jWStk rB}zt|s,WYdSd}~XYntk rVYdSXdS)z. Whether this path is a FIFO. FN)rrr}rr"rr|r r r!is_fifosz Path.is_fifoc Cs\zt|jWStk rB}zt|s,WYdSd}~XYntk rVYdSXdS)z0 Whether this path is a socket. FN)r rr}rr"rr|r r r! is_socketszPath.is_socketcCs`|js\|js\|jr\|jddddkr\|j|jddd}||g|jddS|S)zl Return a new path with expanded ~ and ~user constructs (as returned by os.path.expanduser) rNrA~)rrrrrr)r-Zhomedirr r r! expandusers zPath.expanduser)N)rF)rI)F)r_rQNNN)NN)NN)rFT)rIFF)F)F)3rDrErFrGrrrrrArEr@rHrJr7rLrMrPrQrTrUrXrurr[r^rrirkrprrryrrrrrrrrr3r{rrr~rrrrrrrr r r r!rsj                 c@seZdZdZdZdS)rzsPath subclass for non-Windows systems. On a POSIX system, instantiating a Path should return this object. r N)rDrErFrGrr r r r!rsc@s,eZdZdZdZddZddZddZd S) rzqPath subclass for Windows systems. On a Windows system, instantiating a Path should return this object. r cCs tddS)Nz*Path.owner() is unsupported on this systemrr,r r r!r[szWindowsPath.ownercCs tddS)Nz*Path.group() is unsupported on this systemrr,r r r!r^szWindowsPath.groupcCs tddS)Nz-Path.is_mount() is unsupported on this systemrr,r r r!rszWindowsPath.is_mountN)rDrErFrGrr[r^rr r r r!r s )Arf functoolsr`rrnrrdr7_collections_abcrrrrrrroperatorrrr r r r r rrZ urllib.parserrrrrZgetwindowsversionr__all__rrr"r'rr(rHrr:r9rrr>rrrrrrrrrrPathLikeregisterrrrrrr r r r!s|  $   ?&f8  +t