rake_commit
This gem automates a pretty standard workflow when committing code to git, svn, and git-svn. Run rake_commit in your current project, which does the following, depending on source control:
git
1. Checks in current changes into a temp commit just in case
2. Resets soft back to origin/branch (in order to collapse changes into one commit)
3. Adds new files to git and removes deleted files
4. Prompts for a commit message
5. Commits to git
6. Pulls changes from origin (and does a rebase to keep a linear history)
7. Runs the default rake task (which should run the tests)
8. Pushes the commit to origin
git-svn
1. Adds new files to git and removes deleted files
2. Prompts for a commit message
3. Commits to local git
4. Pulls changes from SVN
5. Runs the default rake task (which should run the tests)
6. Pushes the commit to SVN
subversion
1. Prompts for a commit message
2. Adds new files to subversion
3. Deletes missing files from subversion
4. svn update
5. Runs the default rake task (which should run the tests)
6. Checks in the code
The first version started with the code posted at Jay Field's Blog: http://blog.jayfields.com/2006/12/ruby-rake-commit.html. Improvements have been added in from several more projects.
Installation
gem install rake_commit
Usage
cd /path/to/project
rake_commit
Command line arguments
--help
Print help information.
--incremental
This will prompt as normal and then commit without running tests or pushing. This is useful for make incremental commits while working.
--no-collapse
This tells rake_commit not to prompt and make a new commit. This is useful when you've done a merge by hand and want to preserve the commit. It will stil run rake and then push if rake succeeds.
--without-prompt <prompt>
This will cause rake_commit to skip the named prompt. For example, if you are working by yourself and do not need to prompt for an author, you can use --without-prompt author
.
Configuration
If the same command line arguments are always used, they can be added to a .rake_commit
file in the root of the project. For example, this .rake_commit
file will tell rake_commit
to only prompt for message:
--without-prompt author
--without-prompt feature
License
rake_commit is released under the MIT license.