當前位置: 首頁>>代碼示例>>Python>>正文


Python requirements.InvalidRequirement方法代碼示例

本文整理匯總了Python中packaging.requirements.InvalidRequirement方法的典型用法代碼示例。如果您正苦於以下問題:Python requirements.InvalidRequirement方法的具體用法?Python requirements.InvalidRequirement怎麽用?Python requirements.InvalidRequirement使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在packaging.requirements的用法示例。


在下文中一共展示了requirements.InvalidRequirement方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: parse

# 需要導入模塊: from packaging import requirements [as 別名]
# 或者: from packaging.requirements import InvalidRequirement [as 別名]
def parse(cls, line):
        """

        :param line:
        :return:
        """
        try:
            # setuptools requires a space before the comment. If this isn't the case, add it.
            if "\t#" in line:
                parsed, = setuptools_parse_requirements_backport(line.replace("\t#", "\t #"))
            else:
                parsed, = setuptools_parse_requirements_backport(line)
        except InvalidRequirement:
            return None
        dep = Dependency(
            name=parsed.name,
            specs=parsed.specifier,
            line=line,
            extras=parsed.extras,
            dependency_type=filetypes.requirements_txt
        )
        return dep 
開發者ID:pypa,項目名稱:pipenv,代碼行數:24,代碼來源:parser.py

示例2: _is_same_dep

# 需要導入模塊: from packaging import requirements [as 別名]
# 或者: from packaging.requirements import InvalidRequirement [as 別名]
def _is_same_dep(cls, dep1, dep2):
        """Definitions are the same if they refer to the same package, even if versions differ."""
        dep1_name = canonicalize_name(requirements.Requirement(dep1).name)
        try:
            dep2_name = canonicalize_name(requirements.Requirement(dep2).name)
        except requirements.InvalidRequirement:
            # we couldn't parse a version, probably a URL
            return False
        return dep1_name == dep2_name 
開發者ID:tox-dev,項目名稱:tox,代碼行數:11,代碼來源:__init__.py

示例3: ensure_requires_satisfied

# 需要導入模塊: from packaging import requirements [as 別名]
# 或者: from packaging.requirements import InvalidRequirement [as 別名]
def ensure_requires_satisfied(config, requires, min_version):
        missing_requirements = []
        failed_to_parse = False
        deps = []
        exists = set()
        for require in requires + [min_version]:
            # noinspection PyBroadException
            try:
                package = requirements.Requirement(require)
                # check if the package even applies
                if package.marker and not package.marker.evaluate({"extra": ""}):
                    continue
                package_name = canonicalize_name(package.name)
                if package_name not in exists:
                    deps.append(DepConfig(require, None))
                    exists.add(package_name)
                    dist = importlib_metadata.distribution(package.name)
                    if not package.specifier.contains(dist.version, prereleases=True):
                        raise MissingDependency(package)
            except requirements.InvalidRequirement as exception:
                failed_to_parse = True
                error("failed to parse {!r}".format(exception))
            except Exception as exception:
                verbosity1("could not satisfy requires {!r}".format(exception))
                missing_requirements.append(str(requirements.Requirement(require)))
        if failed_to_parse:
            raise tox.exception.BadRequirement()
        if WITHIN_PROVISION and missing_requirements:
            msg = "break infinite loop provisioning within {} missing {}"
            raise tox.exception.Error(msg.format(sys.executable, missing_requirements))
        config.run_provision = bool(len(missing_requirements))
        return deps 
開發者ID:tox-dev,項目名稱:tox,代碼行數:34,代碼來源:__init__.py

示例4: _convert_deps

# 需要導入模塊: from packaging import requirements [as 別名]
# 或者: from packaging.requirements import InvalidRequirement [as 別名]
def _convert_deps(*, deps, name, version, extra):

        # filter result
        result = []
        for dep in deps:
            try:
                req = Requirement(dep)
            except InvalidRequirement as e:
                msg = 'cannot parse requirement: {} from {} {}'
                try:
                    # try to parse with dropped out markers
                    req = Requirement(dep.split(';')[0])
                except InvalidRequirement:
                    raise ValueError(msg.format(dep, name, version)) from e
                else:
                    logger.warning('cannot parse marker', extra=dict(
                        requirement=dep,
                        source_name=name,
                        source_version=version,
                    ))

            try:
                dep_extras = req.marker and Markers(req.marker).get_strings('extra')
            except ValueError:  # unsupported operation for version marker python_version: in
                dep_extras = set()

            # it's not extra and we want not extra too
            if not dep_extras and extra is None:
                result.append(req)
                continue
            # it's extra, but we want not the extra
            # or it's not the extra, but we want extra.
            if not dep_extras or extra is None:
                continue
            # it's extra and we want this extra
            for dep_extra in dep_extras:
                if dep_extra == extra:
                    result.append(req)
                    break

        return tuple(result) 
開發者ID:dephell,項目名稱:dephell,代碼行數:43,代碼來源:_base.py

示例5: _make_req

# 需要導入模塊: from packaging import requirements [as 別名]
# 或者: from packaging.requirements import InvalidRequirement [as 別名]
def _make_req(test_id, i, name, req_str):
    try:
        return Requirement(req_str)
    except InvalidRequirement as e:
        raise MalformedYAML(test_id, "{} has invalid requirement {!r}", name, req_str) 
開發者ID:pradyunsg,項目名稱:zazo,代碼行數:7,代碼來源:translate.py

示例6: _validate_plugins

# 需要導入模塊: from packaging import requirements [as 別名]
# 或者: from packaging.requirements import InvalidRequirement [as 別名]
def _validate_plugins(self) -> None:
        required_plugins = sorted(self.getini("required_plugins"))
        if not required_plugins:
            return

        # Imported lazily to improve start-up time.
        from packaging.version import Version
        from packaging.requirements import InvalidRequirement, Requirement

        plugin_info = self.pluginmanager.list_plugin_distinfo()
        plugin_dist_info = {dist.project_name: dist.version for _, dist in plugin_info}

        missing_plugins = []
        for required_plugin in required_plugins:
            spec = None
            try:
                spec = Requirement(required_plugin)
            except InvalidRequirement:
                missing_plugins.append(required_plugin)
                continue

            if spec.name not in plugin_dist_info:
                missing_plugins.append(required_plugin)
            elif Version(plugin_dist_info[spec.name]) not in spec.specifier:
                missing_plugins.append(required_plugin)

        if missing_plugins:
            fail(
                "Missing required plugins: {}".format(", ".join(missing_plugins)),
                pytrace=False,
            ) 
開發者ID:pytest-dev,項目名稱:pytest,代碼行數:33,代碼來源:__init__.py

示例7: parse_info

# 需要導入模塊: from packaging import requirements [as 別名]
# 或者: from packaging.requirements import InvalidRequirement [as 別名]
def parse_info(cls, content: str, root=None, urls: Dict[str, str] = None) -> RootDependency:
        if urls is None:
            urls = dict()

        info = Parser().parsestr(content)
        root = RootDependency(
            raw_name=cls._get(info, 'Name'),
            version=cls._get(info, 'Version') or '0.0.0',

            description=cls._get(info, 'Summary'),
            license=cls._get(info, 'License'),

            keywords=cls._get(info, 'Keywords').split(','),
            classifiers=cls._get_list(info, 'Classifier'),
            platforms=cls._get_list(info, 'Platform'),
        )

        # links
        fields = (
            (HOMEPAGE_FIELD, 'Home-Page'),
            (DOWNLOAD_FIELD, 'Download-URL'),
        )
        for key, name in fields:
            link = cls._get(info, name)
            if link:
                root.links[key] = link
        for link in cls._get_list(info, 'Project-URL'):
            key, url = link.split(', ')
            root.links[key.lower()] = url

        # authors
        for name in ('author', 'maintainer'):
            author = cls._get(info, name)
            if author:
                root.authors += (
                    Author(name=author, mail=cls._get(info, name + '_email')),
                )

        # dependencies
        deps = []
        for req in cls._get_list(info, 'Requires-Dist'):
            try:
                req = PackagingRequirement(req)
            except InvalidRequirement:
                cls.logger.warning('invalid requirement', extra=dict(
                    requirement=req,
                    package_name=root.name,
                    package_version=root.version,
                ))
                continue
            deps.extend(DependencyMaker.from_requirement(
                source=root,
                req=req,
                url=urls.get(req.name),
            ))
        root.attach_dependencies(deps)
        return root 
開發者ID:dephell,項目名稱:dephell,代碼行數:59,代碼來源:egginfo.py


注:本文中的packaging.requirements.InvalidRequirement方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。