Psyduck - 可達鴨 之 鴨力山大2


Server : LiteSpeed
System : Linux premium217.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User : alloknri ( 880)
PHP Version : 8.1.34
Disable Function : NONE
Directory :  /opt/alt/python27/lib64/python2.7/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //opt/alt/python27/lib64/python2.7/subprocess.py
# subprocess - Subprocesses with accessible I/O streams
#
# For more information about this module, see PEP 324.
#
# Copyright (c) 2003-2005 by Peter Astrand <astrand@lysator.liu.se>
#
# Licensed to PSF under a Contributor Agreement.
# See http://www.python.org/2.4/license for licensing details.

r"""Subprocesses with accessible I/O streams

This module allows you to spawn processes, connect to their
input/output/error pipes, and obtain their return codes.

For a complete description of this module see the Python documentation.

Main API
========
call(...): Runs a command, waits for it to complete, then returns
    the return code.
check_call(...): Same as call() but raises CalledProcessError()
    if return code is not 0
check_output(...): Same as check_call() but returns the contents of
    stdout instead of a return code
Popen(...): A class for flexibly executing a command in a new process

Constants
---------
PIPE:    Special value that indicates a pipe should be created
STDOUT:  Special value that indicates that stderr should go to stdout
"""

import sys
mswindows = (sys.platform == "win32")

import os
import types
import traceback
import gc
import signal
import errno

# Exception classes used by this module.
class CalledProcessError(Exception):
    """This exception is raised when a process run by check_call() or
    check_output() returns a non-zero exit status.

    Attributes:
      cmd, returncode, output
    """
    def __init__(self, returncode, cmd, output=None):
        self.returncode = returncode
        self.cmd = cmd
        self.output = output
    def __str__(self):
        return "Command '%s' returned non-zero exit status %d" % (self.cmd, self.returncode)


if mswindows:
    import threading
    import msvcrt
    import _subprocess
    class STARTUPINFO:
        dwFlags = 0
        hStdInput = None
        hStdOutput = None
        hStdError = None
        wShowWindow = 0
    class pywintypes:
        error = IOError
else:
    import select
    _has_poll = hasattr(select, 'poll')
    try:
        import threading
    except ImportError:
        threading = None
    import fcntl
    import pickle

    # When select or poll has indicated that the file is writable,
    # we can write up to _PIPE_BUF bytes without risk of blocking.
    # POSIX defines PIPE_BUF as >= 512.
    _PIPE_BUF = getattr(select, 'PIPE_BUF', 512)


__all__ = ["Popen", "PIPE", "STDOUT", "call", "check_call",
           "check_output", "CalledProcessError"]

if mswindows:
    from _subprocess import (CREATE_NEW_CONSOLE, CREATE_NEW_PROCESS_GROUP,
                             STD_INPUT_HANDLE, STD_OUTPUT_HANDLE,
                             STD_ERROR_HANDLE, SW_HIDE,
                             STARTF_USESTDHANDLES, STARTF_USESHOWWINDOW)

    __all__.extend(["CREATE_NEW_CONSOLE", "CREATE_NEW_PROCESS_GROUP",
                    "STD_INPUT_HANDLE", "STD_OUTPUT_HANDLE",
                    "STD_ERROR_HANDLE", "SW_HIDE",
                    "STARTF_USESTDHANDLES", "STARTF_USESHOWWINDOW"])
try:
    MAXFD = os.sysconf("SC_OPEN_MAX")
except:
    MAXFD = 256

_active = []

def _cleanup():
    for inst in _active[:]:
        res = inst._internal_poll(_deadstate=sys.maxint)
        if res is not None:
            try:
                _active.remove(inst)
            except ValueError:
                # This can happen if two threads create a new Popen instance.
                # It's harmless that it was already removed, so ignore.
                pass

PIPE = -1
STDOUT = -2


def _eintr_retry_call(func, *args):
    while True:
        try:
            return func(*args)
        except (OSError, IOError) as e:
            if e.errno == errno.EINTR:
                continue
            raise


# XXX This function is only used by multiprocessing and the test suite,
# but it's here so that it can be imported when Python is compiled without
# threads.

def _args_from_interpreter_flags():
    """Return a list of command-line arguments reproducing the current
    settings in sys.flags and sys.warnoptions."""
    flag_opt_map = {
        'debug': 'd',
        # 'inspect': 'i',
        # 'interactive': 'i',
        'optimize': 'O',
        'dont_write_bytecode': 'B',
        'no_user_site': 's',
        'no_site': 'S',
        'ignore_environment': 'E',
        'verbose': 'v',
        'bytes_warning': 'b',
        'py3k_warning': '3',
    }
    args = []
    for flag, opt in flag_opt_map.items():
        v = getattr(sys.flags, flag)
        if v > 0:
            args.append('-' + opt * v)
    if getattr(sys.flags, 'hash_randomization') != 0:
        args.append('-R')
    for opt in sys.warnoptions:
        args.append('-W' + opt)
    return args


def call(*popenargs, **kwargs):
    """Run command with arguments.  Wait for command to complete, then
    return the returncode attribute.

    The arguments are the same as for the Popen constructor.  Example:

    retcode = call(["ls", "-l"])
    """
    return Popen(*popenargs, **kwargs).wait()


def check_call(*popenargs, **kwargs):
    """Run command with arguments.  Wait for command to complete.  If
    the exit code was zero then return, otherwise raise
    CalledProcessError.  The CalledProcessError object will have the
    return code in the returncode attribute.

    The arguments are the same as for the Popen constructor.  Example:

    check_call(["ls", "-l"])
    """
    retcode = call(*popenargs, **kwargs)
    if retcode:
        cmd = kwargs.get("args")
        if cmd is None:
            cmd = popenargs[0]
        raise CalledProcessError(retcode, cmd)
    return 0


def check_output(*popenargs, **kwargs):
    r"""Run command with arguments and return its output as a byte string.

    If the exit code was non-zero it raises a CalledProcessError.  The
    CalledProcessError object will have the return code in the returncode
    attribute and output in the output attribute.

    The arguments are the same as for the Popen constructor.  Example:

    >>> check_output(["ls", "-l", "/dev/null"])
    'crw-rw-rw- 1 root root 1, 3 Oct 18  2007 /dev/null\n'

    The stdout argument is not allowed as it is used internally.
    To capture standard error in the result, use stderr=STDOUT.

    >>> check_output(["/bin/sh", "-c",
    ...               "ls -l non_existent_file ; exit 0"],
    ...              stderr=STDOUT)
    'ls: non_existent_file: No such file or directory\n'
    """
    if 'stdout' in kwargs:
        raise ValueError('stdout argument not allowed, it will be overridden.')
    process = Popen(stdout=PIPE, *popenargs, **kwargs)
    output, unused_err = process.communicate()
    retcode = process.poll()
    if retcode:
        cmd = kwargs.get("args")
        if cmd is None:
            cmd = popenargs[0]
        raise CalledProcessError(retcode, cmd, output=output)
    return output


def list2cmdline(seq):
    """
    Translate a sequence of arguments into a command line
    string, using the same rules as the MS C runtime:

    1) Arguments are delimited by white space, which is either a
       space or a tab.

    2) A string surrounded by double quotation marks is
       interpreted as a single argument, regardless of white space
       contained within.  A quoted string can be embedded in an
       argument.

    3) A double quotation mark preceded by a backslash is
       interpreted as a literal double quotation mark.

    4) Backslashes are interpreted literally, unless they
       immediately precede a double quotation mark.

    5) If backslashes immediately precede a double quotation mark,
       every pair of backslashes is interpreted as a literal
       backslash.  If the number of backslashes is odd, the last
       backslash escapes the next double quotation mark as
       described in rule 3.
    """

    # See
    # http://msdn.microsoft.com/en-us/library/17w5ykft.aspx
    # or search http://msdn.microsoft.com for
    # "Parsing C++ Command-Line Arguments"
    result = []
    needquote = False
    for arg in seq:
        bs_buf = []

        # Add a space to separate this argument from the others
        if result:
            result.append(' ')

        needquote = (" " in arg) or ("\t" in arg) or not arg
        if needquote:
            result.append('"')

        for c in arg:
            if c == '\\':
                # Don't know if we need to double yet.
                bs_buf.append(c)
            elif c == '"':
                # Double backslashes.
                result.append('\\' * len(bs_buf)*2)
                bs_buf = []
                result.append('\\"')
            else:
                # Normal char
                if bs_buf:
                    result.extend(bs_buf)
                    bs_buf = []
                result.append(c)

        # Add remaining backslashes, if any.
        if bs_buf:
            result.extend(bs_buf)

        if needquote:
            result.extend(bs_buf)
            result.append('"')

    return ''.join(result)


class Popen(object):
    """ Execute a child program in a new process.

    For a complete description of the arguments see the Python documentation.

    Arguments:
      args: A string, or a sequence of program arguments.

      bufsize: supplied as the buffering argument to the open() function when
          creating the stdin/stdout/stderr pipe file objects

      executable: A replacement program to execute.

      stdin, stdout and stderr: These specify the executed programs' standard
          input, standard output and standard error file handles, respectively.

      preexec_fn: (POSIX only) An object to be called in the child process
          just before the child is executed.

      close_fds: Controls closing or inheriting of file descriptors.

      shell: If true, the command will be executed through the shell.

      cwd: Sets the current directory before the child is executed.

      env: Defines the environment variables for the new process.

      universal_newlines: If true, use universal line endings for file
          objects stdin, stdout and stderr.

      startupinfo and creationflags (Windows only)

    Attributes:
        stdin, stdout, stderr, pid, returncode
    """
    _child_created = False  # Set here since __del__ checks it

    def __init__(self, args, bufsize=0, executable=None,
                 stdin=None, stdout=None, stderr=None,
                 preexec_fn=None, close_fds=False, shell=False,
                 cwd=None, env=None, universal_newlines=False,
                 startupinfo=None, creationflags=0):
        """Create new Popen instance."""
        _cleanup()

        if not isinstance(bufsize, (int, long)):
            raise TypeError("bufsize must be an integer")

        if mswindows:
            if preexec_fn is not None:
                raise ValueError("preexec_fn is not supported on Windows "
                                 "platforms")
            if close_fds and (stdin is not None or stdout is not None or
                              stderr is not None):
                raise ValueError("close_fds is not supported on Windows "
                                 "platforms if you redirect stdin/stdout/stderr")
        else:
            # POSIX
            if startupinfo is not None:
                raise ValueError("startupinfo is only supported on Windows "
                                 "platforms")
            if creationflags != 0:
                raise ValueError("creationflags is only supported on Windows "
                                 "platforms")

        self.stdin = None
        self.stdout = None
        self.stderr = None
        self.pid = None
        self.returncode = None
        self.universal_newlines = universal_newlines

        # Input and output objects. The general principle is like
        # this:
        #
        # Parent                   Child
        # ------                   -----
        # p2cwrite   ---stdin--->  p2cread
        # c2pread    <--stdout---  c2pwrite
        # errread    <--stderr---  errwrite
        #
        # On POSIX, the child objects are file descriptors.  On
        # Windows, these are Windows file handles.  The parent objects
        # are file descriptors on both platforms.  The parent objects
        # are None when not using PIPEs. The child objects are None
        # when not redirecting.

        (p2cread, p2cwrite,
         c2pread, c2pwrite,
         errread, errwrite), to_close = self._get_handles(stdin, stdout, stderr)

        try:
            self._execute_child(args, executable, preexec_fn, close_fds,
                                cwd, env, universal_newlines,
                                startupinfo, creationflags, shell, to_close,
                                p2cread, p2cwrite,
                                c2pread, c2pwrite,
                                errread, errwrite)
        except Exception:
            # Preserve original exception in case os.close raises.
            exc_type, exc_value, exc_trace = sys.exc_info()

            for fd in to_close:
                try:
                    if mswindows:
                        fd.Close()
                    else:
                        os.close(fd)
                except EnvironmentError:
                    pass

            raise exc_type, exc_value, exc_trace

        if mswindows:
            if p2cwrite is not None:
                p2cwrite = msvcrt.open_osfhandle(p2cwrite.Detach(), 0)
            if c2pread is not None:
                c2pread = msvcrt.open_osfhandle(c2pread.Detach(), 0)
            if errread is not None:
                errread = msvcrt.open_osfhandle(errread.Detach(), 0)

        if p2cwrite is not None:
            self.stdin = os.fdopen(p2cwrite, 'wb', bufsize)
        if c2pread is not None:
            if universal_newlines:
                self.stdout = os.fdopen(c2pread, 'rU', bufsize)
            else:
                self.stdout = os.fdopen(c2pread, 'rb', bufsize)
        if errread is not None:
            if universal_newlines:
                self.stderr = os.fdopen(errread, 'rU', bufsize)
            else:
                self.stderr = os.fdopen(errread, 'rb', bufsize)


    def _translate_newlines(self, data):
        data = data.replace("\r\n", "\n")
        data = data.replace("\r", "\n")
        return data


    def __del__(self, _maxint=sys.maxint):
        # If __init__ hasn't had a chance to execute (e.g. if it
        # was passed an undeclared keyword argument), we don't
        # have a _child_created attribute at all.
        if not self._child_created:
            # We didn't get to successfully create a child process.
            return
        # In case the child hasn't been waited on, check if it's done.
        self._internal_poll(_deadstate=_maxint)
        if self.returncode is None and _active is not None:
            # Child is still running, keep us alive until we can wait on it.
            _active.append(self)


    def communicate(self, input=None):
        """Interact with process: Send data to stdin.  Read data from
        stdout and stderr, until end-of-file is reached.  Wait for
        process to terminate.  The optional input argument should be a
        string to be sent to the child process, or None, if no data
        should be sent to the child.

        communicate() returns a tuple (stdout, stderr)."""

        # Optimization: If we are only using one pipe, or no pipe at
        # all, using select() or threads is unnecessary.
        if [self.stdin, self.stdout, self.stderr].count(None) >= 2:
            stdout = None
            stderr = None
            if self.stdin:
                if input:
                    try:
                        self.stdin.write(input)
                    except IOError as e:
                        if e.errno != errno.EPIPE and e.errno != errno.EINVAL:
                            raise
                self.stdin.close()
            elif self.stdout:
                stdout = _eintr_retry_call(self.stdout.read)
                self.stdout.close()
            elif self.stderr:
                stderr = _eintr_retry_call(self.stderr.read)
                self.stderr.close()
            self.wait()
            return (stdout, stderr)

        return self._communicate(input)


    def poll(self):
        """Check if child process has terminated. Set and return returncode
        attribute."""
        return self._internal_poll()


    if mswindows:
        #
        # Windows methods
        #
        def _get_handles(self, stdin, stdout, stderr):
            """Construct and return tuple with IO objects:
            p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite
            """
            to_close = set()
            if stdin is None and stdout is None and stderr is None:
                return (None, None, None, None, None, None), to_close

            p2cread, p2cwrite = None, None
            c2pread, c2pwrite = None, None
            errread, errwrite = None, None

            if stdin is None:
                p2cread = _subprocess.GetStdHandle(_subprocess.STD_INPUT_HANDLE)
                if p2cread is None:
                    p2cread, _ = _subprocess.CreatePipe(None, 0)
            elif stdin == PIPE:
                p2cread, p2cwrite = _subprocess.CreatePipe(None, 0)
            elif isinstance(stdin, (int, long)):
                p2cread = msvcrt.get_osfhandle(stdin)
            else:
                # Assuming file-like object
                p2cread = msvcrt.get_osfhandle(stdin.fileno())
            p2cread = self._make_inheritable(p2cread)
            # We just duplicated the handle, it has to be closed at the end
            to_close.add(p2cread)
            if stdin == PIPE:
                to_close.add(p2cwrite)

            if stdout is None:
                c2pwrite = _subprocess.GetStdHandle(_subprocess.STD_OUTPUT_HANDLE)
                if c2pwrite is None:
                    _, c2pwrite = _subprocess.CreatePipe(None, 0)
            elif stdout == PIPE:
                c2pread, c2pwrite = _subprocess.CreatePipe(None, 0)
            elif isinstance(stdout, (int, long)):
                c2pwrite = msvcrt.get_osfhandle(stdout)
            else:
                # Assuming file-like object
                c2pwrite = msvcrt.get_osfhandle(stdout.fileno())
            c2pwrite = self._make_inheritable(c2pwrite)
            # We just duplicated the handle, it has to be closed at the end
            to_close.add(c2pwrite)
            if stdout == PIPE:
                to_close.add(c2pread)

            if stderr is None:
                errwrite = _subprocess.GetStdHandle(_subprocess.STD_ERROR_HANDLE)
                if errwrite is None:
                    _, errwrite = _subprocess.CreatePipe(None, 0)
            elif stderr == PIPE:
                errread, errwrite = _subprocess.CreatePipe(None, 0)
            elif stderr == STDOUT:
                errwrite = c2pwrite
            elif isinstance(stderr, (int, long)):
                errwrite = msvcrt.get_osfhandle(stderr)
            else:
                # Assuming file-like object
                errwrite = msvcrt.get_osfhandle(stderr.fileno())
            errwrite = self._make_inheritable(errwrite)
            # We just duplicated the handle, it has to be closed at the end
            to_close.add(errwrite)
            if stderr == PIPE:
                to_close.add(errread)

            return (p2cread, p2cwrite,
                    c2pread, c2pwrite,
                    errread, errwrite), to_close


        def _make_inheritable(self, handle):
            """Return a duplicate of handle, which is inheritable"""
            return _subprocess.DuplicateHandle(_subprocess.GetCurrentProcess(),
                                handle, _subprocess.GetCurrentProcess(), 0, 1,
                                _subprocess.DUPLICATE_SAME_ACCESS)


        def _find_w9xpopen(self):
            """Find and return absolut path to w9xpopen.exe"""
            w9xpopen = os.path.join(
                            os.path.dirname(_subprocess.GetModuleFileName(0)),
                                    "w9xpopen.exe")
            if not os.path.exists(w9xpopen):
                # Eeek - file-not-found - possibly an embedding
                # situation - see if we can locate it in sys.exec_prefix
                w9xpopen = os.path.join(os.path.dirname(sys.exec_prefix),
                                        "w9xpopen.exe")
                if not os.path.exists(w9xpopen):
                    raise RuntimeError("Cannot locate w9xpopen.exe, which is "
                                       "needed for Popen to work with your "
                                       "shell or platform.")
            return w9xpopen


        def _execute_child(self, args, executable, preexec_fn, close_fds,
                           cwd, env, universal_newlines,
                           startupinfo, creationflags, shell, to_close,
                           p2cread, p2cwrite,
                           c2pread, c2pwrite,
                           errread, errwrite):
            """Execute program (MS Windows version)"""

            if not isinstance(args, types.StringTypes):
                args = list2cmdline(args)

            # Process startup details
            if startupinfo is None:
                startupinfo = STARTUPINFO()
            if None not in (p2cread, c2pwrite, errwrite):
                startupinfo.dwFlags |= _subprocess.STARTF_USESTDHANDLES
                startupinfo.hStdInput = p2cread
                startupinfo.hStdOutput = c2pwrite
                startupinfo.hStdError = errwrite

            if shell:
                startupinfo.dwFlags |= _subprocess.STARTF_USESHOWWINDOW
                startupinfo.wShowWindow = _subprocess.SW_HIDE
                comspec = os.environ.get("COMSPEC", "cmd.exe")
                args = '{} /c "{}"'.format (comspec, args)
                if (_subprocess.GetVersion() >= 0x80000000 or
                        os.path.basename(comspec).lower() == "command.com"):
                    # Win9x, or using command.com on NT. We need to
                    # use the w9xpopen intermediate program. For more
                    # information, see KB Q150956
                    # (http://web.archive.org/web/20011105084002/http://support.microsoft.com/support/kb/articles/Q150/9/56.asp)
                    w9xpopen = self._find_w9xpopen()
                    args = '"%s" %s' % (w9xpopen, args)
                    # Not passing CREATE_NEW_CONSOLE has been known to
                    # cause random failures on win9x.  Specifically a
                    # dialog: "Your program accessed mem currently in
                    # use at xxx" and a hopeful warning about the
                    # stability of your system.  Cost is Ctrl+C wont
                    # kill children.
                    creationflags |= _subprocess.CREATE_NEW_CONSOLE

            def _close_in_parent(fd):
                fd.Close()
                to_close.remove(fd)

            # Start the process
            try:
                hp, ht, pid, tid = _subprocess.CreateProcess(executable, args,
                                         # no special security
                                         None, None,
                                         int(not close_fds),
                                         creationflags,
                                         env,
                                         cwd,
                                         startupinfo)
            except pywintypes.error, e:
                # Translate pywintypes.error to WindowsError, which is
                # a subclass of OSError.  FIXME: We should really
                # translate errno using _sys_errlist (or similar), but
                # how can this be done from Python?
                raise WindowsError(*e.args)
            finally:
                # Child is launched. Close the parent's copy of those pipe
                # handles that only the child should have open.  You need
                # to make sure that no handles to the write end of the
                # output pipe are maintained in this process or else the
                # pipe will not close when the child process exits and the
                # ReadFile will hang.
                if p2cread is not None:
                    _close_in_parent(p2cread)
                if c2pwrite is not None:
                    _close_in_parent(c2pwrite)
                if errwrite is not None:
                    _close_in_parent(errwrite)

            # Retain the process handle, but close the thread handle
            self._child_created = True
            self._handle = hp
            self.pid = pid
            ht.Close()

        def _internal_poll(self, _deadstate=None,
                _WaitForSingleObject=_subprocess.WaitForSingleObject,
                _WAIT_OBJECT_0=_subprocess.WAIT_OBJECT_0,
                _GetExitCodeProcess=_subprocess.GetExitCodeProcess):
            """Check if child process has terminated.  Returns returncode
            attribute.

            This method is called by __del__, so it can only refer to objects
            in its local scope.

            """
            if self.returncode is None:
                if _WaitForSingleObject(self._handle, 0) == _WAIT_OBJECT_0:
                    self.returncode = _GetExitCodeProcess(self._handle)
            return self.returncode


        def wait(self):
            """Wait for child process to terminate.  Returns returncode
            attribute."""
            if self.returncode is None:
                _subprocess.WaitForSingleObject(self._handle,
                                                _subprocess.INFINITE)
                self.returncode = _subprocess.GetExitCodeProcess(self._handle)
            return self.returncode


        def _readerthread(self, fh, buffer):
            buffer.append(fh.read())


        def _communicate(self, input):
            stdout = None # Return
            stderr = None # Return

            if self.stdout:
                stdout = []
                stdout_thread = threading.Thread(target=self._readerthread,
                                                 args=(self.stdout, stdout))
                stdout_thread.setDaemon(True)
                stdout_thread.start()
            if self.stderr:
                stderr = []
                stderr_thread = threading.Thread(target=self._readerthread,
                                                 args=(self.stderr, stderr))
                stderr_thread.setDaemon(True)
                stderr_thread.start()

            if self.stdin:
                if input is not None:
                    try:
                        self.stdin.write(input)
                    except IOError as e:
                        if e.errno == errno.EPIPE:
                            # communicate() should ignore broken pipe error
                            pass
                        elif e.errno == errno.EINVAL:
                            # bpo-19612, bpo-30418: On Windows, stdin.write()
                            # fails with EINVAL if the child process exited or
                            # if the child process is still running but closed
                            # the pipe.
                            pass
                        else:
                            raise
                self.stdin.close()

            if self.stdout:
                stdout_thread.join()
            if self.stderr:
                stderr_thread.join()

            # All data exchanged.  Translate lists into strings.
            if stdout is not None:
                stdout = stdout[0]
            if stderr is not None:
                stderr = stderr[0]

            # Translate newlines, if requested.  We cannot let the file
            # object do the translation: It is based on stdio, which is
            # impossible to combine with select (unless forcing no
            # buffering).
            if self.universal_newlines and hasattr(file, 'newlines'):
                if stdout:
                    stdout = self._translate_newlines(stdout)
                if stderr:
                    stderr = self._translate_newlines(stderr)

            self.wait()
            return (stdout, stderr)

        def send_signal(self, sig):
            """Send a signal to the process
            """
            if sig == signal.SIGTERM:
                self.terminate()
            elif sig == signal.CTRL_C_EVENT:
                os.kill(self.pid, signal.CTRL_C_EVENT)
            elif sig == signal.CTRL_BREAK_EVENT:
                os.kill(self.pid, signal.CTRL_BREAK_EVENT)
            else:
                raise ValueError("Unsupported signal: {}".format(sig))

        def terminate(self):
            """Terminates the process
            """
            try:
                _subprocess.TerminateProcess(self._handle, 1)
            except OSError as e:
                # ERROR_ACCESS_DENIED (winerror 5) is received when the
                # process already died.
                if e.winerror != 5:
                    raise
                rc = _subprocess.GetExitCodeProcess(self._handle)
                if rc == _subprocess.STILL_ACTIVE:
                    raise
                self.returncode = rc

        kill = terminate

    else:
        #
        # POSIX methods
        #
        def _get_handles(self, stdin, stdout, stderr):
            """Construct and return tuple with IO objects:
            p2cread, p2cwrite, c2pread, c2pwrite, errread, errwrite
            """
            to_close = set()
            p2cread, p2cwrite = None, None
            c2pread, c2pwrite = None, None
            errread, errwrite = None, None

            if stdin is None:
                pass
            elif stdin == PIPE:
                p2cread, p2cwrite = self.pipe_cloexec()
                to_close.update((p2cread, p2cwrite))
            elif isinstance(stdin, (int, long)):
                p2cread = stdin
            else:
                # Assuming file-like object
                p2cread = stdin.fileno()

            if stdout is None:
                pass
            elif stdout == PIPE:
                c2pread, c2pwrite = self.pipe_cloexec()
                to_close.update((c2pread, c2pwrite))
            elif isinstance(stdout, (int, long)):
                c2pwrite = stdout
            else:
                # Assuming file-like object
                c2pwrite = stdout.fileno()

            if stderr is None:
                pass
            elif stderr == PIPE:
                errread, errwrite = self.pipe_cloexec()
                to_close.update((errread, errwrite))
            elif stderr == STDOUT:
                if c2pwrite is not None:
                    errwrite = c2pwrite
                else: # child's stdout is not set, use parent's stdout
                    errwrite = sys.__stdout__.fileno()
            elif isinstance(stderr, (int, long)):
                errwrite = stderr
            else:
                # Assuming file-like object
                errwrite = stderr.fileno()

            return (p2cread, p2cwrite,
                    c2pread, c2pwrite,
                    errread, errwrite), to_close


        def _set_cloexec_flag(self, fd, cloexec=True):
            try:
                cloexec_flag = fcntl.FD_CLOEXEC
            except AttributeError:
                cloexec_flag = 1

            old = fcntl.fcntl(fd, fcntl.F_GETFD)
            if cloexec:
                fcntl.fcntl(fd, fcntl.F_SETFD, old | cloexec_flag)
            else:
                fcntl.fcntl(fd, fcntl.F_SETFD, old & ~cloexec_flag)


        def pipe_cloexec(self):
            """Create a pipe with FDs set CLOEXEC."""
            # Pipes' FDs are set CLOEXEC by default because we don't want them
            # to be inherited by other subprocesses: the CLOEXEC flag is removed
            # from the child's FDs by _dup2(), between fork() and exec().
            # This is not atomic: we would need the pipe2() syscall for that.
            r, w = os.pipe()
            self._set_cloexec_flag(r)
            self._set_cloexec_flag(w)
            return r, w


        def _close_fds(self, but):
            if hasattr(os, 'closerange'):
                os.closerange(3, but)
                os.closerange(but + 1, MAXFD)
            else:
                for i in xrange(3, MAXFD):
                    if i == but:
                        continue
                    try:
                        os.close(i)
                    except:
                        pass


        # Used as a bandaid workaround for https://bugs.python.org/issue27448
        # to prevent multiple simultaneous subprocess launches from interfering
        # with one another and leaving gc disabled.
        if threading:
            _disabling_gc_lock = threading.Lock()
        else:
            class _noop_context_manager(object):
                # A dummy context manager that does nothing for the rare
                # user of a --without-threads build.
                def __enter__(self): pass
                def __exit__(self, *args): pass

            _disabling_gc_lock = _noop_context_manager()


        def _execute_child(self, args, executable, preexec_fn, close_fds,
                           cwd, env, universal_newlines,
                           startupinfo, creationflags, shell, to_close,
                           p2cread, p2cwrite,
                           c2pread, c2pwrite,
                           errread, errwrite):
            """Execute program (POSIX version)"""

            if isinstance(args, types.StringTypes):
                args = [args]
            else:
                args = list(args)

            if shell:
                args = ["/bin/sh", "-c"] + args
                if executable:
                    args[0] = executable

            if executable is None:
                executable = args[0]

            def _close_in_parent(fd):
                os.close(fd)
                to_close.remove(fd)

            # For transferring possible exec failure from child to parent
            # The first char specifies the exception type: 0 means
            # OSError, 1 means some other error.
            errpipe_read, errpipe_write = self.pipe_cloexec()
            try:
                try:
                    with self._disabling_gc_lock:
                        gc_was_enabled = gc.isenabled()
                        # Disable gc to avoid bug where gc -> file_dealloc ->
                        # write to stderr -> hang.
                        # https://bugs.python.org/issue1336
                        gc.disable()
                    try:
                        self.pid = os.fork()
                    except:
                        if gc_was_enabled:
                            gc.enable()
                        raise
                    self._child_created = True
                    if self.pid == 0:
                        # Child
                        try:
                            # Close parent's pipe ends
                            if p2cwrite is not None:
                                os.close(p2cwrite)
                            if c2pread is not None:
                                os.close(c2pread)
                            if errread is not None:
                                os.close(errread)
                            os.close(errpipe_read)

                            # When duping fds, if there arises a situation
                            # where one of the fds is either 0, 1 or 2, it
                            # is possible that it is overwritten (#12607).
                            if c2pwrite == 0:
                                c2pwrite = os.dup(c2pwrite)
                            if errwrite == 0 or errwrite == 1:
                                errwrite = os.dup(errwrite)

                            # Dup fds for child
                            def _dup2(a, b):
                                # dup2() removes the CLOEXEC flag but
                                # we must do it ourselves if dup2()
                                # would be a no-op (issue #10806).
                                if a == b:
                                    self._set_cloexec_flag(a, False)
                                elif a is not None:
                                    os.dup2(a, b)
                            _dup2(p2cread, 0)
                            _dup2(c2pwrite, 1)
                            _dup2(errwrite, 2)

                            # Close pipe fds.  Make sure we don't close the
                            # same fd more than once, or standard fds.
                            closed = { None }
                            for fd in [p2cread, c2pwrite, errwrite]:
                                if fd not in closed and fd > 2:
                                    os.close(fd)
                                    closed.add(fd)

                            if cwd is not None:
                                os.chdir(cwd)

                            if preexec_fn:
                                preexec_fn()

                            # Close all other fds, if asked for - after
                            # preexec_fn(), which may open FDs.
                            if close_fds:
                                self._close_fds(but=errpipe_write)

                            if env is None:
                                os.execvp(executable, args)
                            else:
                                os.execvpe(executable, args, env)

                        except:
                            exc_type, exc_value, tb = sys.exc_info()
                            # Save the traceback and attach it to the exception object
                            exc_lines = traceback.format_exception(exc_type,
                                                                   exc_value,
                                                                   tb)
                            exc_value.child_traceback = ''.join(exc_lines)
                            os.write(errpipe_write, pickle.dumps(exc_value))

                        finally:
                            # This exitcode won't be reported to applications, so it
                            # really doesn't matter what we return.
                            os._exit(255)

                    # Parent
                    if gc_was_enabled:
                        gc.enable()
                finally:
                    # be sure the FD is closed no matter what
                    os.close(errpipe_write)

                # Wait for exec to fail or succeed; possibly raising exception
                data = _eintr_retry_call(os.read, errpipe_read, 1048576)
                pickle_bits = []
                while data:
                    pickle_bits.append(data)
                    data = _eintr_retry_call(os.read, errpipe_read, 1048576)
                data = "".join(pickle_bits)
            finally:
                if p2cread is not None and p2cwrite is not None:
                    _close_in_parent(p2cread)
                if c2pwrite is not None and c2pread is not None:
                    _close_in_parent(c2pwrite)
                if errwrite is not None and errread is not None:
                    _close_in_parent(errwrite)

                # be sure the FD is closed no matter what
                os.close(errpipe_read)

            if data != "":
                try:
                    _eintr_retry_call(os.waitpid, self.pid, 0)
                except OSError as e:
                    if e.errno != errno.ECHILD:
                        raise
                child_exception = pickle.loads(data)
                raise child_exception


        def _handle_exitstatus(self, sts, _WIFSIGNALED=os.WIFSIGNALED,
                _WTERMSIG=os.WTERMSIG, _WIFEXITED=os.WIFEXITED,
                _WEXITSTATUS=os.WEXITSTATUS, _WIFSTOPPED=os.WIFSTOPPED,
                _WSTOPSIG=os.WSTOPSIG):
            # This method is called (indirectly) by __del__, so it cannot
            # refer to anything outside of its local scope.
            if _WIFSIGNALED(sts):
                self.returncode = -_WTERMSIG(sts)
            elif _WIFEXITED(sts):
                self.returncode = _WEXITSTATUS(sts)
            elif _WIFSTOPPED(sts):
                self.returncode = -_WSTOPSIG(sts)
            else:
                # Should never happen
                raise RuntimeError("Unknown child exit status!")


        def _internal_poll(self, _deadstate=None, _waitpid=os.waitpid,
                _WNOHANG=os.WNOHANG, _os_error=os.error, _ECHILD=errno.ECHILD):
            """Check if child process has terminated.  Returns returncode
            attribute.

            This method is called by __del__, so it cannot reference anything
            outside of the local scope (nor can any methods it calls).

            """
            if self.returncode is None:
                try:
                    pid, sts = _waitpid(self.pid, _WNOHANG)
                    if pid == self.pid:
                        self._handle_exitstatus(sts)
                except _os_error as e:
                    if _deadstate is not None:
                        self.returncode = _deadstate
                    if e.errno == _ECHILD:
                        # This happens if SIGCLD is set to be ignored or
                        # waiting for child processes has otherwise been
                        # disabled for our process.  This child is dead, we
                        # can't get the status.
                        # http://bugs.python.org/issue15756
                        self.returncode = 0
            return self.returncode


        def wait(self):
            """Wait for child process to terminate.  Returns returncode
            attribute."""
            while self.returncode is None:
                try:
                    pid, sts = _eintr_retry_call(os.waitpid, self.pid, 0)
                except OSError as e:
                    if e.errno != errno.ECHILD:
                        raise
                    # This happens if SIGCLD is set to be ignored or waiting
                    # for child processes has otherwise been disabled for our
                    # process.  This child is dead, we can't get the status.
                    pid = self.pid
                    sts = 0
                # Check the pid and loop as waitpid has been known to return
                # 0 even without WNOHANG in odd situations.  issue14396.
                if pid == self.pid:
                    self._handle_exitstatus(sts)
            return self.returncode


        def _communicate(self, input):
            if self.stdin:
                # Flush stdio buffer.  This might block, if the user has
                # been writing to .stdin in an uncontrolled fashion.
                self.stdin.flush()
                if not input:
                    self.stdin.close()

            if _has_poll:
                stdout, stderr = self._communicate_with_poll(input)
            else:
                stdout, stderr = self._communicate_with_select(input)

            # All data exchanged.  Translate lists into strings.
            if stdout is not None:
                stdout = ''.join(stdout)
            if stderr is not None:
                stderr = ''.join(stderr)

            # Translate newlines, if requested.  We cannot let the file
            # object do the translation: It is based on stdio, which is
            # impossible to combine with select (unless forcing no
            # buffering).
            if self.universal_newlines and hasattr(file, 'newlines'):
                if stdout:
                    stdout = self._translate_newlines(stdout)
                if stderr:
                    stderr = self._translate_newlines(stderr)

            self.wait()
            return (stdout, stderr)


        def _communicate_with_poll(self, input):
            stdout = None # Return
            stderr = None # Return
            fd2file = {}
            fd2output = {}

            poller = select.poll()
            def register_and_append(file_obj, eventmask):
                poller.register(file_obj.fileno(), eventmask)
                fd2file[file_obj.fileno()] = file_obj

            def close_unregister_and_remove(fd):
                poller.unregister(fd)
                fd2file[fd].close()
                fd2file.pop(fd)

            if self.stdin and input:
                register_and_append(self.stdin, select.POLLOUT)

            select_POLLIN_POLLPRI = select.POLLIN | select.POLLPRI
            if self.stdout:
                register_and_append(self.stdout, select_POLLIN_POLLPRI)
                fd2output[self.stdout.fileno()] = stdout = []
            if self.stderr:
                register_and_append(self.stderr, select_POLLIN_POLLPRI)
                fd2output[self.stderr.fileno()] = stderr = []

            input_offset = 0
            while fd2file:
                try:
                    ready = poller.poll()
                except select.error, e:
                    if e.args[0] == errno.EINTR:
                        continue
                    raise

                for fd, mode in ready:
                    if mode & select.POLLOUT:
                        chunk = input[input_offset : input_offset + _PIPE_BUF]
                        try:
                            input_offset += os.write(fd, chunk)
                        except OSError as e:
                            if e.errno == errno.EPIPE:
                                close_unregister_and_remove(fd)
                            else:
                                raise
                        else:
                            if input_offset >= len(input):
                                close_unregister_and_remove(fd)
                    elif mode & select_POLLIN_POLLPRI:
                        data = os.read(fd, 4096)
                        if not data:
                            close_unregister_and_remove(fd)
                        fd2output[fd].append(data)
                    else:
                        # Ignore hang up or errors.
                        close_unregister_and_remove(fd)

            return (stdout, stderr)


        def _communicate_with_select(self, input):
            read_set = []
            write_set = []
            stdout = None # Return
            stderr = None # Return

            if self.stdin and input:
                write_set.append(self.stdin)
            if self.stdout:
                read_set.append(self.stdout)
                stdout = []
            if self.stderr:
                read_set.append(self.stderr)
                stderr = []

            input_offset = 0
            while read_set or write_set:
                try:
                    rlist, wlist, xlist = select.select(read_set, write_set, [])
                except select.error, e:
                    if e.args[0] == errno.EINTR:
                        continue
                    raise

                if self.stdin in wlist:
                    chunk = input[input_offset : input_offset + _PIPE_BUF]
                    try:
                        bytes_written = os.write(self.stdin.fileno(), chunk)
                    except OSError as e:
                        if e.errno == errno.EPIPE:
                            self.stdin.close()
                            write_set.remove(self.stdin)
                        else:
                            raise
                    else:
                        input_offset += bytes_written
                        if input_offset >= len(input):
                            self.stdin.close()
                            write_set.remove(self.stdin)

                if self.stdout in rlist:
                    data = os.read(self.stdout.fileno(), 1024)
                    if data == "":
                        self.stdout.close()
                        read_set.remove(self.stdout)
                    stdout.append(data)

                if self.stderr in rlist:
                    data = os.read(self.stderr.fileno(), 1024)
                    if data == "":
                        self.stderr.close()
                        read_set.remove(self.stderr)
                    stderr.append(data)

            return (stdout, stderr)


        def send_signal(self, sig):
            """Send a signal to the process
            """
            os.kill(self.pid, sig)

        def terminate(self):
            """Terminate the process with SIGTERM
            """
            self.send_signal(signal.SIGTERM)

        def kill(self):
            """Kill the process with SIGKILL
            """
            self.send_signal(signal.SIGKILL)


def _demo_posix():
    #
    # Example 1: Simple redirection: Get process list
    #
    plist = Popen(["ps"], stdout=PIPE).communicate()[0]
    print "Process list:"
    print plist

    #
    # Example 2: Change uid before executing child
    #
    if os.getuid() == 0:
        p = Popen(["id"], preexec_fn=lambda: os.setuid(100))
        p.wait()

    #
    # Example 3: Connecting several subprocesses
    #
    print "Looking for 'hda'..."
    p1 = Popen(["dmesg"], stdout=PIPE)
    p2 = Popen(["grep", "hda"], stdin=p1.stdout, stdout=PIPE)
    print repr(p2.communicate()[0])

    #
    # Example 4: Catch execution error
    #
    print
    print "Trying a weird file..."
    try:
        print Popen(["/this/path/does/not/exist"]).communicate()
    except OSError, e:
        if e.errno == errno.ENOENT:
            print "The file didn't exist.  I thought so..."
            print "Child traceback:"
            print e.child_traceback
        else:
            print "Error", e.errno
    else:
        print >>sys.stderr, "Gosh.  No error."


def _demo_windows():
    #
    # Example 1: Connecting several subprocesses
    #
    print "Looking for 'PROMPT' in set output..."
    p1 = Popen("set", stdout=PIPE, shell=True)
    p2 = Popen('find "PROMPT"', stdin=p1.stdout, stdout=PIPE)
    print repr(p2.communicate()[0])

    #
    # Example 2: Simple execution of program
    #
    print "Executing calc..."
    p = Popen("calc")
    p.wait()


if __name__ == "__main__":
    if mswindows:
        _demo_windows()
    else:
        _demo_posix()
Name
Size
Permissions
Options
bsddb
--
drwxr-xr-x
compiler
--
drwxr-xr-x
config
--
drwxr-xr-x
ctypes
--
drwxr-xr-x
curses
--
drwxr-xr-x
distutils
--
drwxr-xr-x
email
--
drwxr-xr-x
encodings
--
drwxr-xr-x
ensurepip
--
drwxr-xr-x
hotshot
--
drwxr-xr-x
idlelib
--
drwxr-xr-x
importlib
--
drwxr-xr-x
json
--
drwxr-xr-x
lib-dynload
--
drwxr-xr-x
lib2to3
--
drwxr-xr-x
logging
--
drwxr-xr-x
multiprocessing
--
drwxr-xr-x
plat-linux2
--
drwxr-xr-x
pydoc_data
--
drwxr-xr-x
site-packages
--
drwxr-xr-x
sqlite3
--
drwxr-xr-x
test
--
drwxr-xr-x
unittest
--
drwxr-xr-x
wsgiref
--
drwxr-xr-x
xml
--
drwxr-xr-x
BaseHTTPServer.py
22.214 KB
-rw-r--r--
BaseHTTPServer.pyc
21.467 KB
-rw-r--r--
BaseHTTPServer.pyo
21.467 KB
-rw-r--r--
Bastion.py
5.609 KB
-rw-r--r--
Bastion.pyc
6.694 KB
-rw-r--r--
Bastion.pyo
6.694 KB
-rw-r--r--
CGIHTTPServer.py
12.782 KB
-rw-r--r--
CGIHTTPServer.pyc
10.925 KB
-rw-r--r--
CGIHTTPServer.pyo
10.925 KB
-rw-r--r--
ConfigParser.py
27.096 KB
-rw-r--r--
ConfigParser.pyc
25.371 KB
-rw-r--r--
ConfigParser.pyo
25.371 KB
-rw-r--r--
Cookie.py
25.916 KB
-rw-r--r--
Cookie.pyc
22.609 KB
-rw-r--r--
Cookie.pyo
22.609 KB
-rw-r--r--
DocXMLRPCServer.py
10.516 KB
-rw-r--r--
DocXMLRPCServer.pyc
10.197 KB
-rw-r--r--
DocXMLRPCServer.pyo
10.091 KB
-rw-r--r--
HTMLParser.py
16.769 KB
-rw-r--r--
HTMLParser.pyc
13.812 KB
-rw-r--r--
HTMLParser.pyo
13.514 KB
-rw-r--r--
MimeWriter.py
6.33 KB
-rw-r--r--
MimeWriter.pyc
7.306 KB
-rw-r--r--
MimeWriter.pyo
7.306 KB
-rw-r--r--
Queue.py
8.376 KB
-rw-r--r--
Queue.pyc
9.559 KB
-rw-r--r--
Queue.pyo
9.559 KB
-rw-r--r--
SimpleHTTPServer.py
7.81 KB
-rw-r--r--
SimpleHTTPServer.pyc
7.962 KB
-rw-r--r--
SimpleHTTPServer.pyo
7.962 KB
-rw-r--r--
SimpleXMLRPCServer.py
25.207 KB
-rw-r--r--
SimpleXMLRPCServer.pyc
22.784 KB
-rw-r--r--
SimpleXMLRPCServer.pyo
22.784 KB
-rw-r--r--
SocketServer.py
23.387 KB
-rw-r--r--
SocketServer.pyc
24.246 KB
-rw-r--r--
SocketServer.pyo
24.246 KB
-rw-r--r--
StringIO.py
10.412 KB
-rw-r--r--
StringIO.pyc
11.452 KB
-rw-r--r--
StringIO.pyo
11.452 KB
-rw-r--r--
UserDict.py
6.895 KB
-rw-r--r--
UserDict.pyc
10.055 KB
-rw-r--r--
UserDict.pyo
10.055 KB
-rw-r--r--
UserList.py
3.559 KB
-rw-r--r--
UserList.pyc
6.854 KB
-rw-r--r--
UserList.pyo
6.854 KB
-rw-r--r--
UserString.py
9.47 KB
-rwxr-xr-x
UserString.pyc
15.379 KB
-rw-r--r--
UserString.pyo
15.379 KB
-rw-r--r--
_LWPCookieJar.py
6.399 KB
-rw-r--r--
_LWPCookieJar.pyc
5.383 KB
-rw-r--r--
_LWPCookieJar.pyo
5.383 KB
-rw-r--r--
_MozillaCookieJar.py
5.661 KB
-rw-r--r--
_MozillaCookieJar.pyc
4.407 KB
-rw-r--r--
_MozillaCookieJar.pyo
4.369 KB
-rw-r--r--
__future__.py
4.277 KB
-rw-r--r--
__future__.pyc
4.2 KB
-rw-r--r--
__future__.pyo
4.2 KB
-rw-r--r--
__phello__.foo.py
0.063 KB
-rw-r--r--
__phello__.foo.pyc
0.135 KB
-rw-r--r--
__phello__.foo.pyo
0.135 KB
-rw-r--r--
_abcoll.py
18.183 KB
-rw-r--r--
_abcoll.pyc
26.4 KB
-rw-r--r--
_abcoll.pyo
26.4 KB
-rw-r--r--
_osx_support.py
18.652 KB
-rw-r--r--
_osx_support.pyc
11.724 KB
-rw-r--r--
_osx_support.pyo
11.724 KB
-rw-r--r--
_pyio.py
67.998 KB
-rw-r--r--
_pyio.pyc
65.406 KB
-rw-r--r--
_pyio.pyo
65.406 KB
-rw-r--r--
_strptime.py
20.242 KB
-rw-r--r--
_strptime.pyc
15.07 KB
-rw-r--r--
_strptime.pyo
15.07 KB
-rw-r--r--
_sysconfigdata.py
20.667 KB
-rw-r--r--
_sysconfigdata.pyc
23.708 KB
-rw-r--r--
_sysconfigdata.pyo
23.708 KB
-rw-r--r--
_threading_local.py
7.09 KB
-rw-r--r--
_threading_local.pyc
6.338 KB
-rw-r--r--
_threading_local.pyo
6.338 KB
-rw-r--r--
_weakrefset.py
5.772 KB
-rw-r--r--
_weakrefset.pyc
10.061 KB
-rw-r--r--
_weakrefset.pyo
10.061 KB
-rw-r--r--
abc.py
6.978 KB
-rw-r--r--
abc.pyc
6.139 KB
-rw-r--r--
abc.pyo
6.084 KB
-rw-r--r--
aifc.py
33.769 KB
-rw-r--r--
aifc.pyc
30.672 KB
-rw-r--r--
aifc.pyo
30.672 KB
-rw-r--r--
antigravity.py
0.059 KB
-rw-r--r--
antigravity.pyc
0.211 KB
-rw-r--r--
antigravity.pyo
0.211 KB
-rw-r--r--
anydbm.py
2.601 KB
-rw-r--r--
anydbm.pyc
2.772 KB
-rw-r--r--
anydbm.pyo
2.772 KB
-rw-r--r--
argparse.py
87.137 KB
-rw-r--r--
argparse.pyc
64.826 KB
-rw-r--r--
argparse.pyo
64.665 KB
-rw-r--r--
ast.py
11.528 KB
-rw-r--r--
ast.pyc
12.939 KB
-rw-r--r--
ast.pyo
12.939 KB
-rw-r--r--
asynchat.py
11.31 KB
-rw-r--r--
asynchat.pyc
8.984 KB
-rw-r--r--
asynchat.pyo
8.984 KB
-rw-r--r--
asyncore.py
20.452 KB
-rw-r--r--
asyncore.pyc
19.199 KB
-rw-r--r--
asyncore.pyo
19.199 KB
-rw-r--r--
atexit.py
1.665 KB
-rw-r--r--
atexit.pyc
2.228 KB
-rw-r--r--
atexit.pyo
2.228 KB
-rw-r--r--
audiodev.py
7.419 KB
-rw-r--r--
audiodev.pyc
8.613 KB
-rw-r--r--
audiodev.pyo
8.613 KB
-rw-r--r--
base64.py
11.539 KB
-rwxr-xr-x
base64.pyc
11.261 KB
-rw-r--r--
base64.pyo
11.261 KB
-rw-r--r--
bdb.py
21.205 KB
-rw-r--r--
bdb.pyc
19.428 KB
-rw-r--r--
bdb.pyo
19.428 KB
-rw-r--r--
binhex.py
14.354 KB
-rw-r--r--
binhex.pyc
15.745 KB
-rw-r--r--
binhex.pyo
15.745 KB
-rw-r--r--
bisect.py
2.534 KB
-rw-r--r--
bisect.pyc
3.063 KB
-rw-r--r--
bisect.pyo
3.063 KB
-rw-r--r--
cProfile.py
6.429 KB
-rwxr-xr-x
cProfile.pyc
6.423 KB
-rw-r--r--
cProfile.pyo
6.423 KB
-rw-r--r--
calendar.py
22.836 KB
-rw-r--r--
calendar.pyc
28.262 KB
-rw-r--r--
calendar.pyo
28.262 KB
-rw-r--r--
cgi.py
34.968 KB
-rwxr-xr-x
cgi.pyc
33.236 KB
-rw-r--r--
cgi.pyo
33.236 KB
-rw-r--r--
cgitb.py
11.89 KB
-rw-r--r--
cgitb.pyc
12.082 KB
-rw-r--r--
cgitb.pyo
12.082 KB
-rw-r--r--
chunk.py
5.292 KB
-rw-r--r--
chunk.pyc
5.61 KB
-rw-r--r--
chunk.pyo
5.61 KB
-rw-r--r--
cmd.py
14.674 KB
-rw-r--r--
cmd.pyc
13.977 KB
-rw-r--r--
cmd.pyo
13.977 KB
-rw-r--r--
code.py
9.95 KB
-rw-r--r--
code.pyc
10.295 KB
-rw-r--r--
code.pyo
10.295 KB
-rw-r--r--
codecs.py
35.296 KB
-rw-r--r--
codecs.pyc
37.154 KB
-rw-r--r--
codecs.pyo
37.154 KB
-rw-r--r--
codeop.py
5.858 KB
-rw-r--r--
codeop.pyc
6.569 KB
-rw-r--r--
codeop.pyo
6.569 KB
-rw-r--r--
collections.py
27.146 KB
-rw-r--r--
collections.pyc
26.21 KB
-rw-r--r--
collections.pyo
26.16 KB
-rw-r--r--
colorsys.py
3.604 KB
-rw-r--r--
colorsys.pyc
3.999 KB
-rw-r--r--
colorsys.pyo
3.999 KB
-rw-r--r--
commands.py
2.485 KB
-rw-r--r--
commands.pyc
2.487 KB
-rw-r--r--
commands.pyo
2.487 KB
-rw-r--r--
compileall.py
7.581 KB
-rw-r--r--
compileall.pyc
6.929 KB
-rw-r--r--
compileall.pyo
6.929 KB
-rw-r--r--
contextlib.py
4.32 KB
-rw-r--r--
contextlib.pyc
4.502 KB
-rw-r--r--
contextlib.pyo
4.502 KB
-rw-r--r--
cookielib.py
63.951 KB
-rw-r--r--
cookielib.pyc
54.674 KB
-rw-r--r--
cookielib.pyo
54.49 KB
-rw-r--r--
copy.py
11.263 KB
-rw-r--r--
copy.pyc
12.215 KB
-rw-r--r--
copy.pyo
12.125 KB
-rw-r--r--
copy_reg.py
6.811 KB
-rw-r--r--
copy_reg.pyc
5.186 KB
-rw-r--r--
copy_reg.pyo
5.143 KB
-rw-r--r--
crypt.py
2.237 KB
-rw-r--r--
crypt.pyc
2.954 KB
-rw-r--r--
crypt.pyo
2.954 KB
-rw-r--r--
csv.py
16.316 KB
-rw-r--r--
csv.pyc
13.559 KB
-rw-r--r--
csv.pyo
13.559 KB
-rw-r--r--
dbhash.py
0.486 KB
-rw-r--r--
dbhash.pyc
0.727 KB
-rw-r--r--
dbhash.pyo
0.727 KB
-rw-r--r--
decimal.py
216.731 KB
-rw-r--r--
decimal.pyc
171.357 KB
-rw-r--r--
decimal.pyo
171.357 KB
-rw-r--r--
difflib.py
80.396 KB
-rw-r--r--
difflib.pyc
61.133 KB
-rw-r--r--
difflib.pyo
61.083 KB
-rw-r--r--
dircache.py
1.1 KB
-rw-r--r--
dircache.pyc
1.59 KB
-rw-r--r--
dircache.pyo
1.59 KB
-rw-r--r--
dis.py
6.347 KB
-rw-r--r--
dis.pyc
6.184 KB
-rw-r--r--
dis.pyo
6.184 KB
-rw-r--r--
doctest.py
102.632 KB
-rw-r--r--
doctest.pyc
83.213 KB
-rw-r--r--
doctest.pyo
82.933 KB
-rw-r--r--
dumbdbm.py
8.927 KB
-rw-r--r--
dumbdbm.pyc
6.829 KB
-rw-r--r--
dumbdbm.pyo
6.829 KB
-rw-r--r--
dummy_thread.py
4.314 KB
-rw-r--r--
dummy_thread.pyc
5.458 KB
-rw-r--r--
dummy_thread.pyo
5.458 KB
-rw-r--r--
dummy_threading.py
2.738 KB
-rw-r--r--
dummy_threading.pyc
1.268 KB
-rw-r--r--
dummy_threading.pyo
1.268 KB
-rw-r--r--
filecmp.py
9.363 KB
-rw-r--r--
filecmp.pyc
9.65 KB
-rw-r--r--
filecmp.pyo
9.65 KB
-rw-r--r--
fileinput.py
13.424 KB
-rw-r--r--
fileinput.pyc
14.541 KB
-rw-r--r--
fileinput.pyo
14.541 KB
-rw-r--r--
fnmatch.py
3.237 KB
-rw-r--r--
fnmatch.pyc
3.605 KB
-rw-r--r--
fnmatch.pyo
3.605 KB
-rw-r--r--
formatter.py
14.562 KB
-rw-r--r--
formatter.pyc
19.706 KB
-rw-r--r--
formatter.pyo
19.706 KB
-rw-r--r--
fpformat.py
4.621 KB
-rw-r--r--
fpformat.pyc
4.694 KB
-rw-r--r--
fpformat.pyo
4.694 KB
-rw-r--r--
fractions.py
21.865 KB
-rw-r--r--
fractions.pyc
19.744 KB
-rw-r--r--
fractions.pyo
19.744 KB
-rw-r--r--
ftplib.py
37.299 KB
-rw-r--r--
ftplib.pyc
34.816 KB
-rw-r--r--
ftplib.pyo
34.816 KB
-rw-r--r--
functools.py
4.693 KB
-rw-r--r--
functools.pyc
6.854 KB
-rw-r--r--
functools.pyo
6.854 KB
-rw-r--r--
genericpath.py
3.126 KB
-rw-r--r--
genericpath.pyc
3.574 KB
-rw-r--r--
genericpath.pyo
3.574 KB
-rw-r--r--
getopt.py
7.147 KB
-rw-r--r--
getopt.pyc
6.625 KB
-rw-r--r--
getopt.pyo
6.581 KB
-rw-r--r--
getpass.py
5.433 KB
-rw-r--r--
getpass.pyc
4.722 KB
-rw-r--r--
getpass.pyo
4.722 KB
-rw-r--r--
gettext.py
22.135 KB
-rw-r--r--
gettext.pyc
18.166 KB
-rw-r--r--
gettext.pyo
18.166 KB
-rw-r--r--
glob.py
3.041 KB
-rw-r--r--
glob.pyc
2.976 KB
-rw-r--r--
glob.pyo
2.976 KB
-rw-r--r--
gzip.py
18.582 KB
-rw-r--r--
gzip.pyc
15.26 KB
-rw-r--r--
gzip.pyo
15.26 KB
-rw-r--r--
hashlib.py
7.658 KB
-rw-r--r--
hashlib.pyc
6.861 KB
-rw-r--r--
hashlib.pyo
6.861 KB
-rw-r--r--
heapq.py
17.866 KB
-rw-r--r--
heapq.pyc
14.451 KB
-rw-r--r--
heapq.pyo
14.451 KB
-rw-r--r--
hmac.py
4.48 KB
-rw-r--r--
hmac.pyc
4.563 KB
-rw-r--r--
hmac.pyo
4.563 KB
-rw-r--r--
htmlentitydefs.py
17.633 KB
-rw-r--r--
htmlentitydefs.pyc
6.23 KB
-rw-r--r--
htmlentitydefs.pyo
6.23 KB
-rw-r--r--
htmllib.py
12.567 KB
-rw-r--r--
htmllib.pyc
20.988 KB
-rw-r--r--
htmllib.pyo
20.988 KB
-rw-r--r--
httplib.py
51.074 KB
-rw-r--r--
httplib.pyc
37.884 KB
-rw-r--r--
httplib.pyo
37.704 KB
-rw-r--r--
ihooks.py
18.541 KB
-rw-r--r--
ihooks.pyc
21.747 KB
-rw-r--r--
ihooks.pyo
21.747 KB
-rw-r--r--
imaplib.py
47.232 KB
-rw-r--r--
imaplib.pyc
45.188 KB
-rw-r--r--
imaplib.pyo
42.486 KB
-rw-r--r--
imghdr.py
3.458 KB
-rw-r--r--
imghdr.pyc
4.928 KB
-rw-r--r--
imghdr.pyo
4.928 KB
-rw-r--r--
imputil.py
25.16 KB
-rw-r--r--
imputil.pyc
15.739 KB
-rw-r--r--
imputil.pyo
15.565 KB
-rw-r--r--
inspect.py
42 KB
-rw-r--r--
inspect.pyc
40.162 KB
-rw-r--r--
inspect.pyo
40.162 KB
-rw-r--r--
io.py
3.244 KB
-rw-r--r--
io.pyc
3.568 KB
-rw-r--r--
io.pyo
3.568 KB
-rw-r--r--
keyword.py
1.958 KB
-rwxr-xr-x
keyword.pyc
2.081 KB
-rw-r--r--
keyword.pyo
2.081 KB
-rw-r--r--
linecache.py
3.933 KB
-rw-r--r--
linecache.pyc
3.271 KB
-rw-r--r--
linecache.pyo
3.271 KB
-rw-r--r--
locale.py
100.424 KB
-rw-r--r--
locale.pyc
55.689 KB
-rw-r--r--
locale.pyo
55.689 KB
-rw-r--r--
macpath.py
6.142 KB
-rw-r--r--
macpath.pyc
7.742 KB
-rw-r--r--
macpath.pyo
7.742 KB
-rw-r--r--
macurl2path.py
2.667 KB
-rw-r--r--
macurl2path.pyc
2.242 KB
-rw-r--r--
macurl2path.pyo
2.242 KB
-rw-r--r--
mailbox.py
79.336 KB
-rw-r--r--
mailbox.pyc
77.699 KB
-rw-r--r--
mailbox.pyo
77.653 KB
-rw-r--r--
mailcap.py
7.255 KB
-rw-r--r--
mailcap.pyc
7.078 KB
-rw-r--r--
mailcap.pyo
7.078 KB
-rw-r--r--
markupbase.py
14.3 KB
-rw-r--r--
markupbase.pyc
9.266 KB
-rw-r--r--
markupbase.pyo
9.074 KB
-rw-r--r--
md5.py
0.35 KB
-rw-r--r--
md5.pyc
0.382 KB
-rw-r--r--
md5.pyo
0.382 KB
-rw-r--r--
mhlib.py
32.65 KB
-rw-r--r--
mhlib.pyc
33.976 KB
-rw-r--r--
mhlib.pyo
33.976 KB
-rw-r--r--
mimetools.py
7 KB
-rw-r--r--
mimetools.pyc
8.263 KB
-rw-r--r--
mimetools.pyo
8.263 KB
-rw-r--r--
mimetypes.py
20.535 KB
-rw-r--r--
mimetypes.pyc
18.297 KB
-rw-r--r--
mimetypes.pyo
18.297 KB
-rw-r--r--
mimify.py
14.678 KB
-rwxr-xr-x
mimify.pyc
11.91 KB
-rw-r--r--
mimify.pyo
11.91 KB
-rw-r--r--
modulefinder.py
23.888 KB
-rw-r--r--
modulefinder.pyc
19.123 KB
-rw-r--r--
modulefinder.pyo
19.043 KB
-rw-r--r--
multifile.py
4.707 KB
-rw-r--r--
multifile.pyc
5.483 KB
-rw-r--r--
multifile.pyo
5.442 KB
-rw-r--r--
mutex.py
1.834 KB
-rw-r--r--
mutex.pyc
2.546 KB
-rw-r--r--
mutex.pyo
2.546 KB
-rw-r--r--
netrc.py
5.75 KB
-rw-r--r--
netrc.pyc
4.718 KB
-rw-r--r--
netrc.pyo
4.718 KB
-rw-r--r--
new.py
0.596 KB
-rw-r--r--
new.pyc
0.854 KB
-rw-r--r--
new.pyo
0.854 KB
-rw-r--r--
nntplib.py
20.967 KB
-rw-r--r--
nntplib.pyc
21.109 KB
-rw-r--r--
nntplib.pyo
21.109 KB
-rw-r--r--
ntpath.py
18.974 KB
-rw-r--r--
ntpath.pyc
13.101 KB
-rw-r--r--
ntpath.pyo
13.101 KB
-rw-r--r--
nturl2path.py
2.362 KB
-rw-r--r--
nturl2path.pyc
1.811 KB
-rw-r--r--
nturl2path.pyo
1.811 KB
-rw-r--r--
numbers.py
10.077 KB
-rw-r--r--
numbers.pyc
14.471 KB
-rw-r--r--
numbers.pyo
14.471 KB
-rw-r--r--
opcode.py
5.346 KB
-rw-r--r--
opcode.pyc
6.064 KB
-rw-r--r--
opcode.pyo
6.064 KB
-rw-r--r--
optparse.py
59.769 KB
-rw-r--r--
optparse.pyc
54.408 KB
-rw-r--r--
optparse.pyo
54.327 KB
-rw-r--r--
os.py
25.303 KB
-rw-r--r--
os.pyc
25.76 KB
-rw-r--r--
os.pyo
25.76 KB
-rw-r--r--
os2emxpath.py
4.526 KB
-rw-r--r--
os2emxpath.pyc
4.533 KB
-rw-r--r--
os2emxpath.pyo
4.533 KB
-rw-r--r--
pdb.doc
7.729 KB
-rw-r--r--
pdb.py
45.027 KB
-rwxr-xr-x
pdb.pyc
44.093 KB
-rw-r--r--
pdb.pyo
44.093 KB
-rw-r--r--
pickle.py
44.423 KB
-rw-r--r--
pickle.pyc
38.977 KB
-rw-r--r--
pickle.pyo
38.785 KB
-rw-r--r--
pickletools.py
72.776 KB
-rw-r--r--
pickletools.pyc
56.102 KB
-rw-r--r--
pickletools.pyo
55.261 KB
-rw-r--r--
pipes.py
9.357 KB
-rw-r--r--
pipes.pyc
9.293 KB
-rw-r--r--
pipes.pyo
9.293 KB
-rw-r--r--
pkgutil.py
19.769 KB
-rw-r--r--
pkgutil.pyc
18.934 KB
-rw-r--r--
pkgutil.pyo
18.934 KB
-rw-r--r--
platform.py
51.561 KB
-rwxr-xr-x
platform.pyc
37.697 KB
-rw-r--r--
platform.pyo
37.697 KB
-rw-r--r--
plistlib.py
14.829 KB
-rw-r--r--
plistlib.pyc
19.539 KB
-rw-r--r--
plistlib.pyo
19.455 KB
-rw-r--r--
popen2.py
8.219 KB
-rw-r--r--
popen2.pyc
9.017 KB
-rw-r--r--
popen2.pyo
8.976 KB
-rw-r--r--
poplib.py
12.523 KB
-rw-r--r--
poplib.pyc
13.451 KB
-rw-r--r--
poplib.pyo
13.451 KB
-rw-r--r--
posixfile.py
7.815 KB
-rw-r--r--
posixfile.pyc
7.625 KB
-rw-r--r--
posixfile.pyo
7.625 KB
-rw-r--r--
posixpath.py
13.958 KB
-rw-r--r--
posixpath.pyc
11.485 KB
-rw-r--r--
posixpath.pyo
11.485 KB
-rw-r--r--
pprint.py
11.501 KB
-rw-r--r--
pprint.pyc
10.196 KB
-rw-r--r--
pprint.pyo
10.023 KB
-rw-r--r--
profile.py
22.257 KB
-rwxr-xr-x
profile.pyc
16.565 KB
-rw-r--r--
profile.pyo
16.324 KB
-rw-r--r--
pstats.py
26.086 KB
-rw-r--r--
pstats.pyc
25.188 KB
-rw-r--r--
pstats.pyo
25.188 KB
-rw-r--r--
pty.py
4.939 KB
-rw-r--r--
pty.pyc
4.977 KB
-rw-r--r--
pty.pyo
4.977 KB
-rw-r--r--
py_compile.py
5.797 KB
-rw-r--r--
py_compile.pyc
6.366 KB
-rw-r--r--
py_compile.pyo
6.366 KB
-rw-r--r--
pyclbr.py
13.074 KB
-rw-r--r--
pyclbr.pyc
9.59 KB
-rw-r--r--
pyclbr.pyo
9.59 KB
-rw-r--r--
pydoc.py
93.434 KB
-rwxr-xr-x
pydoc.pyc
92.689 KB
-rw-r--r--
pydoc.pyo
92.627 KB
-rw-r--r--
quopri.py
6.814 KB
-rwxr-xr-x
quopri.pyc
6.56 KB
-rw-r--r--
quopri.pyo
6.56 KB
-rw-r--r--
random.py
31.696 KB
-rw-r--r--
random.pyc
25.647 KB
-rw-r--r--
random.pyo
25.647 KB
-rw-r--r--
re.py
13.108 KB
-rw-r--r--
re.pyc
13.365 KB
-rw-r--r--
re.pyo
13.365 KB
-rw-r--r--
repr.py
4.195 KB
-rw-r--r--
repr.pyc
5.475 KB
-rw-r--r--
repr.pyo
5.475 KB
-rw-r--r--
rexec.py
19.676 KB
-rw-r--r--
rexec.pyc
23.998 KB
-rw-r--r--
rexec.pyo
23.998 KB
-rw-r--r--
rfc822.py
32.756 KB
-rw-r--r--
rfc822.pyc
31.829 KB
-rw-r--r--
rfc822.pyo
31.829 KB
-rw-r--r--
rlcompleter.py
5.851 KB
-rw-r--r--
rlcompleter.pyc
6.037 KB
-rw-r--r--
rlcompleter.pyo
6.037 KB
-rw-r--r--
robotparser.py
7.515 KB
-rw-r--r--
robotparser.pyc
8.12 KB
-rw-r--r--
robotparser.pyo
8.12 KB
-rw-r--r--
runpy.py
10.821 KB
-rw-r--r--
runpy.pyc
8.851 KB
-rw-r--r--
runpy.pyo
8.851 KB
-rw-r--r--
sched.py
4.969 KB
-rw-r--r--
sched.pyc
4.991 KB
-rw-r--r--
sched.pyo
4.991 KB
-rw-r--r--
sets.py
18.604 KB
-rw-r--r--
sets.pyc
17.21 KB
-rw-r--r--
sets.pyo
17.21 KB
-rw-r--r--
sgmllib.py
17.465 KB
-rw-r--r--
sgmllib.pyc
15.671 KB
-rw-r--r--
sgmllib.pyo
15.671 KB
-rw-r--r--
sha.py
0.384 KB
-rw-r--r--
sha.pyc
0.424 KB
-rw-r--r--
sha.pyo
0.424 KB
-rw-r--r--
shelve.py
7.986 KB
-rw-r--r--
shelve.pyc
10.358 KB
-rw-r--r--
shelve.pyo
10.358 KB
-rw-r--r--
shlex.py
10.902 KB
-rw-r--r--
shlex.pyc
7.546 KB
-rw-r--r--
shlex.pyo
7.546 KB
-rw-r--r--
shutil.py
19.405 KB
-rw-r--r--
shutil.pyc
19.188 KB
-rw-r--r--
shutil.pyo
19.188 KB
-rw-r--r--
site.py
19.177 KB
-rw-r--r--
site.pyc
19.354 KB
-rw-r--r--
site.pyo
19.354 KB
-rw-r--r--
smtpd.py
18.117 KB
-rwxr-xr-x
smtpd.pyc
15.904 KB
-rw-r--r--
smtpd.pyo
15.904 KB
-rw-r--r--
smtplib.py
31.391 KB
-rwxr-xr-x
smtplib.pyc
30.292 KB
-rw-r--r--
smtplib.pyo
30.292 KB
-rw-r--r--
sndhdr.py
5.833 KB
-rw-r--r--
sndhdr.pyc
7.404 KB
-rw-r--r--
sndhdr.pyo
7.404 KB
-rw-r--r--
socket.py
20.132 KB
-rw-r--r--
socket.pyc
16.154 KB
-rw-r--r--
socket.pyo
16.07 KB
-rw-r--r--
sre.py
0.375 KB
-rw-r--r--
sre.pyc
0.52 KB
-rw-r--r--
sre.pyo
0.52 KB
-rw-r--r--
sre_compile.py
19.358 KB
-rw-r--r--
sre_compile.pyc
12.456 KB
-rw-r--r--
sre_compile.pyo
12.304 KB
-rw-r--r--
sre_constants.py
7.028 KB
-rw-r--r--
sre_constants.pyc
6.113 KB
-rw-r--r--
sre_constants.pyo
6.113 KB
-rw-r--r--
sre_parse.py
29.98 KB
-rw-r--r--
sre_parse.pyc
21.117 KB
-rw-r--r--
sre_parse.pyo
21.117 KB
-rw-r--r--
ssl.py
36.577 KB
-rw-r--r--
ssl.pyc
32.241 KB
-rw-r--r--
ssl.pyo
32.241 KB
-rw-r--r--
stat.py
1.799 KB
-rw-r--r--
stat.pyc
2.813 KB
-rw-r--r--
stat.pyo
2.813 KB
-rw-r--r--
statvfs.py
0.877 KB
-rw-r--r--
statvfs.pyc
0.618 KB
-rw-r--r--
statvfs.pyo
0.618 KB
-rw-r--r--
string.py
21.043 KB
-rw-r--r--
string.pyc
20.627 KB
-rw-r--r--
string.pyo
20.627 KB
-rw-r--r--
stringold.py
12.157 KB
-rw-r--r--
stringold.pyc
12.598 KB
-rw-r--r--
stringold.pyo
12.598 KB
-rw-r--r--
stringprep.py
13.205 KB
-rw-r--r--
stringprep.pyc
14.401 KB
-rw-r--r--
stringprep.pyo
14.331 KB
-rw-r--r--
struct.py
0.08 KB
-rw-r--r--
struct.pyc
0.246 KB
-rw-r--r--
struct.pyo
0.246 KB
-rw-r--r--
subprocess.py
49.336 KB
-rw-r--r--
subprocess.pyc
32.324 KB
-rw-r--r--
subprocess.pyo
32.324 KB
-rw-r--r--
sunau.py
16.818 KB
-rw-r--r--
sunau.pyc
18.572 KB
-rw-r--r--
sunau.pyo
18.572 KB
-rw-r--r--
sunaudio.py
1.366 KB
-rw-r--r--
sunaudio.pyc
2.004 KB
-rw-r--r--
sunaudio.pyo
2.004 KB
-rw-r--r--
symbol.py
2.019 KB
-rwxr-xr-x
symbol.pyc
2.98 KB
-rw-r--r--
symbol.pyo
2.98 KB
-rw-r--r--
symtable.py
7.263 KB
-rw-r--r--
symtable.pyc
12.145 KB
-rw-r--r--
symtable.pyo
12.017 KB
-rw-r--r--
sysconfig.py
22.316 KB
-rw-r--r--
sysconfig.pyc
17.73 KB
-rw-r--r--
sysconfig.pyo
17.728 KB
-rw-r--r--
tabnanny.py
11.083 KB
-rwxr-xr-x
tabnanny.pyc
8.308 KB
-rw-r--r--
tabnanny.pyo
8.308 KB
-rw-r--r--
tarfile.py
88.445 KB
-rw-r--r--
tarfile.pyc
76.537 KB
-rw-r--r--
tarfile.pyo
76.537 KB
-rw-r--r--
telnetlib.py
26.402 KB
-rw-r--r--
telnetlib.pyc
23.03 KB
-rw-r--r--
telnetlib.pyo
23.03 KB
-rw-r--r--
tempfile.py
19.089 KB
-rw-r--r--
tempfile.pyc
20.553 KB
-rw-r--r--
tempfile.pyo
20.553 KB
-rw-r--r--
textwrap.py
16.875 KB
-rw-r--r--
textwrap.pyc
11.991 KB
-rw-r--r--
textwrap.pyo
11.901 KB
-rw-r--r--
this.py
0.979 KB
-rw-r--r--
this.pyc
1.204 KB
-rw-r--r--
this.pyo
1.204 KB
-rw-r--r--
threading.py
46.174 KB
-rw-r--r--
threading.pyc
42.968 KB
-rw-r--r--
threading.pyo
40.845 KB
-rw-r--r--
timeit.py
12.501 KB
-rwxr-xr-x
timeit.pyc
12.063 KB
-rw-r--r--
timeit.pyo
12.063 KB
-rw-r--r--
toaiff.py
3.068 KB
-rw-r--r--
toaiff.pyc
3.084 KB
-rw-r--r--
toaiff.pyo
3.084 KB
-rw-r--r--
token.py
2.854 KB
-rw-r--r--
token.pyc
3.79 KB
-rw-r--r--
token.pyo
3.79 KB
-rw-r--r--
tokenize.py
17.073 KB
-rw-r--r--
tokenize.pyc
14.368 KB
-rw-r--r--
tokenize.pyo
14.313 KB
-rw-r--r--
trace.py
29.2 KB
-rwxr-xr-x
trace.pyc
22.69 KB
-rw-r--r--
trace.pyo
22.629 KB
-rw-r--r--
traceback.py
11.021 KB
-rw-r--r--
traceback.pyc
11.659 KB
-rw-r--r--
traceback.pyo
11.659 KB
-rw-r--r--
tty.py
0.858 KB
-rw-r--r--
tty.pyc
1.324 KB
-rw-r--r--
tty.pyo
1.324 KB
-rw-r--r--
types.py
2.045 KB
-rw-r--r--
types.pyc
2.75 KB
-rw-r--r--
types.pyo
2.75 KB
-rw-r--r--
urllib.py
58.816 KB
-rw-r--r--
urllib.pyc
51.348 KB
-rw-r--r--
urllib.pyo
51.255 KB
-rw-r--r--
urllib2.py
51.306 KB
-rw-r--r--
urllib2.pyc
47.802 KB
-rw-r--r--
urllib2.pyo
47.709 KB
-rw-r--r--
urlparse.py
16.287 KB
-rw-r--r--
urlparse.pyc
15.514 KB
-rw-r--r--
urlparse.pyo
15.514 KB
-rw-r--r--
user.py
1.589 KB
-rw-r--r--
user.pyc
1.696 KB
-rw-r--r--
user.pyo
1.696 KB
-rw-r--r--
uu.py
6.55 KB
-rwxr-xr-x
uu.pyc
4.351 KB
-rw-r--r--
uu.pyo
4.351 KB
-rw-r--r--
uuid.py
22.632 KB
-rw-r--r--
uuid.pyc
23.221 KB
-rw-r--r--
uuid.pyo
23.107 KB
-rw-r--r--
warnings.py
14.476 KB
-rw-r--r--
warnings.pyc
13.485 KB
-rw-r--r--
warnings.pyo
12.715 KB
-rw-r--r--
wave.py
18.146 KB
-rw-r--r--
wave.pyc
20.191 KB
-rw-r--r--
wave.pyo
20.051 KB
-rw-r--r--
weakref.py
14.482 KB
-rw-r--r--
weakref.pyc
16.729 KB
-rw-r--r--
weakref.pyo
16.729 KB
-rw-r--r--
webbrowser.py
22.202 KB
-rwxr-xr-x
webbrowser.pyc
19.858 KB
-rw-r--r--
webbrowser.pyo
19.814 KB
-rw-r--r--
whichdb.py
3.309 KB
-rw-r--r--
whichdb.pyc
2.214 KB
-rw-r--r--
whichdb.pyo
2.214 KB
-rw-r--r--
wsgiref.egg-info
0.183 KB
-rw-r--r--
xdrlib.py
5.927 KB
-rw-r--r--
xdrlib.pyc
10.203 KB
-rw-r--r--
xdrlib.pyo
10.203 KB
-rw-r--r--
xmllib.py
34.048 KB
-rw-r--r--
xmllib.pyc
26.904 KB
-rw-r--r--
xmllib.pyo
26.904 KB
-rw-r--r--
xmlrpclib.py
50.914 KB
-rw-r--r--
xmlrpclib.pyc
44.812 KB
-rw-r--r--
xmlrpclib.pyo
44.632 KB
-rw-r--r--
zipfile.py
58.083 KB
-rw-r--r--
zipfile.pyc
41.924 KB
-rw-r--r--
zipfile.pyo
41.924 KB
-rw-r--r--