NAME
Config::Model::AnyThing - Base class for configuration tree item
SYNOPSIS
package Config::Model::SomeThing ;
use base qw/Config::Model::AnyThing/ ;
DESCRIPTION
This class must be inherited by all nodes or leaves of the configuration tree.
AnyThing provides some methods and no constructor.
Introspection methods
element_name()
Returns the element name that contain this object.
index_value()
For object stored in an array or hash element, returns the index (or key) containing this object.
parent()
Returns the node containing this object. May return undef if parent()
is called on the root of the tree.
get_type()
Returns the type (e.g. list
or hash
or leaf
or node
or warped_node
of the element containing this object. See "element_type".
root()
Returns the root node of the configuration tree.
location()
Returns the node location in the configuration tree. This location conforms with the syntax defined by "grab()" method.
Information management
grab(...)
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)
- strict
-
When set to 1,
grab
will throw an exception if no object is found using the passed string. When set to 0, the object found at last will be returned. For instance, for the stepgood_step wrong_step
, only the object held bygood_step
will be returned. (default is 1) - type
-
Either
node
,leaf
,hash
orlist
. Returns only an object of requested type. Depending onstrict
value,grab
will either throw an exception or return the last found object of requested type. (optional, default toundef
, which means any type of object) - autoadd
-
When set to 1,
hash
orlist
configuration element are created when requested by the passed steps. (default is 1).
The step
parameters is made of the following items separated by spaces:
- -
-
Go up one node
- !
-
Go to the root node.
- xxx
-
Go down using
xxx
element. - xxx:yy
-
Go down using
xxx
element and idyy
(valid for hash or list elements) - ?xxx
-
Go up the tree until a node containing element
xxx
is found. Then go down the tree like itemxxx
.If
?xxx:yy
, go up the tree the same way. But no check is done to see if idyy
actually exists or not. Only the elementxxx
is considered when going up the tree.
grab_value(...)
Like "grab(...)", but will return the value of a leaf object, not just the leaf object.
Will raise an exception if following the steps ends on anything but a leaf.
grab_root()
Returns the root of the configuration tree.
search_element( element => <name> [, privilege => ... ] )
From this node (or warped node), search an element (respecting privilege level).
This method returns a Config::Model::Searcher object. See Config::Model::Searcher for details on how to handle a search.
AUTHOR
Dominique Dumont, (ddumont at cpan dot org)
SEE ALSO
Config::Model, Config::Model::Instance, Config::Model::Node, Config::Model::Loader, Config::Model::Dumper