Source code for click_extra.timer

# 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.
"""Command execution time measurement."""

from __future__ import annotations

from gettext import gettext as _
from time import perf_counter

from . import context, echo
from .parameters import ExtraOption

TYPE_CHECKING = False
if TYPE_CHECKING:
    from collections.abc import Sequence

    import click


[docs] class TimerOption(ExtraOption): """A pre-configured option that is adding a ``--time``/``--no-time`` flag to print elapsed time at the end of CLI execution. The start time is made available in the context in ``ctx.meta[click_extra.context.START_TIME]``. """
[docs] def print_timer(self) -> None: """Compute and print elapsed execution time. Always prints, even when a sibling eager option (``--version``, ``--show-params``, ``--show-config``…) short-circuited the command body via ``ctx.exit()``. That makes ``--time`` a usable probe for the cost of Click Extra's own machinery (option parsing, config loading, eager callbacks), not just user command bodies. """ echo(f"Execution time: {perf_counter() - self.start_time:0.3f} seconds.")
[docs] def init_timer( self, ctx: click.Context, param: click.Parameter, value: bool, ) -> None: """Set up the execution-timer machinery for the current invocation. Captures :func:`time.perf_counter` as the start time, stores it on ``ctx.meta`` under :data:`click_extra.context.START_TIME`, and queues :py:meth:`print_timer` as a context-close callback so the elapsed duration is printed even when a sibling eager option (``--version``, ``--show-params``…) short-circuits the command body. Renamed from ``register_timer_on_close`` to align with the ``init_<system>`` convention shared with :class:`~click_extra.table.TableFormatOption.init_formatter` and :class:`~click_extra.table.SortByOption.init_sort`. """ if not value or ctx.resilient_parsing: return # Only capture the start time when the user requested timing. self.start_time = perf_counter() context.set(ctx, context.START_TIME, self.start_time) # Register printing at the end of execution. ctx.call_on_close(self.print_timer)
def __init__( self, param_decls: Sequence[str] | None = None, default=False, expose_value=False, is_eager=True, help=_("Measure and print elapsed execution time."), **kwargs, ) -> None: if not param_decls: param_decls = ("--time/--no-time",) kwargs.setdefault("callback", self.init_timer) super().__init__( param_decls=param_decls, default=default, expose_value=expose_value, is_eager=is_eager, help=help, **kwargs, )