GRAYBYTE WORDPRESS FILE MANAGER4197

Server IP : 198.54.121.189 / Your IP : 216.73.216.224
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/cloudlinux/venv/lib/python3.11/site-packages/setuptools/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/cloudlinux/venv/lib/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

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
June 25 2025 08:31:36
root / root
0755
__pycache__
--
May 15 2025 08:30:44
root / root
0755
_distutils
--
May 15 2025 08:30:34
root / root
0755
_vendor
--
May 15 2025 08:30:38
root / root
0755
command
--
May 15 2025 08:30:34
root / root
0755
compat
--
May 15 2025 08:30:34
root / root
0755
config
--
May 15 2025 08:30:34
root / root
0755
tests
--
May 15 2025 08:30:34
root / root
0755
__init__.py
10.162 KB
April 17 2025 13:10:58
root / root
0644
_core_metadata.py
11.697 KB
April 17 2025 13:10:58
root / root
0644
_entry_points.py
2.256 KB
April 17 2025 13:10:58
root / root
0644
_imp.py
2.378 KB
April 17 2025 13:10:58
root / root
0644
_importlib.py
0.218 KB
April 17 2025 13:10:58
root / root
0644
_itertools.py
0.642 KB
April 17 2025 13:10:58
root / root
0644
_normalization.py
5.688 KB
April 17 2025 13:10:58
root / root
0644
_path.py
2.622 KB
April 17 2025 13:10:58
root / root
0644
_reqs.py
1.404 KB
April 17 2025 13:10:58
root / root
0644
_shutil.py
1.461 KB
April 17 2025 13:10:58
root / root
0644
_static.py
4.741 KB
April 17 2025 13:10:58
root / root
0644
archive_util.py
7.184 KB
April 17 2025 13:10:58
root / root
0644
build_meta.py
19.967 KB
April 17 2025 13:10:58
root / root
0644
cli-32.exe
11.5 KB
April 17 2025 13:10:58
root / root
0644
cli-64.exe
14 KB
April 17 2025 13:10:58
root / root
0644
cli-arm64.exe
13.5 KB
April 17 2025 13:10:58
root / root
0644
cli.exe
11.5 KB
April 17 2025 13:10:58
root / root
0644
depends.py
5.825 KB
April 17 2025 13:10:58
root / root
0644
discovery.py
20.76 KB
April 17 2025 13:10:58
root / root
0644
dist.py
43.845 KB
April 17 2025 13:10:58
root / root
0644
errors.py
2.953 KB
April 17 2025 13:10:58
root / root
0644
extension.py
6.526 KB
April 17 2025 13:10:58
root / root
0644
glob.py
5.92 KB
April 17 2025 13:10:58
root / root
0644
gui-32.exe
11.5 KB
April 17 2025 13:10:58
root / root
0644
gui-64.exe
14 KB
April 17 2025 13:10:58
root / root
0644
gui-arm64.exe
13.5 KB
April 17 2025 13:10:58
root / root
0644
gui.exe
11.5 KB
April 17 2025 13:10:58
root / root
0644
installer.py
4.99 KB
April 17 2025 13:10:58
root / root
0644
launch.py
0.801 KB
April 17 2025 13:10:58
root / root
0644
logging.py
1.231 KB
April 17 2025 13:10:58
root / root
0644
modified.py
0.555 KB
April 17 2025 13:10:58
root / root
0644
monkey.py
3.63 KB
April 17 2025 13:10:58
root / root
0644
msvc.py
40.655 KB
April 17 2025 13:10:58
root / root
0644
namespaces.py
3.097 KB
April 17 2025 13:10:58
root / root
0644
package_index.py
38.179 KB
April 17 2025 13:10:58
root / root
0644
sandbox.py
14.557 KB
April 17 2025 13:10:58
root / root
0644
script (dev).tmpl
0.213 KB
April 17 2025 13:10:58
root / root
0644
script.tmpl
0.135 KB
April 17 2025 13:10:58
root / root
0644
unicode_utils.py
3.114 KB
April 17 2025 13:10:58
root / root
0644
version.py
0.157 KB
April 17 2025 13:10:58
root / root
0644
warnings.py
3.707 KB
April 17 2025 13:10:58
root / root
0644
wheel.py
8.422 KB
April 17 2025 13:10:58
root / root
0644
windows_support.py
0.709 KB
April 17 2025 13:10:58
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF