diff options
author | Pierre Sassoulas <pierre.sassoulas@gmail.com> | 2021-04-01 08:56:25 +0200 |
---|---|---|
committer | Pierre Sassoulas <pierre.sassoulas@gmail.com> | 2021-04-03 22:49:21 +0200 |
commit | 63ca05977dc11efe4c51f64a08c02fd0fb0566fc (patch) | |
tree | 192c6555626d84b39d34d37c23e24baa7c846eb5 /pylint/utils/utils.py | |
parent | 8b3b8e27c891c4678b2e239c899fb4e12714ab67 (diff) | |
download | pylint-git-63ca05977dc11efe4c51f64a08c02fd0fb0566fc.tar.gz |
Move utils.expand_module in its own file in lint
We never used it anywhere else than lint so it belong in lint.
Diffstat (limited to 'pylint/utils/utils.py')
-rw-r--r-- | pylint/utils/utils.py | 139 |
1 files changed, 0 insertions, 139 deletions
diff --git a/pylint/utils/utils.py b/pylint/utils/utils.py index b06cf3026..4b1d7566c 100644 --- a/pylint/utils/utils.py +++ b/pylint/utils/utils.py @@ -98,145 +98,6 @@ def tokenize_module(module): return list(tokenize.tokenize(readline)) -def _basename_in_ignore_list_re(base_name, ignore_list_re): - """Determines if the basename is matched in a regex ignorelist - - :param str base_name: The basename of the file - :param list ignore_list_re: A collection of regex patterns to match against. - Successful matches are ignored. - - :returns: `True` if the basename is ignored, `False` otherwise. - :rtype: bool - """ - for file_pattern in ignore_list_re: - if file_pattern.match(base_name): - return True - return False - - -def _modpath_from_file(filename, is_namespace, path=None): - def _is_package_cb(path, parts): - return modutils.check_modpath_has_init(path, parts) or is_namespace - - return modutils.modpath_from_file_with_callback( - filename, path=path, is_package_cb=_is_package_cb - ) - - -def get_python_path(filepath): - dirname = os.path.realpath(os.path.expanduser(filepath)) - if not os.path.isdir(dirname): - dirname = os.path.dirname(dirname) - while True: - if not os.path.exists(os.path.join(dirname, "__init__.py")): - return dirname - old_dirname = dirname - dirname = os.path.dirname(dirname) - if old_dirname == dirname: - return os.getcwd() - return None - - -def expand_modules(files_or_modules, ignore_list, ignore_list_re): - """take a list of files/modules/packages and return the list of tuple - (file, module name) which have to be actually checked - """ - result = [] - errors = [] - path = sys.path.copy() - - for something in files_or_modules: - if os.path.basename(something) in ignore_list: - continue - if _basename_in_ignore_list_re(os.path.basename(something), ignore_list_re): - continue - - module_path = get_python_path(something) - additional_search_path = [".", module_path] + path - if os.path.exists(something): - # this is a file or a directory - try: - modname = ".".join( - modutils.modpath_from_file(something, path=additional_search_path) - ) - except ImportError: - modname = os.path.splitext(os.path.basename(something))[0] - if os.path.isdir(something): - filepath = os.path.join(something, "__init__.py") - else: - filepath = something - else: - # suppose it's a module or package - modname = something - try: - filepath = modutils.file_from_modpath( - modname.split("."), path=additional_search_path - ) - if filepath is None: - continue - except (ImportError, SyntaxError) as ex: - # The SyntaxError is a Python bug and should be - # removed once we move away from imp.find_module: https://bugs.python.org/issue10588 - errors.append({"key": "fatal", "mod": modname, "ex": ex}) - continue - - filepath = os.path.normpath(filepath) - modparts = (modname or something).split(".") - - try: - spec = modutils.file_info_from_modpath( - modparts, path=additional_search_path - ) - except ImportError: - # Might not be acceptable, don't crash. - is_namespace = False - is_directory = os.path.isdir(something) - else: - is_namespace = modutils.is_namespace(spec) - is_directory = modutils.is_directory(spec) - - if not is_namespace: - result.append( - { - "path": filepath, - "name": modname, - "isarg": True, - "basepath": filepath, - "basename": modname, - } - ) - - has_init = ( - not (modname.endswith(".__init__") or modname == "__init__") - and os.path.basename(filepath) == "__init__.py" - ) - if has_init or is_namespace or is_directory: - for subfilepath in modutils.get_module_files( - os.path.dirname(filepath), ignore_list, list_all=is_namespace - ): - if filepath == subfilepath: - continue - if _basename_in_ignore_list_re( - os.path.basename(subfilepath), ignore_list_re - ): - continue - - modpath = _modpath_from_file( - subfilepath, is_namespace, path=additional_search_path - ) - submodname = ".".join(modpath) - result.append( - { - "path": subfilepath, - "name": submodname, - "isarg": False, - "basepath": filepath, - "basename": modname, - } - ) - return result, errors - - def register_plugins(linter, directory): """load all module and package in the given directory, looking for a 'register' function in each one, used to register pylint checkers |