Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/book/git-editor

Edit and regenerate a Git repository with very little code
https://github.com/book/git-editor

Last synced: about 1 month ago
JSON representation

Edit and regenerate a Git repository with very little code

Awesome Lists containing this project

README

        

Git-Editor

"Git::Editor" provides the tools to create an editor for a Git
repository.

Objects in the Git object database are uniquely identified by their
SHA-1 hash. It's not technically possible to modify an object, as the
hash of the modified object will be different from the original hash,
thus creating a new and different object.

However, to the casual user, the unique relationship between a commit
object and its id is largely irrelevant. When someone makes a typo in a
commit message, "git commit --amend" allows to modify the most recent
commit (of course, the truth is that a new commit object is created and
the current branch is simply made to points to the newly created
commit).

If the commit having a typo is already the parent of several other
commits, simply creating a new, modified commit is not enough, as the
children of the original commit will still point to it. When doing such
modifications, one wants to preserve the "identity" of the original
commit, and therefore modify (or rather, re-create) all commits that
directly or indirectly depend on it, and not keep any reference to
them.

"Git::Editor" lets one assemble modification rules ("apply this code to
every commit matching these conditions") and apply them on a list of
commits (obtained through "git rev-list"). All descendant commits (in
the provided commit list) will be rewritten to point to the newly
created commits.

The included git-editor program is the recommended tool to edit a Git
repository (rather than rolling your own using Git::Editor> directly).

INSTALLATION

To install this module, run the following commands:

perl Makefile.PL
make
make test
make install

Alternatively, to install with Module::Build, you can use the following commands:

perl Build.PL
./Build
./Build test
./Build install

SUPPORT AND DOCUMENTATION

After installing, you can find documentation for this module with the
perldoc command.

perldoc Git::Editor

You can also look for information at:

RT, CPAN's request tracker
http://rt.cpan.org/NoAuth/Bugs.html?Dist=Git-Editor

AnnoCPAN, Annotated CPAN documentation
http://annocpan.org/dist/Git-Editor

CPAN Ratings
http://cpanratings.perl.org/d/Git-Editor

Search CPAN
http://search.cpan.org/dist/Git-Editor/

LICENSE AND COPYRIGHT

Copyright (C) 2010 Philippe Bruhat (BooK)

This program is free software; you can redistribute it and/or modify it
under the terms of either: the GNU General Public License as published
by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.