本文整理匯總了Python中pkg_resources.Environment.best_match方法的典型用法代碼示例。如果您正苦於以下問題:Python Environment.best_match方法的具體用法?Python Environment.best_match怎麽用?Python Environment.best_match使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類pkg_resources.Environment
的用法示例。
在下文中一共展示了Environment.best_match方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: Bootstrapper
# 需要導入模塊: from pkg_resources import Environment [as 別名]
# 或者: from pkg_resources.Environment import best_match [as 別名]
#.........這裏部分代碼省略.........
logger.critical("Got force_setuptools=%r AND force_distribute=%r",
force_setuptools, force_distribute)
raise ValueError("Can't force both on setuptools and distribute !")
if force_setuptools is not None:
setuptools, setuptools_rhs = 'setuptools', force_setuptools
if force_distribute is not None:
setuptools, setuptools_rhs = 'distribute', force_distribute
# actually, installing distribute with any version of setuptools or
# itself happens to work... provided that the magic buildout marker
# that tells is setup no to touch the global site-packages is there
# otherwise, it'd try the rename an .egg_info, and would fail for non-
# privileged users, even for a local egg production.
# Usually, the shell would set it, thankfully it's not libc's concern
if setuptools == 'distribute':
os.environ['_'] = 'buildout_unibootstrap'
if DISTRIBUTE and setuptools == 'setuptools':
self.setuptools_req = self._setuptools_req(setuptools_rhs)
self.init_ez_install_distribute_to_setuptools()
return
self.setuptools_req = Requirement.parse(setuptools + setuptools_rhs)
self._ez_install_pypath = None
def ensure_req(self, req):
"""Make sure that requirement is satisfied and return location.
Either we have it already, or we install it.
"""
# we don't use obtain() because it's not clear how it would
# not use the working set with the full sys.path instead of our empty
# one (fearing also slight behaviour changes across versions)
dist = self.env.best_match(req, self.ws)
if dist is None:
dist = self.grab_req(req)
self.init_env()
dist = self.env.best_match(req, self.ws)
if dist is None:
raise LookupError(req)
logger.info("Requirement %s fulfilled at %s", req, dist.location)
return dist.location
def grab_req(self, req):
"""Install a requirement to self.eggs_dir.
We don't use the internal API of setuptools and spawn of subprocess
because:
- we might use a different version of setuptools than the one we import
from here
- the command-line (or surface) API is obviously very stable
"""
if self.offline:
# actually, we would have a small ability to find setuptools
# eggs that are present locally, but that's too complicated for
# now and has few chances of success
self.error("%s is not available in specified dists "
"directory %s, and can't be downloaded "
"(offline mode is requested)" % (req, self.eggs_dir))
logger.info("%s not available locally, attempting to download", req)
os_env = dict(os.environ)
pypath = self._ez_install_pypath
if pypath is not None:
os_env['PYTHONPATH'] = pypath
subprocess.check_call(self._ez_install +
示例2: DistributionsManager
# 需要導入模塊: from pkg_resources import Environment [as 別名]
# 或者: from pkg_resources.Environment import best_match [as 別名]
class DistributionsManager(object):
def __init__(self):
self.mod_folder = os.path.join(os.getcwd(), "raduga_modules")
if not os.path.exists(self.mod_folder):
os.mkdir(self.mod_folder)
self._init_environment()
def _init_environment(self):
dist_folders = map(lambda d: os.path.join(os.getcwd(), self.mod_folder, d), os.listdir(self.mod_folder))
dist_folders = filter(lambda f: os.path.exists(os.path.join(f, "EGG-INFO")), dist_folders)
dists = map(lambda f: Distribution.from_filename(f) , dist_folders)
#
self.pkg_env = Environment()
for dist in dists: self.pkg_env.add(dist)
def _add_to_environment(self, egg_folder):
dist = Distribution.from_filename(egg_folder)
self.pkg_env.add(dist)
def _match_req(self, req):
return self.pkg_env.best_match(req, working_set)
def _flatten_reqs(self, *req_sets):
# req_sets further in the list take precedence
reqs = {}
for rset in req_sets:
for sreq in rset:
req = Requirement.parse(sreq)
reqs[req.key] = req
return reqs.values()
@contextmanager
def requirement_loader(self, *req_sets):
# Save sys.path and sys.modules, to be restored later
import sys, copy
old_path = copy.copy(sys.path)
old_sys_modules = sys.modules.keys()
# Find distributions for all the requirements
req_dists = []
reqs = self._flatten_reqs(req_sets)
for req in reqs:
match = self._match_req(req)
if match is None:
raise RuntimeError("Unable to find distribution matching %s" % str(req))
req_dists.append(match)
# Activate the distributions, return control
for req in req_dists: req.activate()
yield
# Restore sys path and modules
sys.path = old_path
for modname in sys.modules.keys():
if not modname in old_sys_modules:
del sys.modules[modname]
def install_dist(self, path):
setup_py = os.path.join(os.getcwd(), path, "setup.py")
if not os.path.isfile(setup_py):
raise RuntimeError("Folder %s doesn't have a setup file" % path)
with self._build_egg_env(path) as tempdir:
import subprocess, zipfile
subprocess.check_call(["python", setup_py, "bdist_egg", "--dist-dir=%s" % tempdir])
egg = os.listdir(tempdir)[0] # egg will be the single entry in the temp folder
# TODO: check if exactly that same egg is installed
eggf = os.path.join(self.mod_folder, egg) # target egg folder
os.mkdir(eggf)
eggz = zipfile.ZipFile(os.path.join(tempdir, egg))
eggz.extractall(eggf)
@contextmanager
def _build_egg_env(self, path):
import tempfile, shutil
old_cwd = os.getcwd()
os.chdir(path)
tempdir = tempfile.mkdtemp()
yield tempdir
shutil.rmtree(tempdir)
os.chdir(old_cwd)