NAME
Config::Simple - Simple Configuration Class
SYNPOSIS
in the app.cfg configuration file:
[mysql]
host=ultracgis.com
login=sherzodr
password=secret
[profile]
first name=Sherzod
last name=Ruzmetov
email=sherzodr@cpan.org
in your Perl application:
use Config::Simple;
my $cfg = new Config::Simple(filename=>"app.cfg");
print "MySQL host: ", $config->param("mysql.host"), "\n";
print "MySQL login: ", $config->param("mysql.login"), "\n";
# to get just [mysql] block:
my $mysql = $cfg->param(-block=>"mysql");
print "MySQL host: ", $mysql->{host}, "\n";
print "MySQL login: ", $mysql->{login}, "\n";
$cfg->write();
# Tied hash access...
tie my %Config, "Config::Simple::Tie", "app.cfg", O_RDONLY|O_CREAT or die $Config::Simple::errstr;
print "MySQL host: ", $Config{'mysql.host'}, "\n";
# setting new MySQL host value
$Config{'mysql.host'} = "new.localhost"; # this also updates the file
delete $Config{'mysql.RaiseError'}; # also updates the file
NOTE
This documentation refers to version 2.4 of Config::Simple. If you have a version older than this, please update it to the latest release ASAP (before you get burned).
DESCRIPTION
This Perl5 library makes it very easy to parse INI-styled configuration files and create once on the fly. It optionally requires Digest::MD5 module.
Config::Simple
modules defines too classes, Config::Simple
and Config::Simple::Tie
. Latter will allow accessing the Configuration files via tied hash variables. In this case, modifications to the values of the hash will reflect in the configuration file right away.
Unlike the case with Config::Simple::Tie
, Config::Simple
classes uses simple OO style, and requires calling method write() if you want to update the contents of the file. Otherwise all the manipulations will take place in memory.
Syntax for Config::Simple::Tie is:
tie my %Hash, "Config::Simple::Tie", "file.cfg" [,mode] [,c] or die $Config::Simple::errstr;
We'll give you a briefe example that makes use of Config::Simple::Tie
and we'll continue on with Config::Simple
methods.
use Config::Simple; # notice, you still have to load Config::Simple
# not Config::Simple::Tie!!!
tie my %Config, "Config::Simple::Tie", "app.cfg" or die "app.cfg: $Config::Simple::errstr";
my $host = $Config{'mysql.host'};
my $login = $Config{'mysql.login'};
delete $Config{'mysql.password'}; # delets from the file as well
$Config{'mysql.login'} = "marley01"; # updates the file
untie %Config; # destroys the connection;
As you see, after you tie a hash variable to Config::Simple::Tie
class, you can use it as an ordinarry HASH, but in the background it will be dealing with a real file.
CONFIGURATION FILE
Configuration file that Config::Simple uses is similar to Window's *.ini file syntax. Example.,
; sample.cfg
[block1]
key1=value1
key2=value2
...
[block2]
key1=value1
key2=value2
...
It can have infinite number of blocks and infinite number of key/value pairs in each block. Block and key names are case sensitive. i.e., [block1] and [Block1] are two completely different blocks. But this might change in the subsequent releases of the library. So please use with caution!
Lines that start with either ';' (semi colon) or '#' (pound) are assumed to be comments till the end of the line. If a line consists of a sole '.' (dot), then all the lines till eof are ignored (it's like __END__ Perl token)
When you create Config::Simple object with $cfg = new Config::Simple(filename=>"sample.cfg") syntax, it reads the above sample.cfg config file, parses the contents, and creates required data structure, which you can access through its public methods.
In this documenation when I mention "name", I'll be refering to block name and key delimited with a dot (.). Forexample, from the above sample.cfg file, following names could be retrieved: block1.key1, block1.key2, block2.key1 and block2.key2 etc.
Here is the configuration file that I use in most of my CGI applications, and I'll be using it in most of the examples throughout this manual:
;app.cfg
[mysql]
host=ultracgis
login=sherzodr
password=secret
db_name=test
RaiseError=1
PrintError=1
fcntl.h Constants
by default Config::Simple exports O_RDONLY
, O_RDWR
, O_CREAT
, O_EXCL
fcnl.h (file control) constants. When you create Config::Simple object by passing it a filename, it will try to read the file. If it fails it creats the file. This is a default behaviour. If you want to control this behavior, you'll need to pass mode with your desired fcntl O_* constants to the constructor:
$config = new Config::Simple(filename=>"app.cfg", mode=>O_RDONLY);
$config = new Config::Simple(filename=>"app.cfg", mode=>O_RDONLY|O_CREAT); # default
$config = new Config::Simple(filename=>"app.cfg", mode=>O_EXCL);
# tied hash access method:
$config = tie %Config, "Config::Simple::Tie", "app.cfg", O_RDONLY;
$config = tie %Config, "Config::Simple::Tie", "app.cfg", O_RDONLY|O_CREAT;
$config = tie %Config, "Config::Simple::Tie", "app.cfg", O_EXCL;
Note: in the tied hash access method, you can ignore the return value of tie() (which is a Config::Simple object). You will not be using it anyways. In case you'll need this at any time in the future, you can always aqcuire it by calling tied() Perl built-in function:
$config = tied(%Config);
fcntl constants:
+===========+============================================================+
| constant | description |
+===========+============================================================+
| O_RDONLY | opens a file for reading only, failes if doesn't exist |
+-----------+------------------------------------------------------------+
| O_RDWR | opens a file for reading and writing |
+-----------+------------------------------------------------------------+
| O_CREAT | creates a file |
+-----------+------------------------------------------------------------+
| O_EXCL | creates a file if it doesn't already exist |
+-----------+------------------------------------------------------------+
METHODS
- new( filename=>$scalar [, mode=>O_*] [, lockfile=>$scalar] [,c=>$boolean] )
-
Constructor method. Requires filename to be present and picks up defaults for the rest if omitted. mode is used while opening the file, lockfile while updating the file.
It returns Config::Simple object if successfull. If it fails, sets the error message to $Config::Simple::errstr variable, and returns undef.
mode can accept any of the above described fcntl constants. Default is
O_RDONLY | O_CREAT
. Default lockfile is the name of the configuration file with ".lock" extensionIf you set the value of
c
to 1 (true), then it checks the configuration file for proper syntax, and throws an exception if it finds a syntax error. Error message looks something likeSyntax error in line 2 of sample.cfg: "this is just wrong" at t/default.t line 11
. If you set it to 0 (false), those lines will just be ignored. - param([args])
-
If called without any arguments, returns the list of all the available blocks in the config. file.
If called with arguments, this method suports several different syntaxes, and we'll discuss them all seperately.
- param($name))
-
returns the value of $name. $name is block and key seperated with a dot. For example, to retrieve the mysql login name from the app.cfg, we could use the following syntax:
$login = $cfg->param("mysql.login");
- param(-name=>$name)
-
the same as "param($name)"
- param($name, $value)
-
updates the value of $name to $value. For example, to set the value of "RaiseError" to 0, and create an new "AutoCommit" key with a true value:
$cfg->param("mysql.RaiseError", 0); $cfg->param("mysql.AutoCommit", 1);
As I implied above, if either the block or the key does not exist, it will be created for you. So
$cfg->param("author.f_name", "Sherzod");
would create an [author] block with "f_name=Sherzod" key/value pair.
- param(-name=>$name, -value=>$value)
-
the same as "param($name, $value)"
- param(-block=>$block)
-
returns the whole block as a hash reference. For example, to get the whole [mysql] block:
$mysql = $cfg->param(-block=>'mysql'); $login = $mysql->{login}; $psswd = $mysql->{password};
- param(-block=>$block, -values=>{key1=>value1, key2=>value2})
-
creates a new block with the specified values, or overrides existing block. For example, to add the [site] block to the above app.cfg with "title=UltraCgis.com" and "description=The coolest site" key/values we could use the following syntax:
$cfg->param(-block=>"site", -values=>{ title=> "UltraCgis.com", description=>"The coolest site", author=>"Sherzod B. Ruzmetov", });
note that if the [site] block already exists, its contents will be cleared and then re-created with the new values.
- set_param($name, $value)
-
This method is provided for backward compatability with 1.x version of Config::Simple. It is identical to param($name, $value) syntax.
- param_hash()
-
handy method to save the contents of the config. file into a hash variable.
%Config = $cfg->param_hash();
Structure of %Config looks like the following:
%Config = ( 'mysql.PrintError' => 1, 'mysql.db_name' => 'test', 'mysql.login' => 'sherzodr', 'mysql.password' => 'secret', 'mysql.host' => 'ultracgis.com', 'mysql.RaiseError' => 1, );
- write([$new_filename])
-
Notice, that all the above manipulations take place in the object's memory, ie, changes you make with param() and set_param() methods do not reflect in the actual config. file. To update the config file in the end, you'll need to call "write()" method with no arguments.
If you want to save newly updated/created configuration into a new file, pass the new filename as the first argument to the write() method, and the original config. file will not be touched.
If it detects that configuration file was updated by a third party while Config::Simple was working on the file, it throws a harmless warning to STDERR, and will copy the original file to a new location with the .bk extension, and updates the configuration file with its own contents.
"write()" returns true if successfull, undef, otherwise. Error message can be accessed either vi $Config::Simple::errstr variable, or by calling "error()" method.
- error()
-
Returns the value of $Config::Simple::errstr
BUGS
Hopefully none.
Please send them to my email if you detect any with a sample code that triggers that bug. Even if you don't have any, just let me konw that you are using it. It just makes me feel good ;-)
COPYRIGHT
Copyright (C) 2002 Sherzod Ruzmetov <sherzodr@cpan.org>
This program is free software; you can redistribute it and/or
modify it under the same terms as Perl itself
AUTHOR
Sherzod B. Ruzmetov <sherzodr@cpan.org>
http://www.ultracgis.com