From e7db41673ef77bb980d3192ae59bea07e2e65507 Mon Sep 17 00:00:00 2001 From: Florian Forster Date: Wed, 13 Aug 2008 09:48:50 +0200 Subject: [PATCH] contrib/collection3: Added the forgotten Collectd::Graph::Config module. --- contrib/collection3/lib/Collectd/Graph/Config.pm | 144 +++++++++++++++++++++++ 1 file changed, 144 insertions(+) create mode 100644 contrib/collection3/lib/Collectd/Graph/Config.pm diff --git a/contrib/collection3/lib/Collectd/Graph/Config.pm b/contrib/collection3/lib/Collectd/Graph/Config.pm new file mode 100644 index 00000000..d20be359 --- /dev/null +++ b/contrib/collection3/lib/Collectd/Graph/Config.pm @@ -0,0 +1,144 @@ +package Collectd::Graph::Config; + +=head1 NAME + +Collectd::Graph::Config - Parse the collection3 config file. + +=cut + +# Copyright (C) 2008 Florian octo Forster +# +# This program is free software; you can redistribute it and/or modify it under +# the terms of the GNU General Public License as published by the Free Software +# Foundation; only version 2 of the License is applicable. +# +# This program is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more +# details. +# +# You should have received a copy of the GNU General Public License along with +# this program; if not, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + +use strict; +use warnings; + +use Carp (qw(cluck confess)); +use Exporter (); +use Config::General ('ParseConfig'); +use Collectd::Graph::Type (); + +@Collectd::Graph::Config::ISA = ('Exporter'); +@Collectd::Graph::Config::EXPORT_OK = (qw(gc_read_config gc_get_config + gc_get_scalar)); + +our $Configuration = undef; + +return (1); + +=head1 EXPORTED FUNCTIONS + +=over 4 + +=item B (I<$file>) + +Reads the configuration from the file located at I<$file>. Returns B when +successfull and B otherwise. + +=cut + +sub gc_read_config +{ + my $file = shift; + my %conf; + + if ($Configuration) + { + return (1); + } + + $file ||= "etc/collection.conf"; + + %conf = ParseConfig (-ConfigFile => $file, + -LowerCaseNames => 1, + -UseApacheInclude => 1, + -IncludeDirectories => 1, + ($Config::General::VERSION >= 2.38) ? (-IncludeAgain => 0) : (), + -MergeDuplicateBlocks => 1, + -CComments => 0); + if (!%conf) + { + return; + } + + $Configuration = \%conf; + return (1); +} # gc_read_config + +=item B () + +Returns the hash as provided by L. The hash is returned as a +hash reference. Don't change it! + +=cut + +sub gc_get_config +{ + return ($Configuration); +} # gc_get_config + +=item B (I<$key>, [I<$default>]) + +Returns the scalar value I<$key> from the config file. If the key does not +exist, I<$default> will be returned. If no default is given, B will be +used in this case. + +=cut + +sub gc_get_scalar +{ + my $key = shift; + my $default = (@_ != 0) ? shift : undef; + my $value; + + if (!$Configuration) + { + return ($default); + } + + $value = $Configuration->{lc ($key)}; + if (!defined ($value)) + { + return ($default); + } + + if (ref ($value) ne '') + { + cluck ("Value for `$key' should be scalar, but actually is " + . ref ($value)); + return ($default); + } + + return ($value); +} # gc_get_config + +=back + +=head1 DEPENDS ON + +L + +=head1 SEE ALSO + +L + +=head1 AUTHOR AND LICENSE + +Copyright (c) 2008 by Florian Forster +EoctoEatEverplant.orgE. Licensed under the terms of the GNU +General Public License, VersionE2 (GPLv2). + +=cut + +# vim: set shiftwidth=2 softtabstop=2 tabstop=8 et fdm=marker : -- 2.11.0