Files
perl-Progress-Any/perl-Progress-Any.spec
2025-08-12 18:16:46 +02:00

85 lines
2.9 KiB
RPMSpec

#
# spec file for package perl-Progress-Any
#
# Copyright (c) 2024 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.
# Please submit bugfixes or comments via https://bugs.opensuse.org/
#
%define cpan_name Progress-Any
Name: perl-Progress-Any
Version: 0.220.0
Release: 0
# 0.220 -> normalize -> 0.220.0
%define cpan_version 0.220
License: Artistic-1.0 OR GPL-1.0-or-later
Summary: Record progress to any output
URL: https://metacpan.org/release/%{cpan_name}
Source0: https://cpan.metacpan.org/authors/id/P/PE/PERLANCAR/%{cpan_name}-%{cpan_version}.tar.gz
Source1: cpanspec.yml
Source100: README.md
BuildArch: noarch
BuildRequires: perl
BuildRequires: perl-macros
BuildRequires: perl(Test::Exception)
BuildRequires: perl(Test::More) >= 0.98
BuildRequires: perl(Time::Duration)
Requires: perl(Time::Duration)
Provides: perl(Progress::Any) = %{version}
Provides: perl(Progress::Any::Output) = %{version}
Provides: perl(Progress::Any::Output::Null) = %{version}
%undefine __perllib_provides
%{perl_requires}
%description
'Progress::Any' is an interface for applications that want to display
progress to users. It decouples progress updating and output, rather
similar to how Log::Any decouples log producers and consumers (output). The
API is also rather similar to Log::Any, except _Adapter_ is called _Output_
and _category_ is called _task_.
Progress::Any records position/target and calculates elapsed time,
estimated remaining time, and percentage of completion. One or more output
modules (Progress::Any::Output::*) display this information.
In your modules, you typically only need to use Progress::Any, get one or
more indicators, set target and update it during work. In your application,
you use Progress::Any::Output and set/add one or more outputs to display
the progress (you'll need to install one of the output modules as they are
not included in this minimal distribution). By setting output only in the
application and not in modules, you separate the formatting/display concern
from the logic.
Screenshots:
%prep
%autosetup -n %{cpan_name}-%{cpan_version}
%build
perl Makefile.PL INSTALLDIRS=vendor
%make_build
%check
make test
%install
%perl_make_install
%perl_process_packlist
%perl_gen_filelist
%files -f %{name}.files
%doc Changes README
%license LICENSE
%changelog