X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=lib%2FPublicInbox%2FAltId.pm;h=f8aa4cb8cf71a244d369fc671bf3639d635acdb4;hb=56489ee40e44255f2f9a00cd608bc366d2586306;hp=6fdc3a2d4df6c141a8b76181ad30829bf43abeb3;hpb=58a5bb3e18901237b1ca34ef8f03f696be27d305;p=public-inbox.git
diff --git a/lib/PublicInbox/AltId.pm b/lib/PublicInbox/AltId.pm
index 6fdc3a2d..f8aa4cb8 100644
--- a/lib/PublicInbox/AltId.pm
+++ b/lib/PublicInbox/AltId.pm
@@ -1,4 +1,4 @@
-# Copyright (C) 2016 all contributors
+# Copyright (C) 2016-2018 all contributors
# License: AGPL-3.0+
package PublicInbox::AltId;
@@ -9,7 +9,7 @@ use URI::Escape qw(uri_unescape);
# spec: TYPE:PREFIX:param1=value1¶m2=value2&...
# Example: serial:gmane:file=/path/to/altmsgmap.sqlite3
sub new {
- my ($class, $inbox, $spec) = @_;
+ my ($class, $inbox, $spec, $writable) = @_;
my ($type, $prefix, $query) = split(/:/, $spec, 3);
$type eq 'serial' or die "non-serial not supported, yet\n";
@@ -22,17 +22,31 @@ sub new {
} split(/[&;]/, $query);
my $f = $params{file} or die "file: required for $type spec $spec\n";
unless (index($f, '/') == 0) {
- $f = "$inbox->{mainrepo}/public-inbox/$f";
+ if (($inbox->{version} || 1) == 1) {
+ $f = "$inbox->{mainrepo}/public-inbox/$f";
+ } else {
+ $f = "$inbox->{mainrepo}/$f";
+ }
}
bless {
- mm_alt => PublicInbox::Msgmap->new_file($f),
+ filename => $f,
+ writable => $writable,
xprefix => 'X'.uc($prefix),
}, $class;
}
+sub mm_alt {
+ my ($self) = @_;
+ $self->{mm_alt} ||= eval {
+ my $f = $self->{filename};
+ my $writable = $self->{filename};
+ PublicInbox::Msgmap->new_file($f, $writable);
+ };
+}
+
sub mid2alt {
my ($self, $mid) = @_;
- $self->{mm_alt}->num_for($mid);
+ $self->mm_alt->num_for($mid);
}
1;