GRAYBYTE WORDPRESS FILE MANAGER3668

Server IP : 198.54.121.189 / Your IP : 216.73.216.140
System : Linux premium69.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /opt/alt/python313/lib64/python3.13/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/alt/python313/lib64/python3.13//ntpath.py
# Module 'ntpath' -- common operations on WinNT/Win95 pathnames
"""Common pathname manipulations, WindowsNT/95 version.

Instead of importing this module directly, import os and refer to this
module as os.path.
"""

# strings representing various path-related bits and pieces
# These are primarily for export; internally, they are hardcoded.
# Should be set before imports for resolving cyclic dependency.
curdir = '.'
pardir = '..'
extsep = '.'
sep = '\\'
pathsep = ';'
altsep = '/'
defpath = '.;C:\\bin'
devnull = 'nul'

import os
import sys
import genericpath
from genericpath import *

__all__ = ["normcase","isabs","join","splitdrive","splitroot","split","splitext",
           "basename","dirname","commonprefix","getsize","getmtime",
           "getatime","getctime", "islink","exists","lexists","isdir","isfile",
           "ismount","isreserved","expanduser","expandvars","normpath",
           "abspath","curdir","pardir","sep","pathsep","defpath","altsep",
           "extsep","devnull","realpath","supports_unicode_filenames","relpath",
           "samefile", "sameopenfile", "samestat", "commonpath", "isjunction",
           "isdevdrive"]

def _get_bothseps(path):
    if isinstance(path, bytes):
        return b'\\/'
    else:
        return '\\/'

# Normalize the case of a pathname and map slashes to backslashes.
# Other normalizations (such as optimizing '../' away) are not done
# (this is done by normpath).

try:
    from _winapi import (
        LCMapStringEx as _LCMapStringEx,
        LOCALE_NAME_INVARIANT as _LOCALE_NAME_INVARIANT,
        LCMAP_LOWERCASE as _LCMAP_LOWERCASE)

    def normcase(s):
        """Normalize case of pathname.

        Makes all characters lowercase and all slashes into backslashes.
        """
        s = os.fspath(s)
        if not s:
            return s
        if isinstance(s, bytes):
            encoding = sys.getfilesystemencoding()
            s = s.decode(encoding, 'surrogateescape').replace('/', '\\')
            s = _LCMapStringEx(_LOCALE_NAME_INVARIANT,
                               _LCMAP_LOWERCASE, s)
            return s.encode(encoding, 'surrogateescape')
        else:
            return _LCMapStringEx(_LOCALE_NAME_INVARIANT,
                                  _LCMAP_LOWERCASE,
                                  s.replace('/', '\\'))
except ImportError:
    def normcase(s):
        """Normalize case of pathname.

        Makes all characters lowercase and all slashes into backslashes.
        """
        s = os.fspath(s)
        if isinstance(s, bytes):
            return os.fsencode(os.fsdecode(s).replace('/', '\\').lower())
        return s.replace('/', '\\').lower()


def isabs(s):
    """Test whether a path is absolute"""
    s = os.fspath(s)
    if isinstance(s, bytes):
        sep = b'\\'
        altsep = b'/'
        colon_sep = b':\\'
        double_sep = b'\\\\'
    else:
        sep = '\\'
        altsep = '/'
        colon_sep = ':\\'
        double_sep = '\\\\'
    s = s[:3].replace(altsep, sep)
    # Absolute: UNC, device, and paths with a drive and root.
    return s.startswith(colon_sep, 1) or s.startswith(double_sep)


# Join two (or more) paths.
def join(path, *paths):
    path = os.fspath(path)
    if isinstance(path, bytes):
        sep = b'\\'
        seps = b'\\/'
        colon_seps = b':\\/'
    else:
        sep = '\\'
        seps = '\\/'
        colon_seps = ':\\/'
    try:
        result_drive, result_root, result_path = splitroot(path)
        for p in paths:
            p_drive, p_root, p_path = splitroot(p)
            if p_root:
                # Second path is absolute
                if p_drive or not result_drive:
                    result_drive = p_drive
                result_root = p_root
                result_path = p_path
                continue
            elif p_drive and p_drive != result_drive:
                if p_drive.lower() != result_drive.lower():
                    # Different drives => ignore the first path entirely
                    result_drive = p_drive
                    result_root = p_root
                    result_path = p_path
                    continue
                # Same drive in different case
                result_drive = p_drive
            # Second path is relative to the first
            if result_path and result_path[-1] not in seps:
                result_path = result_path + sep
            result_path = result_path + p_path
        ## add separator between UNC and non-absolute path
        if (result_path and not result_root and
            result_drive and result_drive[-1] not in colon_seps):
            return result_drive + sep + result_path
        return result_drive + result_root + result_path
    except (TypeError, AttributeError, BytesWarning):
        genericpath._check_arg_types('join', path, *paths)
        raise


# Split a path in a drive specification (a drive letter followed by a
# colon) and the path specification.
# It is always true that drivespec + pathspec == p
def splitdrive(p):
    """Split a pathname into drive/UNC sharepoint and relative path specifiers.
    Returns a 2-tuple (drive_or_unc, path); either part may be empty.

    If you assign
        result = splitdrive(p)
    It is always true that:
        result[0] + result[1] == p

    If the path contained a drive letter, drive_or_unc will contain everything
    up to and including the colon.  e.g. splitdrive("c:/dir") returns ("c:", "/dir")

    If the path contained a UNC path, the drive_or_unc will contain the host name
    and share up to but not including the fourth directory separator character.
    e.g. splitdrive("//host/computer/dir") returns ("//host/computer", "/dir")

    Paths cannot contain both a drive letter and a UNC path.

    """
    drive, root, tail = splitroot(p)
    return drive, root + tail


try:
    from nt import _path_splitroot_ex as splitroot
except ImportError:
    def splitroot(p):
        """Split a pathname into drive, root and tail.

        The tail contains anything after the root."""
        p = os.fspath(p)
        if isinstance(p, bytes):
            sep = b'\\'
            altsep = b'/'
            colon = b':'
            unc_prefix = b'\\\\?\\UNC\\'
            empty = b''
        else:
            sep = '\\'
            altsep = '/'
            colon = ':'
            unc_prefix = '\\\\?\\UNC\\'
            empty = ''
        normp = p.replace(altsep, sep)
        if normp[:1] == sep:
            if normp[1:2] == sep:
                # UNC drives, e.g. \\server\share or \\?\UNC\server\share
                # Device drives, e.g. \\.\device or \\?\device
                start = 8 if normp[:8].upper() == unc_prefix else 2
                index = normp.find(sep, start)
                if index == -1:
                    return p, empty, empty
                index2 = normp.find(sep, index + 1)
                if index2 == -1:
                    return p, empty, empty
                return p[:index2], p[index2:index2 + 1], p[index2 + 1:]
            else:
                # Relative path with root, e.g. \Windows
                return empty, p[:1], p[1:]
        elif normp[1:2] == colon:
            if normp[2:3] == sep:
                # Absolute drive-letter path, e.g. X:\Windows
                return p[:2], p[2:3], p[3:]
            else:
                # Relative path with drive, e.g. X:Windows
                return p[:2], empty, p[2:]
        else:
            # Relative path, e.g. Windows
            return empty, empty, p


# Split a path in head (everything up to the last '/') and tail (the
# rest).  After the trailing '/' is stripped, the invariant
# join(head, tail) == p holds.
# The resulting head won't end in '/' unless it is the root.

def split(p):
    """Split a pathname.

    Return tuple (head, tail) where tail is everything after the final slash.
    Either part may be empty."""
    p = os.fspath(p)
    seps = _get_bothseps(p)
    d, r, p = splitroot(p)
    # set i to index beyond p's last slash
    i = len(p)
    while i and p[i-1] not in seps:
        i -= 1
    head, tail = p[:i], p[i:]  # now tail has no slashes
    return d + r + head.rstrip(seps), tail


# Split a path in root and extension.
# The extension is everything starting at the last dot in the last
# pathname component; the root is everything before that.
# It is always true that root + ext == p.

def splitext(p):
    p = os.fspath(p)
    if isinstance(p, bytes):
        return genericpath._splitext(p, b'\\', b'/', b'.')
    else:
        return genericpath._splitext(p, '\\', '/', '.')
splitext.__doc__ = genericpath._splitext.__doc__


# Return the tail (basename) part of a path.

def basename(p):
    """Returns the final component of a pathname"""
    return split(p)[1]


# Return the head (dirname) part of a path.

def dirname(p):
    """Returns the directory component of a pathname"""
    return split(p)[0]


# Is a path a mount point?
# Any drive letter root (eg c:\)
# Any share UNC (eg \\server\share)
# Any volume mounted on a filesystem folder
#
# No one method detects all three situations. Historically we've lexically
# detected drive letter roots and share UNCs. The canonical approach to
# detecting mounted volumes (querying the reparse tag) fails for the most
# common case: drive letter roots. The alternative which uses GetVolumePathName
# fails if the drive letter is the result of a SUBST.
try:
    from nt import _getvolumepathname
except ImportError:
    _getvolumepathname = None
def ismount(path):
    """Test whether a path is a mount point (a drive root, the root of a
    share, or a mounted volume)"""
    path = os.fspath(path)
    seps = _get_bothseps(path)
    path = abspath(path)
    drive, root, rest = splitroot(path)
    if drive and drive[0] in seps:
        return not rest
    if root and not rest:
        return True

    if _getvolumepathname:
        x = path.rstrip(seps)
        y =_getvolumepathname(path).rstrip(seps)
        return x.casefold() == y.casefold()
    else:
        return False


_reserved_chars = frozenset(
    {chr(i) for i in range(32)} |
    {'"', '*', ':', '<', '>', '?', '|', '/', '\\'}
)

_reserved_names = frozenset(
    {'CON', 'PRN', 'AUX', 'NUL', 'CONIN$', 'CONOUT$'} |
    {f'COM{c}' for c in '123456789\xb9\xb2\xb3'} |
    {f'LPT{c}' for c in '123456789\xb9\xb2\xb3'}
)

def isreserved(path):
    """Return true if the pathname is reserved by the system."""
    # Refer to "Naming Files, Paths, and Namespaces":
    # https://docs.microsoft.com/en-us/windows/win32/fileio/naming-a-file
    path = os.fsdecode(splitroot(path)[2]).replace(altsep, sep)
    return any(_isreservedname(name) for name in reversed(path.split(sep)))

def _isreservedname(name):
    """Return true if the filename is reserved by the system."""
    # Trailing dots and spaces are reserved.
    if name[-1:] in ('.', ' '):
        return name not in ('.', '..')
    # Wildcards, separators, colon, and pipe (*?"<>/\:|) are reserved.
    # ASCII control characters (0-31) are reserved.
    # Colon is reserved for file streams (e.g. "name:stream[:type]").
    if _reserved_chars.intersection(name):
        return True
    # DOS device names are reserved (e.g. "nul" or "nul .txt"). The rules
    # are complex and vary across Windows versions. On the side of
    # caution, return True for names that may not be reserved.
    return name.partition('.')[0].rstrip(' ').upper() in _reserved_names


# Expand paths beginning with '~' or '~user'.
# '~' means $HOME; '~user' means that user's home directory.
# If the path doesn't begin with '~', or if the user or $HOME is unknown,
# the path is returned unchanged (leaving error reporting to whatever
# function is called with the expanded path as argument).
# See also module 'glob' for expansion of *, ? and [...] in pathnames.
# (A function should also be defined to do full *sh-style environment
# variable expansion.)

def expanduser(path):
    """Expand ~ and ~user constructs.

    If user or $HOME is unknown, do nothing."""
    path = os.fspath(path)
    if isinstance(path, bytes):
        seps = b'\\/'
        tilde = b'~'
    else:
        seps = '\\/'
        tilde = '~'
    if not path.startswith(tilde):
        return path
    i, n = 1, len(path)
    while i < n and path[i] not in seps:
        i += 1

    if 'USERPROFILE' in os.environ:
        userhome = os.environ['USERPROFILE']
    elif 'HOMEPATH' not in os.environ:
        return path
    else:
        drive = os.environ.get('HOMEDRIVE', '')
        userhome = join(drive, os.environ['HOMEPATH'])

    if i != 1: #~user
        target_user = path[1:i]
        if isinstance(target_user, bytes):
            target_user = os.fsdecode(target_user)
        current_user = os.environ.get('USERNAME')

        if target_user != current_user:
            # Try to guess user home directory.  By default all user
            # profile directories are located in the same place and are
            # named by corresponding usernames.  If userhome isn't a
            # normal profile directory, this guess is likely wrong,
            # so we bail out.
            if current_user != basename(userhome):
                return path
            userhome = join(dirname(userhome), target_user)

    if isinstance(path, bytes):
        userhome = os.fsencode(userhome)

    return userhome + path[i:]


# Expand paths containing shell variable substitutions.
# The following rules apply:
#       - no expansion within single quotes
#       - '$$' is translated into '$'
#       - '%%' is translated into '%' if '%%' are not seen in %var1%%var2%
#       - ${varname} is accepted.
#       - $varname is accepted.
#       - %varname% is accepted.
#       - varnames can be made out of letters, digits and the characters '_-'
#         (though is not verified in the ${varname} and %varname% cases)
# XXX With COMMAND.COM you can use any characters in a variable name,
# XXX except '^|<>='.

def expandvars(path):
    """Expand shell variables of the forms $var, ${var} and %var%.

    Unknown variables are left unchanged."""
    path = os.fspath(path)
    if isinstance(path, bytes):
        if b'$' not in path and b'%' not in path:
            return path
        import string
        varchars = bytes(string.ascii_letters + string.digits + '_-', 'ascii')
        quote = b'\''
        percent = b'%'
        brace = b'{'
        rbrace = b'}'
        dollar = b'$'
        environ = getattr(os, 'environb', None)
    else:
        if '$' not in path and '%' not in path:
            return path
        import string
        varchars = string.ascii_letters + string.digits + '_-'
        quote = '\''
        percent = '%'
        brace = '{'
        rbrace = '}'
        dollar = '$'
        environ = os.environ
    res = path[:0]
    index = 0
    pathlen = len(path)
    while index < pathlen:
        c = path[index:index+1]
        if c == quote:   # no expansion within single quotes
            path = path[index + 1:]
            pathlen = len(path)
            try:
                index = path.index(c)
                res += c + path[:index + 1]
            except ValueError:
                res += c + path
                index = pathlen - 1
        elif c == percent:  # variable or '%'
            if path[index + 1:index + 2] == percent:
                res += c
                index += 1
            else:
                path = path[index+1:]
                pathlen = len(path)
                try:
                    index = path.index(percent)
                except ValueError:
                    res += percent + path
                    index = pathlen - 1
                else:
                    var = path[:index]
                    try:
                        if environ is None:
                            value = os.fsencode(os.environ[os.fsdecode(var)])
                        else:
                            value = environ[var]
                    except KeyError:
                        value = percent + var + percent
                    res += value
        elif c == dollar:  # variable or '$$'
            if path[index + 1:index + 2] == dollar:
                res += c
                index += 1
            elif path[index + 1:index + 2] == brace:
                path = path[index+2:]
                pathlen = len(path)
                try:
                    index = path.index(rbrace)
                except ValueError:
                    res += dollar + brace + path
                    index = pathlen - 1
                else:
                    var = path[:index]
                    try:
                        if environ is None:
                            value = os.fsencode(os.environ[os.fsdecode(var)])
                        else:
                            value = environ[var]
                    except KeyError:
                        value = dollar + brace + var + rbrace
                    res += value
            else:
                var = path[:0]
                index += 1
                c = path[index:index + 1]
                while c and c in varchars:
                    var += c
                    index += 1
                    c = path[index:index + 1]
                try:
                    if environ is None:
                        value = os.fsencode(os.environ[os.fsdecode(var)])
                    else:
                        value = environ[var]
                except KeyError:
                    value = dollar + var
                res += value
                if c:
                    index -= 1
        else:
            res += c
        index += 1
    return res


# Normalize a path, e.g. A//B, A/./B and A/foo/../B all become A\B.
# Previously, this function also truncated pathnames to 8+3 format,
# but as this module is called "ntpath", that's obviously wrong!
try:
    from nt import _path_normpath as normpath

except ImportError:
    def normpath(path):
        """Normalize path, eliminating double slashes, etc."""
        path = os.fspath(path)
        if isinstance(path, bytes):
            sep = b'\\'
            altsep = b'/'
            curdir = b'.'
            pardir = b'..'
        else:
            sep = '\\'
            altsep = '/'
            curdir = '.'
            pardir = '..'
        path = path.replace(altsep, sep)
        drive, root, path = splitroot(path)
        prefix = drive + root
        comps = path.split(sep)
        i = 0
        while i < len(comps):
            if not comps[i] or comps[i] == curdir:
                del comps[i]
            elif comps[i] == pardir:
                if i > 0 and comps[i-1] != pardir:
                    del comps[i-1:i+1]
                    i -= 1
                elif i == 0 and root:
                    del comps[i]
                else:
                    i += 1
            else:
                i += 1
        # If the path is now empty, substitute '.'
        if not prefix and not comps:
            comps.append(curdir)
        return prefix + sep.join(comps)


# Return an absolute path.
try:
    from nt import _getfullpathname

except ImportError: # not running on Windows - mock up something sensible
    def abspath(path):
        """Return the absolute version of a path."""
        path = os.fspath(path)
        if not isabs(path):
            if isinstance(path, bytes):
                cwd = os.getcwdb()
            else:
                cwd = os.getcwd()
            path = join(cwd, path)
        return normpath(path)

else:  # use native Windows method on Windows
    def abspath(path):
        """Return the absolute version of a path."""
        try:
            return _getfullpathname(normpath(path))
        except (OSError, ValueError):
            # See gh-75230, handle outside for cleaner traceback
            pass
        path = os.fspath(path)
        if not isabs(path):
            if isinstance(path, bytes):
                sep = b'\\'
                getcwd = os.getcwdb
            else:
                sep = '\\'
                getcwd = os.getcwd
            drive, root, path = splitroot(path)
            # Either drive or root can be nonempty, but not both.
            if drive or root:
                try:
                    path = join(_getfullpathname(drive + root), path)
                except (OSError, ValueError):
                    # Drive "\0:" cannot exist; use the root directory.
                    path = drive + sep + path
            else:
                path = join(getcwd(), path)
        return normpath(path)

try:
    from nt import _findfirstfile, _getfinalpathname, readlink as _nt_readlink
except ImportError:
    # realpath is a no-op on systems without _getfinalpathname support.
    realpath = abspath
else:
    def _readlink_deep(path):
        # These error codes indicate that we should stop reading links and
        # return the path we currently have.
        # 1: ERROR_INVALID_FUNCTION
        # 2: ERROR_FILE_NOT_FOUND
        # 3: ERROR_DIRECTORY_NOT_FOUND
        # 5: ERROR_ACCESS_DENIED
        # 21: ERROR_NOT_READY (implies drive with no media)
        # 32: ERROR_SHARING_VIOLATION (probably an NTFS paging file)
        # 50: ERROR_NOT_SUPPORTED (implies no support for reparse points)
        # 67: ERROR_BAD_NET_NAME (implies remote server unavailable)
        # 87: ERROR_INVALID_PARAMETER
        # 4390: ERROR_NOT_A_REPARSE_POINT
        # 4392: ERROR_INVALID_REPARSE_DATA
        # 4393: ERROR_REPARSE_TAG_INVALID
        allowed_winerror = 1, 2, 3, 5, 21, 32, 50, 67, 87, 4390, 4392, 4393

        seen = set()
        while normcase(path) not in seen:
            seen.add(normcase(path))
            try:
                old_path = path
                path = _nt_readlink(path)
                # Links may be relative, so resolve them against their
                # own location
                if not isabs(path):
                    # If it's something other than a symlink, we don't know
                    # what it's actually going to be resolved against, so
                    # just return the old path.
                    if not islink(old_path):
                        path = old_path
                        break
                    path = normpath(join(dirname(old_path), path))
            except OSError as ex:
                if ex.winerror in allowed_winerror:
                    break
                raise
            except ValueError:
                # Stop on reparse points that are not symlinks
                break
        return path

    def _getfinalpathname_nonstrict(path):
        # These error codes indicate that we should stop resolving the path
        # and return the value we currently have.
        # 1: ERROR_INVALID_FUNCTION
        # 2: ERROR_FILE_NOT_FOUND
        # 3: ERROR_DIRECTORY_NOT_FOUND
        # 5: ERROR_ACCESS_DENIED
        # 21: ERROR_NOT_READY (implies drive with no media)
        # 32: ERROR_SHARING_VIOLATION (probably an NTFS paging file)
        # 50: ERROR_NOT_SUPPORTED
        # 53: ERROR_BAD_NETPATH
        # 65: ERROR_NETWORK_ACCESS_DENIED
        # 67: ERROR_BAD_NET_NAME (implies remote server unavailable)
        # 87: ERROR_INVALID_PARAMETER
        # 123: ERROR_INVALID_NAME
        # 161: ERROR_BAD_PATHNAME
        # 1920: ERROR_CANT_ACCESS_FILE
        # 1921: ERROR_CANT_RESOLVE_FILENAME (implies unfollowable symlink)
        allowed_winerror = 1, 2, 3, 5, 21, 32, 50, 53, 65, 67, 87, 123, 161, 1920, 1921

        # Non-strict algorithm is to find as much of the target directory
        # as we can and join the rest.
        tail = path[:0]
        while path:
            try:
                path = _getfinalpathname(path)
                return join(path, tail) if tail else path
            except OSError as ex:
                if ex.winerror not in allowed_winerror:
                    raise
                try:
                    # The OS could not resolve this path fully, so we attempt
                    # to follow the link ourselves. If we succeed, join the tail
                    # and return.
                    new_path = _readlink_deep(path)
                    if new_path != path:
                        return join(new_path, tail) if tail else new_path
                except OSError:
                    # If we fail to readlink(), let's keep traversing
                    pass
                # If we get these errors, try to get the real name of the file without accessing it.
                if ex.winerror in (1, 5, 32, 50, 87, 1920, 1921):
                    try:
                        name = _findfirstfile(path)
                        path, _ = split(path)
                    except OSError:
                        path, name = split(path)
                else:
                    path, name = split(path)
                if path and not name:
                    return path + tail
                tail = join(name, tail) if tail else name
        return tail

    def realpath(path, *, strict=False):
        path = normpath(path)
        if isinstance(path, bytes):
            prefix = b'\\\\?\\'
            unc_prefix = b'\\\\?\\UNC\\'
            new_unc_prefix = b'\\\\'
            cwd = os.getcwdb()
            # bpo-38081: Special case for realpath(b'nul')
            devnull = b'nul'
            if normcase(path) == devnull:
                return b'\\\\.\\NUL'
        else:
            prefix = '\\\\?\\'
            unc_prefix = '\\\\?\\UNC\\'
            new_unc_prefix = '\\\\'
            cwd = os.getcwd()
            # bpo-38081: Special case for realpath('nul')
            devnull = 'nul'
            if normcase(path) == devnull:
                return '\\\\.\\NUL'
        had_prefix = path.startswith(prefix)
        if not had_prefix and not isabs(path):
            path = join(cwd, path)
        try:
            path = _getfinalpathname(path)
            initial_winerror = 0
        except ValueError as ex:
            # gh-106242: Raised for embedded null characters
            # In strict mode, we convert into an OSError.
            # Non-strict mode returns the path as-is, since we've already
            # made it absolute.
            if strict:
                raise OSError(str(ex)) from None
            path = normpath(path)
        except OSError as ex:
            if strict:
                raise
            initial_winerror = ex.winerror
            path = _getfinalpathname_nonstrict(path)
        # The path returned by _getfinalpathname will always start with \\?\ -
        # strip off that prefix unless it was already provided on the original
        # path.
        if not had_prefix and path.startswith(prefix):
            # For UNC paths, the prefix will actually be \\?\UNC\
            # Handle that case as well.
            if path.startswith(unc_prefix):
                spath = new_unc_prefix + path[len(unc_prefix):]
            else:
                spath = path[len(prefix):]
            # Ensure that the non-prefixed path resolves to the same path
            try:
                if _getfinalpathname(spath) == path:
                    path = spath
            except ValueError as ex:
                # Unexpected, as an invalid path should not have gained a prefix
                # at any point, but we ignore this error just in case.
                pass
            except OSError as ex:
                # If the path does not exist and originally did not exist, then
                # strip the prefix anyway.
                if ex.winerror == initial_winerror:
                    path = spath
        return path


# All supported version have Unicode filename support.
supports_unicode_filenames = True

def relpath(path, start=None):
    """Return a relative version of a path"""
    path = os.fspath(path)
    if not path:
        raise ValueError("no path specified")

    if isinstance(path, bytes):
        sep = b'\\'
        curdir = b'.'
        pardir = b'..'
    else:
        sep = '\\'
        curdir = '.'
        pardir = '..'

    if start is None:
        start = curdir
    else:
        start = os.fspath(start)

    try:
        start_abs = abspath(start)
        path_abs = abspath(path)
        start_drive, _, start_rest = splitroot(start_abs)
        path_drive, _, path_rest = splitroot(path_abs)
        if normcase(start_drive) != normcase(path_drive):
            raise ValueError("path is on mount %r, start on mount %r" % (
                path_drive, start_drive))

        start_list = start_rest.split(sep) if start_rest else []
        path_list = path_rest.split(sep) if path_rest else []
        # Work out how much of the filepath is shared by start and path.
        i = 0
        for e1, e2 in zip(start_list, path_list):
            if normcase(e1) != normcase(e2):
                break
            i += 1

        rel_list = [pardir] * (len(start_list)-i) + path_list[i:]
        if not rel_list:
            return curdir
        return sep.join(rel_list)
    except (TypeError, ValueError, AttributeError, BytesWarning, DeprecationWarning):
        genericpath._check_arg_types('relpath', path, start)
        raise


# Return the longest common sub-path of the iterable of paths given as input.
# The function is case-insensitive and 'separator-insensitive', i.e. if the
# only difference between two paths is the use of '\' versus '/' as separator,
# they are deemed to be equal.
#
# However, the returned path will have the standard '\' separator (even if the
# given paths had the alternative '/' separator) and will have the case of the
# first path given in the iterable. Additionally, any trailing separator is
# stripped from the returned path.

def commonpath(paths):
    """Given an iterable of path names, returns the longest common sub-path."""
    paths = tuple(map(os.fspath, paths))
    if not paths:
        raise ValueError('commonpath() arg is an empty iterable')

    if isinstance(paths[0], bytes):
        sep = b'\\'
        altsep = b'/'
        curdir = b'.'
    else:
        sep = '\\'
        altsep = '/'
        curdir = '.'

    try:
        drivesplits = [splitroot(p.replace(altsep, sep).lower()) for p in paths]
        split_paths = [p.split(sep) for d, r, p in drivesplits]

        # Check that all drive letters or UNC paths match. The check is made only
        # now otherwise type errors for mixing strings and bytes would not be
        # caught.
        if len({d for d, r, p in drivesplits}) != 1:
            raise ValueError("Paths don't have the same drive")

        drive, root, path = splitroot(paths[0].replace(altsep, sep))
        if len({r for d, r, p in drivesplits}) != 1:
            if drive:
                raise ValueError("Can't mix absolute and relative paths")
            else:
                raise ValueError("Can't mix rooted and not-rooted paths")

        common = path.split(sep)
        common = [c for c in common if c and c != curdir]

        split_paths = [[c for c in s if c and c != curdir] for s in split_paths]
        s1 = min(split_paths)
        s2 = max(split_paths)
        for i, c in enumerate(s1):
            if c != s2[i]:
                common = common[:i]
                break
        else:
            common = common[:len(s1)]

        return drive + root + sep.join(common)
    except (TypeError, AttributeError):
        genericpath._check_arg_types('commonpath', *paths)
        raise


try:
    # The isdir(), isfile(), islink(), exists() and lexists() implementations
    # in genericpath use os.stat(). This is overkill on Windows. Use simpler
    # builtin functions if they are available.
    from nt import _path_isdir as isdir
    from nt import _path_isfile as isfile
    from nt import _path_islink as islink
    from nt import _path_isjunction as isjunction
    from nt import _path_exists as exists
    from nt import _path_lexists as lexists
except ImportError:
    # Use genericpath.* as imported above
    pass


try:
    from nt import _path_isdevdrive
    def isdevdrive(path):
        """Determines whether the specified path is on a Windows Dev Drive."""
        try:
            return _path_isdevdrive(abspath(path))
        except OSError:
            return False
except ImportError:
    # Use genericpath.isdevdrive as imported above
    pass

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
May 13 2025 08:38:47
root / root
0755
__pycache__
--
May 13 2025 08:36:33
root / linksafe
0755
_pyrepl
--
May 13 2025 08:36:33
root / linksafe
0755
asyncio
--
May 13 2025 08:36:33
root / linksafe
0755
collections
--
May 13 2025 08:36:33
root / linksafe
0755
concurrent
--
May 13 2025 08:36:33
root / linksafe
0755
config-3.13-x86_64-linux-gnu
--
May 13 2025 08:38:47
root / linksafe
0755
ctypes
--
May 13 2025 08:36:33
root / linksafe
0755
curses
--
May 13 2025 08:36:33
root / linksafe
0755
dbm
--
May 13 2025 08:36:33
root / linksafe
0755
email
--
May 13 2025 08:36:33
root / linksafe
0755
encodings
--
May 13 2025 08:36:33
root / linksafe
0755
ensurepip
--
May 13 2025 08:36:33
root / linksafe
0755
html
--
May 13 2025 08:36:33
root / linksafe
0755
http
--
May 13 2025 08:36:33
root / linksafe
0755
importlib
--
May 13 2025 08:36:33
root / linksafe
0755
json
--
May 13 2025 08:36:33
root / linksafe
0755
lib-dynload
--
May 13 2025 08:36:33
root / linksafe
0755
logging
--
May 13 2025 08:36:33
root / linksafe
0755
multiprocessing
--
May 13 2025 08:36:33
root / linksafe
0755
pathlib
--
May 13 2025 08:36:33
root / linksafe
0755
pydoc_data
--
May 13 2025 08:36:33
root / linksafe
0755
re
--
May 13 2025 08:36:33
root / linksafe
0755
site-packages
--
May 13 2025 08:36:33
root / linksafe
0755
sqlite3
--
May 13 2025 08:36:33
root / linksafe
0755
sysconfig
--
May 13 2025 08:36:33
root / linksafe
0755
tomllib
--
May 13 2025 08:36:33
root / linksafe
0755
unittest
--
May 13 2025 08:36:33
root / linksafe
0755
urllib
--
May 13 2025 08:36:33
root / linksafe
0755
venv
--
May 13 2025 08:36:33
root / linksafe
0755
wsgiref
--
May 13 2025 08:36:33
root / linksafe
0755
xml
--
May 13 2025 08:36:33
root / linksafe
0755
xmlrpc
--
May 13 2025 08:36:33
root / linksafe
0755
zipfile
--
May 13 2025 08:36:33
root / linksafe
0755
zoneinfo
--
May 13 2025 08:36:33
root / linksafe
0755
LICENSE.txt
13.485 KB
April 08 2025 13:54:08
root / linksafe
0644
__future__.py
5.096 KB
April 25 2025 15:04:28
root / linksafe
0644
__hello__.py
0.222 KB
April 25 2025 15:04:28
root / linksafe
0644
_aix_support.py
3.927 KB
April 25 2025 15:04:26
root / linksafe
0644
_android_support.py
6.733 KB
April 25 2025 15:04:20
root / linksafe
0644
_apple_support.py
2.203 KB
April 25 2025 15:04:26
root / linksafe
0644
_collections_abc.py
31.508 KB
April 25 2025 15:04:21
root / linksafe
0644
_colorize.py
2.781 KB
April 25 2025 15:04:20
root / linksafe
0644
_compat_pickle.py
8.53 KB
April 25 2025 15:04:26
root / linksafe
0644
_compression.py
5.548 KB
April 25 2025 15:04:21
root / linksafe
0644
_ios_support.py
2.609 KB
April 25 2025 15:04:26
root / linksafe
0644
_markupbase.py
14.31 KB
April 25 2025 15:04:21
root / linksafe
0644
_opcode_metadata.py
9.048 KB
April 25 2025 15:04:26
root / linksafe
0644
_osx_support.py
21.507 KB
April 25 2025 15:04:26
root / linksafe
0644
_py_abc.py
6.044 KB
April 25 2025 15:04:27
root / linksafe
0644
_pydatetime.py
89.831 KB
April 25 2025 15:04:28
root / linksafe
0644
_pydecimal.py
221.956 KB
April 25 2025 15:04:19
root / linksafe
0644
_pyio.py
91.1 KB
April 25 2025 15:04:21
root / linksafe
0644
_pylong.py
11.553 KB
April 25 2025 15:04:21
root / linksafe
0644
_sitebuiltins.py
3.055 KB
April 25 2025 15:04:21
root / linksafe
0644
_strptime.py
28.693 KB
April 25 2025 15:04:27
root / linksafe
0644
_sysconfigdata__linux_x86_64-linux-gnu.py
65.617 KB
April 25 2025 15:09:38
root / linksafe
0644
_sysconfigdata_d_linux_x86_64-linux-gnu.py
65.6 KB
April 25 2025 15:05:28
root / linksafe
0644
_threading_local.py
7.051 KB
April 25 2025 15:04:20
root / linksafe
0644
_weakrefset.py
5.755 KB
April 25 2025 15:04:20
root / linksafe
0644
abc.py
6.385 KB
April 25 2025 15:04:20
root / linksafe
0644
antigravity.py
0.488 KB
April 25 2025 15:04:21
root / linksafe
0644
argparse.py
99.266 KB
April 25 2025 15:04:26
root / linksafe
0644
ast.py
63.912 KB
April 25 2025 15:04:26
root / linksafe
0644
base64.py
21.136 KB
April 25 2025 15:04:21
root / linksafe
0755
bdb.py
34.515 KB
April 25 2025 15:04:25
root / linksafe
0644
bisect.py
3.343 KB
April 25 2025 15:04:19
root / linksafe
0644
bz2.py
11.688 KB
April 25 2025 15:04:26
root / linksafe
0644
cProfile.py
6.481 KB
April 25 2025 15:04:19
root / linksafe
0755
calendar.py
25.466 KB
April 25 2025 15:04:26
root / linksafe
0644
cmd.py
14.957 KB
April 25 2025 15:04:19
root / linksafe
0644
code.py
12.861 KB
April 25 2025 15:04:21
root / linksafe
0644
codecs.py
36.063 KB
April 25 2025 15:04:21
root / linksafe
0644
codeop.py
5.691 KB
April 25 2025 15:04:20
root / linksafe
0644
colorsys.py
3.967 KB
April 25 2025 15:04:20
root / linksafe
0644
compileall.py
20.181 KB
April 25 2025 15:04:20
root / linksafe
0644
configparser.py
52.512 KB
April 25 2025 15:04:20
root / linksafe
0644
contextlib.py
27.149 KB
April 25 2025 15:04:20
root / linksafe
0644
contextvars.py
0.126 KB
April 25 2025 15:04:26
root / linksafe
0644
copy.py
8.765 KB
April 25 2025 15:04:20
root / linksafe
0644
copyreg.py
7.436 KB
April 25 2025 15:04:26
root / linksafe
0644
csv.py
18.729 KB
April 25 2025 15:04:21
root / linksafe
0644
dataclasses.py
63.032 KB
April 25 2025 15:04:26
root / linksafe
0644
datetime.py
0.262 KB
April 25 2025 15:04:28
root / linksafe
0644
decimal.py
2.732 KB
April 25 2025 15:04:26
root / linksafe
0644
difflib.py
81.414 KB
April 25 2025 15:04:21
root / linksafe
0644
dis.py
40.002 KB
April 25 2025 15:04:21
root / linksafe
0644
doctest.py
106.771 KB
April 25 2025 15:04:21
root / linksafe
0644
enum.py
83.481 KB
April 25 2025 15:04:21
root / linksafe
0644
filecmp.py
10.402 KB
April 25 2025 15:04:20
root / linksafe
0644
fileinput.py
15.349 KB
April 25 2025 15:04:21
root / linksafe
0644
fnmatch.py
6.035 KB
April 25 2025 15:04:20
root / linksafe
0644
fractions.py
39.083 KB
April 25 2025 15:04:19
root / linksafe
0644
ftplib.py
33.921 KB
April 25 2025 15:04:20
root / linksafe
0644
functools.py
38.206 KB
April 25 2025 15:04:28
root / linksafe
0644
genericpath.py
5.836 KB
April 25 2025 15:04:28
root / linksafe
0644
getopt.py
7.313 KB
April 25 2025 15:04:26
root / linksafe
0644
getpass.py
6.087 KB
April 25 2025 15:04:19
root / linksafe
0644
gettext.py
21.029 KB
April 25 2025 15:04:26
root / linksafe
0644
glob.py
19.258 KB
April 25 2025 15:04:20
root / linksafe
0644
graphlib.py
9.422 KB
April 25 2025 15:04:19
root / linksafe
0644
gzip.py
24.056 KB
April 25 2025 15:04:26
root / linksafe
0644
hashlib.py
9.13 KB
April 25 2025 15:04:28
root / linksafe
0644
heapq.py
22.484 KB
April 25 2025 15:04:19
root / linksafe
0644
hmac.py
7.535 KB
April 25 2025 15:04:21
root / linksafe
0644
imaplib.py
52.773 KB
April 25 2025 15:04:26
root / linksafe
0644
inspect.py
124.36 KB
April 25 2025 15:04:25
root / linksafe
0644
io.py
3.498 KB
April 25 2025 15:04:21
root / linksafe
0644
ipaddress.py
79.232 KB
April 25 2025 15:04:26
root / linksafe
0644
keyword.py
1.048 KB
April 25 2025 15:04:26
root / linksafe
0644
linecache.py
7.113 KB
April 25 2025 15:04:21
root / linksafe
0644
locale.py
77.13 KB
April 25 2025 15:04:26
root / linksafe
0644
lzma.py
13.085 KB
April 25 2025 15:04:27
root / linksafe
0644
mailbox.py
79.73 KB
April 25 2025 15:04:25
root / linksafe
0644
mimetypes.py
23.292 KB
April 25 2025 15:04:26
root / linksafe
0644
modulefinder.py
23.234 KB
April 25 2025 15:04:20
root / linksafe
0644
netrc.py
6.76 KB
April 25 2025 15:04:21
root / linksafe
0644
ntpath.py
31.542 KB
April 25 2025 15:04:20
root / linksafe
0644
nturl2path.py
2.318 KB
April 25 2025 15:04:26
root / linksafe
0644
numbers.py
11.198 KB
April 25 2025 15:04:28
root / linksafe
0644
opcode.py
2.759 KB
April 25 2025 15:04:28
root / linksafe
0644
operator.py
10.723 KB
April 25 2025 15:04:26
root / linksafe
0644
optparse.py
58.954 KB
April 25 2025 15:04:26
root / linksafe
0644
os.py
40.623 KB
April 25 2025 15:04:20
root / linksafe
0644
pdb.py
88.807 KB
April 25 2025 15:04:21
root / linksafe
0755
pickle.py
65.388 KB
April 25 2025 15:04:21
root / linksafe
0644
pickletools.py
91.848 KB
April 25 2025 15:04:20
root / linksafe
0644
pkgutil.py
17.853 KB
April 25 2025 15:04:21
root / linksafe
0644
platform.py
46.249 KB
April 25 2025 15:04:21
root / linksafe
0755
plistlib.py
29.096 KB
April 25 2025 15:04:19
root / linksafe
0644
poplib.py
14.262 KB
April 25 2025 15:04:19
root / linksafe
0644
posixpath.py
17.529 KB
April 25 2025 15:04:21
root / linksafe
0644
pprint.py
23.592 KB
April 25 2025 15:04:21
root / linksafe
0644
profile.py
22.61 KB
April 25 2025 15:04:21
root / linksafe
0755
pstats.py
28.609 KB
April 25 2025 15:04:20
root / linksafe
0644
pty.py
5.993 KB
April 25 2025 15:04:19
root / linksafe
0644
py_compile.py
7.653 KB
April 25 2025 15:04:26
root / linksafe
0644
pyclbr.py
11.129 KB
April 25 2025 15:04:19
root / linksafe
0644
pydoc.py
107.493 KB
April 25 2025 15:04:21
root / linksafe
0755
queue.py
13.165 KB
April 25 2025 15:04:26
root / linksafe
0644
quopri.py
7.028 KB
April 25 2025 15:04:26
root / linksafe
0755
random.py
36.139 KB
April 25 2025 15:04:19
root / linksafe
0644
reprlib.py
7.023 KB
April 25 2025 15:04:21
root / linksafe
0644
rlcompleter.py
7.732 KB
April 25 2025 15:04:28
root / linksafe
0644
runpy.py
12.583 KB
April 25 2025 15:04:19
root / linksafe
0644
sched.py
6.202 KB
April 25 2025 15:04:26
root / linksafe
0644
secrets.py
1.938 KB
April 25 2025 15:04:21
root / linksafe
0644
selectors.py
19.001 KB
April 25 2025 15:04:21
root / linksafe
0644
shelve.py
8.604 KB
April 25 2025 15:04:26
root / linksafe
0644
shlex.py
13.04 KB
April 25 2025 15:04:28
root / linksafe
0644
shutil.py
56.116 KB
April 25 2025 15:04:26
root / linksafe
0644
signal.py
2.437 KB
April 25 2025 15:04:26
root / linksafe
0644
site.py
24.791 KB
April 25 2025 15:04:25
root / linksafe
0644
smtplib.py
42.524 KB
April 25 2025 15:04:20
root / linksafe
0755
socket.py
36.874 KB
April 25 2025 15:04:27
root / linksafe
0644
socketserver.py
27.407 KB
April 25 2025 15:04:28
root / linksafe
0644
sre_compile.py
0.226 KB
April 25 2025 15:04:20
root / linksafe
0644
sre_constants.py
0.227 KB
April 25 2025 15:04:20
root / linksafe
0644
sre_parse.py
0.224 KB
April 25 2025 15:04:21
root / linksafe
0644
ssl.py
51.471 KB
April 25 2025 15:04:26
root / linksafe
0644
stat.py
6.003 KB
April 25 2025 15:04:26
root / linksafe
0644
statistics.py
60.382 KB
April 25 2025 15:04:21
root / linksafe
0644
string.py
11.51 KB
April 25 2025 15:04:26
root / linksafe
0644
stringprep.py
12.614 KB
April 25 2025 15:04:21
root / linksafe
0644
struct.py
0.251 KB
April 25 2025 15:04:21
root / linksafe
0644
subprocess.py
87.146 KB
April 25 2025 15:04:19
root / linksafe
0644
symtable.py
13.874 KB
April 25 2025 15:04:26
root / linksafe
0644
tabnanny.py
11.274 KB
April 25 2025 15:04:26
root / linksafe
0755
tarfile.py
107.496 KB
April 25 2025 15:04:21
root / linksafe
0755
tempfile.py
31.607 KB
April 25 2025 15:04:19
root / linksafe
0644
textwrap.py
19.472 KB
April 25 2025 15:04:20
root / linksafe
0644
this.py
0.979 KB
April 25 2025 15:04:21
root / linksafe
0644
threading.py
53.874 KB
April 25 2025 15:04:26
root / linksafe
0644
timeit.py
13.161 KB
April 25 2025 15:04:21
root / linksafe
0755
token.py
2.431 KB
April 25 2025 15:04:20
root / linksafe
0644
tokenize.py
21.063 KB
April 25 2025 15:04:26
root / linksafe
0644
trace.py
29.031 KB
April 25 2025 15:04:19
root / linksafe
0755
traceback.py
64.313 KB
April 25 2025 15:04:26
root / linksafe
0644
tracemalloc.py
17.624 KB
April 25 2025 15:04:26
root / linksafe
0644
tty.py
1.987 KB
April 25 2025 15:04:19
root / linksafe
0644
types.py
10.944 KB
April 25 2025 15:04:19
root / linksafe
0644
typing.py
129.607 KB
April 25 2025 15:04:26
root / linksafe
0644
uuid.py
28.458 KB
April 25 2025 15:04:21
root / linksafe
0644
warnings.py
26.316 KB
April 25 2025 15:04:21
root / linksafe
0644
wave.py
22.691 KB
April 25 2025 15:04:20
root / linksafe
0644
weakref.py
21.009 KB
April 25 2025 15:04:26
root / linksafe
0644
webbrowser.py
23.729 KB
April 25 2025 15:04:26
root / linksafe
0755
zipapp.py
8.416 KB
April 25 2025 15:04:21
root / linksafe
0644
zipimport.py
32.119 KB
April 25 2025 15:04:26
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF