SILENT KILLERPanel

Current Path: > > usr > lib64 > python2.7 > distutils > > >


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: //usr/lib64/python2.7/distutils///

NameTypeSizeLast ModifiedActions
command Directory - -
README File 295 bytes April 10 2024 04:58:35.
__init__.py File 236 bytes April 10 2024 04:58:35.
__init__.pyc File 415 bytes April 10 2024 04:58:46.
__init__.pyo File 415 bytes April 10 2024 04:58:46.
archive_util.py File 8219 bytes April 10 2024 04:58:35.
archive_util.pyc File 7601 bytes April 10 2024 04:58:46.
archive_util.pyo File 7601 bytes April 10 2024 04:58:46.
bcppcompiler.py File 14941 bytes April 10 2024 04:58:35.
bcppcompiler.pyc File 7882 bytes April 10 2024 04:58:46.
bcppcompiler.pyo File 7882 bytes April 10 2024 04:58:46.
ccompiler.py File 46726 bytes April 10 2024 04:58:35.
ccompiler.pyc File 36882 bytes April 10 2024 04:58:46.
ccompiler.pyo File 36741 bytes April 10 2024 04:58:44.
cmd.py File 19270 bytes April 10 2024 04:58:35.
cmd.pyc File 16804 bytes April 10 2024 04:58:46.
cmd.pyo File 16804 bytes April 10 2024 04:58:46.
config.py File 4134 bytes April 10 2024 04:58:35.
config.pyc File 3565 bytes April 10 2024 04:58:46.
config.pyo File 3565 bytes April 10 2024 04:58:46.
core.py File 9019 bytes April 10 2024 04:58:35.
core.pyc File 7536 bytes April 10 2024 04:58:46.
core.pyo File 7536 bytes April 10 2024 04:58:46.
cygwinccompiler.py File 17735 bytes April 10 2024 04:58:35.
cygwinccompiler.pyc File 9825 bytes April 10 2024 04:58:46.
cygwinccompiler.pyo File 9825 bytes April 10 2024 04:58:46.
debug.py File 162 bytes April 10 2024 04:58:35.
debug.pyc File 254 bytes April 10 2024 04:58:46.
debug.pyo File 254 bytes April 10 2024 04:58:46.
dep_util.py File 3509 bytes April 10 2024 04:58:35.
dep_util.pyc File 3180 bytes April 10 2024 04:58:46.
dep_util.pyo File 3180 bytes April 10 2024 04:58:46.
dir_util.py File 7868 bytes April 10 2024 04:58:35.
dir_util.pyc File 6786 bytes April 10 2024 04:58:46.
dir_util.pyo File 6786 bytes April 10 2024 04:58:46.
dist.py File 50049 bytes April 10 2024 04:58:35.
dist.pyc File 39176 bytes April 10 2024 04:58:46.
dist.pyo File 39176 bytes April 10 2024 04:58:46.
emxccompiler.py File 11931 bytes April 10 2024 04:58:35.
emxccompiler.pyc File 7467 bytes April 10 2024 04:58:46.
emxccompiler.pyo File 7467 bytes April 10 2024 04:58:46.
errors.py File 3494 bytes April 10 2024 04:58:35.
errors.pyc File 6285 bytes April 10 2024 04:58:46.
errors.pyo File 6285 bytes April 10 2024 04:58:46.
extension.py File 10904 bytes April 10 2024 04:58:35.
extension.pyc File 7412 bytes April 10 2024 04:58:46.
extension.pyo File 7186 bytes April 10 2024 04:58:44.
fancy_getopt.py File 17948 bytes April 10 2024 04:58:35.
fancy_getopt.pyc File 11958 bytes April 10 2024 04:58:46.
fancy_getopt.pyo File 11781 bytes April 10 2024 04:58:44.
file_util.py File 8131 bytes April 10 2024 04:58:35.
file_util.pyc File 6750 bytes April 10 2024 04:58:46.
file_util.pyo File 6750 bytes April 10 2024 04:58:46.
filelist.py File 12689 bytes April 10 2024 04:58:35.
filelist.pyc File 10756 bytes April 10 2024 04:58:46.
filelist.pyo File 10756 bytes April 10 2024 04:58:46.
log.py File 1686 bytes April 10 2024 04:58:35.
log.pyc File 2786 bytes April 10 2024 04:58:46.
log.pyo File 2786 bytes April 10 2024 04:58:46.
msvc9compiler.py File 31004 bytes April 10 2024 04:58:35.
msvc9compiler.pyc File 21497 bytes April 10 2024 04:58:46.
msvc9compiler.pyo File 21424 bytes April 10 2024 04:58:44.
msvccompiler.py File 23637 bytes April 10 2024 04:58:35.
msvccompiler.pyc File 17525 bytes April 10 2024 04:58:46.
msvccompiler.pyo File 17525 bytes April 10 2024 04:58:46.
spawn.py File 8648 bytes April 10 2024 04:58:35.
spawn.pyc File 6427 bytes April 10 2024 04:58:46.
spawn.pyo File 6427 bytes April 10 2024 04:58:46.
sysconfig.py File 17707 bytes April 10 2024 04:58:41.
sysconfig.py.debug-build File 17622 bytes April 10 2024 04:58:35.
sysconfig.pyc File 13404 bytes April 10 2024 04:58:46.
sysconfig.pyo File 13404 bytes April 10 2024 04:58:46.
text_file.py File 12428 bytes April 10 2024 04:58:35.
text_file.pyc File 9259 bytes April 10 2024 04:58:46.
text_file.pyo File 9259 bytes April 10 2024 04:58:46.
unixccompiler.py File 14222 bytes April 10 2024 04:58:35.
unixccompiler.py.distutils-rpath File 13677 bytes April 10 2024 04:58:35.
unixccompiler.pyc File 8229 bytes April 10 2024 04:58:46.
unixccompiler.pyo File 8229 bytes April 10 2024 04:58:46.
util.py File 18236 bytes April 10 2024 04:58:35.
util.pyc File 14386 bytes April 10 2024 04:58:46.
util.pyo File 14386 bytes April 10 2024 04:58:46.
version.py File 11433 bytes April 10 2024 04:58:35.
version.pyc File 7208 bytes April 10 2024 04:58:46.
version.pyo File 7208 bytes April 10 2024 04:58:46.
versionpredicate.py File 5095 bytes April 10 2024 04:58:35.
versionpredicate.pyc File 5542 bytes April 10 2024 04:58:46.
versionpredicate.pyo File 5542 bytes April 10 2024 04:58:46.

Reading File: //usr/lib64/python2.7/distutils////file_util.py

"""distutils.file_util

Utility functions for operating on single files.
"""

__revision__ = "$Id$"

import os
from distutils.errors import DistutilsFileError
from distutils import log

# for generating verbose output in 'copy_file()'
_copy_action = {None: 'copying',
                'hard': 'hard linking',
                'sym': 'symbolically linking'}


def _copy_file_contents(src, dst, buffer_size=16*1024):
    """Copy the file 'src' to 'dst'.

    Both must be filenames. Any error opening either file, reading from
    'src', or writing to 'dst', raises DistutilsFileError.  Data is
    read/written in chunks of 'buffer_size' bytes (default 16k).  No attempt
    is made to handle anything apart from regular files.
    """
    # Stolen from shutil module in the standard library, but with
    # custom error-handling added.
    fsrc = None
    fdst = None
    try:
        try:
            fsrc = open(src, 'rb')
        except os.error, (errno, errstr):
            raise DistutilsFileError("could not open '%s': %s" % (src, errstr))

        if os.path.exists(dst):
            try:
                os.unlink(dst)
            except os.error, (errno, errstr):
                raise DistutilsFileError(
                      "could not delete '%s': %s" % (dst, errstr))

        try:
            fdst = open(dst, 'wb')
        except os.error, (errno, errstr):
            raise DistutilsFileError(
                  "could not create '%s': %s" % (dst, errstr))

        while 1:
            try:
                buf = fsrc.read(buffer_size)
            except os.error, (errno, errstr):
                raise DistutilsFileError(
                      "could not read from '%s': %s" % (src, errstr))

            if not buf:
                break

            try:
                fdst.write(buf)
            except os.error, (errno, errstr):
                raise DistutilsFileError(
                      "could not write to '%s': %s" % (dst, errstr))

    finally:
        if fdst:
            fdst.close()
        if fsrc:
            fsrc.close()

def copy_file(src, dst, preserve_mode=1, preserve_times=1, update=0,
              link=None, verbose=1, dry_run=0):
    """Copy a file 'src' to 'dst'.

    If 'dst' is a directory, then 'src' is copied there with the same name;
    otherwise, it must be a filename.  (If the file exists, it will be
    ruthlessly clobbered.)  If 'preserve_mode' is true (the default),
    the file's mode (type and permission bits, or whatever is analogous on
    the current platform) is copied.  If 'preserve_times' is true (the
    default), the last-modified and last-access times are copied as well.
    If 'update' is true, 'src' will only be copied if 'dst' does not exist,
    or if 'dst' does exist but is older than 'src'.

    'link' allows you to make hard links (os.link) or symbolic links
    (os.symlink) instead of copying: set it to "hard" or "sym"; if it is
    None (the default), files are copied.  Don't set 'link' on systems that
    don't support it: 'copy_file()' doesn't check if hard or symbolic
    linking is available. If hardlink fails, falls back to
    _copy_file_contents().

    Under Mac OS, uses the native file copy function in macostools; on
    other systems, uses '_copy_file_contents()' to copy file contents.

    Return a tuple (dest_name, copied): 'dest_name' is the actual name of
    the output file, and 'copied' is true if the file was copied (or would
    have been copied, if 'dry_run' true).
    """
    # XXX if the destination file already exists, we clobber it if
    # copying, but blow up if linking.  Hmmm.  And I don't know what
    # macostools.copyfile() does.  Should definitely be consistent, and
    # should probably blow up if destination exists and we would be
    # changing it (ie. it's not already a hard/soft link to src OR
    # (not update) and (src newer than dst).

    from distutils.dep_util import newer
    from stat import ST_ATIME, ST_MTIME, ST_MODE, S_IMODE

    if not os.path.isfile(src):
        raise DistutilsFileError(
              "can't copy '%s': doesn't exist or not a regular file" % src)

    if os.path.isdir(dst):
        dir = dst
        dst = os.path.join(dst, os.path.basename(src))
    else:
        dir = os.path.dirname(dst)

    if update and not newer(src, dst):
        if verbose >= 1:
            log.debug("not copying %s (output up-to-date)", src)
        return dst, 0

    try:
        action = _copy_action[link]
    except KeyError:
        raise ValueError("invalid value '%s' for 'link' argument" % link)

    if verbose >= 1:
        if os.path.basename(dst) == os.path.basename(src):
            log.info("%s %s -> %s", action, src, dir)
        else:
            log.info("%s %s -> %s", action, src, dst)

    if dry_run:
        return (dst, 1)

    # If linking (hard or symbolic), use the appropriate system call
    # (Unix only, of course, but that's the caller's responsibility)
    if link == 'hard':
        if not (os.path.exists(dst) and os.path.samefile(src, dst)):
            try:
                os.link(src, dst)
                return (dst, 1)
            except OSError:
                # If hard linking fails, fall back on copying file
                # (some special filesystems don't support hard linking
                #  even under Unix, see issue #8876).
                pass
    elif link == 'sym':
        if not (os.path.exists(dst) and os.path.samefile(src, dst)):
            os.symlink(src, dst)
            return (dst, 1)

    # Otherwise (non-Mac, not linking), copy the file contents and
    # (optionally) copy the times and mode.
    _copy_file_contents(src, dst)
    if preserve_mode or preserve_times:
        st = os.stat(src)

        # According to David Ascher <da@ski.org>, utime() should be done
        # before chmod() (at least under NT).
        if preserve_times:
            os.utime(dst, (st[ST_ATIME], st[ST_MTIME]))
        if preserve_mode:
            os.chmod(dst, S_IMODE(st[ST_MODE]))

    return (dst, 1)

# XXX I suspect this is Unix-specific -- need porting help!
def move_file (src, dst, verbose=1, dry_run=0):
    """Move a file 'src' to 'dst'.

    If 'dst' is a directory, the file will be moved into it with the same
    name; otherwise, 'src' is just renamed to 'dst'.  Return the new
    full name of the file.

    Handles cross-device moves on Unix using 'copy_file()'.  What about
    other systems???
    """
    from os.path import exists, isfile, isdir, basename, dirname
    import errno

    if verbose >= 1:
        log.info("moving %s -> %s", src, dst)

    if dry_run:
        return dst

    if not isfile(src):
        raise DistutilsFileError("can't move '%s': not a regular file" % src)

    if isdir(dst):
        dst = os.path.join(dst, basename(src))
    elif exists(dst):
        raise DistutilsFileError(
              "can't move '%s': destination '%s' already exists" %
              (src, dst))

    if not isdir(dirname(dst)):
        raise DistutilsFileError(
              "can't move '%s': destination '%s' not a valid path" % \
              (src, dst))

    copy_it = 0
    try:
        os.rename(src, dst)
    except os.error, (num, msg):
        if num == errno.EXDEV:
            copy_it = 1
        else:
            raise DistutilsFileError(
                  "couldn't move '%s' to '%s': %s" % (src, dst, msg))

    if copy_it:
        copy_file(src, dst, verbose=verbose)
        try:
            os.unlink(src)
        except os.error, (num, msg):
            try:
                os.unlink(dst)
            except os.error:
                pass
            raise DistutilsFileError(
                  ("couldn't move '%s' to '%s' by copy/delete: " +
                   "delete '%s' failed: %s") %
                  (src, dst, src, msg))
    return dst


def write_file (filename, contents):
    """Create a file with the specified name and write 'contents' (a
    sequence of strings without line terminators) to it.
    """
    f = open(filename, "w")
    try:
        for line in contents:
            f.write(line + "\n")
    finally:
        f.close()

SILENT KILLER Tool