-# Copyright (C) 2014, Eric Wong <normalperson@yhbt.net> and all contributors
+# Copyright (C) 2014-2015 all contributors <meta@public-inbox.org>
# License: AGPLv3 or later (https://www.gnu.org/licenses/agpl-3.0.txt)
+#
+# Used throughout the project for reading configuration
package PublicInbox::Config;
use strict;
use warnings;
+use base qw/Exporter/;
+our @EXPORT_OK = qw/try_cat/;
use File::Path::Expand qw/expand_filename/;
-use IPC::Run;
# returns key-value pairs of config directives in a hash
# if keys may be multi-value, the value is an array ref containing all values
sub new {
my ($class, $file) = @_;
- my ($in, $out);
-
$file = default_file() unless defined($file);
- IPC::Run::run([qw/git config --file/, $file, '-l'], \$in, \$out);
- $? == 0 or die "git config --file $file -l failed: $?\n";
- my %rv;
- foreach my $line (split(/\n/, $out)) {
- my ($k, $v) = split(/=/, $line, 2);
- my $cur = $rv{$k};
-
- if (defined $cur) {
- if (ref($cur) eq "ARRAY") {
- push @$cur, $v;
- } else {
- $rv{$k} = [ $cur, $v ];
- }
- } else {
- $rv{$k} = $v;
- }
- }
- bless \%rv, $class;
+ bless git_config_dump($file), $class;
}
sub lookup {
my $pfx;
foreach my $k (keys %$self) {
- $k =~ /\A(publicinbox\.[A-Z0-9a-z-]+)\.address\z/ or next;
+ $k =~ /\A(publicinbox\.[\w-]+)\.address\z/ or next;
my $v = $self->{$k};
if (ref($v) eq "ARRAY") {
foreach my $alias (@$v) {
defined $pfx or return;
my %rv;
- foreach my $k (qw(mainrepo address)) {
+ foreach my $k (qw(mainrepo address filter)) {
my $v = $self->{"$pfx.$k"};
$rv{$k} = $v if defined $v;
}
$self->{"publicinbox.$listname.$key"};
}
+sub config_dir { $ENV{PI_DIR} || expand_filename('~/.public-inbox') }
+
sub default_file {
my $f = $ENV{PI_CONFIG};
return $f if defined $f;
- my $pi_dir = $ENV{PI_DIR} || expand_filename('~/.public-inbox/');
- "$pi_dir/config";
+ config_dir() . '/config';
+}
+
+sub git_config_dump {
+ my ($file) = @_;
+ my ($in, $out);
+ my @cmd = (qw/git config/, "--file=$file", '-l');
+ my $cmd = join(' ', @cmd);
+ my $pid = open(my $fh, '-|', @cmd);
+ defined $pid or die "$cmd failed: $!";
+ my %rv;
+ foreach my $line (<$fh>) {
+ chomp $line;
+ my ($k, $v) = split(/=/, $line, 2);
+ my $cur = $rv{$k};
+
+ if (defined $cur) {
+ if (ref($cur) eq "ARRAY") {
+ push @$cur, $v;
+ } else {
+ $rv{$k} = [ $cur, $v ];
+ }
+ } else {
+ $rv{$k} = $v;
+ }
+ }
+ close $fh or die "failed to close ($cmd) pipe: $!";
+ $? and warn "$$ $cmd exited with: ($pid) $?";
+ \%rv;
+}
+
+sub try_cat {
+ my ($path) = @_;
+ my $rv;
+ if (open(my $fh, '<', $path)) {
+ local $/;
+ $rv = <$fh>;
+ }
+ $rv;
}
1;