diff --git a/mypy.ini b/mypy.ini index 4e119c252..a0f63e7d8 100644 --- a/mypy.ini +++ b/mypy.ini @@ -25,9 +25,6 @@ ignore_errors = True [mypy-poetry.core.semver.*] ignore_errors = True -[mypy-poetry.core.spdx.*] -ignore_errors = True - [mypy-poetry.core.vcs.*] ignore_errors = True diff --git a/poetry/core/spdx/helpers.py b/poetry/core/spdx/helpers.py index a1a1d73c8..d51d6d9b4 100644 --- a/poetry/core/spdx/helpers.py +++ b/poetry/core/spdx/helpers.py @@ -2,42 +2,45 @@ import os from io import open -from typing import TYPE_CHECKING from typing import Dict from typing import Optional +from .license import License -if TYPE_CHECKING: - from .license import License # noqa +_licenses: Optional[Dict[str, License]] = None -_licenses: Optional[Dict[str, "License"]] = None +def license_by_id(identifier: str) -> License: -def license_by_id(identifier: str) -> "License": - from .license import License # noqa - - if _licenses is None: - load_licenses() + licenses = _lazy_load_licenses() id = identifier.lower() - if id not in _licenses: + if id not in licenses: if not identifier: raise ValueError("A license identifier is required") return License(identifier, identifier, False, False) - return _licenses[id] + return licenses[id] -def load_licenses() -> None: - from .license import License # noqa +def _lazy_load_licenses() -> Dict[str, License]: global _licenses - _licenses = {} + if _licenses is None: + licenses = _load_licenses() + _licenses = licenses + return licenses + else: + return _licenses + + +def _load_licenses() -> Dict[str, License]: + licenses = {} licenses_file = os.path.join(os.path.dirname(__file__), "data", "licenses.json") with open(licenses_file, encoding="utf-8") as f: @@ -45,18 +48,20 @@ def load_licenses() -> None: for name, license_info in data.items(): license = License(name, license_info[0], license_info[1], license_info[2]) - _licenses[name.lower()] = license + licenses[name.lower()] = license full_name = license_info[0].lower() - if full_name in _licenses: - existing_license = _licenses[full_name] + if full_name in licenses: + existing_license = licenses[full_name] if not existing_license.is_deprecated: continue - _licenses[full_name] = license + licenses[full_name] = license # Add a Proprietary license for non-standard licenses - _licenses["proprietary"] = License("Proprietary", "Proprietary", False, False) + licenses["proprietary"] = License("Proprietary", "Proprietary", False, False) + + return licenses if __name__ == "__main__": diff --git a/poetry/core/spdx/updater.py b/poetry/core/spdx/updater.py index 29adfaea3..d4ec3df4c 100644 --- a/poetry/core/spdx/updater.py +++ b/poetry/core/spdx/updater.py @@ -10,7 +10,7 @@ try: from urllib.request import urlopen except ImportError: - from urllib2 import urlopen + from urllib2 import urlopen # type: ignore class Updater: