summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAn-Cheng Huang <ancheng@vyatta.com>2008-02-05 11:19:35 -0800
committerAn-Cheng Huang <ancheng@vyatta.com>2008-02-05 11:19:35 -0800
commitefe5aea36400ea839c38055576a8fb44bab6a04e (patch)
tree8a3fb69c5f0d2fa556ff034c7961368909f920a2
parentf61275805c551b81337b90c91da957a428f6bcaf (diff)
downloadvyatta-cfg-efe5aea36400ea839c38055576a8fb44bab6a04e.tar.gz
vyatta-cfg-efe5aea36400ea839c38055576a8fb44bab6a04e.zip
fix for bug 2734: different messages for "empty" and "invalid".
-rw-r--r--scripts/VyattaConfig.pm16
-rwxr-xr-xscripts/VyattaConfigOutput.pm4
2 files changed, 14 insertions, 6 deletions
diff --git a/scripts/VyattaConfig.pm b/scripts/VyattaConfig.pm
index 6c37073..9020af0 100644
--- a/scripts/VyattaConfig.pm
+++ b/scripts/VyattaConfig.pm
@@ -402,8 +402,9 @@ sub createNewConfigDOMTree {
###### functions for templates ######
-# $1: array representing the config path (note that path must be present
-# in current config)
+# $1: array representing the config node path.
+# returns the filesystem path to the template of the specified node,
+# or undef if the specified node path is not valid.
sub getTmplPath {
my $self = shift;
my @cfg_path = @{$_[0]};
@@ -417,8 +418,8 @@ sub getTmplPath {
$tpath .= "/node.tag";
next;
}
- # the path is not valid! not supposed to happen!
- die "Node path \"" . (join ' ', @cfg_path) . "\" is not valid";
+ # the path is not valid!
+ return undef;
}
return $tpath
}
@@ -427,6 +428,7 @@ sub isTagNode {
my $self = shift;
my $cfg_path_ref = shift;
my $tpath = $self->getTmplPath($cfg_path_ref);
+ return undef if (!defined($tpath));
if (-d "$tpath/node.tag") {
return 1;
}
@@ -437,6 +439,7 @@ sub hasTmplChildren {
my $self = shift;
my $cfg_path_ref = shift;
my $tpath = $self->getTmplPath($cfg_path_ref);
+ return undef if (!defined($tpath));
opendir(TDIR, $tpath) or return 0;
my @tchildren = grep !/^node\.def$/, (grep !/^\./, (readdir TDIR));
closedir TDIR;
@@ -446,12 +449,15 @@ sub hasTmplChildren {
return 0;
}
-# returns ($is_multi, $is_text)
+# $cfg_path_ref: ref to array containing the node path.
+# returns ($is_multi, $is_text, $default),
+# or undef if specified node is not valid.
sub parseTmpl {
my $self = shift;
my $cfg_path_ref = shift;
my ($is_multi, $is_text, $default) = (0, 0, undef);
my $tpath = $self->getTmplPath($cfg_path_ref);
+ return undef if (!defined($tpath));
if (! -r "$tpath/node.def") {
return ($is_multi, $is_text);
}
diff --git a/scripts/VyattaConfigOutput.pm b/scripts/VyattaConfigOutput.pm
index 861316a..5f92c15 100755
--- a/scripts/VyattaConfigOutput.pm
+++ b/scripts/VyattaConfigOutput.pm
@@ -283,8 +283,10 @@ sub outputNewConfig {
if (defined($config->existsOrig()) && !defined($config->exists())) {
# this is a deleted node
print 'Configuration under "' . (join ' ', @_) . "\" has been deleted\n";
+ } elsif (!defined($config->getTmplPath(\@_))) {
+ print "Specified configuration path is not valid\n";
} else {
- print "Current configuration is empty\n";
+ print 'Configuration under "' . (join ' ', @_) . "\" is empty\n";
}
}
}