# this usually in ~/.public-inbox/config and parseable with git-config(1)
# update t/config.t if changing this, that test relies on this
[publicinbox "test"]
+ address = try@public-inbox.org
+ address = sandbox@public-inbox.org
address = test@public-inbox.org
mainrepo = /home/pi/test-main.git
- description = test repo, occasionally reset
+ description = test/sandbox area, occasionally reset
url = http://example.com/test
[publicinbox "bugs"]
address = bugs@public-inbox.org
use File::Path::Expand qw/expand_filename/;
# 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 @cfg = `git config -l`;
$? == 0 or die "git config -l failed: $?\n";
chomp @cfg;
- my %rv = map { split(/=/, $_, 2) } @cfg;
+ my %rv;
+ foreach my $line (@cfg) {
+ 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;
}
foreach my $k (keys %$self) {
$k =~ /\A(publicinbox\.[A-Z0-9a-z-]+)\.address\z/ or next;
- (lc($self->{$k}) eq $addr) or next;
- $pfx = $1;
- last;
+ my $v = $self->{$k};
+ if (ref($v) eq "ARRAY") {
+ foreach my $alias (@$v) {
+ (lc($alias) eq $addr) or next;
+ $pfx = $1;
+ last;
+ }
+ } else {
+ (lc($v) eq $addr) or next;
+ $pfx = $1;
+ last;
+ }
}
defined $pfx or return;
- my %rv = map {
- $_ => $self->{"$pfx.$_"}
- } (qw(mainrepo description address));
+ my %rv;
+ foreach my $k (qw(mainrepo description address)) {
+ my $v = $self->{"$pfx.$k"};
+ $rv{$k} = $v if defined $v;
+ }
my $listname = $pfx;
$listname =~ s/\Apublicinbox\.//;
$rv{listname} = $listname;
is($cfg->lookup('blah@example.com'), undef,
"non-existent lookup returns undef");
+
+ my $test = $cfg->lookup('test@public-inbox.org');
+ is_deeply($test, {
+ 'address' => ['try@public-inbox.org',
+ 'sandbox@public-inbox.org',
+ 'test@public-inbox.org'],
+ 'mainrepo' => '/home/pi/test-main.git',
+ 'description' => 'test/sandbox area, occasionally reset',
+ 'listname' => 'test',
+ }, "lookup matches expected output for test");
}
done_testing();