NAME

Zoidberg::PdParse - parses Zoidbergs config files

SYNOPSIS

use Zoidberg::PdParse;
$Zoidberg::PdParse::base_dir = $my_config_dir;
my $config_hash_ref = pd_read('my_config_file.pd');

ABSTRACT

This module parses Zoidbergs config files.

DESCRIPTION

The Zoidberg object and some Zoidberg plugins inherit from this object to read and write config files. The format used is actually output of Data::Dumper. We give these files the extension ".pd" this means "Perl Dump". These files can contain all kinds of code that will be executed in a eval() function. There should be assigned a $VAR1 (as done by Data::Dumper output) preferrably this should be a hash reference.

EXPORT

@EXPORT = qw/pd_read pd_write pd_merge/;

@EXPORT_OK = qw/pd_read_multi pd_forget/;

( This module modifies the global settings of Data::Dumper )

METHODS

pd_read($file_name, $pre_eval)

Returns the contents of single file as a hash ref. $pre_eval can contain perl code as a string, this code will be evalled in the same scope as the config file. This can for example be used to allow variables in the config file.

This function caches read files, use pd_forget to flash cache. Due to this cache loops between files should not be a problem.

pd_read_multi(@file_names)

Returns a merge of the contents of array files as hash ref. Can also be called as pd_read_multi([@file_names], @options) in this case @options is passed on to pd_read

pd_write($file, $hash_ref)

Dump the contents of $hash_ref to $file. Retuns 1 on succes.

pd_merge(@hash_refs)

Merges @hash_refs to single ref. This is for example used to let multiple config files overload each other. The last array element is the last processed, and thus in case of overloading the most specific.

pd_forget

Forget read files.

AUTHOR

R.L. Zwart, <rlzwart@cpan.org> Jaap Karssenberg || Pardus [Larus] <pardus@cpan.org>

Copyright (c) 2002 Raoul L. Zwart. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

SEE ALSO

Zoidberg

http://zoidberg.sourceforge.net.