The following commit has been merged in the master branch:
commit e1fb5e5c6be00244636d0dfd7c92b88673c7d839
Author: Raphaël Hertzog <[email protected]>
Date: Mon Nov 9 22:39:25 2009 +0100
Dpkg::Conf: new module to parse options from a configuration file
diff --git a/scripts/Dpkg/Conf.pm b/scripts/Dpkg/Conf.pm
new file mode 100644
index 0000000..2de197f
--- /dev/null
+++ b/scripts/Dpkg/Conf.pm
@@ -0,0 +1,117 @@
+# Copyright © 2009 Raphaël Hertzog <[email protected]>
+#
+# 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; either version 2 of the License, or
+# (at your option) any later version.
+#
+# 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, see <http://www.gnu.org/licenses/>.
+
+package Dpkg::Conf;
+
+use strict;
+use warnings;
+
+use Dpkg::Gettext;
+use Dpkg::ErrorHandling;
+
+use overload
+ '@{}' => sub { $_[0]->{'options'} },
+ '""' => sub { join(" ", @{$_[0]->{'options'}}) },
+ fallback => 1;
+
+=head1 NAME
+
+Dpkg::Conf - parse dpkg configuration files
+
+=head1 DESCRIPTION
+
+The Dpkg::Conf object can be used to read options from a configuration
+file. It can exports an array that can then be parsed exactly like @ARGV.
+
+=head1 FUNCTIONS
+
+=over 4
+
+=item my $conf = Dpkg::Conf->new()
+
+Create a new Dpkg::Conf object.
+
+=cut
+
+sub new {
+ my ($this, %opts) = @_;
+ my $class = ref($this) || $this;
+
+ my $self = {
+ options => [],
+ };
+ bless $self, $class;
+
+ return $self;
+}
+
+=item @$conf
+
+Returns the list of options to be parsed.
+
+=item $conf->load($file)
+
+Read options from a file. Return the number of options parsed.
+
+=item $conf->parse($fh)
+
+Parse options from a file handle. Return the number of options parsed.
+
+=cut
+
+sub load {
+ my ($self, $file) = @_;
+ open(my $fh, "<", $file) or syserr(_g("cannot read %s"), $file);
+ my $ret = $self->parse($fh, $file);
+ close($fh);
+ return $ret;
+}
+
+sub parse {
+ my ($self, $fh, $desc) = @_;
+ my $count = 0;
+ while (<$fh>) {
+ chomp;
+ s/^\s+//; s/\s+$//; # Strip leading/trailing spaces
+ s/\s+=\s+/=/; # Remove spaces around the first =
+ s/\s+/=/ unless m/=/; # First spaces becomes = if no =
+ next if /^#/ or /^$/; # Skip empty lines and comments
+ if (/^(\S+)(?:=(.*))?$/) {
+ my ($name, $value) = ($1, $2);
+ $name = "--$name" unless $name =~ /^-/;
+ if (defined $value) {
+ $value =~ s/^"(.*)"$/$1/ or $value =~ s/^'(.*)'$/$1/;
+ push @{$self->{'options'}}, "$name=$value";
+ } else {
+ push @{$self->{'options'}}, $name;
+ }
+ $count++;
+ } else {
+ warning(_g("invalid syntax for option in %s, line %d"),
+ $desc, $.);
+ }
+ }
+ return $count;
+}
+
+=back
+
+=head1 AUTHOR
+
+Raphaël Hertzog <[email protected]>.
+
+=cut
+
+1;
diff --git a/scripts/Makefile.am b/scripts/Makefile.am
index a3468ae..27ff34d 100644
--- a/scripts/Makefile.am
+++ b/scripts/Makefile.am
@@ -96,6 +96,7 @@ nobase_dist_perllib_DATA = \
Dpkg/Changelog/Parse.pm \
Dpkg/Checksums.pm \
Dpkg/Compression.pm \
+ Dpkg/Conf.pm \
Dpkg/Control.pm \
Dpkg/Control/Changelog.pm \
Dpkg/Control/Fields.pm \
diff --git a/scripts/po/POTFILES.in b/scripts/po/POTFILES.in
index 82a400a..97d44fc 100644
--- a/scripts/po/POTFILES.in
+++ b/scripts/po/POTFILES.in
@@ -21,6 +21,7 @@ scripts/Dpkg/Changelog/Entry.pm
scripts/Dpkg/Changelog/Entry/Debian.pm
scripts/Dpkg/Changelog/Parse.pm
scripts/Dpkg/Checksums.pm
+scripts/Dpkg/Conf.pm
scripts/Dpkg/Control.pm
scripts/Dpkg/Control/Changelog.pm
scripts/Dpkg/Control/Fields.pm
--
dpkg's main repository
--
To UNSUBSCRIBE, email to [email protected]
with a subject of "unsubscribe". Trouble? Contact [email protected]