404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.140.185.250: ~ $
#! /bin/env python

# NOTE: the above "/usr/local/bin/python" is NOT a mistake.  It is
# intentionally NOT "/usr/bin/env python".  On many systems
# (e.g. Solaris), /usr/local/bin is not in $PATH as passed to CGI
# scripts, and /usr/local/bin is the default directory where Python is
# installed, so /usr/bin/env would be unable to find python.  Granted,
# binary installations by Linux vendors often install Python in
# /usr/bin.  So let those vendors patch cgi.py to match their choice
# of installation.

"""Support module for CGI (Common Gateway Interface) scripts.

This module defines a number of utilities for use by CGI scripts
written in Python.
"""

# XXX Perhaps there should be a slimmed version that doesn't contain
# all those backwards compatible and debugging classes and functions?

# History
# -------
#
# Michael McLay started this module.  Steve Majewski changed the
# interface to SvFormContentDict and FormContentDict.  The multipart
# parsing was inspired by code submitted by Andreas Paepcke.  Guido van
# Rossum rewrote, reformatted and documented the module and is currently
# responsible for its maintenance.
#

__version__ = "2.6"


# Imports
# =======

from operator import attrgetter
import sys
import os
import UserDict
import urlparse

from warnings import filterwarnings, catch_warnings, warn
with catch_warnings():
    if sys.py3kwarning:
        filterwarnings("ignore", ".*mimetools has been removed",
                       DeprecationWarning)
        filterwarnings("ignore", ".*rfc822 has been removed",
                       DeprecationWarning)
    import mimetools
    import rfc822

try:
    from cStringIO import StringIO
except ImportError:
    from StringIO import StringIO

__all__ = ["MiniFieldStorage", "FieldStorage", "FormContentDict",
           "SvFormContentDict", "InterpFormContentDict", "FormContent",
           "parse", "parse_qs", "parse_qsl", "parse_multipart",
           "parse_header", "print_exception", "print_environ",
           "print_form", "print_directory", "print_arguments",
           "print_environ_usage", "escape"]

# Logging support
# ===============

logfile = ""            # Filename to log to, if not empty
logfp = None            # File object to log to, if not None

def initlog(*allargs):
    """Write a log message, if there is a log file.

    Even though this function is called initlog(), you should always
    use log(); log is a variable that is set either to initlog
    (initially), to dolog (once the log file has been opened), or to
    nolog (when logging is disabled).

    The first argument is a format string; the remaining arguments (if
    any) are arguments to the % operator, so e.g.
        log("%s: %s", "a", "b")
    will write "a: b" to the log file, followed by a newline.

    If the global logfp is not None, it should be a file object to
    which log data is written.

    If the global logfp is None, the global logfile may be a string
    giving a filename to open, in append mode.  This file should be
    world writable!!!  If the file can't be opened, logging is
    silently disabled (since there is no safe place where we could
    send an error message).

    """
    global logfp, log
    if logfile and not logfp:
        try:
            logfp = open(logfile, "a")
        except IOError:
            pass
    if not logfp:
        log = nolog
    else:
        log = dolog
    log(*allargs)

def dolog(fmt, *args):
    """Write a log message to the log file.  See initlog() for docs."""
    logfp.write(fmt%args + "\n")

def nolog(*allargs):
    """Dummy function, assigned to log when logging is disabled."""
    pass

log = initlog           # The current logging function


# Parsing functions
# =================

# Maximum input we will accept when REQUEST_METHOD is POST
# 0 ==> unlimited input
maxlen = 0

def parse(fp=None, environ=os.environ, keep_blank_values=0, strict_parsing=0):
    """Parse a query in the environment or from a file (default stdin)

        Arguments, all optional:

        fp              : file pointer; default: sys.stdin

        environ         : environment dictionary; default: os.environ

        keep_blank_values: flag indicating whether blank values in
            percent-encoded forms should be treated as blank strings.
            A true value indicates that blanks should be retained as
            blank strings.  The default false value indicates that
            blank values are to be ignored and treated as if they were
            not included.

        strict_parsing: flag indicating what to do with parsing errors.
            If false (the default), errors are silently ignored.
            If true, errors raise a ValueError exception.
    """
    if fp is None:
        fp = sys.stdin
    if not 'REQUEST_METHOD' in environ:
        environ['REQUEST_METHOD'] = 'GET'       # For testing stand-alone
    if environ['REQUEST_METHOD'] == 'POST':
        ctype, pdict = parse_header(environ['CONTENT_TYPE'])
        if ctype == 'multipart/form-data':
            return parse_multipart(fp, pdict)
        elif ctype == 'application/x-www-form-urlencoded':
            clength = int(environ['CONTENT_LENGTH'])
            if maxlen and clength > maxlen:
                raise ValueError, 'Maximum content length exceeded'
            qs = fp.read(clength)
        else:
            qs = ''                     # Unknown content-type
        if 'QUERY_STRING' in environ:
            if qs: qs = qs + '&'
            qs = qs + environ['QUERY_STRING']
        elif sys.argv[1:]:
            if qs: qs = qs + '&'
            qs = qs + sys.argv[1]
        environ['QUERY_STRING'] = qs    # XXX Shouldn't, really
    elif 'QUERY_STRING' in environ:
        qs = environ['QUERY_STRING']
    else:
        if sys.argv[1:]:
            qs = sys.argv[1]
        else:
            qs = ""
        environ['QUERY_STRING'] = qs    # XXX Shouldn't, really
    return urlparse.parse_qs(qs, keep_blank_values, strict_parsing)


# parse query string function called from urlparse,
# this is done in order to maintain backward compatibility.

def parse_qs(qs, keep_blank_values=0, strict_parsing=0):
    """Parse a query given as a string argument."""
    warn("cgi.parse_qs is deprecated, use urlparse.parse_qs instead",
         PendingDeprecationWarning, 2)
    return urlparse.parse_qs(qs, keep_blank_values, strict_parsing)


def parse_qsl(qs, keep_blank_values=0, strict_parsing=0, max_num_fields=None):
    """Parse a query given as a string argument."""
    warn("cgi.parse_qsl is deprecated, use urlparse.parse_qsl instead",
         PendingDeprecationWarning, 2)
    return urlparse.parse_qsl(qs, keep_blank_values, strict_parsing,
                              max_num_fields)

def parse_multipart(fp, pdict):
    """Parse multipart input.

    Arguments:
    fp   : input file
    pdict: dictionary containing other parameters of content-type header

    Returns a dictionary just like parse_qs(): keys are the field names, each
    value is a list of values for that field.  This is easy to use but not
    much good if you are expecting megabytes to be uploaded -- in that case,
    use the FieldStorage class instead which is much more flexible.  Note
    that content-type is the raw, unparsed contents of the content-type
    header.

    XXX This does not parse nested multipart parts -- use FieldStorage for
    that.

    XXX This should really be subsumed by FieldStorage altogether -- no
    point in having two implementations of the same parsing algorithm.
    Also, FieldStorage protects itself better against certain DoS attacks
    by limiting the size of the data read in one chunk.  The API here
    does not support that kind of protection.  This also affects parse()
    since it can call parse_multipart().

    """
    boundary = ""
    if 'boundary' in pdict:
        boundary = pdict['boundary']
    if not valid_boundary(boundary):
        raise ValueError,  ('Invalid boundary in multipart form: %r'
                            % (boundary,))

    nextpart = "--" + boundary
    lastpart = "--" + boundary + "--"
    partdict = {}
    terminator = ""

    while terminator != lastpart:
        bytes = -1
        data = None
        if terminator:
            # At start of next part.  Read headers first.
            headers = mimetools.Message(fp)
            clength = headers.getheader('content-length')
            if clength:
                try:
                    bytes = int(clength)
                except ValueError:
                    pass
            if bytes > 0:
                if maxlen and bytes > maxlen:
                    raise ValueError, 'Maximum content length exceeded'
                data = fp.read(bytes)
            else:
                data = ""
        # Read lines until end of part.
        lines = []
        while 1:
            line = fp.readline()
            if not line:
                terminator = lastpart # End outer loop
                break
            if line[:2] == "--":
                terminator = line.strip()
                if terminator in (nextpart, lastpart):
                    break
            lines.append(line)
        # Done with part.
        if data is None:
            continue
        if bytes < 0:
            if lines:
                # Strip final line terminator
                line = lines[-1]
                if line[-2:] == "\r\n":
                    line = line[:-2]
                elif line[-1:] == "\n":
                    line = line[:-1]
                lines[-1] = line
                data = "".join(lines)
        line = headers['content-disposition']
        if not line:
            continue
        key, params = parse_header(line)
        if key != 'form-data':
            continue
        if 'name' in params:
            name = params['name']
        else:
            continue
        if name in partdict:
            partdict[name].append(data)
        else:
            partdict[name] = [data]

    return partdict


def _parseparam(s):
    while s[:1] == ';':
        s = s[1:]
        end = s.find(';')
        while end > 0 and (s.count('"', 0, end) - s.count('\\"', 0, end)) % 2:
            end = s.find(';', end + 1)
        if end < 0:
            end = len(s)
        f = s[:end]
        yield f.strip()
        s = s[end:]

def parse_header(line):
    """Parse a Content-type like header.

    Return the main content-type and a dictionary of options.

    """
    parts = _parseparam(';' + line)
    key = parts.next()
    pdict = {}
    for p in parts:
        i = p.find('=')
        if i >= 0:
            name = p[:i].strip().lower()
            value = p[i+1:].strip()
            if len(value) >= 2 and value[0] == value[-1] == '"':
                value = value[1:-1]
                value = value.replace('\\\\', '\\').replace('\\"', '"')
            pdict[name] = value
    return key, pdict


# Classes for field storage
# =========================

class MiniFieldStorage:

    """Like FieldStorage, for use when no file uploads are possible."""

    # Dummy attributes
    filename = None
    list = None
    type = None
    file = None
    type_options = {}
    disposition = None
    disposition_options = {}
    headers = {}

    def __init__(self, name, value):
        """Constructor from field name and value."""
        self.name = name
        self.value = value
        # self.file = StringIO(value)

    def __repr__(self):
        """Return printable representation."""
        return "MiniFieldStorage(%r, %r)" % (self.name, self.value)


class FieldStorage:

    """Store a sequence of fields, reading multipart/form-data.

    This class provides naming, typing, files stored on disk, and
    more.  At the top level, it is accessible like a dictionary, whose
    keys are the field names.  (Note: None can occur as a field name.)
    The items are either a Python list (if there's multiple values) or
    another FieldStorage or MiniFieldStorage object.  If it's a single
    object, it has the following attributes:

    name: the field name, if specified; otherwise None

    filename: the filename, if specified; otherwise None; this is the
        client side filename, *not* the file name on which it is
        stored (that's a temporary file you don't deal with)

    value: the value as a *string*; for file uploads, this
        transparently reads the file every time you request the value

    file: the file(-like) object from which you can read the data;
        None if the data is stored a simple string

    type: the content-type, or None if not specified

    type_options: dictionary of options specified on the content-type
        line

    disposition: content-disposition, or None if not specified

    disposition_options: dictionary of corresponding options

    headers: a dictionary(-like) object (sometimes rfc822.Message or a
        subclass thereof) containing *all* headers

    The class is subclassable, mostly for the purpose of overriding
    the make_file() method, which is called internally to come up with
    a file open for reading and writing.  This makes it possible to
    override the default choice of storing all files in a temporary
    directory and unlinking them as soon as they have been opened.

    """

    def __init__(self, fp=None, headers=None, outerboundary="",
                 environ=os.environ, keep_blank_values=0, strict_parsing=0,
                 max_num_fields=None):
        """Constructor.  Read multipart/* until last part.

        Arguments, all optional:

        fp              : file pointer; default: sys.stdin
            (not used when the request method is GET)

        headers         : header dictionary-like object; default:
            taken from environ as per CGI spec

        outerboundary   : terminating multipart boundary
            (for internal use only)

        environ         : environment dictionary; default: os.environ

        keep_blank_values: flag indicating whether blank values in
            percent-encoded forms should be treated as blank strings.
            A true value indicates that blanks should be retained as
            blank strings.  The default false value indicates that
            blank values are to be ignored and treated as if they were
            not included.

        strict_parsing: flag indicating what to do with parsing errors.
            If false (the default), errors are silently ignored.
            If true, errors raise a ValueError exception.

        max_num_fields: int. If set, then __init__ throws a ValueError
            if there are more than n fields read by parse_qsl().

        """
        method = 'GET'
        self.keep_blank_values = keep_blank_values
        self.strict_parsing = strict_parsing
        self.max_num_fields = max_num_fields
        if 'REQUEST_METHOD' in environ:
            method = environ['REQUEST_METHOD'].upper()
        self.qs_on_post = None
        if method == 'GET' or method == 'HEAD':
            if 'QUERY_STRING' in environ:
                qs = environ['QUERY_STRING']
            elif sys.argv[1:]:
                qs = sys.argv[1]
            else:
                qs = ""
            fp = StringIO(qs)
            if headers is None:
                headers = {'content-type':
                           "application/x-www-form-urlencoded"}
        if headers is None:
            headers = {}
            if method == 'POST':
                # Set default content-type for POST to what's traditional
                headers['content-type'] = "application/x-www-form-urlencoded"
            if 'CONTENT_TYPE' in environ:
                headers['content-type'] = environ['CONTENT_TYPE']
            if 'QUERY_STRING' in environ:
                self.qs_on_post = environ['QUERY_STRING']
            if 'CONTENT_LENGTH' in environ:
                headers['content-length'] = environ['CONTENT_LENGTH']
        self.fp = fp or sys.stdin
        self.headers = headers
        self.outerboundary = outerboundary

        # Process content-disposition header
        cdisp, pdict = "", {}
        if 'content-disposition' in self.headers:
            cdisp, pdict = parse_header(self.headers['content-disposition'])
        self.disposition = cdisp
        self.disposition_options = pdict
        self.name = None
        if 'name' in pdict:
            self.name = pdict['name']
        self.filename = None
        if 'filename' in pdict:
            self.filename = pdict['filename']

        # Process content-type header
        #
        # Honor any existing content-type header.  But if there is no
        # content-type header, use some sensible defaults.  Assume
        # outerboundary is "" at the outer level, but something non-false
        # inside a multi-part.  The default for an inner part is text/plain,
        # but for an outer part it should be urlencoded.  This should catch
        # bogus clients which erroneously forget to include a content-type
        # header.
        #
        # See below for what we do if there does exist a content-type header,
        # but it happens to be something we don't understand.
        if 'content-type' in self.headers:
            ctype, pdict = parse_header(self.headers['content-type'])
        elif self.outerboundary or method != 'POST':
            ctype, pdict = "text/plain", {}
        else:
            ctype, pdict = 'application/x-www-form-urlencoded', {}
        self.type = ctype
        self.type_options = pdict
        self.innerboundary = ""
        if 'boundary' in pdict:
            self.innerboundary = pdict['boundary']
        clen = -1
        if 'content-length' in self.headers:
            try:
                clen = int(self.headers['content-length'])
            except ValueError:
                pass
            if maxlen and clen > maxlen:
                raise ValueError, 'Maximum content length exceeded'
        self.length = clen

        self.list = self.file = None
        self.done = 0
        if ctype == 'application/x-www-form-urlencoded':
            self.read_urlencoded()
        elif ctype[:10] == 'multipart/':
            self.read_multi(environ, keep_blank_values, strict_parsing)
        else:
            self.read_single()

    def __repr__(self):
        """Return a printable representation."""
        return "FieldStorage(%r, %r, %r)" % (
                self.name, self.filename, self.value)

    def __iter__(self):
        return iter(self.keys())

    def __getattr__(self, name):
        if name != 'value':
            raise AttributeError, name
        if self.file:
            self.file.seek(0)
            value = self.file.read()
            self.file.seek(0)
        elif self.list is not None:
            value = self.list
        else:
            value = None
        return value

    def __getitem__(self, key):
        """Dictionary style indexing."""
        if self.list is None:
            raise TypeError, "not indexable"
        found = []
        for item in self.list:
            if item.name == key: found.append(item)
        if not found:
            raise KeyError, key
        if len(found) == 1:
            return found[0]
        else:
            return found

    def getvalue(self, key, default=None):
        """Dictionary style get() method, including 'value' lookup."""
        if key in self:
            value = self[key]
            if type(value) is type([]):
                return map(attrgetter('value'), value)
            else:
                return value.value
        else:
            return default

    def getfirst(self, key, default=None):
        """ Return the first value received."""
        if key in self:
            value = self[key]
            if type(value) is type([]):
                return value[0].value
            else:
                return value.value
        else:
            return default

    def getlist(self, key):
        """ Return list of received values."""
        if key in self:
            value = self[key]
            if type(value) is type([]):
                return map(attrgetter('value'), value)
            else:
                return [value.value]
        else:
            return []

    def keys(self):
        """Dictionary style keys() method."""
        if self.list is None:
            raise TypeError, "not indexable"
        return list(set(item.name for item in self.list))

    def has_key(self, key):
        """Dictionary style has_key() method."""
        if self.list is None:
            raise TypeError, "not indexable"
        return any(item.name == key for item in self.list)

    def __contains__(self, key):
        """Dictionary style __contains__ method."""
        if self.list is None:
            raise TypeError, "not indexable"
        return any(item.name == key for item in self.list)

    def __len__(self):
        """Dictionary style len(x) support."""
        return len(self.keys())

    def __nonzero__(self):
        return bool(self.list)

    def read_urlencoded(self):
        """Internal: read data in query string format."""
        qs = self.fp.read(self.length)
        if self.qs_on_post:
            qs += '&' + self.qs_on_post
        query = urlparse.parse_qsl(qs, self.keep_blank_values,
                                   self.strict_parsing, self.max_num_fields)
        self.list = [MiniFieldStorage(key, value) for key, value in query]
        self.skip_lines()

    FieldStorageClass = None

    def read_multi(self, environ, keep_blank_values, strict_parsing):
        """Internal: read a part that is itself multipart."""
        ib = self.innerboundary
        if not valid_boundary(ib):
            raise ValueError, 'Invalid boundary in multipart form: %r' % (ib,)
        self.list = []
        if self.qs_on_post:
            query = urlparse.parse_qsl(self.qs_on_post,
                                       self.keep_blank_values,
                                       self.strict_parsing,
                                       self.max_num_fields)
            self.list.extend(MiniFieldStorage(key, value)
                             for key, value in query)
            FieldStorageClass = None

        # Propagate max_num_fields into the sub class appropriately
        max_num_fields = self.max_num_fields
        if max_num_fields is not None:
            max_num_fields -= len(self.list)

        klass = self.FieldStorageClass or self.__class__
        part = klass(self.fp, {}, ib,
                     environ, keep_blank_values, strict_parsing,
                     max_num_fields)

        # Throw first part away
        while not part.done:
            headers = rfc822.Message(self.fp)
            part = klass(self.fp, headers, ib,
                         environ, keep_blank_values, strict_parsing,
                         max_num_fields)

            if max_num_fields is not None:
                max_num_fields -= 1
                if part.list:
                    max_num_fields -= len(part.list)
                if max_num_fields < 0:
                    raise ValueError('Max number of fields exceeded')

            self.list.append(part)
        self.skip_lines()

    def read_single(self):
        """Internal: read an atomic part."""
        if self.length >= 0:
            self.read_binary()
            self.skip_lines()
        else:
            self.read_lines()
        self.file.seek(0)

    bufsize = 8*1024            # I/O buffering size for copy to file

    def read_binary(self):
        """Internal: read binary data."""
        self.file = self.make_file('b')
        todo = self.length
        if todo >= 0:
            while todo > 0:
                data = self.fp.read(min(todo, self.bufsize))
                if not data:
                    self.done = -1
                    break
                self.file.write(data)
                todo = todo - len(data)

    def read_lines(self):
        """Internal: read lines until EOF or outerboundary."""
        self.file = self.__file = StringIO()
        if self.outerboundary:
            self.read_lines_to_outerboundary()
        else:
            self.read_lines_to_eof()

    def __write(self, line):
        if self.__file is not None:
            if self.__file.tell() + len(line) > 1000:
                self.file = self.make_file('')
                self.file.write(self.__file.getvalue())
                self.__file = None
        self.file.write(line)

    def read_lines_to_eof(self):
        """Internal: read lines until EOF."""
        while 1:
            line = self.fp.readline(1<<16)
            if not line:
                self.done = -1
                break
            self.__write(line)

    def read_lines_to_outerboundary(self):
        """Internal: read lines until outerboundary."""
        next = "--" + self.outerboundary
        last = next + "--"
        delim = ""
        last_line_lfend = True
        while 1:
            line = self.fp.readline(1<<16)
            if not line:
                self.done = -1
                break
            if delim == "\r":
                line = delim + line
                delim = ""
            if line[:2] == "--" and last_line_lfend:
                strippedline = line.strip()
                if strippedline == next:
                    break
                if strippedline == last:
                    self.done = 1
                    break
            odelim = delim
            if line[-2:] == "\r\n":
                delim = "\r\n"
                line = line[:-2]
                last_line_lfend = True
            elif line[-1] == "\n":
                delim = "\n"
                line = line[:-1]
                last_line_lfend = True
            elif line[-1] == "\r":
                # We may interrupt \r\n sequences if they span the 2**16
                # byte boundary
                delim = "\r"
                line = line[:-1]
                last_line_lfend = False
            else:
                delim = ""
                last_line_lfend = False
            self.__write(odelim + line)

    def skip_lines(self):
        """Internal: skip lines until outer boundary if defined."""
        if not self.outerboundary or self.done:
            return
        next = "--" + self.outerboundary
        last = next + "--"
        last_line_lfend = True
        while 1:
            line = self.fp.readline(1<<16)
            if not line:
                self.done = -1
                break
            if line[:2] == "--" and last_line_lfend:
                strippedline = line.strip()
                if strippedline == next:
                    break
                if strippedline == last:
                    self.done = 1
                    break
            last_line_lfend = line.endswith('\n')

    def make_file(self, binary=None):
        """Overridable: return a readable & writable file.

        The file will be used as follows:
        - data is written to it
        - seek(0)
        - data is read from it

        The 'binary' argument is unused -- the file is always opened
        in binary mode.

        This version opens a temporary file for reading and writing,
        and immediately deletes (unlinks) it.  The trick (on Unix!) is
        that the file can still be used, but it can't be opened by
        another process, and it will automatically be deleted when it
        is closed or when the current process terminates.

        If you want a more permanent file, you derive a class which
        overrides this method.  If you want a visible temporary file
        that is nevertheless automatically deleted when the script
        terminates, try defining a __del__ method in a derived class
        which unlinks the temporary files you have created.

        """
        import tempfile
        return tempfile.TemporaryFile("w+b")



# Backwards Compatibility Classes
# ===============================

class FormContentDict(UserDict.UserDict):
    """Form content as dictionary with a list of values per field.

    form = FormContentDict()

    form[key] -> [value, value, ...]
    key in form -> Boolean
    form.keys() -> [key, key, ...]
    form.values() -> [[val, val, ...], [val, val, ...], ...]
    form.items() ->  [(key, [val, val, ...]), (key, [val, val, ...]), ...]
    form.dict == {key: [val, val, ...], ...}

    """
    def __init__(self, environ=os.environ, keep_blank_values=0, strict_parsing=0):
        self.dict = self.data = parse(environ=environ,
                                      keep_blank_values=keep_blank_values,
                                      strict_parsing=strict_parsing)
        self.query_string = environ['QUERY_STRING']


class SvFormContentDict(FormContentDict):
    """Form content as dictionary expecting a single value per field.

    If you only expect a single value for each field, then form[key]
    will return that single value.  It will raise an IndexError if
    that expectation is not true.  If you expect a field to have
    possible multiple values, than you can use form.getlist(key) to
    get all of the values.  values() and items() are a compromise:
    they return single strings where there is a single value, and
    lists of strings otherwise.

    """
    def __getitem__(self, key):
        if len(self.dict[key]) > 1:
            raise IndexError, 'expecting a single value'
        return self.dict[key][0]
    def getlist(self, key):
        return self.dict[key]
    def values(self):
        result = []
        for value in self.dict.values():
            if len(value) == 1:
                result.append(value[0])
            else: result.append(value)
        return result
    def items(self):
        result = []
        for key, value in self.dict.items():
            if len(value) == 1:
                result.append((key, value[0]))
            else: result.append((key, value))
        return result


class InterpFormContentDict(SvFormContentDict):
    """This class is present for backwards compatibility only."""
    def __getitem__(self, key):
        v = SvFormContentDict.__getitem__(self, key)
        if v[0] in '0123456789+-.':
            try: return int(v)
            except ValueError:
                try: return float(v)
                except ValueError: pass
        return v.strip()
    def values(self):
        result = []
        for key in self.keys():
            try:
                result.append(self[key])
            except IndexError:
                result.append(self.dict[key])
        return result
    def items(self):
        result = []
        for key in self.keys():
            try:
                result.append((key, self[key]))
            except IndexError:
                result.append((key, self.dict[key]))
        return result


class FormContent(FormContentDict):
    """This class is present for backwards compatibility only."""
    def values(self, key):
        if key in self.dict :return self.dict[key]
        else: return None
    def indexed_value(self, key, location):
        if key in self.dict:
            if len(self.dict[key]) > location:
                return self.dict[key][location]
            else: return None
        else: return None
    def value(self, key):
        if key in self.dict: return self.dict[key][0]
        else: return None
    def length(self, key):
        return len(self.dict[key])
    def stripped(self, key):
        if key in self.dict: return self.dict[key][0].strip()
        else: return None
    def pars(self):
        return self.dict


# Test/debug code
# ===============

def test(environ=os.environ):
    """Robust test CGI script, usable as main program.

    Write minimal HTTP headers and dump all information provided to
    the script in HTML form.

    """
    print "Content-type: text/html"
    print
    sys.stderr = sys.stdout
    try:
        form = FieldStorage()   # Replace with other classes to test those
        print_directory()
        print_arguments()
        print_form(form)
        print_environ(environ)
        print_environ_usage()
        def f():
            exec "testing print_exception() -- <I>italics?</I>"
        def g(f=f):
            f()
        print "<H3>What follows is a test, not an actual exception:</H3>"
        g()
    except:
        print_exception()

    print "<H1>Second try with a small maxlen...</H1>"

    global maxlen
    maxlen = 50
    try:
        form = FieldStorage()   # Replace with other classes to test those
        print_directory()
        print_arguments()
        print_form(form)
        print_environ(environ)
    except:
        print_exception()

def print_exception(type=None, value=None, tb=None, limit=None):
    if type is None:
        type, value, tb = sys.exc_info()
    import traceback
    print
    print "<H3>Traceback (most recent call last):</H3>"
    list = traceback.format_tb(tb, limit) + \
           traceback.format_exception_only(type, value)
    print "<PRE>%s<B>%s</B></PRE>" % (
        escape("".join(list[:-1])),
        escape(list[-1]),
        )
    del tb

def print_environ(environ=os.environ):
    """Dump the shell environment as HTML."""
    keys = environ.keys()
    keys.sort()
    print
    print "<H3>Shell Environment:</H3>"
    print "<DL>"
    for key in keys:
        print "<DT>", escape(key), "<DD>", escape(environ[key])
    print "</DL>"
    print

def print_form(form):
    """Dump the contents of a form as HTML."""
    keys = form.keys()
    keys.sort()
    print
    print "<H3>Form Contents:</H3>"
    if not keys:
        print "<P>No form fields."
    print "<DL>"
    for key in keys:
        print "<DT>" + escape(key) + ":",
        value = form[key]
        print "<i>" + escape(repr(type(value))) + "</i>"
        print "<DD>" + escape(repr(value))
    print "</DL>"
    print

def print_directory():
    """Dump the current directory as HTML."""
    print
    print "<H3>Current Working Directory:</H3>"
    try:
        pwd = os.getcwd()
    except os.error, msg:
        print "os.error:", escape(str(msg))
    else:
        print escape(pwd)
    print

def print_arguments():
    print
    print "<H3>Command Line Arguments:</H3>"
    print
    print sys.argv
    print

def print_environ_usage():
    """Dump a list of environment variables used by CGI as HTML."""
    print """
<H3>These environment variables could have been set:</H3>
<UL>
<LI>AUTH_TYPE
<LI>CONTENT_LENGTH
<LI>CONTENT_TYPE
<LI>DATE_GMT
<LI>DATE_LOCAL
<LI>DOCUMENT_NAME
<LI>DOCUMENT_ROOT
<LI>DOCUMENT_URI
<LI>GATEWAY_INTERFACE
<LI>LAST_MODIFIED
<LI>PATH
<LI>PATH_INFO
<LI>PATH_TRANSLATED
<LI>QUERY_STRING
<LI>REMOTE_ADDR
<LI>REMOTE_HOST
<LI>REMOTE_IDENT
<LI>REMOTE_USER
<LI>REQUEST_METHOD
<LI>SCRIPT_NAME
<LI>SERVER_NAME
<LI>SERVER_PORT
<LI>SERVER_PROTOCOL
<LI>SERVER_ROOT
<LI>SERVER_SOFTWARE
</UL>
In addition, HTTP headers sent by the server may be passed in the
environment as well.  Here are some common variable names:
<UL>
<LI>HTTP_ACCEPT
<LI>HTTP_CONNECTION
<LI>HTTP_HOST
<LI>HTTP_PRAGMA
<LI>HTTP_REFERER
<LI>HTTP_USER_AGENT
</UL>
"""


# Utilities
# =========

def escape(s, quote=None):
    '''Replace special characters "&", "<" and ">" to HTML-safe sequences.
    If the optional flag quote is true, the quotation mark character (")
    is also translated.'''
    s = s.replace("&", "&amp;") # Must be done first!
    s = s.replace("<", "&lt;")
    s = s.replace(">", "&gt;")
    if quote:
        s = s.replace('"', "&quot;")
    return s

def valid_boundary(s, _vb_pattern="^[ -~]{0,200}[!-~]$"):
    import re
    return re.match(_vb_pattern, s)

# Invoke mainline
# ===============

# Call test() when this file is run as a script (not imported as a module)
if __name__ == '__main__':
    test()

Filemanager

Name Type Size Permission Actions
bsddb Folder 0755
compiler Folder 0755
config Folder 0755
ctypes Folder 0755
curses Folder 0755
distutils Folder 0755
email Folder 0755
encodings Folder 0755
ensurepip Folder 0755
hotshot Folder 0755
idlelib Folder 0755
importlib Folder 0755
json Folder 0755
lib-dynload Folder 0755
lib2to3 Folder 0755
logging Folder 0755
multiprocessing Folder 0755
plat-linux2 Folder 0755
pydoc_data Folder 0755
site-packages Folder 0755
sqlite3 Folder 0755
test Folder 0755
unittest Folder 0755
wsgiref Folder 0755
xml Folder 0755
BaseHTTPServer.py File 22.21 KB 0644
BaseHTTPServer.pyc File 21.47 KB 0644
BaseHTTPServer.pyo File 21.47 KB 0644
Bastion.py File 5.61 KB 0644
Bastion.pyc File 6.69 KB 0644
Bastion.pyo File 6.69 KB 0644
CGIHTTPServer.py File 12.78 KB 0644
CGIHTTPServer.pyc File 10.92 KB 0644
CGIHTTPServer.pyo File 10.92 KB 0644
ConfigParser.py File 27.1 KB 0644
ConfigParser.pyc File 25.37 KB 0644
ConfigParser.pyo File 25.37 KB 0644
Cookie.py File 25.92 KB 0644
Cookie.pyc File 22.61 KB 0644
Cookie.pyo File 22.61 KB 0644
DocXMLRPCServer.py File 10.52 KB 0644
DocXMLRPCServer.pyc File 10.2 KB 0644
DocXMLRPCServer.pyo File 10.09 KB 0644
HTMLParser.py File 16.77 KB 0644
HTMLParser.pyc File 13.81 KB 0644
HTMLParser.pyo File 13.51 KB 0644
MimeWriter.py File 6.33 KB 0644
MimeWriter.pyc File 7.31 KB 0644
MimeWriter.pyo File 7.31 KB 0644
Queue.py File 8.38 KB 0644
Queue.pyc File 9.56 KB 0644
Queue.pyo File 9.56 KB 0644
SimpleHTTPServer.py File 7.81 KB 0644
SimpleHTTPServer.pyc File 7.96 KB 0644
SimpleHTTPServer.pyo File 7.96 KB 0644
SimpleXMLRPCServer.py File 25.21 KB 0644
SimpleXMLRPCServer.pyc File 22.78 KB 0644
SimpleXMLRPCServer.pyo File 22.78 KB 0644
SocketServer.py File 23.39 KB 0644
SocketServer.pyc File 24.25 KB 0644
SocketServer.pyo File 24.25 KB 0644
StringIO.py File 10.41 KB 0644
StringIO.pyc File 11.45 KB 0644
StringIO.pyo File 11.45 KB 0644
UserDict.py File 6.89 KB 0644
UserDict.pyc File 10.05 KB 0644
UserDict.pyo File 10.05 KB 0644
UserList.py File 3.56 KB 0644
UserList.pyc File 6.85 KB 0644
UserList.pyo File 6.85 KB 0644
UserString.py File 9.46 KB 0755
UserString.pyc File 15.38 KB 0644
UserString.pyo File 15.38 KB 0644
_LWPCookieJar.py File 6.4 KB 0644
_LWPCookieJar.pyc File 5.38 KB 0644
_LWPCookieJar.pyo File 5.38 KB 0644
_MozillaCookieJar.py File 5.66 KB 0644
_MozillaCookieJar.pyc File 4.41 KB 0644
_MozillaCookieJar.pyo File 4.37 KB 0644
__future__.py File 4.28 KB 0644
__future__.pyc File 4.2 KB 0644
__future__.pyo File 4.2 KB 0644
__phello__.foo.py File 64 B 0644
__phello__.foo.pyc File 138 B 0644
__phello__.foo.pyo File 138 B 0644
_abcoll.py File 18.18 KB 0644
_abcoll.pyc File 26.4 KB 0644
_abcoll.pyo File 26.4 KB 0644
_osx_support.py File 18.65 KB 0644
_osx_support.pyc File 11.72 KB 0644
_osx_support.pyo File 11.72 KB 0644
_pyio.py File 68 KB 0644
_pyio.pyc File 65.41 KB 0644
_pyio.pyo File 65.41 KB 0644
_strptime.py File 20.24 KB 0644
_strptime.pyc File 15.07 KB 0644
_strptime.pyo File 15.07 KB 0644
_sysconfigdata.py File 20.65 KB 0644
_sysconfigdata.pyc File 23.69 KB 0644
_sysconfigdata.pyo File 23.69 KB 0644
_threading_local.py File 7.09 KB 0644
_threading_local.pyc File 6.34 KB 0644
_threading_local.pyo File 6.34 KB 0644
_weakrefset.py File 5.77 KB 0644
_weakrefset.pyc File 10.06 KB 0644
_weakrefset.pyo File 10.06 KB 0644
abc.py File 6.98 KB 0644
abc.pyc File 6.14 KB 0644
abc.pyo File 6.08 KB 0644
aifc.py File 33.77 KB 0644
aifc.pyc File 30.67 KB 0644
aifc.pyo File 30.67 KB 0644
antigravity.py File 60 B 0644
antigravity.pyc File 216 B 0644
antigravity.pyo File 216 B 0644
anydbm.py File 2.6 KB 0644
anydbm.pyc File 2.77 KB 0644
anydbm.pyo File 2.77 KB 0644
argparse.py File 87.14 KB 0644
argparse.pyc File 64.83 KB 0644
argparse.pyo File 64.67 KB 0644
ast.py File 11.53 KB 0644
ast.pyc File 12.94 KB 0644
ast.pyo File 12.94 KB 0644
asynchat.py File 11.31 KB 0644
asynchat.pyc File 8.98 KB 0644
asynchat.pyo File 8.98 KB 0644
asyncore.py File 20.45 KB 0644
asyncore.pyc File 19.2 KB 0644
asyncore.pyo File 19.2 KB 0644
atexit.py File 1.67 KB 0644
atexit.pyc File 2.23 KB 0644
atexit.pyo File 2.23 KB 0644
audiodev.py File 7.42 KB 0644
audiodev.pyc File 8.61 KB 0644
audiodev.pyo File 8.61 KB 0644
base64.py File 11.53 KB 0755
base64.pyc File 11.26 KB 0644
base64.pyo File 11.26 KB 0644
bdb.py File 21.21 KB 0644
bdb.pyc File 19.43 KB 0644
bdb.pyo File 19.43 KB 0644
binhex.py File 14.35 KB 0644
binhex.pyc File 15.75 KB 0644
binhex.pyo File 15.75 KB 0644
bisect.py File 2.53 KB 0644
bisect.pyc File 3.06 KB 0644
bisect.pyo File 3.06 KB 0644
cProfile.py File 6.42 KB 0755
cProfile.pyc File 6.42 KB 0644
cProfile.pyo File 6.42 KB 0644
calendar.py File 22.84 KB 0644
calendar.pyc File 28.26 KB 0644
calendar.pyo File 28.26 KB 0644
cgi.py File 34.96 KB 0755
cgi.pyc File 33.24 KB 0644
cgi.pyo File 33.24 KB 0644
cgitb.py File 11.89 KB 0644
cgitb.pyc File 12.08 KB 0644
cgitb.pyo File 12.08 KB 0644
chunk.py File 5.29 KB 0644
chunk.pyc File 5.61 KB 0644
chunk.pyo File 5.61 KB 0644
cmd.py File 14.67 KB 0644
cmd.pyc File 13.98 KB 0644
cmd.pyo File 13.98 KB 0644
code.py File 9.95 KB 0644
code.pyc File 10.29 KB 0644
code.pyo File 10.29 KB 0644
codecs.py File 35.3 KB 0644
codecs.pyc File 37.15 KB 0644
codecs.pyo File 37.15 KB 0644
codeop.py File 5.86 KB 0644
codeop.pyc File 6.57 KB 0644
codeop.pyo File 6.57 KB 0644
collections.py File 27.15 KB 0644
collections.pyc File 26.21 KB 0644
collections.pyo File 26.16 KB 0644
colorsys.py File 3.6 KB 0644
colorsys.pyc File 4 KB 0644
colorsys.pyo File 4 KB 0644
commands.py File 2.49 KB 0644
commands.pyc File 2.49 KB 0644
commands.pyo File 2.49 KB 0644
compileall.py File 7.58 KB 0644
compileall.pyc File 6.93 KB 0644
compileall.pyo File 6.93 KB 0644
contextlib.py File 4.32 KB 0644
contextlib.pyc File 4.5 KB 0644
contextlib.pyo File 4.5 KB 0644
cookielib.py File 63.95 KB 0644
cookielib.pyc File 54.67 KB 0644
cookielib.pyo File 54.49 KB 0644
copy.py File 11.26 KB 0644
copy.pyc File 12.21 KB 0644
copy.pyo File 12.13 KB 0644
copy_reg.py File 6.81 KB 0644
copy_reg.pyc File 5.19 KB 0644
copy_reg.pyo File 5.14 KB 0644
crypt.py File 2.24 KB 0644
crypt.pyc File 2.95 KB 0644
crypt.pyo File 2.95 KB 0644
csv.py File 16.32 KB 0644
csv.pyc File 13.56 KB 0644
csv.pyo File 13.56 KB 0644
dbhash.py File 498 B 0644
dbhash.pyc File 744 B 0644
dbhash.pyo File 744 B 0644
decimal.py File 216.73 KB 0644
decimal.pyc File 171.36 KB 0644
decimal.pyo File 171.36 KB 0644
difflib.py File 80.4 KB 0644
difflib.pyc File 61.13 KB 0644
difflib.pyo File 61.08 KB 0644
dircache.py File 1.1 KB 0644
dircache.pyc File 1.59 KB 0644
dircache.pyo File 1.59 KB 0644
dis.py File 6.35 KB 0644
dis.pyc File 6.18 KB 0644
dis.pyo File 6.18 KB 0644
doctest.py File 102.63 KB 0644
doctest.pyc File 83.21 KB 0644
doctest.pyo File 82.93 KB 0644
dumbdbm.py File 8.93 KB 0644
dumbdbm.pyc File 6.83 KB 0644
dumbdbm.pyo File 6.83 KB 0644
dummy_thread.py File 4.31 KB 0644
dummy_thread.pyc File 5.46 KB 0644
dummy_thread.pyo File 5.46 KB 0644
dummy_threading.py File 2.74 KB 0644
dummy_threading.pyc File 1.27 KB 0644
dummy_threading.pyo File 1.27 KB 0644
filecmp.py File 9.36 KB 0644
filecmp.pyc File 9.65 KB 0644
filecmp.pyo File 9.65 KB 0644
fileinput.py File 13.42 KB 0644
fileinput.pyc File 14.54 KB 0644
fileinput.pyo File 14.54 KB 0644
fnmatch.py File 3.24 KB 0644
fnmatch.pyc File 3.61 KB 0644
fnmatch.pyo File 3.61 KB 0644
formatter.py File 14.56 KB 0644
formatter.pyc File 19.71 KB 0644
formatter.pyo File 19.71 KB 0644
fpformat.py File 4.62 KB 0644
fpformat.pyc File 4.69 KB 0644
fpformat.pyo File 4.69 KB 0644
fractions.py File 21.87 KB 0644
fractions.pyc File 19.74 KB 0644
fractions.pyo File 19.74 KB 0644
ftplib.py File 37.3 KB 0644
ftplib.pyc File 34.82 KB 0644
ftplib.pyo File 34.82 KB 0644
functools.py File 4.69 KB 0644
functools.pyc File 6.85 KB 0644
functools.pyo File 6.85 KB 0644
genericpath.py File 3.13 KB 0644
genericpath.pyc File 3.57 KB 0644
genericpath.pyo File 3.57 KB 0644
getopt.py File 7.15 KB 0644
getopt.pyc File 6.63 KB 0644
getopt.pyo File 6.58 KB 0644
getpass.py File 5.43 KB 0644
getpass.pyc File 4.72 KB 0644
getpass.pyo File 4.72 KB 0644
gettext.py File 22.13 KB 0644
gettext.pyc File 18.17 KB 0644
gettext.pyo File 18.17 KB 0644
glob.py File 3.04 KB 0644
glob.pyc File 2.98 KB 0644
glob.pyo File 2.98 KB 0644
gzip.py File 18.58 KB 0644
gzip.pyc File 15.26 KB 0644
gzip.pyo File 15.26 KB 0644
hashlib.py File 7.66 KB 0644
hashlib.pyc File 6.86 KB 0644
hashlib.pyo File 6.86 KB 0644
heapq.py File 17.87 KB 0644
heapq.pyc File 14.45 KB 0644
heapq.pyo File 14.45 KB 0644
hmac.py File 4.48 KB 0644
hmac.pyc File 4.56 KB 0644
hmac.pyo File 4.56 KB 0644
htmlentitydefs.py File 17.63 KB 0644
htmlentitydefs.pyc File 6.23 KB 0644
htmlentitydefs.pyo File 6.23 KB 0644
htmllib.py File 12.57 KB 0644
htmllib.pyc File 20.99 KB 0644
htmllib.pyo File 20.99 KB 0644
httplib.py File 51.07 KB 0644
httplib.pyc File 37.88 KB 0644
httplib.pyo File 37.7 KB 0644
ihooks.py File 18.54 KB 0644
ihooks.pyc File 21.75 KB 0644
ihooks.pyo File 21.75 KB 0644
imaplib.py File 47.23 KB 0644
imaplib.pyc File 45.19 KB 0644
imaplib.pyo File 42.49 KB 0644
imghdr.py File 3.46 KB 0644
imghdr.pyc File 4.93 KB 0644
imghdr.pyo File 4.93 KB 0644
imputil.py File 25.16 KB 0644
imputil.pyc File 15.74 KB 0644
imputil.pyo File 15.57 KB 0644
inspect.py File 42 KB 0644
inspect.pyc File 40.16 KB 0644
inspect.pyo File 40.16 KB 0644
io.py File 3.24 KB 0644
io.pyc File 3.57 KB 0644
io.pyo File 3.57 KB 0644
keyword.py File 1.95 KB 0755
keyword.pyc File 2.08 KB 0644
keyword.pyo File 2.08 KB 0644
linecache.py File 3.93 KB 0644
linecache.pyc File 3.27 KB 0644
linecache.pyo File 3.27 KB 0644
locale.py File 100.42 KB 0644
locale.pyc File 55.69 KB 0644
locale.pyo File 55.69 KB 0644
macpath.py File 6.14 KB 0644
macpath.pyc File 7.74 KB 0644
macpath.pyo File 7.74 KB 0644
macurl2path.py File 2.67 KB 0644
macurl2path.pyc File 2.24 KB 0644
macurl2path.pyo File 2.24 KB 0644
mailbox.py File 79.34 KB 0644
mailbox.pyc File 77.7 KB 0644
mailbox.pyo File 77.65 KB 0644
mailcap.py File 7.25 KB 0644
mailcap.pyc File 7.08 KB 0644
mailcap.pyo File 7.08 KB 0644
markupbase.py File 14.3 KB 0644
markupbase.pyc File 9.27 KB 0644
markupbase.pyo File 9.07 KB 0644
md5.py File 358 B 0644
md5.pyc File 391 B 0644
md5.pyo File 391 B 0644
mhlib.py File 32.65 KB 0644
mhlib.pyc File 33.98 KB 0644
mhlib.pyo File 33.98 KB 0644
mimetools.py File 7 KB 0644
mimetools.pyc File 8.26 KB 0644
mimetools.pyo File 8.26 KB 0644
mimetypes.py File 20.54 KB 0644
mimetypes.pyc File 18.3 KB 0644
mimetypes.pyo File 18.3 KB 0644
mimify.py File 14.67 KB 0755
mimify.pyc File 11.91 KB 0644
mimify.pyo File 11.91 KB 0644
modulefinder.py File 23.89 KB 0644
modulefinder.pyc File 19.12 KB 0644
modulefinder.pyo File 19.04 KB 0644
multifile.py File 4.71 KB 0644
multifile.pyc File 5.48 KB 0644
multifile.pyo File 5.44 KB 0644
mutex.py File 1.83 KB 0644
mutex.pyc File 2.55 KB 0644
mutex.pyo File 2.55 KB 0644
netrc.py File 5.75 KB 0644
netrc.pyc File 4.72 KB 0644
netrc.pyo File 4.72 KB 0644
new.py File 610 B 0644
new.pyc File 875 B 0644
new.pyo File 875 B 0644
nntplib.py File 20.97 KB 0644
nntplib.pyc File 21.11 KB 0644
nntplib.pyo File 21.11 KB 0644
ntpath.py File 18.97 KB 0644
ntpath.pyc File 13.1 KB 0644
ntpath.pyo File 13.1 KB 0644
nturl2path.py File 2.36 KB 0644
nturl2path.pyc File 1.81 KB 0644
nturl2path.pyo File 1.81 KB 0644
numbers.py File 10.08 KB 0644
numbers.pyc File 14.47 KB 0644
numbers.pyo File 14.47 KB 0644
opcode.py File 5.35 KB 0644
opcode.pyc File 6.06 KB 0644
opcode.pyo File 6.06 KB 0644
optparse.py File 59.77 KB 0644
optparse.pyc File 54.41 KB 0644
optparse.pyo File 54.33 KB 0644
os.py File 25.3 KB 0644
os.pyc File 25.76 KB 0644
os.pyo File 25.76 KB 0644
os2emxpath.py File 4.53 KB 0644
os2emxpath.pyc File 4.53 KB 0644
os2emxpath.pyo File 4.53 KB 0644
pdb.doc File 7.73 KB 0644
pdb.py File 45.01 KB 0755
pdb.pyc File 44.09 KB 0644
pdb.pyo File 44.09 KB 0644
pickle.py File 44.42 KB 0644
pickle.pyc File 38.98 KB 0644
pickle.pyo File 38.79 KB 0644
pickletools.py File 72.78 KB 0644
pickletools.pyc File 56.1 KB 0644
pickletools.pyo File 55.26 KB 0644
pipes.py File 9.36 KB 0644
pipes.pyc File 9.29 KB 0644
pipes.pyo File 9.29 KB 0644
pkgutil.py File 19.77 KB 0644
pkgutil.pyc File 18.93 KB 0644
pkgutil.pyo File 18.93 KB 0644
platform.py File 51.55 KB 0755
platform.pyc File 37.7 KB 0644
platform.pyo File 37.7 KB 0644
plistlib.py File 14.83 KB 0644
plistlib.pyc File 19.54 KB 0644
plistlib.pyo File 19.46 KB 0644
popen2.py File 8.22 KB 0644
popen2.pyc File 9.02 KB 0644
popen2.pyo File 8.98 KB 0644
poplib.py File 12.52 KB 0644
poplib.pyc File 13.45 KB 0644
poplib.pyo File 13.45 KB 0644
posixfile.py File 7.82 KB 0644
posixfile.pyc File 7.63 KB 0644
posixfile.pyo File 7.63 KB 0644
posixpath.py File 13.96 KB 0644
posixpath.pyc File 11.49 KB 0644
posixpath.pyo File 11.49 KB 0644
pprint.py File 11.5 KB 0644
pprint.pyc File 10.2 KB 0644
pprint.pyo File 10.02 KB 0644
profile.py File 22.24 KB 0755
profile.pyc File 16.57 KB 0644
profile.pyo File 16.32 KB 0644
pstats.py File 26.09 KB 0644
pstats.pyc File 25.19 KB 0644
pstats.pyo File 25.19 KB 0644
pty.py File 4.94 KB 0644
pty.pyc File 4.98 KB 0644
pty.pyo File 4.98 KB 0644
py_compile.py File 5.8 KB 0644
py_compile.pyc File 6.37 KB 0644
py_compile.pyo File 6.37 KB 0644
pyclbr.py File 13.07 KB 0644
pyclbr.pyc File 9.59 KB 0644
pyclbr.pyo File 9.59 KB 0644
pydoc.py File 93.42 KB 0755
pydoc.pyc File 92.69 KB 0644
pydoc.pyo File 92.63 KB 0644
quopri.py File 6.8 KB 0755
quopri.pyc File 6.56 KB 0644
quopri.pyo File 6.56 KB 0644
random.py File 31.7 KB 0644
random.pyc File 25.65 KB 0644
random.pyo File 25.65 KB 0644
re.py File 13.11 KB 0644
re.pyc File 13.37 KB 0644
re.pyo File 13.37 KB 0644
repr.py File 4.2 KB 0644
repr.pyc File 5.47 KB 0644
repr.pyo File 5.47 KB 0644
rexec.py File 19.68 KB 0644
rexec.pyc File 24 KB 0644
rexec.pyo File 24 KB 0644
rfc822.py File 32.76 KB 0644
rfc822.pyc File 31.83 KB 0644
rfc822.pyo File 31.83 KB 0644
rlcompleter.py File 5.85 KB 0644
rlcompleter.pyc File 6.04 KB 0644
rlcompleter.pyo File 6.04 KB 0644
robotparser.py File 7.51 KB 0644
robotparser.pyc File 8.12 KB 0644
robotparser.pyo File 8.12 KB 0644
runpy.py File 10.82 KB 0644
runpy.pyc File 8.85 KB 0644
runpy.pyo File 8.85 KB 0644
sched.py File 4.97 KB 0644
sched.pyc File 4.99 KB 0644
sched.pyo File 4.99 KB 0644
sets.py File 18.6 KB 0644
sets.pyc File 17.21 KB 0644
sets.pyo File 17.21 KB 0644
sgmllib.py File 17.46 KB 0644
sgmllib.pyc File 15.67 KB 0644
sgmllib.pyo File 15.67 KB 0644
sha.py File 393 B 0644
sha.pyc File 434 B 0644
sha.pyo File 434 B 0644
shelve.py File 7.99 KB 0644
shelve.pyc File 10.36 KB 0644
shelve.pyo File 10.36 KB 0644
shlex.py File 10.9 KB 0644
shlex.pyc File 7.55 KB 0644
shlex.pyo File 7.55 KB 0644
shutil.py File 19.41 KB 0644
shutil.pyc File 19.19 KB 0644
shutil.pyo File 19.19 KB 0644
site.py File 19.18 KB 0644
site.pyc File 19.35 KB 0644
site.pyo File 19.35 KB 0644
smtpd.py File 18.1 KB 0755
smtpd.pyc File 15.9 KB 0644
smtpd.pyo File 15.9 KB 0644
smtplib.py File 31.38 KB 0755
smtplib.pyc File 30.29 KB 0644
smtplib.pyo File 30.29 KB 0644
sndhdr.py File 5.83 KB 0644
sndhdr.pyc File 7.4 KB 0644
sndhdr.pyo File 7.4 KB 0644
socket.py File 20.13 KB 0644
socket.pyc File 16.15 KB 0644
socket.pyo File 16.07 KB 0644
sre.py File 384 B 0644
sre.pyc File 532 B 0644
sre.pyo File 532 B 0644
sre_compile.py File 19.36 KB 0644
sre_compile.pyc File 12.46 KB 0644
sre_compile.pyo File 12.3 KB 0644
sre_constants.py File 7.03 KB 0644
sre_constants.pyc File 6.11 KB 0644
sre_constants.pyo File 6.11 KB 0644
sre_parse.py File 29.98 KB 0644
sre_parse.pyc File 21.12 KB 0644
sre_parse.pyo File 21.12 KB 0644
ssl.py File 36.58 KB 0644
ssl.pyc File 32.24 KB 0644
ssl.pyo File 32.24 KB 0644
stat.py File 1.8 KB 0644
stat.pyc File 2.81 KB 0644
stat.pyo File 2.81 KB 0644
statvfs.py File 898 B 0644
statvfs.pyc File 633 B 0644
statvfs.pyo File 633 B 0644
string.py File 21.04 KB 0644
string.pyc File 20.63 KB 0644
string.pyo File 20.63 KB 0644
stringold.py File 12.16 KB 0644
stringold.pyc File 12.6 KB 0644
stringold.pyo File 12.6 KB 0644
stringprep.py File 13.21 KB 0644
stringprep.pyc File 14.4 KB 0644
stringprep.pyo File 14.33 KB 0644
struct.py File 82 B 0644
struct.pyc File 252 B 0644
struct.pyo File 252 B 0644
subprocess.py File 49.34 KB 0644
subprocess.pyc File 32.32 KB 0644
subprocess.pyo File 32.32 KB 0644
sunau.py File 16.82 KB 0644
sunau.pyc File 18.57 KB 0644
sunau.pyo File 18.57 KB 0644
sunaudio.py File 1.37 KB 0644
sunaudio.pyc File 2 KB 0644
sunaudio.pyo File 2 KB 0644
symbol.py File 2.01 KB 0755
symbol.pyc File 2.98 KB 0644
symbol.pyo File 2.98 KB 0644
symtable.py File 7.26 KB 0644
symtable.pyc File 12.14 KB 0644
symtable.pyo File 12.02 KB 0644
sysconfig.py File 22.32 KB 0644
sysconfig.pyc File 17.73 KB 0644
sysconfig.pyo File 17.73 KB 0644
tabnanny.py File 11.07 KB 0755
tabnanny.pyc File 8.31 KB 0644
tabnanny.pyo File 8.31 KB 0644
tarfile.py File 88.45 KB 0644
tarfile.pyc File 76.54 KB 0644
tarfile.pyo File 76.54 KB 0644
telnetlib.py File 26.4 KB 0644
telnetlib.pyc File 23.03 KB 0644
telnetlib.pyo File 23.03 KB 0644
tempfile.py File 19.09 KB 0644
tempfile.pyc File 20.55 KB 0644
tempfile.pyo File 20.55 KB 0644
textwrap.py File 16.88 KB 0644
textwrap.pyc File 11.99 KB 0644
textwrap.pyo File 11.9 KB 0644
this.py File 1002 B 0644
this.pyc File 1.2 KB 0644
this.pyo File 1.2 KB 0644
threading.py File 46.17 KB 0644
threading.pyc File 42.97 KB 0644
threading.pyo File 40.84 KB 0644
timeit.py File 12.49 KB 0755
timeit.pyc File 12.06 KB 0644
timeit.pyo File 12.06 KB 0644
toaiff.py File 3.07 KB 0644
toaiff.pyc File 3.08 KB 0644
toaiff.pyo File 3.08 KB 0644
token.py File 2.85 KB 0644
token.pyc File 3.79 KB 0644
token.pyo File 3.79 KB 0644
tokenize.py File 17.07 KB 0644
tokenize.pyc File 14.37 KB 0644
tokenize.pyo File 14.31 KB 0644
trace.py File 29.19 KB 0755
trace.pyc File 22.69 KB 0644
trace.pyo File 22.63 KB 0644
traceback.py File 11.02 KB 0644
traceback.pyc File 11.66 KB 0644
traceback.pyo File 11.66 KB 0644
tty.py File 879 B 0644
tty.pyc File 1.32 KB 0644
tty.pyo File 1.32 KB 0644
types.py File 2.04 KB 0644
types.pyc File 2.75 KB 0644
types.pyo File 2.75 KB 0644
urllib.py File 58.82 KB 0644
urllib.pyc File 51.35 KB 0644
urllib.pyo File 51.25 KB 0644
urllib2.py File 51.31 KB 0644
urllib2.pyc File 47.8 KB 0644
urllib2.pyo File 47.71 KB 0644
urlparse.py File 16.29 KB 0644
urlparse.pyc File 15.51 KB 0644
urlparse.pyo File 15.51 KB 0644
user.py File 1.59 KB 0644
user.pyc File 1.7 KB 0644
user.pyo File 1.7 KB 0644
uu.py File 6.54 KB 0755
uu.pyc File 4.35 KB 0644
uu.pyo File 4.35 KB 0644
uuid.py File 22.63 KB 0644
uuid.pyc File 23.22 KB 0644
uuid.pyo File 23.11 KB 0644
warnings.py File 14.48 KB 0644
warnings.pyc File 13.49 KB 0644
warnings.pyo File 12.71 KB 0644
wave.py File 18.15 KB 0644
wave.pyc File 20.19 KB 0644
wave.pyo File 20.05 KB 0644
weakref.py File 14.48 KB 0644
weakref.pyc File 16.73 KB 0644
weakref.pyo File 16.73 KB 0644
webbrowser.py File 22.19 KB 0755
webbrowser.pyc File 19.86 KB 0644
webbrowser.pyo File 19.81 KB 0644
whichdb.py File 3.31 KB 0644
whichdb.pyc File 2.21 KB 0644
whichdb.pyo File 2.21 KB 0644
wsgiref.egg-info File 187 B 0644
xdrlib.py File 5.93 KB 0644
xdrlib.pyc File 10.2 KB 0644
xdrlib.pyo File 10.2 KB 0644
xmllib.py File 34.05 KB 0644
xmllib.pyc File 26.9 KB 0644
xmllib.pyo File 26.9 KB 0644
xmlrpclib.py File 50.91 KB 0644
xmlrpclib.pyc File 44.81 KB 0644
xmlrpclib.pyo File 44.63 KB 0644
zipfile.py File 58.08 KB 0644
zipfile.pyc File 41.92 KB 0644
zipfile.pyo File 41.92 KB 0644