Fuzion Logo
fuzion-lang.dev — The Fuzion Language Portal
JavaScript seems to be disabled. Functionality is limited.

time/stopwatch.fz


# This file is part of the Fuzion language implementation.
#
# The Fuzion language implementation 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, version 3 of the License.
#
# The Fuzion language implementation 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 The
# Fuzion language implementation.  If not, see <https://www.gnu.org/licenses/>.


# -----------------------------------------------------------------------
#
#  Tokiwa Software GmbH, Germany
#
#  Source code of Fuzion standard library feature time.stopwatch
#
#  Author: Michael Lill (michael.lill@tokiwa.software)
#
# -----------------------------------------------------------------------

# stopwatch measures the execution duration of f
#
public stopwatch(f () -> unit) time.duration ! time.nano =>
  start := time.nano.env.read
  f()
  end := time.nano.env.read
  end - start


# stopwatch measures the execution duration of f
#
public stopwatch(T type, f () -> T) (T, time.duration) ! time.nano =>
  start := time.nano.env.read
  res := f()
  end := time.nano.env.read
  (res, end - start)

last changed: 2026-05-12