# Copyright Kevin Deldycke <kevin@deldycke.com> and contributors.## This program is Free Software; you can redistribute it and/or# modify it under the terms of the GNU General Public License# as published by the Free Software Foundation; either version 2# of the License, or (at your option) any later version.## This program is distributed in the hope that it will be useful,# but WITHOUT ANY WARRANTY; without even the implied warranty of# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the# GNU General Public License for more details.## You should have received a copy of the GNU General Public License# along with this program; if not, write to the Free Software# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA."""Decorators for group, commands and options."""fromfunctoolsimportwrapsimportclickimportcloupfrom.colorizeimportColorOptionfrom.commandsimportDEFAULT_HELP_NAMES,ExtraCommand,ExtraGroup,default_extra_paramsfrom.configimportConfigOptionfrom.loggingimportVerbosityOptionfrom.parametersimportShowParamsOptionfrom.tabulateimportTableFormatOptionfrom.telemetryimportTelemetryOptionfrom.timerimportTimerOptionfrom.versionimportExtraVersionOption
[docs]defallow_missing_parenthesis(dec_factory):"""Allow to use decorators with or without parenthesis. As proposed in `Cloup issue #127 <https://github.com/janluke/cloup/issues/127#issuecomment-1264704896>`_. """@wraps(dec_factory)defnew_factory(*args,**kwargs):ifargsandcallable(args[0]):returndec_factory(*args[1:],**kwargs)(args[0])returndec_factory(*args,**kwargs)returnnew_factory
[docs]defdecorator_factory(dec,*new_args,**new_defaults):"""Clone decorator with a set of new defaults. Used to create our own collection of decorators for our custom options, based on Cloup's. """@allow_missing_parenthesisdefdecorator(*args,**kwargs):"""Returns a new decorator instantiated with custom defaults. These defaults values are merged with the user's own arguments. A special case is made for the ``params`` argument, to allow it to be callable. This limits the issue of the mutable options being shared between commands. This decorator can be used with or without arguments. """ifnotargs:args=new_args# Use a copy of the defaults to avoid modifying the original dict.new_kwargs=new_defaults.copy()new_kwargs.update(kwargs)# If the params argument is a callable, we need to call it to get the actual# list of options.params_func=new_kwargs.get("params")ifcallable(params_func):new_kwargs["params"]=params_func()# Return the original decorator with the new defaults.returndec(*args,**new_kwargs)returndecorator
# Redefine Cloup decorators to allow them to be used with or without parenthesis.command=decorator_factory(dec=cloup.command)group=decorator_factory(dec=cloup.group)# Customize existing Click decorators with better default parameters.help_option=decorator_factory(# XXX parameters are not named because of the way the default option names are# passed to HelpOption.# TODO: try the following instead once https://github.com/pallets/click/pull/2840# is merged:# dec=click.decorators.help_option,# param_decls=DEFAULT_HELP_NAMES,click.decorators.help_option,*DEFAULT_HELP_NAMES,)# Copy Click and Cloup decorators with better defaults, and prefix them with "extra_".extra_command=decorator_factory(dec=cloup.command,cls=ExtraCommand,params=default_extra_params,)extra_group=decorator_factory(dec=cloup.group,cls=ExtraGroup,params=default_extra_params,)extra_version_option=decorator_factory(dec=cloup.option,cls=ExtraVersionOption)# New option decorators provided by Click Extra.color_option=decorator_factory(dec=cloup.option,cls=ColorOption)config_option=decorator_factory(dec=cloup.option,cls=ConfigOption)show_params_option=decorator_factory(dec=cloup.option,cls=ShowParamsOption)table_format_option=decorator_factory(dec=cloup.option,cls=TableFormatOption)telemetry_option=decorator_factory(dec=cloup.option,cls=TelemetryOption)timer_option=decorator_factory(dec=cloup.option,cls=TimerOption)verbosity_option=decorator_factory(dec=cloup.option,cls=VerbosityOption)