diff --git a/src/Makefile.in b/src/Makefile.in index 16f9df9d..ba2715f3 100644 --- a/src/Makefile.in +++ b/src/Makefile.in @@ -78,7 +78,7 @@ NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : subdir = src -DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/Makefile.am +DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/Makefile.am README ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ diff --git a/src/niceload b/src/niceload index 534479c6..1785914e 100755 --- a/src/niceload +++ b/src/niceload @@ -3,7 +3,7 @@ # Copyright (C) 2004,2005,2006,2006,2008,2009,2010 Ole Tange, # http://ole.tange.dk # -# Copyright (C) 2010,2011,2012,2013,2014 Ole Tange, +# Copyright (C) 2010,2011,2012,2013,2014,2015 Ole Tange, # http://ole.tange.dk and Free Software Foundation, Inc. # # This program is free software; you can redistribute it and/or modify diff --git a/src/parallel b/src/parallel index 2359c7e8..36dfcf60 100755 --- a/src/parallel +++ b/src/parallel @@ -1,7 +1,7 @@ #!/usr/bin/env perl -# Copyright (C) 2007,2008,2009,2010,2011,2012,2013,2014 Ole Tange and -# Free Software Foundation, Inc. +# Copyright (C) 2007,2008,2009,2010,2011,2012,2013,2014,2015 Ole Tange +# and Free Software Foundation, Inc. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -951,7 +951,7 @@ sub parse_options { sub init_globals { # Defaults: - $Global::version = 20141212; + $Global::version = 20141225; $Global::progname = 'parallel'; $Global::infinity = 2**31; $Global::debug = 0; @@ -1481,7 +1481,7 @@ sub shell_quote { # @shell_quoted_strings = string quoted with \ as needed by the shell my @strings = (@_); for my $a (@strings) { - $a =~ s/([\002-\011\013-\032\\\#\?\`\(\)\{\}\[\]\*\>\<\~\|\; \"\!\$\&\'\202-\377])/\\$1/g; + $a =~ s/([\002-\011\013-\032\\\#\?\`\(\)\{\}\[\]\^\*\>\<\~\|\; \"\!\$\&\'\202-\377])/\\$1/g; $a =~ s/[\n]/'\n'/g; # filenames with '\n' is quoted using \' } return wantarray ? @strings : "@strings"; @@ -3036,7 +3036,8 @@ sub version { } print join("\n", "GNU $Global::progname $Global::version", - "Copyright (C) 2007,2008,2009,2010,2011,2012,2013,2014 Ole Tange and Free Software Foundation, Inc.", + "Copyright (C) 2007,2008,2009,2010,2011,2012,2013,2014,2015 Ole Tange", + "and Free Software Foundation, Inc.", "License GPLv3+: GNU GPL version 3 or later ", "This is free software: you are free to change and redistribute it.", "GNU $Global::progname comes with no warranty.", @@ -3341,13 +3342,15 @@ sub kill_youngster_if_not_enough_mem { # If less than 50% enough free mem: kill off the youngest child # Put the child back in the queue. my %jobs_of; - use Tie::RefHash; - tie %jobs_of, 'Tie::RefHash'; + my @sshlogins; for my $job (values %Global::running) { + if(not $jobs_of{$job->sshlogin()}) { + push @sshlogins, $job->sshlogin(); + } push @{$jobs_of{$job->sshlogin()}}, $job; } - for my $sshlogin (keys %jobs_of) { + for my $sshlogin (@sshlogins) { for my $job (sort { $b->seq() <=> $a->seq() } @{$jobs_of{$sshlogin}}) { if($sshlogin->memfree() < $opt::memfree * 0.5) { ::debug("mem","\n",map { $_->seq()." " } (sort { $b->seq() <=> $a->seq() } @{$jobs_of{$sshlogin}})); @@ -3375,6 +3378,9 @@ sub multiply_binary_prefix { # Returns: # $value = int with prefixes multiplied my $s = shift; + if(not $s) { + return $s; + } $s =~ s/ki/*1024/gi; $s =~ s/mi/*1024*1024/gi; $s =~ s/gi/*1024*1024*1024/gi; @@ -3994,7 +4000,6 @@ sub loadavg_too_high { }; $ps =~ s/[ \t\n]+/ /g; $cmd = "perl -e ".::shell_quote_scalar($ps); - $cmd =~ s/\^/\\^/g; } return $cmd; } @@ -4057,7 +4062,6 @@ sub loadavg { } else { $cmd .= loadavg_cmd(); } -# $cmd .= "ps ax -o state,command"; # As the command can take long to run if run remote # save it to a tmp file before moving it to the correct file ::debug("load", "Cmd: ", $cmd); @@ -4273,6 +4277,7 @@ sub compute_number_of_processes { # Cleanup: Unget the command_lines or the @args $Global::JobQueue->{'commandlinequeue'}->{'arg_queue'}->unget(@args); $Global::JobQueue->unget(@jobs); + @jobs = undef; } sub processes_available_by_system_limit { @@ -7208,6 +7213,7 @@ sub replaced { my $regexp = join('|', map { my $s = $_; $s =~ s/(\W)/\\$1/g; $s } sort { length $b <=> length $a } keys %replace); for(@target) { + # ::debug("replace","Replace in ",::my_dump($_)); s/($regexp)/join(" ",@{$replace{$1}})/ge; } } @@ -7228,6 +7234,7 @@ sub new { my $return_files = shift; my @unget = (); my ($count,$posrpl,$perlexpr); + my ($replacecount_ref, $len_ref); my @command = @$commandref; # If the first command start with '-' it is probably an option if($command[0] =~ /^\s*(-\S+)/) { @@ -7282,10 +7289,11 @@ sub new { } } # Add {} if no replacement strings in @command - my($replacecount_ref, $len_ref, @command) = + ($replacecount_ref, $len_ref, @command) = replacement_counts_and_lengths(@command); - if("@command" =~ /^\S*\257 +This is free software: you are free to change and redistribute it. GNU parallel comes with no warranty. Web site: http://www.gnu.org/software/parallel -When using programs that use GNU Parallel to process data for publication please cite: - -O. Tange (2011): GNU Parallel - The Command-Line Power Tool, -;login: The USENIX Magazine, February 2011:42-47. - -Or you can get GNU Parallel without this requirement by paying 10000 EUR. +When using programs that use GNU Parallel to process data for publication +please cite as described in 'parallel --bibtex'. echo '### bug #39787: --xargs broken' ### bug #39787: --xargs broken nice perl -e 'for(1..30000){print "$_\n"}' | $NICEPAR --xargs -k echo | perl -ne 'print length $_,"\n"' diff --git a/testsuite/wanted-results/parallel-local9 b/testsuite/wanted-results/parallel-local9 index 1d50b9c6..66a55420 100644 --- a/testsuite/wanted-results/parallel-local9 +++ b/testsuite/wanted-results/parallel-local9 @@ -206,12 +206,14 @@ With --plus: {} = {+/}/{/} = {.}.{+.} = {+/}/{/.}.{+.} = {..}.{+..} = See 'man parallel' for details +Academic tradition requires you to cite works you base your article on. When using programs that use GNU Parallel to process data for publication please cite: O. Tange (2011): GNU Parallel - The Command-Line Power Tool, ;login: The USENIX Magazine, February 2011:42-47. -Or you can get GNU Parallel without this requirement by paying 10000 EUR. +If you pay 10000 EUR you should feel free to use GNU Parallel without citing. + parallel: Error: Parsing of --jobs/-j/--max-procs/-P failed. echo '### Test of -j filename'; echo 3 >/tmp/jobs_to_run1; parallel -j /tmp/jobs_to_run1 -v sleep {} ::: 10 8 6 5 4; # Should give 6 8 10 5 4 ### Test of -j filename diff --git a/testsuite/wanted-results/test13 b/testsuite/wanted-results/test13 index 6c952f4c..c32da0a3 100644 --- a/testsuite/wanted-results/test13 +++ b/testsuite/wanted-results/test13 @@ -51,8 +51,6 @@ job2 14 15 16 -17 -18 2 3 4 @@ -61,10 +59,10 @@ job2 7 8 9 -Running 'parallel -j0 -N9 --pipe parallel -j0' or raising ulimit -n or /etc/security/limits.conf may help. +Running 'parallel -j0 -N8 --pipe parallel -j0' or raising ulimit -n or /etc/security/limits.conf may help. parallel: SIGTERM received. No new jobs will be started. -parallel: Waiting for these 9 jobs to finish. Send SIGTERM again to stop now. -parallel: Warning: Only enough file handles to run 9 jobs in parallel. +parallel: Waiting for these 8 jobs to finish. Send SIGTERM again to stop now. +parallel: Warning: Only enough file handles to run 8 jobs in parallel. parallel: sleep 3; echo 10 parallel: sleep 3; echo 11 parallel: sleep 3; echo 12 @@ -72,8 +70,7 @@ parallel: sleep 3; echo 13 parallel: sleep 3; echo 14 parallel: sleep 3; echo 15 parallel: sleep 3; echo 16 -parallel: sleep 3; echo 17 -parallel: sleep 3; echo 18 +parallel: sleep 3; echo 9 ### Test bug: empty line for | sh with -k a b diff --git a/testsuite/wanted-results/test15 b/testsuite/wanted-results/test15 index e2d07d6a..aecb222f 100644 --- a/testsuite/wanted-results/test15 +++ b/testsuite/wanted-results/test15 @@ -1,12 +1,13 @@ ### Test -p --interactive spawn /tmp/parallel-script-for-expect +Academic tradition requires you to cite works you base your article on. When using programs that use GNU Parallel to process data for publication please cite: O. Tange (2011): GNU Parallel - The Command-Line Power Tool, ;login: The USENIX Magazine, February 2011:42-47. This helps funding further development; and it won't cost you a cent. -Or you can get GNU Parallel without this requirement by paying 10000 EUR. +If you pay 10000 EUR you should feel free to use GNU Parallel without citing. To silence this citation notice run 'parallel --bibtex' once or use '--no-notice'. @@ -15,13 +16,14 @@ sleep 0.1; echo opt-p 2 ?...n sleep 0.1; echo opt-p 3 ?...y opt-p 1 opt-p 3 +Academic tradition requires you to cite works you base your article on. When using programs that use GNU Parallel to process data for publication please cite: O. Tange (2011): GNU Parallel - The Command-Line Power Tool, ;login: The USENIX Magazine, February 2011:42-47. This helps funding further development; and it won't cost you a cent. -Or you can get GNU Parallel without this requirement by paying 10000 EUR. +If you pay 10000 EUR you should feel free to use GNU Parallel without citing. To silence this citation notice run 'parallel --bibtex' once or use '--no-notice'. @@ -256,13 +258,14 @@ xargs Expect: 3 1 2 1 2 parallel Expect: 3 1 via psedotty 2 +Academic tradition requires you to cite works you base your article on. When using programs that use GNU Parallel to process data for publication please cite: O. Tange (2011): GNU Parallel - The Command-Line Power Tool, ;login: The USENIX Magazine, February 2011:42-47. This helps funding further development; and it won't cost you a cent. -Or you can get GNU Parallel without this requirement by paying 10000 EUR. +If you pay 10000 EUR you should feel free to use GNU Parallel without citing. To silence this citation notice run 'parallel --bibtex' once or use '--no-notice'. @@ -275,13 +278,14 @@ xargs Expect: 1 3 2 3 2 parallel Expect: 1 3 2 via pseudotty +Academic tradition requires you to cite works you base your article on. When using programs that use GNU Parallel to process data for publication please cite: O. Tange (2011): GNU Parallel - The Command-Line Power Tool, ;login: The USENIX Magazine, February 2011:42-47. This helps funding further development; and it won't cost you a cent. -Or you can get GNU Parallel without this requirement by paying 10000 EUR. +If you pay 10000 EUR you should feel free to use GNU Parallel without citing. To silence this citation notice run 'parallel --bibtex' once or use '--no-notice'. @@ -387,10 +391,10 @@ line 2 ### Test --no-run-if-empty and -r: This should give no output ### Test --help and -h: Help output (just check we get the same amount of lines) Output from -h and --help -33 -33 +35 +35 ### Test --version: Version output (just check we get the same amount of lines) -14 +11 ### Test --verbose and -t echo bar echo car