blob: 46dcb23b7aa67439bfb2a7a7fe6361cdbdbc08d6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
package modparm;
use diagnostics;
use strict;
#-######################################################################################
#- misc imports
#-######################################################################################
use common qw(:common :functional);
use log;
#-######################################################################################
#- Functions
#-######################################################################################
sub read_modparm_file {
my $file = -e "modparm.lst" ? "modparm.lst" : "$ENV{SHARE_PATH}/modparm.lst";
my @line;
my %modparm_hash;
local *F;
open F, $file or log::l("missing $file: $!"), return;
foreach (<F>) {
chomp;
@line = split ':';
$modparm_hash{$line[0]}{$line[1]} = {
type => $line[2],
default => $line[3],
desc => $line [4],
};
}
\%modparm_hash;
}
sub get_options_result($@) {
my ($module, @value) = @_;
my $modparm_hash = modparm::read_modparm_file;
mapn {
my ($a, $b) = @_;
$a ? "$b=$a" : ()
} \@value, [ keys %{$modparm_hash->{$module}} ];
}
sub get_options_name($) {
my ($module) = @_;
my @names;
my $modparm_hash = modparm::read_modparm_file;
while (my ($k, $v) = each %{$modparm_hash->{$module} || {}}) {
my $opttype = $v->{type};
my $default = $v->{default};
push @names, "$k ($v->{type})" . (defined($v->{default}) && "[$v->{default}]");
}
@names;
}
1;
|