From 81f3abcb7db6944451a53c88afe6527252ed56cd Mon Sep 17 00:00:00 2001 From: Stephen Hemminger Date: Tue, 5 May 2009 16:18:54 -0700 Subject: 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. --- lib/Vyatta/Config.pm | 29 +++++++++++++++-------------- 1 file changed, 15 insertions(+), 14 deletions(-) (limited to 'lib') 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"; } } } -- cgit v1.2.3