| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- # Licensed under the GPL: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
- # For details: https://github.com/pylint-dev/pylint/blob/main/LICENSE
- # Copyright (c) https://github.com/pylint-dev/pylint/blob/main/CONTRIBUTORS.txt
- from __future__ import annotations
- __all__ = [
- "__version__",
- "version",
- "modify_sys_path",
- "run_pylint",
- "run_epylint",
- "run_symilar",
- "run_pyreverse",
- ]
- import os
- import sys
- import warnings
- from collections.abc import Sequence
- from typing import NoReturn
- from pylint.__pkginfo__ import __version__
- # pylint: disable=import-outside-toplevel
- def run_pylint(argv: Sequence[str] | None = None) -> None:
- """Run pylint.
- argv can be a sequence of strings normally supplied as arguments on the command line
- """
- from pylint.lint import Run as PylintRun
- try:
- PylintRun(argv or sys.argv[1:])
- except KeyboardInterrupt:
- sys.exit(1)
- def _run_pylint_config(argv: Sequence[str] | None = None) -> None:
- """Run pylint-config.
- argv can be a sequence of strings normally supplied as arguments on the command line
- """
- from pylint.lint.run import _PylintConfigRun
- _PylintConfigRun(argv or sys.argv[1:])
- def run_epylint(argv: Sequence[str] | None = None) -> NoReturn:
- """Run epylint.
- argv can be a list of strings normally supplied as arguments on the command line
- """
- from pylint.epylint import Run as EpylintRun
- warnings.warn(
- "'run_epylint' will be removed in pylint 3.0, use "
- "https://github.com/emacsorphanage/pylint instead.",
- DeprecationWarning,
- stacklevel=1,
- )
- EpylintRun(argv)
- def run_pyreverse(argv: Sequence[str] | None = None) -> NoReturn:
- """Run pyreverse.
- argv can be a sequence of strings normally supplied as arguments on the command line
- """
- from pylint.pyreverse.main import Run as PyreverseRun
- PyreverseRun(argv or sys.argv[1:])
- def run_symilar(argv: Sequence[str] | None = None) -> NoReturn:
- """Run symilar.
- argv can be a sequence of strings normally supplied as arguments on the command line
- """
- from pylint.checkers.similar import Run as SimilarRun
- SimilarRun(argv or sys.argv[1:])
- def modify_sys_path() -> None:
- """Modify sys path for execution as Python module.
- Strip out the current working directory from sys.path.
- Having the working directory in `sys.path` means that `pylint` might
- inadvertently import user code from modules having the same name as
- stdlib or pylint's own modules.
- CPython issue: https://bugs.python.org/issue33053
- - Remove the first entry. This will always be either "" or the working directory
- - Remove the working directory from the second and third entries
- if PYTHONPATH includes a ":" at the beginning or the end.
- https://github.com/pylint-dev/pylint/issues/3636
- Don't remove it if PYTHONPATH contains the cwd or '.' as the entry will
- only be added once.
- - Don't remove the working directory from the rest. It will be included
- if pylint is installed in an editable configuration (as the last item).
- https://github.com/pylint-dev/pylint/issues/4161
- """
- cwd = os.getcwd()
- if sys.path[0] in ("", ".", cwd):
- sys.path.pop(0)
- env_pythonpath = os.environ.get("PYTHONPATH", "")
- if env_pythonpath.startswith(":") and env_pythonpath not in (f":{cwd}", ":."):
- sys.path.pop(0)
- elif env_pythonpath.endswith(":") and env_pythonpath not in (f"{cwd}:", ".:"):
- sys.path.pop(1)
- version = __version__
|