File: //proc/3/cwd/usr/lib64/python2.7/ihooks.pyc
�
zfc           @   s�  d  Z  d d l m Z m Z e d d d �[ d d l Z d d l Z d d l Z d d l Z d d d	 d
 d d d
 d g Z d Z	 d d l m
 Z
 m Z m Z d d l m
 Z
 m Z m Z e
 Z e Z d d d �  �  YZ d e f d �  �  YZ d e f d �  �  YZ d	 e f d �  �  YZ d
 e f d �  �  YZ d e f d �  �  YZ d e f d �  �  YZ d Z d a d d � Z d �  Z d S(   s,	  Import hook support.
Consistent use of this module will make it possible to change the
different mechanisms involved in loading modules independently.
While the built-in module imp exports interfaces to the built-in
module searching and loading algorithm, and it is possible to replace
the built-in function __import__ in order to change the semantics of
the import statement, until now it has been difficult to combine the
effect of different __import__ hacks, like loading modules from URLs
by rimport.py, or restricted execution by rexec.py.
This module defines three new concepts:
1) A "file system hooks" class provides an interface to a filesystem.
One hooks class is defined (Hooks), which uses the interface provided
by standard modules os and os.path.  It should be used as the base
class for other hooks classes.
2) A "module loader" class provides an interface to search for a
module in a search path and to load it.  It defines a method which
searches for a module in a single directory; by overriding this method
one can redefine the details of the search.  If the directory is None,
built-in and frozen modules are searched instead.
Two module loader class are defined, both implementing the search
strategy used by the built-in __import__ function: ModuleLoader uses
the imp module's find_module interface, while HookableModuleLoader
uses a file system hooks class to interact with the file system.  Both
use the imp module's load_* interfaces to actually load the module.
3) A "module importer" class provides an interface to import a
module, as well as interfaces to reload and unload a module.  It also
provides interfaces to install and uninstall itself instead of the
default __import__ and reload (and unload) functions.
One module importer class is defined (ModuleImporter), which uses a
module loader instance passed in (by default HookableModuleLoader is
instantiated).
The classes defined here should be used as base classes for extended
functionality along those lines.
If a module importer class supports dotted names, its import_module()
must return a different value depending on whether it is called on
behalf of a "from ... import ..." statement or not.  (This is caused
by the way the __import__ hook is used by the Python interpreter.)  It
would also do wise to install a different version of reload().
i����(   t   warnpy3kt   warns0   the ihooks module has been removed in Python 3.0t
   stackleveli   Nt   BasicModuleLoadert   Hookst   ModuleLoadert   FancyModuleLoadert   BasicModuleImportert   ModuleImportert   installt	   uninstalli    (   t   C_EXTENSIONt	   PY_SOURCEt   PY_COMPILED(   t	   C_BUILTINt	   PY_FROZENt
   PKG_DIRECTORYt   _Verbosec           B   s8   e  Z e d  � Z d �  Z d �  Z d �  Z d �  Z RS(   c         C   s
   | |  _  d  S(   N(   t   verbose(   t   selfR   (    (    s   /usr/lib64/python2.7/ihooks.pyt   __init__K   s    c         C   s   |  j  S(   N(   R   (   R   (    (    s   /usr/lib64/python2.7/ihooks.pyt   get_verboseN   s    c         C   s
   | |  _  d  S(   N(   R   (   R   R   (    (    s   /usr/lib64/python2.7/ihooks.pyt   set_verboseQ   s    c         G   s   |  j  r |  j | �  n  d  S(   N(   R   t   message(   R   t   args(    (    s   /usr/lib64/python2.7/ihooks.pyt   noteV   s    	c         G   s   | r | | GHn | GHd  S(   N(    (   R   t   formatR   (    (    s   /usr/lib64/python2.7/ihooks.pyR   Z   s    (   t   __name__t
   __module__t   VERBOSER   R   R   R   R   (    (    (    s   /usr/lib64/python2.7/ihooks.pyR   I   s
   			c           B   s>