Config::Model::AnyThing - Base class for configuration tree item
version 1.259
# internal class
This class must be inherited by all nodes or leaves of the configuration tree.
AnyThing provides some methods and no constructor.
Returns the element name that contain this object.
For object stored in an array or hash element, returns the index (or key) containing this object.
Returns the node containing this object. May return undef if parent() is called on the root of the tree.
parent()
Returns the type (e.g. list or hash or leaf or node or warped_node) of the element containing this object.
list
hash
leaf
node
warped_node
Returns the root node of the configuration tree.
Returns the node location in the configuration tree. This location conforms with the syntax defined by "grab()" method.
Return the element name with its index (if any). I.e. returns foo:bar or foo.
foo:bar
foo
Annotation is a way to store miscellaneous information associated to each node. (Yeah... comments) These comments will be saved outside of the configuration file and restored the next time the command is run.
Without argument, return a string containing the object's annotation (or an empty string).
With several arguments, join the arguments with "\n", store the annotations and return the resulting string.
Load annotations in configuration tree from a pod document. The pod must be in the form:
=over =item path Annotation text =back
Grab an object from the configuration tree.
Parameters are:
step
A string indicating the steps to follow in the tree to find the required item. (mandatory)
mode
When set to strict, grab will throw an exception if no object is found using the passed string. When set to adaptative, the object found at last will be returned. For instance, for the step good_step wrong_step, only the object held by good_step will be returned. When set to loose, grab will return undef in case of problem. (default is strict)
strict
grab
adaptative
good_step wrong_step
good_step
loose
type
Either node, leaf, hash or list. Returns only an object of requested type. Depending on strict value, grab will either throw an exception or return the last found object of requested type. (optional, default to undef, which means any type of object)
undef
autoadd
When set to 1, hash or list configuration element are created when requested by the passed steps. (default is 1).
When set to 1, grab will return an object even if this one is not available. I.e. even if this element was warped out. (default is 0).
The step parameters is made of the following items separated by spaces:
Go up one node
Go to the root node.
Go up the configuration tree until the Foo configuration class is found. Raise an exception if no Foo class is found when root node is reached.
Foo
Go down using xxx element.
xxx
Go down using xxx element and id yy (valid for hash or list elements)
yy
Go up the tree until a node containing element xxx is found. Then go down the tree like item xxx.
If ?xxx:yy, go up the tree the same way. But no check is done to see if id yy actually exists or not. Only the element xxx is considered when going up the tree.
?xxx:yy
Like "grab(...)", but will return the value of a leaf or check_list object, not just the leaf object.
Will raise an exception if following the steps ends on anything but a leaf or a check_list.
Like "grab(...)", but will return the annotation of an object.
Returns the root of the configuration tree.
Go up the configuration tree until the Foo configuration class is found. Returns the found node or undef.
Returns an object dedicated to search an element in the configuration model (respecting privilege level).
This method returns a Config::Model::SearchElement object. See Config::Model::Searcher for details on how to handle a search.
Dumps the configuration data of the node and its siblings into a perl data structure.
Returns a hash ref containing the data. See Config::Model::DumpAsData for details.
Returns a string describing any issue with Config::Model::Warper object. Returns '' if invoked on a tree object without warp specification.
Dominique Dumont, (ddumont at cpan dot org)
Config::Model, Config::Model::Instance, Config::Model::Node, Config::Model::Loader, Config::Model::Dumper
To install Config::Model, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Config::Model
CPAN shell
perl -MCPAN -e shell install Config::Model
For more information on module installation, please visit the detailed CPAN module installation guide.