Config helps you manipulate your configuration whether they are stored in XML files, PHP arrays or other kind of datasources. It supports these features:
Parse different configuration formats.
Manipulate sections, directives, comments, blanks the way you want.
Write them back to a datasource in your preferred format.
The Config object acts as a container for other Config_Container objects. It doesn't do much but makes handling IO operations easier. It contains the root Config_Container object which in turn contains a child Config_Container object. Config_Container objects store references to their parent and have an array of children. This structure makes it easy to access the different containers and their contents.
A Config_Container object can be of different type:
Section: a section contains other Config_Container objects.
Directive: a directive does not contain any other object but has content and a name. See them as key-value pairs.
Comment: just like directives, comments have content but they don't have a name. They are rendered in a special way according to the configuration type you choosed.
Blank: they don't have neither content or name but are used to indicate blank lines if your renderer uses them.
When using the Config package, most of the work is done with Config_Container objects.
Example 31-1. An example that will create a new Config_Container
|
The above example illustrates how Config and Config_Container can interact. There are other ways. You could have for example first created the Config object and then used $config->getRoot() to add sections and directives to the returned object reference.
Example 31-2. Reading configuration from an XML file
In this example the XML file config.xml looks like this:
|
For more information, You can read API doc, sample of package, tests of package, and a great tutorial of DevShed about the Config package.