diff options
author | Stephen Hemminger <stephen.hemminger@vyatta.com> | 2009-05-05 16:18:54 -0700 |
---|---|---|
committer | Stephen Hemminger <stephen.hemminger@vyatta.com> | 2009-05-05 16:18:54 -0700 |
commit | 81f3abcb7db6944451a53c88afe6527252ed56cd (patch) | |
tree | 81890666916095df859b90ade03c45103c37d32e /lib/Vyatta | |
parent | 4bb0ddbedb63316038f18a71a525ed3e3b5a7bb7 (diff) | |
download | vyatta-cfg-81f3abcb7db6944451a53c88afe6527252ed56cd.tar.gz vyatta-cfg-81f3abcb7db6944451a53c88afe6527252ed56cd.zip |
Fix warnings from using undefined variable
Several places in the the listNodes() code would generate warnings
if strict warnings enabled because they had constructs like "$path $node"
which aren't correct if $path was not defined.
Diffstat (limited to 'lib/Vyatta')
-rwxr-xr-x | lib/Vyatta/Config.pm | 29 |
1 files changed, 15 insertions, 14 deletions
diff --git a/lib/Vyatta/Config.pm b/lib/Vyatta/Config.pm index 38bec27..f80ff86 100755 --- a/lib/Vyatta/Config.pm +++ b/lib/Vyatta/Config.pm @@ -73,17 +73,16 @@ sub listNodes { my ($self, $path) = @_; my @nodes = (); - if (defined $path) { + if ($path) { $path =~ s/\//%2F/g; $path =~ s/\s+/\//g; $path = $self->{_new_config_dir_base} . $self->{_current_dir_level} . "/" . $path; - } - else { + } else { $path = $self->{_new_config_dir_base} . $self->{_current_dir_level}; } #print "DEBUG Vyatta::Config->listNodes(): path = $path\n"; - opendir my $dir, "$path" or return (); + opendir my $dir, $path or return (); @nodes = grep !/^\./, readdir $dir; closedir $dir; @@ -153,7 +152,7 @@ sub listOrigNodesNoDef { } #print "DEBUG Vyatta::Config->listNodes(): path = $path\n"; - opendir my $dir, "$path" or return (); + opendir my $dir, $path or return (); @nodes = grep !/^\./, readdir $dir; closedir $dir; @@ -302,8 +301,8 @@ sub isDeleted { # "level" defaults to current sub listDeleted { my ($self, $path) = @_; - my @new_nodes = $self->listNodes("$path"); - my @orig_nodes = $self->listOrigNodes("$path"); + my @new_nodes = $self->listNodes($path); + my @orig_nodes = $self->listOrigNodes($path); my %new_hash = map { $_ => 1 } @new_nodes; my @deleted = grep { !defined($new_hash{$_}) } @orig_nodes; return @deleted; @@ -381,20 +380,22 @@ sub listNodeStatus { my %nodehash = (); # find deleted nodes first - @nodes = $self->listDeleted("$path"); + @nodes = $self->listDeleted($path); foreach my $node (@nodes) { if ($node =~ /.+/) { $nodehash{$node} = "deleted" }; } @nodes = (); - @nodes = $self->listNodes("$path"); + @nodes = $self->listNodes($path); foreach my $node (@nodes) { if ($node =~ /.+/) { - #print "DEBUG Vyatta::Config->listNodeStatus(): node $node\n"; - # No deleted nodes -- added, changed, ot static only. - if ($self->isAdded("$path $node")) { $nodehash{$node} = "added"; } - elsif ($self->isChanged("$path $node")) { $nodehash{$node} = "changed"; } - else { $nodehash{$node} = "static"; } + my $nodepath = $node; + $nodepath = "$path $node" if ($path); + #print "DEBUG Vyatta::Config->listNodeStatus(): node $node\n"; + # No deleted nodes -- added, changed, ot static only. + if ($self->isAdded($nodepath)) { $nodehash{$node} = "added"; } + elsif ($self->isChanged($nodepath)) { $nodehash{$node} = "changed"; } + else { $nodehash{$node} = "static"; } } } |