Orbits  1
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Macros Pages
Public Member Functions | Public Attributes | Private Member Functions | List of all members
pkg_resources.WorkingSet Class Reference
Inheritance diagram for pkg_resources.WorkingSet:
_object

Public Member Functions

def __init__
 
def add_entry
 
def __contains__
 
def find
 
def iter_entry_points
 
def run_script
 
def __iter__
 
def add
 
def resolve
 
def find_plugins
 
def require
 
def subscribe
 
def __getstate__
 
def __setstate__
 

Public Attributes

 entries
 
 entry_keys
 
 by_key
 
 callbacks
 

Private Member Functions

def _build_master
 
def _build_from_requirements
 
def _added_new
 

Detailed Description

A collection of active distributions on sys.path (or a similar list)

Constructor & Destructor Documentation

def pkg_resources.WorkingSet.__init__ (   self,
  entries = None 
)
A collection of active distributions on sys.path (or a similar list)
Create working set from list of path entries (default=sys.path)

Member Function Documentation

def pkg_resources.WorkingSet.__contains__ (   self,
  dist 
)
True if `dist` is the active distribution for its project
def pkg_resources.WorkingSet.__getstate__ (   self)
def pkg_resources.WorkingSet.__iter__ (   self)
Yield distributions for non-duplicate projects in the working set

The yield order is the order in which the items' path entries were
added to the working set.
def pkg_resources.WorkingSet.__setstate__ (   self,
  e_k_b_c 
)
def pkg_resources.WorkingSet._added_new (   self,
  dist 
)
private
def pkg_resources.WorkingSet._build_from_requirements (   cls,
  req_spec 
)
private
Build a working set from a requirement spec. Rewrites sys.path.
def pkg_resources.WorkingSet._build_master (   cls)
private
Prepare the master working set.
def pkg_resources.WorkingSet.add (   self,
  dist,
  entry = None,
  insert = True,
  replace = False 
)
Add `dist` to working set, associated with `entry`

If `entry` is unspecified, it defaults to the ``.location`` of `dist`.
On exit from this routine, `entry` is added to the end of the working
set's ``.entries`` (if it wasn't already present).

`dist` is only added to the working set if it's for a project that
doesn't already have a distribution in the set, unless `replace=True`.
If it's added, any callbacks registered with the ``subscribe()`` method
will be called.
def pkg_resources.WorkingSet.add_entry (   self,
  entry 
)
Add a path item to ``.entries``, finding any distributions on it

``find_distributions(entry, True)`` is used to find distributions
corresponding to the path entry, and they are added.  `entry` is
always appended to ``.entries``, even if it is already present.
(This is because ``sys.path`` can contain the same value more than
once, and the ``.entries`` of the ``sys.path`` WorkingSet should always
equal ``sys.path``.)
def pkg_resources.WorkingSet.find (   self,
  req 
)
Find a distribution matching requirement `req`

If there is an active distribution for the requested project, this
returns it as long as it meets the version requirement specified by
`req`.  But, if there is an active distribution for the project and it
does *not* meet the `req` requirement, ``VersionConflict`` is raised.
If there is no active distribution for the requested project, ``None``
is returned.
def pkg_resources.WorkingSet.find_plugins (   self,
  plugin_env,
  full_env = None,
  installer = None,
  fallback = True 
)
Find all activatable distributions in `plugin_env`

Example usage::

    distributions, errors = working_set.find_plugins(
Environment(plugin_dirlist)
    )
    map(working_set.add, distributions)  # add plugins+libs to sys.path
    print 'Could not load', errors        # display errors

The `plugin_env` should be an ``Environment`` instance that contains
only distributions that are in the project's "plugin directory" or
directories. The `full_env`, if supplied, should be an ``Environment``
contains all currently-available distributions.  If `full_env` is not
supplied, one is created automatically from the ``WorkingSet`` this
method is called on, which will typically mean that every directory on
``sys.path`` will be scanned for distributions.

`installer` is a standard installer callback as used by the
``resolve()`` method. The `fallback` flag indicates whether we should
attempt to resolve older versions of a plugin if the newest version
cannot be resolved.

This method returns a 2-tuple: (`distributions`, `error_info`), where
`distributions` is a list of the distributions found in `plugin_env`
that were loadable, along with any other distributions that are needed
to resolve their dependencies.  `error_info` is a dictionary mapping
unloadable plugin distributions to an exception instance describing the
error that occurred. Usually this will be a ``DistributionNotFound`` or
``VersionConflict`` instance.
def pkg_resources.WorkingSet.iter_entry_points (   self,
  group,
  name = None 
)
Yield entry point objects from `group` matching `name`

If `name` is None, yields all entry points in `group` from all
distributions in the working set, otherwise only ones matching
both `group` and `name` are yielded (in distribution order).
def pkg_resources.WorkingSet.require (   self,
  requirements 
)
Ensure that distributions matching `requirements` are activated

`requirements` must be a string or a (possibly-nested) sequence
thereof, specifying the distributions and versions required.  The
return value is a sequence of the distributions that needed to be
activated to fulfill the requirements; all relevant distributions are
included, even if they were already activated in this working set.
def pkg_resources.WorkingSet.resolve (   self,
  requirements,
  env = None,
  installer = None,
  replace_conflicting = False 
)
List all distributions needed to (recursively) meet `requirements`

`requirements` must be a sequence of ``Requirement`` objects.  `env`,
if supplied, should be an ``Environment`` instance.  If
not supplied, it defaults to all distributions available within any
entry or distribution in the working set.  `installer`, if supplied,
will be invoked with each requirement that cannot be met by an
already-installed distribution; it should return a ``Distribution`` or
``None``.

Unless `replace_conflicting=True`, raises a VersionConflict exception if
any requirements are found on the path that have the correct name but
the wrong version.  Otherwise, if an `installer` is supplied it will be
invoked to obtain the correct version of the requirement and activate
it.
def pkg_resources.WorkingSet.run_script (   self,
  requires,
  script_name 
)
Locate distribution for `requires` and run `script_name` script
def pkg_resources.WorkingSet.subscribe (   self,
  callback 
)
Invoke `callback` for all distributions (including existing ones)

Member Data Documentation

pkg_resources.WorkingSet.by_key
pkg_resources.WorkingSet.callbacks
pkg_resources.WorkingSet.entries
pkg_resources.WorkingSet.entry_keys

The documentation for this class was generated from the following file:

Copyright 2014 Google Inc. All rights reserved.