| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | #
 | 
					
						
							| 
									
										
										
										
											2015-03-23 11:21:40 +00:00
										 |  |  | # spec file for package perl-Parallel-ForkManager
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | #
 | 
					
						
							| 
									
										
										
										
											2018-07-21 09:27:51 +00:00
										 |  |  | # Copyright (c) 2018 SUSE LINUX GmbH, Nuernberg, Germany.
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | #
 | 
					
						
							|  |  |  | # 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.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-08 15:13:24 +00:00
										 |  |  | # Please submit bugfixes or comments via https://bugs.opensuse.org/
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | #
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-23 11:21:40 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | Name:           perl-Parallel-ForkManager
 | 
					
						
							| 
									
										
										
										
											2018-11-08 15:13:24 +00:00
										 |  |  | Version:        2.02
 | 
					
						
							| 
									
										
										
										
											2015-03-23 11:21:40 +00:00
										 |  |  | Release:        0
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  | %define cpan_name Parallel-ForkManager
 | 
					
						
							|  |  |  | Summary:        Simple Parallel Processing Fork Manager
 | 
					
						
							| 
									
										
										
										
											2018-07-21 09:27:51 +00:00
										 |  |  | License:        Artistic-1.0 OR GPL-1.0-or-later
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | Group:          Development/Libraries/Perl
 | 
					
						
							| 
									
										
										
										
											2018-11-08 15:13:24 +00:00
										 |  |  | Url:            https://metacpan.org/release/%{cpan_name}
 | 
					
						
							| 
									
										
										
										
											2018-07-21 09:27:51 +00:00
										 |  |  | Source0:        https://cpan.metacpan.org/authors/id/Y/YA/YANICK/%{cpan_name}-%{version}.tar.gz
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  | Source1:        cpanspec.yml
 | 
					
						
							|  |  |  | BuildArch:      noarch
 | 
					
						
							|  |  |  | BuildRoot:      %{_tmppath}/%{name}-%{version}-build
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | BuildRequires:  perl
 | 
					
						
							|  |  |  | BuildRequires:  perl-macros
 | 
					
						
							| 
									
										
										
										
											2018-11-08 15:13:24 +00:00
										 |  |  | BuildRequires:  perl(Moo)
 | 
					
						
							|  |  |  | BuildRequires:  perl(Moo::Role)
 | 
					
						
							| 
									
										
										
										
											2015-11-30 15:25:41 +00:00
										 |  |  | BuildRequires:  perl(Test::More) >= 0.94
 | 
					
						
							| 
									
										
										
										
											2015-10-10 11:11:00 +00:00
										 |  |  | BuildRequires:  perl(Test::Warn)
 | 
					
						
							| 
									
										
										
										
											2018-11-08 15:13:24 +00:00
										 |  |  | Requires:       perl(Moo)
 | 
					
						
							|  |  |  | Requires:       perl(Moo::Role)
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | %{perl_requires}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %description
 | 
					
						
							|  |  |  | This module is intended for use in operations that can be done in parallel
 | 
					
						
							|  |  |  | where the number of processes to be forked off should be limited. Typical
 | 
					
						
							|  |  |  | use is a downloader which will be retrieving hundreds/thousands of files.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The code for a downloader would look something like this:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   use LWP::Simple;
 | 
					
						
							|  |  |  |   use Parallel::ForkManager;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  |   my @links=(
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  |     ["http://www.foo.bar/rulez.data","rulez_data.txt"],
 | 
					
						
							|  |  |  |     ["http://new.host/more_data.doc","more_data.doc"],
 | 
					
						
							|  |  |  |     ...
 | 
					
						
							|  |  |  |   );
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   # Max 30 processes for parallel download
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  |   my $pm = Parallel::ForkManager->new(30);
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  |   LINKS:
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  |   foreach my $linkarray (@links) {
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  |     $pm->start and next LINKS; # do the fork
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  |     my ($link, $fn) = @$linkarray;
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  |     warn "Cannot get $fn from $link"
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  |       if getstore($link, $fn) != RC_OK;
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     $pm->finish; # do the exit in the child process
 | 
					
						
							|  |  |  |   }
 | 
					
						
							|  |  |  |   $pm->wait_all_children;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | First you need to instantiate the ForkManager with the "new" constructor.
 | 
					
						
							|  |  |  | You must specify the maximum number of processes to be created. If you
 | 
					
						
							|  |  |  | specify 0, then NO fork will be done; this is good for debugging purposes.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Next, use $pm->start to do the fork. $pm returns 0 for the child process,
 | 
					
						
							| 
									
										
										
										
											2015-11-30 15:25:41 +00:00
										 |  |  | and child pid for the parent process (see also perlfunc(1p)/fork()). The
 | 
					
						
							|  |  |  | "and next" skips the internal loop in the parent process. NOTE: $pm->start
 | 
					
						
							|  |  |  | dies if the fork fails.
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | $pm->finish terminates the child process (assuming a fork was done in the
 | 
					
						
							|  |  |  | "start").
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | NOTE: You cannot use $pm->start if you are already in the child process. If
 | 
					
						
							|  |  |  | you want to manage another set of subprocesses in the child process, you
 | 
					
						
							|  |  |  | must instantiate another Parallel::ForkManager object!
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %prep
 | 
					
						
							|  |  |  | %setup -q -n %{cpan_name}-%{version}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %build
 | 
					
						
							| 
									
										
										
										
											2018-11-08 15:13:24 +00:00
										 |  |  | perl Makefile.PL INSTALLDIRS=vendor
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  | %{__make} %{?_smp_mflags}
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | %check
 | 
					
						
							| 
									
										
										
										
											2015-05-13 14:59:39 +00:00
										 |  |  | %{__make} test
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | %install
 | 
					
						
							|  |  |  | %perl_make_install
 | 
					
						
							|  |  |  | %perl_process_packlist
 | 
					
						
							|  |  |  | %perl_gen_filelist
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %files -f %{name}.files
 | 
					
						
							|  |  |  | %defattr(-,root,root,755)
 | 
					
						
							| 
									
										
										
										
											2018-07-21 09:27:51 +00:00
										 |  |  | %doc Changes CODE_OF_CONDUCT.md CONTRIBUTORS doap.xml examples README.mkdn
 | 
					
						
							| 
									
										
										
										
											2011-04-22 06:55:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | %changelog
 |