]> mj.ucw.cz Git - libucw.git/blobdiff - lib/perl/Config.pm
fixes
[libucw.git] / lib / perl / Config.pm
index ff28f5dfb28f2dcb7b001bcbf2aa6cedaeb23416..8d98c5615aa92a8736430c4e21c4aea4bcd86d98 100644 (file)
@@ -1,6 +1,6 @@
 #      Perl module for parsing Sherlock configuration files (using the config utility)
 #
-#      (c) 2002 Martin Mares <mj@ucw.cz>
+#      (c) 2002--2005 Martin Mares <mj@ucw.cz>
 #
 #      This software may be freely distributed and used according to the terms
 #      of the GNU Lesser General Public License.
@@ -21,6 +21,7 @@ sub Parse(@) {
        my $override_config = 0;
        push @options, "config|C=s" => sub { my ($o,$a)=@_; $defargs .= " -C'$a'"; $override_config=1; };
        push @options, "set|S=s" => sub { my ($o,$a)=@_; $defargs .= " -S'$a'"; };
+       Getopt::Long::Configure("bundling");
        Getopt::Long::GetOptions(@options) or return 0;
        if (!$override_config && $DefaultConfigFile) {
                $defargs = "-C'$DefaultConfigFile' $defargs";
@@ -28,11 +29,12 @@ sub Parse(@) {
        foreach my $section (keys %Sections) {
                my $opts = $Sections{$section};
                my $optlist = join(" ", keys %$opts);
+               my %filtered_opts = map { my $t=$_; $t=~s/[#\$]+$//; $t => $$opts{$_} } keys %$opts;
                my @l = `bin/config $defargs $section $optlist`;
                $? && exit 1;
                foreach my $o (@l) {
                        $o =~ /^CF_([^=]+)='(.*)'\n$/ or die "Cannot parse bin/config output: $_";
-                       my $var = $$opts{$1};
+                       my $var = $filtered_opts{$1};
                        my $val = $2;
                        if (ref $var eq "SCALAR") {
                                $$var = $val;