=head1 NAME public-inbox-cindex - create and update code repository search indices =head1 SYNOPSIS public-inbox-cindex [OPTIONS] -g GIT_DIR [-g GIT_DIR]... public-inbox-cindex [OPTIONS] --update =head1 DESCRIPTION public-inbox-cindex creates and updates the Xapian search index for git code repository (C) search. It can also associate (fuzzy join) coderepos with Xapian-indexed inboxes. It only indexes commit messages and diffs as they would show up in an email. It does not index the contents of blobs directly. Like inbox indices, coderepo indices can either be internal or external to a coderepo. Either way, they're both created and updated through public-inbox-cindex. Once the initial indices are created by public-inbox-cindex, the L switch will incrementally update them. =head1 OPTIONS =over =item -d EXTDIR Use the given directory as an external index. External indices are generally recommended to internal indices since they do not need write access to any code repositories themselves. They are highly recommended when many repositories share a common history or if there is an M:N relationship between inboxes and coderepos. =item -j JOBS =item --jobs=JOBS Influences the number of Xapian indexing shards. If the repo has not been indexed or initialized, C shards will be created. Default: the number of existing Xapian shards =item --reindex Forces a re-index of all commits. This can be used for in-place upgrades and bugfixes while read-only processes are utilizing the index. =item --update =item -u Incrementally index all previously-indexed coderepos. =item --prune Removes commits which are no longer accessible via git. Use this after L (or L). =item --no-fsync =item --dangerous =item --max-size SIZE =item --batch-size SIZE These affect the coderepo index the same way they affect inbox indices. See L. =back =head1 FILES For internal indices, the Xapian DB is stored in C<$GIT_DIR/public-inbox-cindex>. External indices are stored wherever L EXTDIR points. =head1 CONFIGURATION =over 8 =item publicinbox.indexMaxSize =item publicinbox.indexBatchSize These configuration knobs affect the coderepo index the same way they affect inbox indices. See L. =back =head1 ENVIRONMENT =over 8 =item PI_CONFIG Used to override the default "~/.public-inbox/config" value. =item XAPIAN_FLUSH_THRESHOLD The number of documents to update before committing changes to disk. This variable is handled directly by Xapian, refer to Xapian API documentation for more details. Use C instead. =back =head1 UPGRADING Occasionally, public-inbox will update its schema version and require a full reindex by running this command with L. =head1 CONTACT Feedback welcome via plain-text mail to L The mail archives are hosted at L and L =head1 COPYRIGHT Copyright all contributors L License: AGPL-3.0+ L =head1 SEE ALSO L