mirror of
https://git.savannah.gnu.org/git/parallel.git
synced 2025-01-10 16:47:55 +00:00
Implemented --tag for remote machines.
This commit is contained in:
parent
a800b4e3d6
commit
3e4f57e5e6
44
src/parallel
44
src/parallel
|
@ -101,8 +101,10 @@ if($::opt_nonall or $::opt_onall) {
|
||||||
open(PARALLEL,"| $0 $options") ||
|
open(PARALLEL,"| $0 $options") ||
|
||||||
::die_bug("This does not run GNU Parallel: $0 $options");
|
::die_bug("This does not run GNU Parallel: $0 $options");
|
||||||
for my $sshlogin (values %Global::host) {
|
for my $sshlogin (values %Global::host) {
|
||||||
print PARALLEL "$0 $suboptions -j1 -S ".
|
print PARALLEL "$0 $suboptions -j1 ".
|
||||||
shell_quote_scalar($sshlogin->string())." ".
|
((defined $::opt_tag) ?
|
||||||
|
"--tagstring ".shell_quote_scalar($sshlogin->string()) : "").
|
||||||
|
" -S ". shell_quote_scalar($sshlogin->string())." ".
|
||||||
shell_quote_scalar($command)." :::: @argfiles\n";
|
shell_quote_scalar($command)." :::: @argfiles\n";
|
||||||
}
|
}
|
||||||
close PARALLEL;
|
close PARALLEL;
|
||||||
|
@ -384,7 +386,7 @@ sub options_hash {
|
||||||
"null|0" => \$::opt_0,
|
"null|0" => \$::opt_0,
|
||||||
"quote|q" => \$::opt_q,
|
"quote|q" => \$::opt_q,
|
||||||
"I=s" => \$::opt_I,
|
"I=s" => \$::opt_I,
|
||||||
"extensionreplace|U=s" => \$::opt_U,
|
"extensionreplace|er|U=s" => \$::opt_U,
|
||||||
"basenamereplace|bnr=s" => \$::opt_basenamereplace,
|
"basenamereplace|bnr=s" => \$::opt_basenamereplace,
|
||||||
"dirnamereplace|dnr=s" => \$::opt_dirnamereplace,
|
"dirnamereplace|dnr=s" => \$::opt_dirnamereplace,
|
||||||
"basenameextensionreplace|bner=s" => \$::opt_basenameextensionreplace,
|
"basenameextensionreplace|bner=s" => \$::opt_basenameextensionreplace,
|
||||||
|
@ -400,6 +402,7 @@ sub options_hash {
|
||||||
"nice=i" => \$::opt_nice,
|
"nice=i" => \$::opt_nice,
|
||||||
"timeout=i" => \$::opt_timeout,
|
"timeout=i" => \$::opt_timeout,
|
||||||
"tag" => \$::opt_tag,
|
"tag" => \$::opt_tag,
|
||||||
|
"tagstring=s" => \$::opt_tagstring,
|
||||||
"onall" => \$::opt_onall,
|
"onall" => \$::opt_onall,
|
||||||
"nonall" => \$::opt_nonall,
|
"nonall" => \$::opt_nonall,
|
||||||
"sshlogin|S=s" => \@::opt_sshlogin,
|
"sshlogin|S=s" => \@::opt_sshlogin,
|
||||||
|
@ -409,12 +412,12 @@ sub options_hash {
|
||||||
"trc=s" => \@::opt_trc,
|
"trc=s" => \@::opt_trc,
|
||||||
"transfer" => \$::opt_transfer,
|
"transfer" => \$::opt_transfer,
|
||||||
"cleanup" => \$::opt_cleanup,
|
"cleanup" => \$::opt_cleanup,
|
||||||
"basefile|B=s" => \@::opt_basefile,
|
"basefile|bf|B=s" => \@::opt_basefile,
|
||||||
"workdir|W=s" => \$::opt_workdir,
|
"workdir|wd|W=s" => \$::opt_workdir,
|
||||||
"tmpdir=s" => \$::opt_tmpdir,
|
"tmpdir=s" => \$::opt_tmpdir,
|
||||||
"tempdir=s" => \$::opt_tmpdir,
|
"tempdir=s" => \$::opt_tmpdir,
|
||||||
"tty|T" => \$::opt_tty,
|
"tty|T" => \$::opt_tty,
|
||||||
"halt-on-error|H=i" => \$::opt_halt_on_error,
|
"halt-on-error|halt|H=i" => \$::opt_halt_on_error,
|
||||||
"retries=i" => \$::opt_retries,
|
"retries=i" => \$::opt_retries,
|
||||||
"dry-run|dryrun" => \$::opt_dryrun,
|
"dry-run|dryrun" => \$::opt_dryrun,
|
||||||
"progress" => \$::opt_progress,
|
"progress" => \$::opt_progress,
|
||||||
|
@ -3468,10 +3471,10 @@ sub print {
|
||||||
if($Global::debug) {
|
if($Global::debug) {
|
||||||
print STDERR "ERR:\n";
|
print STDERR "ERR:\n";
|
||||||
}
|
}
|
||||||
if($::opt_tag) {
|
if($::opt_tag or defined $::opt_tagstring) {
|
||||||
my $tag = $self->{'commandline'}->args_as_string();
|
my $tag = $self->tag();
|
||||||
while(<$err>) {
|
while(<$err>) {
|
||||||
print STDERR $tag,"\t",$_;
|
print STDERR $tag,$_;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
my $buf;
|
my $buf;
|
||||||
|
@ -3489,12 +3492,13 @@ sub print {
|
||||||
if($Global::debug) {
|
if($Global::debug) {
|
||||||
print STDOUT "OUT:\n";
|
print STDOUT "OUT:\n";
|
||||||
}
|
}
|
||||||
if($::opt_tag) {
|
if($::opt_tag or defined $::opt_tagstring) {
|
||||||
my $tag = $self->{'commandline'}->args_as_string();
|
my $tag = $self->tag();
|
||||||
while(<$out>) {
|
while(<$out>) {
|
||||||
print STDOUT $tag,"\t",$_;
|
print STDOUT $tag,$_;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
my $buf;
|
||||||
while(sysread($out,$buf,1000_000)) {
|
while(sysread($out,$buf,1000_000)) {
|
||||||
print STDOUT $buf;
|
print STDOUT $buf;
|
||||||
}
|
}
|
||||||
|
@ -3506,6 +3510,20 @@ sub print {
|
||||||
close $err;
|
close $err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub tag {
|
||||||
|
my $self = shift;
|
||||||
|
if(not defined $self->{'tag'}) {
|
||||||
|
$self->{'tag'} = "";
|
||||||
|
if(defined $::opt_tagstring) {
|
||||||
|
$self->{'tag'} .= $::opt_tagstring."\t";
|
||||||
|
}
|
||||||
|
if(defined $::opt_tag) {
|
||||||
|
$self->{'tag'} .= $self->{'commandline'}->args_as_string()."\t";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $self->{'tag'};
|
||||||
|
}
|
||||||
|
|
||||||
sub exitstatus {
|
sub exitstatus {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
return $self->{'exitstatus'};
|
return $self->{'exitstatus'};
|
||||||
|
@ -3634,7 +3652,7 @@ sub populate {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(($::opt_m or $::opt_X) and not $CommandLine::already_spread
|
if(($::opt_m or $::opt_X) and not $CommandLine::already_spread
|
||||||
and $self->{'arg_queue'}->empty()) {
|
and $self->{'arg_queue'}->empty() and $Global::max_jobs_running) {
|
||||||
# -m or -X and EOF => Spread the arguments over all jobslots
|
# -m or -X and EOF => Spread the arguments over all jobslots
|
||||||
# (unless they are already spread)
|
# (unless they are already spread)
|
||||||
$CommandLine::already_spread++;
|
$CommandLine::already_spread++;
|
||||||
|
|
Loading…
Reference in a new issue