GRAYBYTE WORDPRESS FILE MANAGER6523

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

Command :


Current File : /lib/python3.6/site-packages/setuptools//glob.py
"""
Filename globbing utility. Mostly a copy of `glob` from Python 3.5.

Changes include:
 * `yield from` and PEP3102 `*` removed.
 * `bytes` changed to `six.binary_type`.
 * Hidden files are not ignored.
"""

import os
import re
import fnmatch
from setuptools.extern.six import binary_type

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


def glob(pathname, recursive=False):
    """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, recursive=False):
    """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, recursive):
    dirname, basename = os.path.split(pathname)
    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:
        if recursive and _isrecursive(basename):
            for x in glob2(dirname, basename):
                yield x
        else:
            for x in glob1(dirname, basename):
                yield x
        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 = _iglob(dirname, recursive)
    else:
        dirs = [dirname]
    if has_magic(basename):
        if recursive and _isrecursive(basename):
            glob_in_dir = glob2
        else:
            glob_in_dir = glob1
    else:
        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).


def glob1(dirname, pattern):
    if not dirname:
        if isinstance(pattern, binary_type):
            dirname = os.curdir.encode('ASCII')
        else:
            dirname = os.curdir
    try:
        names = os.listdir(dirname)
    except OSError:
        return []
    return fnmatch.filter(names, pattern)


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.


def glob2(dirname, pattern):
    assert _isrecursive(pattern)
    yield pattern[:0]
    for x in _rlistdir(dirname):
        yield x


# Recursively yields relative pathnames inside a literal directory.
def _rlistdir(dirname):
    if not dirname:
        if isinstance(dirname, binary_type):
            dirname = binary_type(os.curdir, 'ASCII')
        else:
            dirname = os.curdir
    try:
        names = os.listdir(dirname)
    except os.error:
        return
    for x in names:
        yield x
        path = os.path.join(dirname, x) if dirname else x
        for y in _rlistdir(path):
            yield os.path.join(x, y)


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


def has_magic(s):
    if isinstance(s, binary_type):
        match = magic_check_bytes.search(s)
    else:
        match = magic_check.search(s)
    return match is not None


def _isrecursive(pattern):
    if isinstance(pattern, binary_type):
        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, binary_type):
        pathname = magic_check_bytes.sub(br'[\1]', pathname)
    else:
        pathname = magic_check.sub(r'[\1]', pathname)
    return drive + pathname

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
July 01 2025 22:14:40
root / root
0755
__pycache__
--
August 20 2024 08:30:55
root / root
0755
_vendor
--
August 20 2024 08:30:55
root / root
0755
command
--
August 20 2024 08:30:55
root / root
0755
extern
--
August 20 2024 08:30:55
root / root
0755
__init__.py
5.566 KB
August 19 2024 07:28:57
root / root
0644
archive_util.py
6.438 KB
August 19 2024 07:28:57
root / root
0644
build_meta.py
5.538 KB
August 19 2024 07:28:57
root / root
0644
config.py
17.584 KB
August 19 2024 07:28:57
root / root
0644
dep_util.py
0.913 KB
August 19 2024 07:28:57
root / root
0644
depends.py
5.7 KB
August 19 2024 07:28:57
root / root
0644
dist.py
41.614 KB
August 19 2024 07:28:57
root / root
0644
extension.py
1.688 KB
August 19 2024 07:28:57
root / root
0644
glibc.py
3.072 KB
August 19 2024 07:28:57
root / root
0644
glob.py
5.085 KB
August 19 2024 07:28:57
root / root
0644
launch.py
0.769 KB
August 19 2024 07:28:57
root / root
0644
lib2to3_ex.py
1.966 KB
August 19 2024 07:28:57
root / root
0644
monkey.py
5.138 KB
August 19 2024 07:28:57
root / root
0644
msvc.py
39.919 KB
August 19 2024 07:28:57
root / root
0644
namespaces.py
3.124 KB
August 19 2024 07:28:57
root / root
0644
package_index.py
39.192 KB
August 19 2024 07:28:57
root / root
0644
pep425tags.py
10.618 KB
August 19 2024 07:28:57
root / root
0644
py27compat.py
0.523 KB
August 19 2024 07:28:57
root / root
0644
py31compat.py
1.164 KB
August 19 2024 07:28:57
root / root
0644
py33compat.py
1.154 KB
August 19 2024 07:28:57
root / root
0644
py36compat.py
2.823 KB
August 19 2024 07:28:57
root / root
0644
sandbox.py
13.941 KB
August 19 2024 07:28:57
root / root
0644
script (dev).tmpl
0.196 KB
August 19 2024 07:28:57
root / root
0644
script.tmpl
0.135 KB
August 19 2024 07:28:57
root / root
0644
site-patch.py
2.253 KB
August 19 2024 07:28:57
root / root
0644
ssl_support.py
8.293 KB
August 19 2024 07:28:57
root / root
0644
unicode_utils.py
0.973 KB
August 19 2024 07:28:57
root / root
0644
version.py
0.141 KB
August 19 2024 07:28:57
root / root
0644
wheel.py
7.596 KB
August 19 2024 07:28:57
root / root
0644
windows_support.py
0.697 KB
August 19 2024 07:28:57
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF