404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.22.74.25: ~ $
"""
Import utilities

Exported classes:
    ImportManager   Manage the import process

    Importer        Base class for replacing standard import functions
    BuiltinImporter Emulate the import mechanism for builtin and frozen modules

    DynLoadSuffixImporter
"""
from warnings import warnpy3k
warnpy3k("the imputil module has been removed in Python 3.0", stacklevel=2)
del warnpy3k

# note: avoid importing non-builtin modules
import imp                      ### not available in Jython?
import sys
import __builtin__

# for the DirectoryImporter
import struct
import marshal

__all__ = ["ImportManager","Importer","BuiltinImporter"]

_StringType = type('')
_ModuleType = type(sys)         ### doesn't work in Jython...

class ImportManager:
    "Manage the import process."

    def install(self, namespace=vars(__builtin__)):
        "Install this ImportManager into the specified namespace."

        if isinstance(namespace, _ModuleType):
            namespace = vars(namespace)

        # Note: we have no notion of "chaining"

        # Record the previous import hook, then install our own.
        self.previous_importer = namespace['__import__']
        self.namespace = namespace
        namespace['__import__'] = self._import_hook

        ### fix this
        #namespace['reload'] = self._reload_hook

    def uninstall(self):
        "Restore the previous import mechanism."
        self.namespace['__import__'] = self.previous_importer

    def add_suffix(self, suffix, importFunc):
        assert hasattr(importFunc, '__call__')
        self.fs_imp.add_suffix(suffix, importFunc)

    ######################################################################
    #
    # PRIVATE METHODS
    #

    clsFilesystemImporter = None

    def __init__(self, fs_imp=None):
        # we're definitely going to be importing something in the future,
        # so let's just load the OS-related facilities.
        if not _os_stat:
            _os_bootstrap()

        # This is the Importer that we use for grabbing stuff from the
        # filesystem. It defines one more method (import_from_dir) for our use.
        if fs_imp is None:
            cls = self.clsFilesystemImporter or _FilesystemImporter
            fs_imp = cls()
        self.fs_imp = fs_imp

        # Initialize the set of suffixes that we recognize and import.
        # The default will import dynamic-load modules first, followed by
        # .py files (or a .py file's cached bytecode)
        for desc in imp.get_suffixes():
            if desc[2] == imp.C_EXTENSION:
                self.add_suffix(desc[0],
                                DynLoadSuffixImporter(desc).import_file)
        self.add_suffix('.py', py_suffix_importer)

    def _import_hook(self, fqname, globals=None, locals=None, fromlist=None):
        """Python calls this hook to locate and import a module."""

        parts = fqname.split('.')

        # determine the context of this import
        parent = self._determine_import_context(globals)

        # if there is a parent, then its importer should manage this import
        if parent:
            module = parent.__importer__._do_import(parent, parts, fromlist)
            if module:
                return module

        # has the top module already been imported?
        try:
            top_module = sys.modules[parts[0]]
        except KeyError:

            # look for the topmost module
            top_module = self._import_top_module(parts[0])
            if not top_module:
                # the topmost module wasn't found at all.
                raise ImportError, 'No module named ' + fqname

        # fast-path simple imports
        if len(parts) == 1:
            if not fromlist:
                return top_module

            if not top_module.__dict__.get('__ispkg__'):
                # __ispkg__ isn't defined (the module was not imported by us),
                # or it is zero.
                #
                # In the former case, there is no way that we could import
                # sub-modules that occur in the fromlist (but we can't raise an
                # error because it may just be names) because we don't know how
                # to deal with packages that were imported by other systems.
                #
                # In the latter case (__ispkg__ == 0), there can't be any sub-
                # modules present, so we can just return.
                #
                # In both cases, since len(parts) == 1, the top_module is also
                # the "bottom" which is the defined return when a fromlist
                # exists.
                return top_module

        importer = top_module.__dict__.get('__importer__')
        if importer:
            return importer._finish_import(top_module, parts[1:], fromlist)

        # Grrr, some people "import os.path" or do "from os.path import ..."
        if len(parts) == 2 and hasattr(top_module, parts[1]):
            if fromlist:
                return getattr(top_module, parts[1])
            else:
                return top_module

        # If the importer does not exist, then we have to bail. A missing
        # importer means that something else imported the module, and we have
        # no knowledge of how to get sub-modules out of the thing.
        raise ImportError, 'No module named ' + fqname

    def _determine_import_context(self, globals):
        """Returns the context in which a module should be imported.

        The context could be a loaded (package) module and the imported module
        will be looked for within that package. The context could also be None,
        meaning there is no context -- the module should be looked for as a
        "top-level" module.
        """

        if not globals or not globals.get('__importer__'):
            # globals does not refer to one of our modules or packages. That
            # implies there is no relative import context (as far as we are
            # concerned), and it should just pick it off the standard path.
            return None

        # The globals refer to a module or package of ours. It will define
        # the context of the new import. Get the module/package fqname.
        parent_fqname = globals['__name__']

        # if a package is performing the import, then return itself (imports
        # refer to pkg contents)
        if globals['__ispkg__']:
            parent = sys.modules[parent_fqname]
            assert globals is parent.__dict__
            return parent

        i = parent_fqname.rfind('.')

        # a module outside of a package has no particular import context
        if i == -1:
            return None

        # if a module in a package is performing the import, then return the
        # package (imports refer to siblings)
        parent_fqname = parent_fqname[:i]
        parent = sys.modules[parent_fqname]
        assert parent.__name__ == parent_fqname
        return parent

    def _import_top_module(self, name):
        # scan sys.path looking for a location in the filesystem that contains
        # the module, or an Importer object that can import the module.
        for item in sys.path:
            if isinstance(item, _StringType):
                module = self.fs_imp.import_from_dir(item, name)
            else:
                module = item.import_top(name)
            if module:
                return module
        return None

    def _reload_hook(self, module):
        "Python calls this hook to reload a module."

        # reloading of a module may or may not be possible (depending on the
        # importer), but at least we can validate that it's ours to reload
        importer = module.__dict__.get('__importer__')
        if not importer:
            ### oops. now what...
            pass

        # okay. it is using the imputil system, and we must delegate it, but
        # we don't know what to do (yet)
        ### we should blast the module dict and do another get_code(). need to
        ### flesh this out and add proper docco...
        raise SystemError, "reload not yet implemented"


class Importer:
    "Base class for replacing standard import functions."

    def import_top(self, name):
        "Import a top-level module."
        return self._import_one(None, name, name)

    ######################################################################
    #
    # PRIVATE METHODS
    #
    def _finish_import(self, top, parts, fromlist):
        # if "a.b.c" was provided, then load the ".b.c" portion down from
        # below the top-level module.
        bottom = self._load_tail(top, parts)

        # if the form is "import a.b.c", then return "a"
        if not fromlist:
            # no fromlist: return the top of the import tree
            return top

        # the top module was imported by self.
        #
        # this means that the bottom module was also imported by self (just
        # now, or in the past and we fetched it from sys.modules).
        #
        # since we imported/handled the bottom module, this means that we can
        # also handle its fromlist (and reliably use __ispkg__).

        # if the bottom node is a package, then (potentially) import some
        # modules.
        #
        # note: if it is not a package, then "fromlist" refers to names in
        #       the bottom module rather than modules.
        # note: for a mix of names and modules in the fromlist, we will
        #       import all modules and insert those into the namespace of
        #       the package module. Python will pick up all fromlist names
        #       from the bottom (package) module; some will be modules that
        #       we imported and stored in the namespace, others are expected
        #       to be present already.
        if bottom.__ispkg__:
            self._import_fromlist(bottom, fromlist)

        # if the form is "from a.b import c, d" then return "b"
        return bottom

    def _import_one(self, parent, modname, fqname):
        "Import a single module."

        # has the module already been imported?
        try:
            return sys.modules[fqname]
        except KeyError:
            pass

        # load the module's code, or fetch the module itself
        result = self.get_code(parent, modname, fqname)
        if result is None:
            return None

        module = self._process_result(result, fqname)

        # insert the module into its parent
        if parent:
            setattr(parent, modname, module)
        return module

    def _process_result(self, result, fqname):
        ispkg, code, values = result
        # did get_code() return an actual module? (rather than a code object)
        is_module = isinstance(code, _ModuleType)

        # use the returned module, or create a new one to exec code into
        if is_module:
            module = code
        else:
            module = imp.new_module(fqname)

        ### record packages a bit differently??
        module.__importer__ = self
        module.__ispkg__ = ispkg

        # insert additional values into the module (before executing the code)
        module.__dict__.update(values)

        # the module is almost ready... make it visible
        sys.modules[fqname] = module

        # execute the code within the module's namespace
        if not is_module:
            try:
                exec code in module.__dict__
            except:
                if fqname in sys.modules:
                    del sys.modules[fqname]
                raise

        # fetch from sys.modules instead of returning module directly.
        # also make module's __name__ agree with fqname, in case
        # the "exec code in module.__dict__" played games on us.
        module = sys.modules[fqname]
        module.__name__ = fqname
        return module

    def _load_tail(self, m, parts):
        """Import the rest of the modules, down from the top-level module.

        Returns the last module in the dotted list of modules.
        """
        for part in parts:
            fqname = "%s.%s" % (m.__name__, part)
            m = self._import_one(m, part, fqname)
            if not m:
                raise ImportError, "No module named " + fqname
        return m

    def _import_fromlist(self, package, fromlist):
        'Import any sub-modules in the "from" list.'

        # if '*' is present in the fromlist, then look for the '__all__'
        # variable to find additional items (modules) to import.
        if '*' in fromlist:
            fromlist = list(fromlist) + \
                       list(package.__dict__.get('__all__', []))

        for sub in fromlist:
            # if the name is already present, then don't try to import it (it
            # might not be a module!).
            if sub != '*' and not hasattr(package, sub):
                subname = "%s.%s" % (package.__name__, sub)
                submod = self._import_one(package, sub, subname)
                if not submod:
                    raise ImportError, "cannot import name " + subname

    def _do_import(self, parent, parts, fromlist):
        """Attempt to import the module relative to parent.

        This method is used when the import context specifies that <self>
        imported the parent module.
        """
        top_name = parts[0]
        top_fqname = parent.__name__ + '.' + top_name
        top_module = self._import_one(parent, top_name, top_fqname)
        if not top_module:
            # this importer and parent could not find the module (relatively)
            return None

        return self._finish_import(top_module, parts[1:], fromlist)

    ######################################################################
    #
    # METHODS TO OVERRIDE
    #
    def get_code(self, parent, modname, fqname):
        """Find and retrieve the code for the given module.

        parent specifies a parent module to define a context for importing. It
        may be None, indicating no particular context for the search.

        modname specifies a single module (not dotted) within the parent.

        fqname specifies the fully-qualified module name. This is a
        (potentially) dotted name from the "root" of the module namespace
        down to the modname.
        If there is no parent, then modname==fqname.

        This method should return None, or a 3-tuple.

        * If the module was not found, then None should be returned.

        * The first item of the 2- or 3-tuple should be the integer 0 or 1,
            specifying whether the module that was found is a package or not.

        * The second item is the code object for the module (it will be
            executed within the new module's namespace). This item can also
            be a fully-loaded module object (e.g. loaded from a shared lib).

        * The third item is a dictionary of name/value pairs that will be
            inserted into new module before the code object is executed. This
            is provided in case the module's code expects certain values (such
            as where the module was found). When the second item is a module
            object, then these names/values will be inserted *after* the module
            has been loaded/initialized.
        """
        raise RuntimeError, "get_code not implemented"


######################################################################
#
# Some handy stuff for the Importers
#

# byte-compiled file suffix character
_suffix_char = __debug__ and 'c' or 'o'

# byte-compiled file suffix
_suffix = '.py' + _suffix_char

def _compile(pathname, timestamp):
    """Compile (and cache) a Python source file.

    The file specified by <pathname> is compiled to a code object and
    returned.

    Presuming the appropriate privileges exist, the bytecodes will be
    saved back to the filesystem for future imports. The source file's
    modification timestamp must be provided as a Long value.
    """
    codestring = open(pathname, 'rU').read()
    if codestring and codestring[-1] != '\n':
        codestring = codestring + '\n'
    code = __builtin__.compile(codestring, pathname, 'exec')

    # try to cache the compiled code
    try:
        f = open(pathname + _suffix_char, 'wb')
    except IOError:
        pass
    else:
        f.write('\0\0\0\0')
        f.write(struct.pack('<I', timestamp))
        marshal.dump(code, f)
        f.flush()
        f.seek(0, 0)
        f.write(imp.get_magic())
        f.close()

    return code

_os_stat = _os_path_join = None
def _os_bootstrap():
    "Set up 'os' module replacement functions for use during import bootstrap."

    names = sys.builtin_module_names

    join = None
    if 'posix' in names:
        sep = '/'
        from posix import stat
    elif 'nt' in names:
        sep = '\\'
        from nt import stat
    elif 'dos' in names:
        sep = '\\'
        from dos import stat
    elif 'os2' in names:
        sep = '\\'
        from os2 import stat
    else:
        raise ImportError, 'no os specific module found'

    if join is None:
        def join(a, b, sep=sep):
            if a == '':
                return b
            lastchar = a[-1:]
            if lastchar == '/' or lastchar == sep:
                return a + b
            return a + sep + b

    global _os_stat
    _os_stat = stat

    global _os_path_join
    _os_path_join = join

def _os_path_isdir(pathname):
    "Local replacement for os.path.isdir()."
    try:
        s = _os_stat(pathname)
    except OSError:
        return None
    return (s.st_mode & 0170000) == 0040000

def _timestamp(pathname):
    "Return the file modification time as a Long."
    try:
        s = _os_stat(pathname)
    except OSError:
        return None
    return long(s.st_mtime)


######################################################################
#
# Emulate the import mechanism for builtin and frozen modules
#
class BuiltinImporter(Importer):
    def get_code(self, parent, modname, fqname):
        if parent:
            # these modules definitely do not occur within a package context
            return None

        # look for the module
        if imp.is_builtin(modname):
            type = imp.C_BUILTIN
        elif imp.is_frozen(modname):
            type = imp.PY_FROZEN
        else:
            # not found
            return None

        # got it. now load and return it.
        module = imp.load_module(modname, None, modname, ('', '', type))
        return 0, module, { }


######################################################################
#
# Internal importer used for importing from the filesystem
#
class _FilesystemImporter(Importer):
    def __init__(self):
        self.suffixes = [ ]

    def add_suffix(self, suffix, importFunc):
        assert hasattr(importFunc, '__call__')
        self.suffixes.append((suffix, importFunc))

    def import_from_dir(self, dir, fqname):
        result = self._import_pathname(_os_path_join(dir, fqname), fqname)
        if result:
            return self._process_result(result, fqname)
        return None

    def get_code(self, parent, modname, fqname):
        # This importer is never used with an empty parent. Its existence is
        # private to the ImportManager. The ImportManager uses the
        # import_from_dir() method to import top-level modules/packages.
        # This method is only used when we look for a module within a package.
        assert parent

        for submodule_path in parent.__path__:
            code = self._import_pathname(_os_path_join(submodule_path, modname), fqname)
            if code is not None:
                return code
        return self._import_pathname(_os_path_join(parent.__pkgdir__, modname),
                                     fqname)

    def _import_pathname(self, pathname, fqname):
        if _os_path_isdir(pathname):
            result = self._import_pathname(_os_path_join(pathname, '__init__'),
                                           fqname)
            if result:
                values = result[2]
                values['__pkgdir__'] = pathname
                values['__path__'] = [ pathname ]
                return 1, result[1], values
            return None

        for suffix, importFunc in self.suffixes:
            filename = pathname + suffix
            try:
                finfo = _os_stat(filename)
            except OSError:
                pass
            else:
                return importFunc(filename, finfo, fqname)
        return None

######################################################################
#
# SUFFIX-BASED IMPORTERS
#

def py_suffix_importer(filename, finfo, fqname):
    file = filename[:-3] + _suffix
    t_py = long(finfo[8])
    t_pyc = _timestamp(file)

    code = None
    if t_pyc is not None and t_pyc >= t_py:
        f = open(file, 'rb')
        if f.read(4) == imp.get_magic():
            t = struct.unpack('<I', f.read(4))[0]
            if t == t_py:
                code = marshal.load(f)
        f.close()
    if code is None:
        file = filename
        code = _compile(file, t_py)

    return 0, code, { '__file__' : file }

class DynLoadSuffixImporter:
    def __init__(self, desc):
        self.desc = desc

    def import_file(self, filename, finfo, fqname):
        fp = open(filename, self.desc[1])
        module = imp.load_module(fqname, fp, filename, self.desc)
        module.__file__ = filename
        return 0, module, { }


######################################################################

def _print_importers():
    items = sys.modules.items()
    items.sort()
    for name, module in items:
        if module:
            print name, module.__dict__.get('__importer__', '-- no importer')
        else:
            print name, '-- non-existent module'

def _test_revamp():
    ImportManager().install()
    sys.path.insert(0, BuiltinImporter())

######################################################################

#
# TODO
#
# from Finn Bock:
#   type(sys) is not a module in Jython. what to use instead?
#   imp.C_EXTENSION is not in Jython. same for get_suffixes and new_module
#
#   given foo.py of:
#      import sys
#      sys.modules['foo'] = sys
#
#   ---- standard import mechanism
#   >>> import foo
#   >>> foo
#   <module 'sys' (built-in)>
#
#   ---- revamped import mechanism
#   >>> import imputil
#   >>> imputil._test_revamp()
#   >>> import foo
#   >>> foo
#   <module 'foo' from 'foo.py'>
#
#
# from MAL:
#   should BuiltinImporter exist in sys.path or hard-wired in ImportManager?
#   need __path__ processing
#   performance
#   move chaining to a subclass [gjs: it's been nuked]
#   deinstall should be possible
#   query mechanism needed: is a specific Importer installed?
#   py/pyc/pyo piping hooks to filter/process these files
#   wish list:
#     distutils importer hooked to list of standard Internet repositories
#     module->file location mapper to speed FS-based imports
#     relative imports
#     keep chaining so that it can play nice with other import hooks
#
# from Gordon:
#   push MAL's mapper into sys.path[0] as a cache (hard-coded for apps)
#
# from Guido:
#   need to change sys.* references for rexec environs
#   need hook for MAL's walk-me-up import strategy, or Tim's absolute strategy
#   watch out for sys.modules[...] is None
#   flag to force absolute imports? (speeds _determine_import_context and
#       checking for a relative module)
#   insert names of archives into sys.path  (see quote below)
#   note: reload does NOT blast module dict
#   shift import mechanisms and policies around; provide for hooks, overrides
#       (see quote below)
#   add get_source stuff
#   get_topcode and get_subcode
#   CRLF handling in _compile
#   race condition in _compile
#   refactoring of os.py to deal with _os_bootstrap problem
#   any special handling to do for importing a module with a SyntaxError?
#       (e.g. clean up the traceback)
#   implement "domain" for path-type functionality using pkg namespace
#       (rather than FS-names like __path__)
#   don't use the word "private"... maybe "internal"
#
#
# Guido's comments on sys.path caching:
#
# We could cache this in a dictionary: the ImportManager can have a
# cache dict mapping pathnames to importer objects, and a separate
# method for coming up with an importer given a pathname that's not yet
# in the cache.  The method should do a stat and/or look at the
# extension to decide which importer class to use; you can register new
# importer classes by registering a suffix or a Boolean function, plus a
# class.  If you register a new importer class, the cache is zapped.
# The cache is independent from sys.path (but maintained per
# ImportManager instance) so that rearrangements of sys.path do the
# right thing.  If a path is dropped from sys.path the corresponding
# cache entry is simply no longer used.
#
# My/Guido's comments on factoring ImportManager and Importer:
#
# > However, we still have a tension occurring here:
# >
# > 1) implementing policy in ImportManager assists in single-point policy
# >    changes for app/rexec situations
# > 2) implementing policy in Importer assists in package-private policy
# >    changes for normal, operating conditions
# >
# > I'll see if I can sort out a way to do this. Maybe the Importer class will
# > implement the methods (which can be overridden to change policy) by
# > delegating to ImportManager.
#
# Maybe also think about what kind of policies an Importer would be
# likely to want to change.  I have a feeling that a lot of the code
# there is actually not so much policy but a *necessity* to get things
# working given the calling conventions for the __import__ hook: whether
# to return the head or tail of a dotted name, or when to do the "finish
# fromlist" stuff.
#

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