# SPDX-License-Identifier: GPL-2.0-or-later
#
# Copyright (C) 2022, Paul Elder <paul.elder@ideasonboard.com>
#
# Base class for algorithm-specific tuning modules


# @var type Type of the module. Defined in the base module.
# @var out_name The key that will be used for the algorithm in the algorithms
#               dictionary in the tuning output file
# @var hr_name Human-readable module name, mostly for debugging
class Module(object):
    type = 'base'
    hr_name = 'Base Module'
    out_name = 'GenericAlgorithm'

    def __init__(self):
        pass

    def validate_config(self, config: dict) -> bool:
        raise NotImplementedError

    # @brief Do the module's processing
    # @param config Full configuration from the input configuration file
    # @param images List of images to process
    # @param outputs The outputs of all modules that were executed before this
    #                module. Note that this is an input parameter, and the
    #                output of this module should be returned directly
    # @return Result of the module's processing. It may be empty. None
    #         indicates failure and that the result should not be used.
    def process(self, config: dict, images: list, outputs: dict) -> dict:
        raise NotImplementedError