third_party.pylibs.pylint.src/pylint/checkers/mapreduce_checker.py

21 lines
761 B
Python
Raw Normal View History

# Copyright (c) 2020 Frank Harrison <frank@doublethefish.com>
2021-02-28 20:13:57 +00:00
# Copyright (c) 2021 Pierre Sassoulas <pierre.sassoulas@gmail.com>
# Copyright (c) 2021 Marc Mueller <30130371+cdce8p@users.noreply.github.com>
# 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
import abc
class MapReduceMixin(metaclass=abc.ABCMeta):
2021-04-26 11:59:44 +00:00
"""A mixin design to allow multiprocess/threaded runs of a Checker"""
@abc.abstractmethod
def get_map_data(self):
2021-04-26 11:59:44 +00:00
"""Returns mergable/reducible data that will be examined"""
@classmethod
@abc.abstractmethod
def reduce_map_data(cls, linter, data):
2021-04-26 11:59:44 +00:00
"""For a given Checker, receives data for all mapped runs"""