D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
proc
/
self
/
root
/
proc
/
self
/
root
/
opt
/
cloudlinux
/
venv
/
lib
/
python3.11
/
site-packages
/
pylint
/
Filename :
__init__.py
back
Copy
# Licensed under the GPL: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html # For details: https://github.com/PyCQA/pylint/blob/main/LICENSE # Copyright (c) https://github.com/PyCQA/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/PyCQA/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/PyCQA/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__