NAME

rgit - Recursively execute a command on all the git repositories in a directory tree.

VERSION

Version 0.04

SYNOPSIS

rgit [-K|-V|-I] [GIT_OPTIONS] COMMAND [COMMAND_ARGS]

DESCRIPTION

This utility recursively searches in the current directory (or in the directory given by the GIT_DIR environment variable if it's set) for all git repositories, sort this list by the repository path, chdir into each of them, and executes the specified git command. Moreover, those formats are substuted in the arguments before running the command :

  • ^n with the current repository name.

  • ^g with the relative path to the current repository.

  • ^G with the absolute path to the current repository.

  • ^w with the relative path to the current repository's working directory.

  • ^W with the absolute path to the current repository's working directory.

  • ^b with a "bareified" relative path, i.e. ^g if this is a bare repository, and ^w.git otherwise.

  • ^B with an absolute version of the "bareified" path.

  • ^R with the absolute path to the current root directory.

  • ^^ with a bare ^.

There are actually a few commands that are only executed once in the current directory : daemon, gui, help, init and version. For any of those, no format substitution is done.

You can specify which git executable to use with the GIT_EXEC_PATH environment variable.

COMMAND LINE SWITCHES

rgit takes its options as the capital switches that comes before the git command. It's possible to bundle them together. They are removed from the argument list before calling git.

  • -K

    Keep processing on error. The default policy is to stop whenever an error occured.

  • -I

    Enables interactive mode when the standard input is a tty. Requires Term::ReadKey to be installed. This lets you choose interactively what to do when one of the commands returns a non-zero status.

  • -V

    Outputs the version.

EXAMPLES

Execute git gc on all the repositories below the current directory :

rgit gc

Tag all the repositories with their name :

rgit tag ^n

Add a remote to all repositories in "/foo/bar" to their bare counterpart in qux on host :

GIT_DIR="/foo/bar" rgit remote add host git://host/qux/^b

DEPENDENCIES

The core modules Carp, Config, Cwd, Exporter, File::Find, File::Spec::Functions and POSIX.

Object::Tiny.

AUTHOR

Vincent Pit, <perl at profvince.com>, http://profvince.com.

You can contact me by mail or on irc.perl.org (vincent).

BUGS

Please report any bugs or feature requests to bug-rgit at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=rgit. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc rgit

Tests code coverage report is available at http://www.profvince.com/perl/cover/rgit.

COPYRIGHT & LICENSE

Copyright 2008 Vincent Pit, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.