SILENT KILLERPanel

Current Path: > > opt > cloudlinux > venv > lib64 > python3.11 > site-packages > setuptools


Operation   : Linux premium131.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
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/cloudlinux/venv/lib64/python3.11/site-packages/setuptools

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
_distutils Directory - -
_vendor Directory - -
command Directory - -
compat Directory - -
config Directory - -
tests Directory - -
__init__.py File 10406 bytes April 17 2025 13:10:58.
_core_metadata.py File 11978 bytes April 17 2025 13:10:58.
_entry_points.py File 2310 bytes April 17 2025 13:10:58.
_imp.py File 2435 bytes April 17 2025 13:10:58.
_importlib.py File 223 bytes April 17 2025 13:10:58.
_itertools.py File 657 bytes April 17 2025 13:10:58.
_normalization.py File 5824 bytes April 17 2025 13:10:58.
_path.py File 2685 bytes April 17 2025 13:10:58.
_reqs.py File 1438 bytes April 17 2025 13:10:58.
_shutil.py File 1496 bytes April 17 2025 13:10:58.
_static.py File 4855 bytes April 17 2025 13:10:58.
archive_util.py File 7356 bytes April 17 2025 13:10:58.
build_meta.py File 20446 bytes April 17 2025 13:10:58.
cli-32.exe File 11776 bytes April 17 2025 13:10:58.
cli-64.exe File 14336 bytes April 17 2025 13:10:58.
cli-arm64.exe File 13824 bytes April 17 2025 13:10:58.
cli.exe File 11776 bytes April 17 2025 13:10:58.
depends.py File 5965 bytes April 17 2025 13:10:58.
discovery.py File 21258 bytes April 17 2025 13:10:58.
dist.py File 44897 bytes April 17 2025 13:10:58.
errors.py File 3024 bytes April 17 2025 13:10:58.
extension.py File 6683 bytes April 17 2025 13:10:58.
glob.py File 6062 bytes April 17 2025 13:10:58.
gui-32.exe File 11776 bytes April 17 2025 13:10:58.
gui-64.exe File 14336 bytes April 17 2025 13:10:58.
gui-arm64.exe File 13824 bytes April 17 2025 13:10:58.
gui.exe File 11776 bytes April 17 2025 13:10:58.
installer.py File 5110 bytes April 17 2025 13:10:58.
launch.py File 820 bytes April 17 2025 13:10:58.
logging.py File 1261 bytes April 17 2025 13:10:58.
modified.py File 568 bytes April 17 2025 13:10:58.
monkey.py File 3717 bytes April 17 2025 13:10:58.
msvc.py File 41631 bytes April 17 2025 13:10:58.
namespaces.py File 3171 bytes April 17 2025 13:10:58.
package_index.py File 39095 bytes April 17 2025 13:10:58.
sandbox.py File 14906 bytes April 17 2025 13:10:58.
script (dev).tmpl File 218 bytes April 17 2025 13:10:58.
script.tmpl File 138 bytes April 17 2025 13:10:58.
unicode_utils.py File 3189 bytes April 17 2025 13:10:58.
version.py File 161 bytes April 17 2025 13:10:58.
warnings.py File 3796 bytes April 17 2025 13:10:58.
wheel.py File 8624 bytes April 17 2025 13:10:58.
windows_support.py File 726 bytes April 17 2025 13:10:58.

Reading File: //opt/cloudlinux/venv/lib64/python3.11/site-packages/setuptools/glob.py

"""
Filename globbing utility. Mostly a copy of `glob` from Python 3.5.

Changes include:
 * `yield from` and PEP3102 `*` removed.
 * Hidden files are not ignored.
"""

from __future__ import annotations

import fnmatch
import os
import re
from collections.abc import Iterable, Iterator
from typing import TYPE_CHECKING, AnyStr, overload

if TYPE_CHECKING:
    from _typeshed import BytesPath, StrOrBytesPath, StrPath

__all__ = ["glob", "iglob", "escape"]


def glob(pathname: AnyStr, recursive: bool = False) -> list[AnyStr]:
    """Return a list of paths matching a pathname pattern.

    The pattern may contain simple shell-style wildcards a la
    fnmatch. However, unlike fnmatch, filenames starting with a
    dot are special cases that are not matched by '*' and '?'
    patterns.

    If recursive is true, the pattern '**' will match any files and
    zero or more directories and subdirectories.
    """
    return list(iglob(pathname, recursive=recursive))


def iglob(pathname: AnyStr, recursive: bool = False) -> Iterator[AnyStr]:
    """Return an iterator which yields the paths matching a pathname pattern.

    The pattern may contain simple shell-style wildcards a la
    fnmatch. However, unlike fnmatch, filenames starting with a
    dot are special cases that are not matched by '*' and '?'
    patterns.

    If recursive is true, the pattern '**' will match any files and
    zero or more directories and subdirectories.
    """
    it = _iglob(pathname, recursive)
    if recursive and _isrecursive(pathname):
        s = next(it)  # skip empty string
        assert not s
    return it


def _iglob(pathname: AnyStr, recursive: bool) -> Iterator[AnyStr]:
    dirname, basename = os.path.split(pathname)
    glob_in_dir = glob2 if recursive and _isrecursive(basename) else glob1

    if not has_magic(pathname):
        if basename:
            if os.path.lexists(pathname):
                yield pathname
        else:
            # Patterns ending with a slash should match only directories
            if os.path.isdir(dirname):
                yield pathname
        return

    if not dirname:
        yield from glob_in_dir(dirname, basename)
        return
    # `os.path.split()` returns the argument itself as a dirname if it is a
    # drive or UNC path.  Prevent an infinite recursion if a drive or UNC path
    # contains magic characters (i.e. r'\\?\C:').
    if dirname != pathname and has_magic(dirname):
        dirs: Iterable[AnyStr] = _iglob(dirname, recursive)
    else:
        dirs = [dirname]
    if not has_magic(basename):
        glob_in_dir = glob0
    for dirname in dirs:
        for name in glob_in_dir(dirname, basename):
            yield os.path.join(dirname, name)


# These 2 helper functions non-recursively glob inside a literal directory.
# They return a list of basenames. `glob1` accepts a pattern while `glob0`
# takes a literal basename (so it only has to check for its existence).


@overload
def glob1(dirname: StrPath, pattern: str) -> list[str]: ...
@overload
def glob1(dirname: BytesPath, pattern: bytes) -> list[bytes]: ...
def glob1(dirname: StrOrBytesPath, pattern: str | bytes) -> list[str] | list[bytes]:
    if not dirname:
        if isinstance(pattern, bytes):
            dirname = os.curdir.encode('ASCII')
        else:
            dirname = os.curdir
    try:
        names = os.listdir(dirname)
    except OSError:
        return []
    # mypy false-positives: str or bytes type possibility is always kept in sync
    return fnmatch.filter(names, pattern)  # type: ignore[type-var, return-value]


def glob0(dirname, basename):
    if not basename:
        # `os.path.split()` returns an empty basename for paths ending with a
        # directory separator.  'q*x/' should match only directories.
        if os.path.isdir(dirname):
            return [basename]
    else:
        if os.path.lexists(os.path.join(dirname, basename)):
            return [basename]
    return []


# This helper function recursively yields relative pathnames inside a literal
# directory.


@overload
def glob2(dirname: StrPath, pattern: str) -> Iterator[str]: ...
@overload
def glob2(dirname: BytesPath, pattern: bytes) -> Iterator[bytes]: ...
def glob2(dirname: StrOrBytesPath, pattern: str | bytes) -> Iterator[str | bytes]:
    assert _isrecursive(pattern)
    yield pattern[:0]
    yield from _rlistdir(dirname)


# Recursively yields relative pathnames inside a literal directory.
@overload
def _rlistdir(dirname: StrPath) -> Iterator[str]: ...
@overload
def _rlistdir(dirname: BytesPath) -> Iterator[bytes]: ...
def _rlistdir(dirname: StrOrBytesPath) -> Iterator[str | bytes]:
    if not dirname:
        if isinstance(dirname, bytes):
            dirname = os.curdir.encode('ASCII')
        else:
            dirname = os.curdir
    try:
        names = os.listdir(dirname)
    except OSError:
        return
    for x in names:
        yield x
        # mypy false-positives: str or bytes type possibility is always kept in sync
        path = os.path.join(dirname, x) if dirname else x  # type: ignore[arg-type]
        for y in _rlistdir(path):
            yield os.path.join(x, y)  # type: ignore[arg-type]


magic_check = re.compile('([*?[])')
magic_check_bytes = re.compile(b'([*?[])')


def has_magic(s: str | bytes) -> bool:
    if isinstance(s, bytes):
        return magic_check_bytes.search(s) is not None
    else:
        return magic_check.search(s) is not None


def _isrecursive(pattern: str | bytes) -> bool:
    if isinstance(pattern, bytes):
        return pattern == b'**'
    else:
        return pattern == '**'


def escape(pathname):
    """Escape all special characters."""
    # Escaping is done by wrapping any of "*?[" between square brackets.
    # Metacharacters do not work in the drive part and shouldn't be escaped.
    drive, pathname = os.path.splitdrive(pathname)
    if isinstance(pathname, bytes):
        pathname = magic_check_bytes.sub(rb'[\1]', pathname)
    else:
        pathname = magic_check.sub(r'[\1]', pathname)
    return drive + pathname

SILENT KILLER Tool