gitflow-avh
AVH Edition of the git extensions to provide high-level repository operations for Vincent Driessen's branching model
Top Related Projects
From git log to SemVer in no time
Quick Overview
GitFlow AVH is an extension of the popular git-flow branching model, providing high-level repository operations for Vincent Driessen's branching model. It offers additional functionality and improvements over the original git-flow, making it easier to manage complex projects with multiple branches and releases.
Pros
- Enhanced feature set compared to the original git-flow
- Active maintenance and community support
- Improved handling of hotfixes and support branches
- Customizable to fit various workflow needs
Cons
- Steeper learning curve for those new to git-flow concepts
- May be overly complex for smaller projects or teams
- Requires discipline and team buy-in to maintain the workflow
- Can be challenging to integrate with some CI/CD pipelines
Code Examples
- Initializing a repository with GitFlow AVH:
git flow init
This command sets up the necessary branch structure for GitFlow in your repository.
- Starting a new feature:
git flow feature start my-new-feature
This creates a new feature branch based on the develop branch.
- Finishing a feature:
git flow feature finish my-new-feature
This merges the feature branch back into develop and deletes the feature branch.
- Creating a release:
git flow release start 1.0.0
git flow release finish 1.0.0
These commands create a release branch, merge it into master and develop, tag the release, and clean up.
Getting Started
To get started with GitFlow AVH:
- Install GitFlow AVH (varies by OS, e.g.,
brew install git-flow-avh
on macOS with Homebrew) - Initialize GitFlow in your repository:
git flow init
- Configure your preferred branch naming conventions when prompted
- Start using GitFlow commands for features, releases, and hotfixes:
git flow feature start my-feature # Work on your feature git flow feature finish my-feature
For more detailed instructions and advanced usage, refer to the project's documentation on GitHub.
Competitor Comparisons
From git log to SemVer in no time
Pros of GitVersion
- Focuses on semantic versioning and automated version numbering
- Supports multiple version strategies and branching models
- Integrates well with CI/CD pipelines and build systems
Cons of GitVersion
- Steeper learning curve for complex versioning scenarios
- May require more configuration for non-standard Git workflows
- Less focus on Git workflow management compared to gitflow-avh
Code Comparison
GitVersion configuration example:
mode: ContinuousDelivery
branches:
develop:
mode: ContinuousDeployment
tag: alpha
release:
mode: ContinuousDelivery
tag: beta
gitflow-avh usage example:
git flow init
git flow feature start new-feature
git flow feature finish new-feature
git flow release start 1.0.0
git flow release finish 1.0.0
Summary
GitVersion excels in automated versioning and CI/CD integration, while gitflow-avh focuses on Git workflow management. GitVersion offers more flexibility in version numbering strategies but may require more setup. gitflow-avh provides a simpler approach to managing feature, release, and hotfix branches but with less emphasis on versioning. Choose GitVersion for complex versioning needs and CI/CD integration, or gitflow-avh for a straightforward Git branching model.
Convert
designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
git-flow (AVH Edition)
A collection of Git extensions to provide high-level repository operations for Vincent Driessen's branching model. This fork adds functionality not added to the original branch.
Getting started
For the best introduction to get started with git flow
, please read Jeff
Kreeftmeijer's blog post:
http://jeffkreeftmeijer.com/2010/why-arent-you-using-git-flow/
Or have a look at one of these screen casts:
- How to use a scalable Git branching model called git-flow (by Build a Module)
- A short introduction to git-flow (by Mark Derricutt)
- On the path with git-flow (by Dave Bock)
A quick cheatsheet was made by Daniel Kummer:
http://danielkummer.github.io/git-flow-cheatsheet/
Installing git-flow
See the Wiki for up-to-date Installation Instructions.
Integration with your shell
For those who use the Bash or ZSH shell, you can use my fork of git-flow-completion which includes several additions for git-flow (AVH Edition), or you can use the original git-flow-completion project by bobthecow. Both offer tab-completion for git-flow subcommands and branch names with my fork including tab-completion for the commands not found in the original git-flow.
FAQ
- See the FAQ section of the project Wiki.
- Version Numbering Scheme.
Starting with version 1.0, the project uses the following scheme: <MAJOR>.<MINOR>.<REVISION>\ - AVH is the acronym of "A VirtualHome"
Please help out
This project is under constant development. Feedback and suggestions are very welcome and I encourage you to use the Issues list on Github to provide that feedback.
Feel free to fork this repository and to commit your additions. For a list of all contributors, please see the AUTHORS file.
Any questions, tips, or general discussion can be posted to the Google group: http://groups.google.com/group/gitflow-users This is the original group set up to support the nvie branch, but I am monitoring the list as well for any questions related to my version. When you do post a question on the list please indicate which version you are, using the complete version number.
Contributing
Fork the repository. Then, run:
git clone -b master git@github.com:<username>/gitflow-avh.git
cd gitflow-avh
The -b master
switch has to be added since the fork operation automatically
clones the develop
branch of the official gitflow repository and cloning it
results in a local repository with just a develop
branch.
If you do not have gitflow installed yet install it by running make && make install
.
After that initialize the local gitflow repository with gitflow itself:
git flow init -d
git flow feature start <your feature>
Then, do work and commit your changes.
git flow feature publish <your feature>
When done, open a pull request to your feature branch.
License terms
git-flow is published under the FreeBSD License, see the LICENSE file. Although the FreeBSD License does not require you to share any modifications you make to the source code, you are very much encouraged and invited to contribute back your modifications to the community, preferably in a Github fork, of course.
git flow usage
Initialization
To initialize a new repo with the basic branch structure, use:
git flow init [-d]
This will then interactively prompt you with some questions on which branches you would like to use as development and production branches, and how you would like your prefixes be named. You may simply press Return on any of those questions to accept the (sane) default suggestions.
The -d
flag will accept all defaults.
Creating feature/release/hotfix/support branches
- To list/start/finish/delete feature branches, use:
git flow feature
git flow feature start <name> [<base>]
git flow feature finish <name>
git flow feature delete <name>
For feature branches, the <base>
arg must be a branch, when omitted it defaults to the develop branch.
- To push/pull a feature branch to the remote repository, use:
git flow feature publish <name>
git flow feature track <name>
- To list/start/finish/delete release branches, use:
git flow release
git flow release start <release> [<base>]
git flow release finish <release>
git flow release delete <release>
For release branches, the <base>
arg must be a branch, when omitted it defaults to the develop branch.
- To list/start/finish/delete hotfix branches, use:
git flow hotfix
git flow hotfix start <release> [<base>]
git flow hotfix finish <release>
git flow hotfix delete <release>
For hotfix branches, the <base>
arg must be a branch, when omitted it defaults to the production branch.
- To list/start support branches, use:
git flow support
git flow support start <release> <base>
For support branches, the <base>
arg must be a branch, when omitted it defaults to the production branch.
Share features with others
You can easily publish a feature you are working on. The reason can be to allow other programmers to work on it or to access it from another machine. The publish/track feature of gitflow simplify the creation of a remote branch and its tracking.
When you want to publish a feature just use:
git flow feature publish <name>
or, if you already are into the feature/<name>
branch, just issue:
git flow feature publish
Now if you execute git branch -avv
you will see that your branch feature/<name>
tracks [origin/feature/<name>]
. To track the same remote branch in another clone of the same repository use:
git flow feature track <name>
This will create a local feature feature/<name>
that tracks the same remote branch as the original one, that is origin/feature/<name>
.
When one developer (depending on your work flow) finishes working on the feature he or she can issue git flow feature finish <name>
and this will automatically delete the remote branch. All other developers shall then run:
git flow feature delete <name>
to get rid of the local feature that tracks a remote branch that no more exist.
Share hotfixes with others
You can publish an hotfix you are working on. The reason can be to allow other programmers to work on it or validate it or to access it from another machine.
When you want to publish an hotfix just use (as you did for features):
git flow hotfix publish <name>
or, if you already are into the hotfix/<name>
branch, just issue:
git flow hotfix publish
Other developers can now update their repositories and checkout the hotfix:
git pull
git checkout hotfix/<name>
and eventually finish it:
git flow hotfix finish
Using Hooks and Filters
For a wide variety of commands hooks or filters can be called before and after
the command.
The files should be placed in .git/hooks
In the directory hooks you can find examples of all the hooks available.
Showing your appreciation
Of course, the best way to show your appreciation for the git-flow tool itself remains contributing to the community. If you'd like to show your appreciation in another way, however, consider donating through PayPal:
Top Related Projects
From git log to SemVer in no time
Convert
designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot