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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
# vim: set et ts=4 sw=4:
# Copyright 2012 Steven Tucker
#
# This file is part of ManaTools
#
# ManaTools is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 2 of the License, or
# (at your option) any later version.
#
# ManaTools is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with ManaTools. If not, see <http://www.gnu.org/licenses/>.
#Class ConfigReader
package ManaTools::ConfigReader;
use strict;
use warnings;
use diagnostics;
use XML::Simple;
use Data::Dumper;
sub new {
my ($class, $fileName) = @_;
my $self = {
data => 0,
catLen => 0,
currCat => 0,
modLen => 0,
currMod => 0,
placeHolder => 0,
};
bless $self, 'ManaTools::ConfigReader';
my $xml = new XML::Simple (KeyAttr=>[]);
$self->{data} = $xml->XMLin($fileName);
if (ref($self->{data}->{category}) eq "HASH") {
# one element alone
my @categories;
push @categories, $self->{data}->{category};
$self->{data}->{category} = undef;
push @{$self->{data}->{category}}, @categories;
}
$self->{catLen} = scalar(@{$self->{data}->{category}});
$self->{currCat} = -1;
if(ref(@{$self->{data}->{category}}[0]->{module}) eq "ARRAY") {
$self->{modLen} = scalar(@{@{$self->{data}->{category}}[0]->{module}});
} else {
$self->{modLen} = 1;
}
$self->{currMod} = -1;
return $self;
}
sub hasNextCat {
my ($self) = @_;
if($self->{currCat} + 1 >= $self->{catLen}) {
return 0;
}
return 1;
}
sub getNextCat {
my ($self) = @_;
$self->{currCat}++;
if($self->{currCat} >= $self->{catLen}) {
return 0;
}
# Reset the Module Count and Mod length for new Category
$self->{currMod} = -1;
if(ref(@{$self->{data}->{category}}[$self->{currCat}]->{module}) eq "ARRAY") {
$self->{modLen} = scalar(@{@{$self->{data}->{category}}[$self->{currCat}]->{module}});
} else {
$self->{modLen} = 1;
}
my $tmp = @{$self->{data}->{category}}[$self->{currCat}];
return $tmp;
}
sub hasNextMod {
my ($self) = @_;
if($self->{currMod} + 1 >= $self->{modLen}) {
return 0;
}
return 1;
}
sub getNextMod {
my ($self) = @_;
my $ret = 0;
$self->{currMod}++;
if($self->{modLen} == 1) {
$ret = @{$self->{data}->{category}}[$self->{currCat}]->{module};
} else {
$ret = @{@{$self->{data}->{category} }[$self->{currCat}]->{module}}[$self->{currMod}];
}
return $ret;
}
1;
|