blob: cc7b0efb4b746f682de0a2c1a217526e8b2a8de1 (
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
|
package modparm;
use diagnostics;
use strict;
use common qw(:common :functional);
use log;
my %modparm_hash;
sub read_modparm_file($) {
my ($file) = @_;
my @line;
local *F;
open F, $file or log::l("missing $file: $!"), return;
while (<F>) {
chomp;
@line = split ':';
$modparm_hash{$line[0]}{$line[1]} = {
type => $line[2],
default => $line[3],
desc => $line [4],
};
}
}
sub get_options_result($@) {
my ($module, @value) = @_;
mapn {
my ($a, $b) = @_;
$a ? "$b=$a" : ()
} \@value, [ keys %{$modparm_hash{$module}} ];
}
sub get_options_name($) {
my ($module) = @_;
my @names;
%modparm_hash or return;
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;
}
if ($::testing) {
read_modparm_file("/tmp/modparm.txt");
}
1;
|