0
  • 我有 5 个 Perl 文件,它们是我环境中 5 种不同状态的验证脚本。

    它们中的每一个都至少有几个子例程。

  • 到目前为止,状态的数量被限制为 5 个并且这些工作正常。但是现在,根据当前的设计,我还有 20 多个环境状态,因此还有 20 个 Perl 脚本。

  • 我想将所有五个脚本移到一个脚本中,该脚本将状态作为参数,并为 5 个不同的状态提供 5 个不同的子例程。

    这样,当我需要为另一个状态添加验证时,我只需要定义一个新的子例程而不是一个全新的 Perl 脚本。

  • 问题是这意味着使用嵌套的子例程(已知会遇到问题),或展开子例程本身。

例如,

原始脚本

$ cat verify1.pl
sub a1 {
    ...
}
sub b1 {
    ...
}
a1(); b1(); a1();
$ cat verify2.pl
sub a2 {
    ...
}
sub b2 {
    ...
}
sub c2 {
    ...
}
a2(); b2(); c2(); a2();
$

合并脚本

$ cat verify.pl
sub one {
    ...
}
sub two {
    ...
}
my ($arg) = @ARGV;
if ($arg == 1) {
    one();  # should do what verify1.pl did
}
elsif ($arg == 2) {
    two();  # should do what verify2.pl did
}
$

我应该怎么做才能解决这个问题?

4

3 回答 3

6
sub one {
    do 'verify1.pl';
}
sub two {
    do 'verify2.pl';
}

但是,从长远来看,最好将脚本转换为模块,以便以现代和理智的方式管理复杂性。

于 2010-10-01T10:03:39.527 回答
2

您可以按照应有的方式正常放置子例程。

sub a1 {
    ...
}
sub b1 {
    ...
}
sub a2 {
    ...
}
sub b2 {
    ...
}
sub c2 {
    ...
}
sub one {
    a1(); b1(); a1();
}
sub two {
    a2(); b2(); c2(); a2();
}
my ($arg) = @ARGV;
if ($arg == 1) {
    one();  # should do what verify1.pl did
}
elsif ($arg == 2) {
    two();  # should do what verify2.pl did
}
于 2010-10-01T10:00:43.230 回答
1

我只需将所有子例程放在一个文件中并重命名任何冲突即可解决此问题。

但是,听起来您的问题是您正在为可能遇到的每种可能的验证情况进行硬编码。更好的方法是提出一个可以动态构建验证管道的流程。由于我不知道您需要什么,因此我不知道Data::Constraint或其他验证模块是否适合您。在问题信息如此之少的情况下,很难给出任何有用的建议。

于 2010-10-01T17:23:54.197 回答