# # spec file for package perl-Term-Shell # # 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 Term-Shell Name: perl-Term-Shell Version: 0.130.0 Release: 0 # 0.13 -> normalize -> 0.130.0 %define cpan_version 0.13 License: Artistic-1.0 OR GPL-1.0-or-later Summary: Simple command-line shell framework URL: https://metacpan.org/release/%{cpan_name} Source0: https://cpan.metacpan.org/authors/id/S/SH/SHLOMIF/%{cpan_name}-%{cpan_version}.tar.gz Source1: cpanspec.yml Source100: README.md BuildArch: noarch BuildRequires: perl BuildRequires: perl-macros BuildRequires: perl(Getopt::Long) >= 2.36 BuildRequires: perl(Module::Build) >= 0.28 BuildRequires: perl(Term::ReadKey) BuildRequires: perl(Test::More) >= 0.88 BuildRequires: perl(Text::Autoformat) Requires: perl(Getopt::Long) >= 2.36 Requires: perl(Term::ReadKey) Requires: perl(Text::Autoformat) Provides: perl(Term::Shell) = %{version} Provides: perl(Term::Shell::OnScopeLeave) = %{version} %undefine __perllib_provides %{perl_requires} %description Term::Shell lets you write simple command-line shells. All the boring details like command-line parsing, terminal handling, and tab completion are handled for you. The base class comes with two commands pre-defined: exit and help. To write a shell with an 'exec' command, do something like this: package MyShell; use base qw(Term::Shell); # or manually edit @MyShell::ISA. sub run_exec { my ($o, $cmd, @args) = @_; if ($cmd ne $0) { print "I'm sorry you're leaving us...\n"; } exec $cmd, @args; exit 1; } When Term::Shell needs to handle the 'exec' command, it will invoke this method. That's all there is to it! You write handlers, and Term::Shell handles the gory details. %prep %autosetup -n %{cpan_name}-%{cpan_version} %build perl Build.PL --installdirs=vendor ./Build build --flags=%{?_smp_mflags} %check ./Build test %install ./Build install --destdir=%{buildroot} --create_packlist=0 %perl_gen_filelist %files -f %{name}.files %doc Changes examples README README.md %license LICENSE %changelog