Considerações ao converter comandos do PowerShell para Perl
Você deve estar ciente de certas considerações importantes ao converter comandos do PowerShell para Perl porque o PowerShell e o Perl têm recursos diferentes.
Tipos de entrada de comando
O OnCommand Workflow Automation (WFA) permite que os designers de fluxo de trabalho usem arrays e hash como entrada para o comando ao definir um comando. Esses tipos de entrada não podem ser usados quando o comando é definido usando Perl. Se você quiser que um comando Perl aceite entradas de array e hash, você pode definir a entrada como uma string no designer. A definição do comando pode então analisar a entrada, que é passada para criar um array ou hash, conforme necessário. A descrição para a entrada descreve o formato em que a entrada é esperada.
my @input_as_array = split(',', $InputString); #Parse the input string of format val1,val2 into an array
my %input_as_hash = split /[;=]/, $InputString; #Parse the input string of format key1=val1;key2=val2 into a hash.
Declaração do PowerShell
Os exemplos a seguir mostram como uma entrada de array pode ser passada para o PowerShell e Perl. Os exemplos descrevem a entrada CronMonth, que especifica o mês em que a tarefa cron está programada para ser executada. Os valores válidos são inteiros -1 a 11. Um valor de -1 indica que o cronograma é executado a cada mês. Qualquer outro valor denota um mês específico, com 0 sendo janeiro e 11 sendo dezembro.
[parameter(Mandatory=$false, HelpMessage="Months in which the schedule executes. This is a comma separated list of values from 0 through 11. Value -1 means all months.")] [ValidateRange(-1, 11)] [array]$CronMonths,
Declaração Perl
GetOptions(
"Cluster=s" => \$Cluster,
"ScheduleName=s" => \$ScheduleName,
"Type=s" => \$Type,
"CronMonths=s" => \$CronMonths,
) or die 'Illegal command parameters\n';
sub get_cron_months {
return get_cron_input_hash('CronMonths', $CronMonths, 'cron-month', -1,
11);
}
sub get_cron_input_hash {
my $input_name = shift;
my $input_value = shift;
my $zapi_element = shift;
my $low = shift;
my $high = shift;
my $exclude = shift;
if (!defined $input_value) {
return undef;
}
my @values = split(',', $input_value);
foreach my $val (@values) {
if ($val !~ /^[+-]?\d+$/) {
die
"Invalid value '$input_value' for $input_name: $val must be an integer.\n";
}
if ($val < $low || $val > $high) {
die
"Invalid value '$input_value' for $input_name: $val must be from $low to $high.\n";
}
if (defined $exclude && $val == $exclude) {
die
"Invalid value '$input_value' for $input_name: $val is not valid.\n";
}
}
# do something
}
Definição do comando
Uma expressão de uma linha no PowerShell usando um operador pipe pode ter que ser expandida em vários blocos de instruções em Perl para alcançar a mesma funcionalidade. Um exemplo de um dos comandos Wait é mostrado na tabela a seguir.
| Declaração do PowerShell | Declaração Perl |
|---|---|
# Get the latest job which moves the specified volume to the specified aggregate. $job = Get-NcJob -Query $query |
where {$_.JobDescription -eq "Split" + $VolumeCloneName} |
Select-Object -First 1 ---- |
my $result = $server->job_get_iter(
'query' => {'job-type' => 'VOL_CLONE_SPLIT'},
'desired-attributes' => {
'job-type' => '',
'job-description' => '',
'job-progress' => '',
'job-state' => ''
}
);
my @jobarray;
for my $job (@{ $result->{'attributes-list'}})
{
my $description = $job->{'job-description'};
if($description =~ /$VolumeCloneName/)
{
push(@jobarray, $job)
}
}
|