a cdh@s2ddlZddlZddlZddlZddlZddlZddlZddlZddlm Z ddl m Z m Z m Z mZmZddlmZddlmZmZmZmZmZmZmZddlmZdZgdZd Zd Z d Z!e e eefZ"ee e!fZ#d d Z$ddZ%Gddde&Z'Gddde'Z(Gddde'Z)e(Z*e)Z+GdddZ,Gddde,Z-e-Z.ddZ/e0edrbe1e/Z/GdddZ2Gdd d Z3Gd!d"d"e2Z4Gd#d$d$e2Z5Gd%d&d&e2Z6Gd'd(d(e Z7Gd)d*d*e&Z8ej9:e8Gd+d,d,e8Z;Gd-d.d.e8ZGd3d4d4e=e<Z?dS)5N)Sequence)EINVALENOENTENOTDIREBADFELOOP) attrgetter)S_ISDIRS_ISLNKS_ISREGS_ISSOCKS_ISBLKS_ISCHRS_ISFIFO)quote_from_bytesT)PurePath PurePosixPathPureWindowsPathPath PosixPath WindowsPath{icCs t|ddtvpt|ddtvS)Nerrnowinerror)getattr_IGNORED_ERROS_IGNORED_WINERRORS) exceptionr/usr/lib64/python3.9/pathlib.py _ignore_error(sr!cCsd|vpd|vpd|vS)N*?[r)patrrr _is_wildcard_pattern-sr&c@s(eZdZdZddZddZddZdS) _FlavourzPA flavour implements a particular (platform-specific) set of path semantics.cCs|jj|_dSN)sepjoinselfrrr __init__7sz_Flavour.__init__c Csg}|j}|j}d}}t|}|D]}|s.q$|r>|||}||\}}} || vrt| |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,partsparsedr)r0drvrootitpartrelxrrr 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<r9drv2root2parts2rrr join_parsed_parts`sz_Flavour.join_parsed_partsN)__name__ __module__ __qualname____doc__r-rArGrrrr r'3s&r'c@seZdZdZdZdZeZej dkZ e dZ dZ hddd d DBd d d DBZefd d ZddZddZddZe fddZddZddZddZdS)_WindowsFlavour\/TntZ4abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZz\\?\>PRNzCONOUT$AUXNULzCONIN$CONcCsh|] }d|qS)zCOM%sr.0crrr z_WindowsFlavour.u123456789¹²³cCsh|] }d|qS)zLPT%srrTrrr rWrXc Cs\|dd}|dd}||krP||krP||\}}|dd}|dd}nd}|dd}||kr||kr||kr||d}|dkr|||d}||dkr|dkrt|}|r||d||||ddfS|d||||ddfSd} } |dkr6||jvr6|dd} |dd}|}||krN|} ||}|| | |fS)NrrBr.:)_split_extended_pathfindlen drive_letterslstrip) r,r>r)firstsecondprefixthirdindexindex2r;r<rrr r3s6      "    z_WindowsFlavour.splitrootcCs|Sr(lowerr,srrr rCsz_WindowsFlavour.casefoldcCsdd|DS)NcSsg|] }|qSrrh)rUprrr rXz2_WindowsFlavour.casefold_parts..rr,r9rrr casefold_partssz_WindowsFlavour.casefold_partscCstt|tjjSr()recompilefnmatch translate IGNORECASE fullmatchr,patternrrr compile_patternsz_WindowsFlavour.compile_patterncCsXd}||rP|dd}|dd}|drP||dd7}d|dd}||fS)Nr.zUNC\rZrM) startswith)r,rk ext_prefixrdrrr r]s    z$_WindowsFlavour._split_extended_pathcCsJ|sdS|ddrdS|dddddd}||jvS)NFrz\\r[r/r\ )rz partitionrstripupperreserved_names)r,r9namerrr is_reserveds "z_WindowsFlavour.is_reservedcCsd|j}t|dkrJ|ddkrJ|ddd}d|t|dfSdt|dSdS)NrYrBr\rNz file:///%s/%szutf-8zfile:)driver_as_posixraurlquote_from_bytesencode)r,pathrrestrrr make_urisz_WindowsFlavour.make_uricCsdtjvrtjd}nHdtjvrVztjd}WntyDd}Yn0|tjd}ntd|rtjd|kr||f\}}}|dtjdkrtd|||d<|s|r||||d d}n ||}|S) N USERPROFILEHOMEPATH HOMEDRIVEr.zCan't determine home directoryUSERNAMEr[%Can't determine home directory for %rrB)osenvironKeyError RuntimeErrorrAr*)r,usernameuserhomer;r<r9rrr gethomedirs*      z_WindowsFlavour.gethomedirN)rHrIrJr)r0has_drvntpathpathmodrr is_supportedsetr`ext_namespace_prefixrr3rCrorxr]rrrrrrr rLrs*    '   rLc@sbeZdZdZdZdZeZej dkZ efddZ ddZ d d Z d d Zd dZddZddZdS) _PosixFlavourrNr.FrOcCsV|rH|d|krH||}t|t|dkrr) stripped_partrrr r3 s   z_PosixFlavour.splitrootcCs|Sr(rrjrrr rCsz_PosixFlavour.casefoldcCs|Sr(rrnrrr rosz_PosixFlavour.casefold_partscCstt|jSr()rprqrrrsrurvrrr rx"sz_PosixFlavour.compile_patterncCsdSNFrrnrrr r%sz_PosixFlavour.is_reservedcCst|}dt|S)Nzfile://)bytesr)r,rbpathrrr r(sz_PosixFlavour.make_uricCsx|s>z tjdWSty:ddl}|tjYS0n6ddl}z||jWStyrtd|Yn0dS)NHOMErr) rrrpwdgetpwuidgetuidpw_dirgetpwnamr)r,rrrrr r.s   z_PosixFlavour.gethomedirN)rHrIrJr)r0r posixpathrrrrr3rCrorxrrrrrrr rs  rc@seZdZdZdS) _AccessorzjAn accessor implements a particular (system-specific or not) way of accessing paths on the filesystem.N)rHrIrJrKrrrr rBsrc@seZdZejZejZejZejZejZej Z e edr>ej Z nddZ ej Z ej Z e edrdejZn eddZejZejZejZe edrejZn dd d ZejZd d Zd dZddZejZeejjZeejjZdS)_NormalAccessorlchmodcCs tddS)Nz%lchmod() not available on this systemNotImplementedError)r,pathobjmoderrr rXsz_NormalAccessor.lchmodlinkcCs tddS)Nz&os.link() not available on this systemrr,targetrrr link_tobsz_NormalAccessor.link_tosymlinkFcCs tddS)Nz)os.symlink() not available on this systemr)r,srcdsttarget_is_directoryrrr rosz_NormalAccessor.symlinkcCs t|Sr()rreadlinkr,rrrr rusz_NormalAccessor.readlinkcCs>zddl}|||jjWSty8tdYn0dS)Nrz*Path.owner() is unsupported on this system)rrstatst_uidpw_name ImportErrorr)r,rrrrr ownerxs  z_NormalAccessor.ownercCs>zddl}|||jjWSty8tdYn0dS)Nrz*Path.group() is unsupported on this system)grpgetgrgidrst_gidgr_namerr)r,rrrrr groups  z_NormalAccessor.groupN)F)rHrIrJrrlstatopenlistdirscandirchmodhasattrrmkdirunlinkrr staticmethodrmdirrenamer2rutimerrrgetcwdr expanduserrealpathrrrr rGs8      rcCsR|d}|dd}|dkr"t}n$d|vr4tdnt|rBt}nt}||||S)NrrB**z:Invalid pattern: '**' can only be an entire path component)_RecursiveWildcardSelector ValueErrorr&_WildcardSelector_PreciseSelector) pattern_partsflavourr% child_partsclsrrr _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,rrrrr 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_direxists _accessorriter _select_from)r, parent_pathpath_clsrrrrrr select_fromsz_Selector.select_fromN)rHrIrJrKr-rrrrr rs rc@seZdZddZdS)rccs |VdSr(r)r,rrrrrrr rsz!_TerminatingSelector._select_fromN)rHrIrJrrrrr rsrc@seZdZddZddZdS)rcCs||_t|||dSr()rrr-)r,rrrrrr r-sz_PreciseSelector.__init__ccsZz@||j}|jr|n||r>|j||||D] }|Vq2WntyTYdS0dSr()_make_child_relpathrrrrPermissionError)r,rrrrrrlrrr rs   z_PreciseSelector._select_fromNrHrIrJr-rrrrr rsrc@seZdZddZddZdS)rcCs|||_t|||dSr()rxmatchrr-r,r%rrrrr r-s z_WildcardSelector.__init__c csz||}t|}Wdn1s(0Y|D]}|jrz|sNWq6Wn:ty}z"t|sjWYd}~q6WYd}~n d}~00|j} || r6|| } |j | |||D] } | Vqq6Wnt yYdS0dSr() listrrOSErrorr!rrrrrr) r,rrrr scandir_itentriesentryerrrlrrr rs& &"   z_WildcardSelector._select_fromNrrrrr rsrc@s$eZdZddZddZddZdS)rcCst|||dSr()rr-rrrr r-sz#_RecursiveWildcardSelector.__init__c cs|Vz||}t|}Wdn1s.0Y|D]v}d}z |}Wn.ty~}zt|sjWYd}~n d}~00|r<|s<||j} || ||D] } | Vqq)formatrrHr+rrr __repr__7sz_PathParents.__repr__N) rHrIrJrK __slots__r-rrr rrrr rs rc@seZdZdZdZddZddZeddZed\d d Z ed]d d Z eddZ ddZ ddZ ddZddZddZddZddZddZed d!Zd"d#Zd$d%Zd&d'Zd(d)Zd*d+Zd,d-Zd.d/Zeed0d1d2Zeed3d4d2Zed5d6Z ed7d8Z!ed9d:Z"ed;d<Z#ed=d>Z$d?d@Z%dAdBZ&dCdDZ'dEdFZ(dGdHZ)edIdJZ*dKdLZ+dMdNZ,dOdPZ-edQdRZ.edSdTZ/dUdVZ0dWdXZ1dYdZZ2d[S)^ra|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$|turtjdkrtnt}||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. rO)rrrrr _from_parts)rargsrrr __new__IszPurePath.__new__cCs|jt|jfSr() __class__tuplerr+rrr __reduce__SszPurePath.__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) isinstancerrrfspathstrr5 TypeErrorr_flavourrA)rrr9arrr _parse_argsXs    zPurePath._parse_argsTcCs<t|}||\}}}||_||_||_|r8||Sr()objectrrrrr_init)rrinitr,r;r<r9rrr rls zPurePath._from_partscCs,t|}||_||_||_|r(||Sr()rrrrrr)rr;r<r9rr,rrr rys zPurePath._from_parsed_partscCs4|s|r$|||j|ddS|j|SdSr)rr*)rr;r<r9rrr _format_parsed_partsszPurePath._format_parsed_partscCsdSr(rr+rrr rszPurePath._initcCs@||\}}}|j|j|j|j|||\}}}||||Sr()rrrGrrrr)r,rr;r<r9rrr _make_childs  zPurePath._make_childcCs@z|jWSty:||j|j|jp,d|_|jYS0dS)z[Return the string representation of the path, suitable for passing to system calls.r/N)r AttributeErrorrrrrr+rrr __str__s  zPurePath.__str__cCst|Sr()rr+rrr __fspath__szPurePath.__fspath__cCs|j}t||jdS)zNReturn the string representation of the path with forward (/) slashes.rN)rrr2r)r,frrr rszPurePath.as_posixcCs t|S)zaReturn the bytes representation of the path. This is only recommended to use under Unix.)rfsencoder+rrr __bytes__szPurePath.__bytes__cCsd|jj|S)Nz{}({!r}))rrrHrr+rrr r szPurePath.__repr__cCs|std|j|S)z Return the path as a 'file' URI.z.relative path can't be expressed as a file URI) is_absoluterrrr+rrr as_uriszPurePath.as_uricCs6z|jWSty0|j|j|_|jYS0dSr()rr!rrorr+rrr _cpartss  zPurePath._cpartscCs&t|tstS|j|jko$|j|juSr()rrNotImplementedr*rr,otherrrr __eq__s zPurePath.__eq__cCs6z|jWSty0tt|j|_|jYS0dSr()r r!hashrr*r+rrr __hash__s  zPurePath.__hash__cCs&t|tr|j|jurtS|j|jkSr(rrrr+r*r,rrr __lt__szPurePath.__lt__cCs&t|tr|j|jurtS|j|jkSr(r1r,rrr __le__szPurePath.__le__cCs&t|tr|j|jurtS|j|jkSr(r1r,rrr __gt__szPurePath.__gt__cCs&t|tr|j|jurtS|j|jkSr(r1r,rrr __ge__szPurePath.__ge__cCs|Sr(r)rrrrr __class_getitem__szPurePath.__class_getitem__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,anchorrrr r8s zPurePath.anchorcCs.|j}t||js|jrdndkr&dS|dS)z!The final path component, if any.rBrr.r[)rr_rrrnrrr rsz PurePath.namecCsD|j}|d}d|kr,t|dkr.rBN)rendswithrar4r,rrrr suffixess   zPurePath.suffixescCsD|j}|d}d|kr,t|dkrs, *  zPurePath.relative_tocGs*z|j|WdSty$YdS0dS)zFReturn True if the path is relative to another path or False. TFN)rOrr,rrr is_relative_to_s   zPurePath.is_relative_tocCs2z|jWSty,t|j|_|jYS0dS)zZAn object providing sequence-like access to the components in the filesystem path.N)r r!rrr+rrr r9hs   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,rrrr joinpathtszPurePath.joinpathcCs*z||fWSty$tYS0dSr()r rr+r,keyrrr __truediv__|s zPurePath.__truediv__cCs0z||g|jWSty*tYS0dSr()rrrr+rRrrr __rtruediv__s zPurePath.__rtruediv__cCs@|j}|j}|j}t|dkr*|s&|r*|S||||ddS)zThe logical parent of the path.rBNr[)rrrr_r)r,r;r<r9rrr parents zPurePath.parentcCst|S)z*A sequence of this path's logical parents.)rr+rrr parentsszPurePath.parentscCs|js dS|jj pt|jS)zSTrue if the path is absolute (has both a root and, if applicable, a drive).F)rrrboolrr+rrr r(szPurePath.is_absolutecCs|j|jS)zaReturn True if the path contains one of the special names reserved by the system, if any.)rrrr+rrr rszPurePath.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 patternFrBNT) rrCrArrrr*r_zipr1rr fnmatchcase) r, path_patternrMr;r< pat_partsr9r>r%rrr rs( zPurePath.matchN)T)T)3rHrIrJrKr rr classmethodrrrrrr r"r#rr'r r)propertyr*r.r0r2r3r4r5r6rrr<r8rr=r@rArCrDrFrOrPr9rQrTrUrVrWr(rrrrrr r;s|             !    rc@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. rN)rHrIrJrK_posix_flavourrr rrrr rsrc@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. rN)rHrIrJrK_windows_flavourrr rrrr rsrc@seZdZdZdZddZddddZdd Zd d Zd d Z deddZ dfddZ e ddZ e ddZddZddZddZddZd d!Zdgd#d$Zd%d&Zd'd(Zd)d*Zdhd-d.Zd/d0Zdid1d2Zd3d4Zdjd5d6Zd7d8Zdkd:d;Zdldd?Z d@dAZ!dmdBdCZ"dDdEZ#dFdGZ$dHdIZ%dJdKZ&dndLdMZ'dNdOZ(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. )rcOsL|turtjdkrtnt}|j|dd}|jjs@td|j f| |S)NrOFrz$cannot instantiate %r on your system) rrrrrrrrrrHr)rrkwargsr,rrr rsz Path.__new__NcCs|dur|j|_nt|_dSr()r_normal_accessor)r,templaterrr rs z Path._initcCs|j|g}||j|j|Sr()rrrr)r,r>r9rrr rs zPath._make_child_relpathcCs|Sr(rr+rrr __enter__szPath.__enter__cCsdSr(r)r,tvtbrrr __exit__s z Path.__exit__cCs|j|||Sr(rr)r,rflagsrrrr _opener sz Path._openercCs|j|||S)zm Open the file pointed by this path and return a file descriptor, as os.open() does. rk)r,rlrrrr _raw_openszPath._raw_opencCs |tS)zjReturn a new path pointing to the current working directory (as returned by os.getcwd()). )rrrrrr cwdszPath.cwdcCs||jdS)zrReturn a new path pointing to the user's home directory (as returned by os.path.expanduser('~')). N)rrrprrr home sz Path.homecCsB|}z |}Wnty2|j|}Yn0tj||S)zoReturn whether other_path is the same or not as this file (as returned by os.path.samefile()). )rr!rrrsamestat)r, other_pathstother_strrr samefile's   z Path.samefileccs,|j|D]}|dvrq ||Vq dS)zyIterate over the files in this directory. Does not yield any result for the special paths '.' and '..'. >z..r/N)rrrr?rrr iterdir2sz Path.iterdirccsntd|||s td||j|f\}}}|s<|rDtdtt||j}| |D] }|Vq^dS)zIterate over this subtree and yield all existing files (of any kind, including directories) matching the given relative pattern. zpathlib.Path.globzUnacceptable pattern: {!r}%Non-relative patterns are unsupportedN) r6auditrrrrArrrrr,rwr;r<rselectorrlrrr glob<sz Path.globccs`td|||j|f\}}}|s*|r2tdtdt||j}||D] }|VqPdS)zRecursively yield all existing files (of any kind, including directories) matching the given relative pattern, anywhere in this subtree. zpathlib.Path.rglobry)rN)r6rzrrArrrrr{rrr rglobJsz Path.rglobcCs6|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. Frard)r(rrrrr)r,objrrr absoluteWs  z Path.absoluteFc Csdd}z|jj||d}Wn.tyJ}z||WYd}~n d}~00||f}|sz |Wn,ty}z||WYd}~n d}~00|S)z Make the path absolute, resolving all symlinks on the way and also normalizing it (for example turning slashes into backslashes under Windows). cSs0t|dd}|jtks|tkr,td|jdS)NrrzSymlink loop from %r)rrr_WINERROR_CANT_RESOLVE_FILENAMErfilename)rrrrr check_eloopns z!Path.resolve..check_eloop)strictN)rrrrr)r,rrrkrrlrrr resolvegs  z Path.resolvecCs |j|S)zh Return the result of the stat() system call on this path, like os.stat() does. )rrr+rrr rsz Path.statcCs |j|S)z: Return the login name of the file owner. )rrr+rrr rsz Path.ownercCs |j|S)z8 Return the group name of the file gid. )rrr+rrr rsz Path.grouprr[c Cstj|||||||jdS)z| Open the file pointed by this path and return a file object, as the built-in open() function does. )opener)iorrm)r,r bufferingencodingerrorsnewlinerrr rsz Path.opencCs8|jdd}|WdS1s*0YdS)zK Open the file in bytes mode, read it, and close the file. rbrNrreadr$rrr read_bytesszPath.read_bytescCs<|jd||d}|WdS1s.0YdS)zJ Open the file in text mode, read it, and close the file. rrrrNr)r,rrr%rrr read_textszPath.read_textcCsBt|}|jdd}||WdS1s40YdS)zO Open the file in bytes mode, write to it, and close the file. wbrN) memoryviewrwrite)r,dataviewr%rrr write_bytesszPath.write_bytescCsXt|tstd|jj|jd||d}||WdS1sJ0YdS)zN Open the file in text mode, write to it, and close the file. zdata must be str, not %swrN)rrrrrHrr)r,rrrr%rrr write_texts  zPath.write_textcCs,|j|}|j|fdd}|j|d|S)zD Return the path to which the symbolic link points. Frar)rrrr)r,rrrrr rs  z Path.readlinkTcCsb|r.z|j|dWnty(Yn0dStjtjB}|sH|tjO}|||}t|dS)zS Create this file with the given access mode, if it doesn't exist. N) rrrrO_CREATO_WRONLYO_EXCLroclose)r,rexist_okrlfdrrr touchs    z Path.touchcCsxz|j||Wn`tyT|r.|j|kr0|jjddd|j|d|dYn tyr|rl|snYn0dS)z< Create a new directory at this given path. T)rWrFN)rrFileNotFoundErrorrVrr)r,rrWrrrr rs   z Path.mkdircCs|j||dS)zF Change the permissions of the path, like os.chmod(). N)rrr,rrrr rsz Path.chmodcCs|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)rrrrrr rsz Path.lchmodcCs.z|j|Wnty(|s$Yn0dS)zd Remove this file or link. If the path is a directory, use rmdir() instead. N)rrr)r, missing_okrrr rs  z Path.unlinkcCs|j|dS)zF Remove this directory. The directory must be empty. N)rrr+rrr rsz Path.rmdircCs |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. )rrr+rrr r sz Path.lstatcCs|j||||S)a2 Rename this path to the target path. The target path may be absolute or relative. Relative paths are interpreted relative to the current working directory, *not* the directory of the Path object. Returns the new Path instance pointing to the target path. )rrrrrrr rs z Path.renamecCs|j||||S)aS Rename this path to the target path, overwriting if that path exists. The target path may be absolute or relative. Relative paths are interpreted relative to the current working directory, *not* the directory of the Path object. Returns the new Path instance pointing to the target path. )rr2rrrrr r2!s z Path.replacecCs|j|||dS)z Make this path a symlink pointing to the target path. Note the order of arguments (link, target) is the reverse of os.symlink. N)rr)r,rrrrr symlink_to.szPath.symlink_tocCs|j||dS)aQ Make the target path a hard link pointing to this path. Note this function does not make this path a hard link to *target*, despite the implication of the function and argument names. The order of arguments (target, link) is the reverse of Path.symlink_to, but matches that of os.link. N)rrrrrr r5s z Path.link_toc CsTz |WnBty<}zt|s&WYd}~dSd}~0tyNYdS0dS)z+ Whether this path exists. NFT)rrr!rr,rrrr rCs  z Path.existsc CsXzt|jWSty@}zt|s*WYd}~dSd}~0tyRYdS0dS)z3 Whether this path is a directory. NF)r rst_moderr!rrrrr rRs z Path.is_dirc CsXzt|jWSty@}zt|s*WYd}~dSd}~0tyRYdS0dS)zq Whether this path is a regular file (also True for symlinks pointing to regular files). NF)r rrrr!rrrrr is_filebs z Path.is_filecCsn|r|sdSz|jj}Wnty8YdS0|j}||krPdS|j}|jj}||kS)z; Check if this path is a POSIX mount point FT)rrrVrst_devrst_ino)r, parent_devdevino parent_inorrr is_mountss    z Path.is_mountc CsXzt|jWSty@}zt|s*WYd}~dSd}~0tyRYdS0dS)z7 Whether this path is a symbolic link. NF)r rrrr!rrrrr rs zPath.is_symlinkc CsXzt|jWSty@}zt|s*WYd}~dSd}~0tyRYdS0dS)z6 Whether this path is a block device. NF)r rrrr!rrrrr is_block_devices zPath.is_block_devicec CsXzt|jWSty@}zt|s*WYd}~dSd}~0tyRYdS0dS)z: Whether this path is a character device. NF)rrrrr!rrrrr is_char_devices zPath.is_char_devicec CsXzt|jWSty@}zt|s*WYd}~dSd}~0tyRYdS0dS)z. Whether this path is a FIFO. NF)rrrrr!rrrrr is_fifos z Path.is_fifoc CsXzt|jWSty@}zt|s*WYd}~dSd}~0tyRYdS0dS)z0 Whether this path is a socket. NF)r rrrr!rrrrr is_sockets zPath.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) rNrB~)rrrrrr)r,homedirrrr rs zPath.expanduser)N)rj)rn)F)rr[NNN)NN)NN)rjT)rnFF)F)F)3rHrIrJrKr rrrrerirmror]rqrrrwrxr}r~rrrrrrrrrrrrrrrrrrrr2rrrrrrrrrrrrrrrr rsh                 rc@seZdZdZdZdS)rzsPath subclass for non-Windows systems. On a POSIX system, instantiating a Path should return this object. rN)rHrIrJrKr rrrr rsrc@seZdZdZdZddZdS)rzqPath subclass for Windows systems. On a Windows system, instantiating a Path should return this object. rcCs tddS)Nz-Path.is_mount() is unsupported on this systemrr+rrr rszWindowsPath.is_mountN)rHrIrJrKr rrrrr rsr)@rr functoolsrrrrrpr6_collections_abcrrrrrrroperatorrrr r r r r rr urllib.parserrsupports_symlinks__all___WINERROR_NOT_READY_WINERROR_INVALID_NAMErrrr!r&rr'rLrr`r_rrrcrrrrrrrrrrPathLikeregisterrrrrrrrrr sp  $   ?9F  ,