X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=public-inbox-index;h=53449556d3c43880cf2fe48b1fa41a3971f1e72c;hb=f76f265a851944b5dedcc3be5f3b5224b6ebda89;hp=9cfcadc2df5d65bff8da98334d310f9f1797d06c;hpb=675494c58ef7a39a92c79cbf02975b9da3991c0b;p=public-inbox.git diff --git a/public-inbox-index b/public-inbox-index old mode 100644 new mode 100755 index 9cfcadc2..53449556 --- a/public-inbox-index +++ b/public-inbox-index @@ -1,5 +1,5 @@ #!/usr/bin/perl -w -# Copyright (C) 2015, all contributors (git clone git://80x24.org/public-inbox) +# Copyright (C) 2015 all contributors # License: AGPLv3 or later (https://www.gnu.org/licenses/agpl-3.0.txt) # Basic tool to create a Xapian search index for a git repository # configured for public-inbox. @@ -10,20 +10,53 @@ use strict; use warnings; my $usage = "public-inbox-index GIT_DIR"; use PublicInbox::Config; -use PublicInbox::Search; -use PublicInbox::GitCatFile; +eval { require PublicInbox::SearchIdx }; +if ($@) { + print STDERR "Search::Xapian required for $0\n"; + exit 1; +} +my @dirs; -sub usage { print STDERR "Usage: $usage\n"; exit 1 } -if (@ARGV) { - foreach my $dir (@ARGV) { - index_dir($dir); +sub resolve_git_dir { + my ($cd) = @_; + my @cmd = qw(git rev-parse --git-dir); + my $cmd = join(' ', @cmd); + my $pid = open my $fh, '-|'; + defined $pid or die "forking $cmd failed: $!\n"; + if ($pid == 0) { + if (defined $cd) { + chdir $cd or die "chdir $cd failed: $!\n"; + } + exec @cmd; + die "Failed to exec $cmd: $!\n"; + } else { + my $dir = eval { + local $/; + <$fh>; + }; + close $fh or die "error in $cmd: $!\n"; + chomp $dir; + return $cd if ($dir eq '.' && defined $cd); + $dir; } -}; +} + +if (@ARGV) { + @dirs = map { resolve_git_dir($_) } @ARGV; +} else { + @dirs = (resolve_git_dir()); +} + +sub usage { print STDERR "Usage: $usage\n"; exit 1 } +usage() unless @dirs; + +foreach my $dir (@dirs) { + index_dir($dir); +} sub index_dir { my ($git_dir) = @_; -d $git_dir or die "$git_dir does not appear to be a git repository\n"; - my $git = PublicInbox::GitCatFile->new($git_dir); - my $s = PublicInbox::Search->new($git_dir, 1); - $s->index_sync($git); + my $s = PublicInbox::SearchIdx->new($git_dir, 1); + $s->index_sync; }