1
0
perl-IPC-System-Simple/perl-IPC-System-Simple.spec

89 lines
2.9 KiB
RPMSpec

#
# spec file for package perl-IPC-System-Simple
#
# Copyright (c) 2013 SUSE LINUX Products GmbH, Nuernberg, Germany.
#
# 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 http://bugs.opensuse.org/
#
Name: perl-IPC-System-Simple
Version: 1.25
Release: 0
%define cpan_name IPC-System-Simple
Summary: Run commands simply, with detailed diagnostics
License: Artistic-1.0 or GPL-1.0+
Group: Development/Libraries/Perl
Url: http://search.cpan.org/dist/IPC-System-Simple/
Source: http://www.cpan.org/authors/id/P/PJ/PJF/%{cpan_name}-%{version}.tar.gz
BuildArch: noarch
BuildRoot: %{_tmppath}/%{name}-%{version}-build
BuildRequires: perl
BuildRequires: perl-macros
#BuildRequires: perl(BSD::Resource)
#BuildRequires: perl(IPC::System::Simple)
%{perl_requires}
%description
Calling Perl's in-built 'system()' function is easy, determining if it was
successful is _hard_. Let's face it, '$?' isn't the nicest variable in the
world to play with, and even if you _do_ check it, producing a
well-formatted error string takes a lot of work.
'IPC::System::Simple' takes the hard work out of calling external commands.
In fact, if you want to be really lazy, you can just write:
use IPC::System::Simple qw(system);
and all of your 'system' commands will either succeed (run to completion
and return a zero exit value), or die with rich diagnostic messages.
The 'IPC::System::Simple' module also provides a simple replacement to
Perl's backticks operator. Simply write:
use IPC::System::Simple qw(capture);
and then use the the /capture() manpage command just like you'd use
backticks. If there's an error, it will die with a detailed description of
what went wrong. Better still, you can even use 'capturex()' to run the
equivalent of backticks, but without the shell:
use IPC::System::Simple qw(capturex);
my $result = capturex($command, @args);
If you want more power than the basic interface, including the ability to
specify which exit values are acceptable, trap errors, or process
diagnostics, then read on!
%prep
%setup -q -n %{cpan_name}-%{version}
find . -type f -print0 | xargs -0 chmod 644
%build
%{__perl} Makefile.PL INSTALLDIRS=vendor
%{__make} %{?_smp_mflags}
%check
%{__make} test
%install
%perl_make_install
%perl_process_packlist
%perl_gen_filelist
%files -f %{name}.files
%defattr(-,root,root,755)
%doc Changes examples LICENSE README
%changelog