We still need to account for msgmap being open all the time
and not having separate read-only vs. read-write packages.
---
lib/PublicInbox/Msgmap.pm | 19 ++++---------------
1 file changed, 4 insertions(+), 15 deletions(-)
diff --git a/lib/PublicInbox/Msgmap.pm b/lib/PublicInbox/Msgmap.pm
index de9fd989..978730e2 100644
--- a/lib/PublicInbox/Msgmap.pm
+++ b/lib/PublicInbox/Msgmap.pm
@@ -257,21 +257,10 @@ sub skip_artnum {
sub check_inodes {
my ($self) = @_;
- # no filename if in-:memory:
- my $f = $self->{dbh}->sqlite_db_filename // return;
- if (my @st = stat($f)) { # did st_dev, st_ino change?
- my $st = pack('dd', $st[0], $st[1]);
- if ($st ne ($self->{st} // $st)) {
- my $tmp = eval { ref($self)->new_file($f) };
- if ($@) {
- warn "E: DBI->connect($f): $@\n";
- } else {
- %$self = %$tmp;
- }
- }
- } else {
- warn "W: stat $f: $!\n";
- }
+ $self->{dbh} // return;
+ my $rw = !$self->{dbh}->{ReadOnly};
+ PublicInbox::Over::check_inodes($self);
+ $self->{dbh} //= PublicInbox::Over::dbh_new($self, !$rw);
}
1;
--
unsubscribe: one-click, see List-Unsubscribe header
archive: https://public-inbox.org/meta/