Skip to content

LBEM Edition of the git extensions to provide high-level repository operations for Vincent Driessen's branching model

License

Notifications You must be signed in to change notification settings

LBEM-CH/gitflow-lbem

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1,307 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

git-flow (LBEM Edition)

A collection of Git extensions to provide high-level repository operations for Vincent Driessen's branching model.

About LBEM Edition

This is a fork of gitflow-cjs that adds workflow enhancements inspired by git-town. LBEM Edition stays close to the CJS version to easily pull upstream bugfixes while adding the following features:

Additional Commands

  • git flow feature sync / git flow bugfix sync - Sync your branch with the base branch (like git-town sync). Handles uncommitted changes automatically, supports rebase or merge strategy.
  • git flow feature propose / git flow bugfix propose - Create a pull request for your branch using gh CLI (falls back to opening browser URL).
  • git flow config export - Export gitflow settings to a .gitflow file for team sharing.

Configuration Enhancements

  • .gitflow file support - Store gitflow configuration in a shareable file. When a developer clones a repo with a .gitflow file and runs git flow init, settings are automatically imported.
  • Finish mode - Configure how finish behaves: classic (traditional merge), propose (create PR), or ask (prompt each time). Set via git flow config set finishmode <mode>.
  • Sync strategy - Choose rebase (default) or merge for sync operations. Set via git flow config set syncstrategy <strategy>.

macOS Compatibility

LBEM Edition includes fixes for macOS compatibility with BSD getopt. Install GNU getopt via Homebrew and set:

export FLAGS_GETOPT_CMD="/usr/local/opt/gnu-getopt/bin/getopt"

Upstream Projects

This project is based on and grateful to:

  • gitflow-cjs - The CJS Edition that continues maintenance after AVH was archived
  • gitflow-avh - The AVH Edition that extended the original gitflow
  • nvie/gitflow - The original gitflow implementation by Vincent Driessen

Why another git-flow fork?

The last commit to gitflow-avh was on May 23, 2019 and has been archived on Jun 19, 2023. Since 2019 there have been a number of issues opened that have not be resolved. gitflow-cjs continues maintenance but we needed additional workflow features for our team.

Getting started

For the best introduction to get started with git flow, please read Jeff Kreeftmeijer's blog post:

Using git-flow to automate your git branching workflow

Or have a look at one of these screen casts:

A quick cheatsheet was made by Daniel Kummer:

https://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 our fork of git-flow-completion which includes several additions for git-flow (CJS & 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>-lbem.<LBEM_REVISION>
  • CJS is the acronym of "CJ Systems"
  • LBEM is the acronym of "Laboratory of Biological Electron Microscopy"

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

Where to contribute?

  • LBEM Edition features (sync, propose, config export, .gitflow file support, finish mode): Please contribute to gitflow-lbem
  • General gitflow bugs and features: Please contribute to the upstream gitflow-cjs repository. We regularly pull in upstream changes.

Quick Start for LBEM Edition contributions

  • Fork and clone gitflow-lbem
  • Create a feature branch based off develop: git flow feature start my-feature
  • Commit your changes to the local branch
  • Push your feature branch: git flow feature publish
  • Create a pull request against the develop branch

Quick Start for general gitflow issues

  • Please fork and clone a local copy of gitflow-cjs
  • Create a separate issue branch based off develop
  • Commit your fix to the local branch
  • Please update your local copy with the latest develop branch of gitflow-cjs
  • Rebase develop onto your local branch
  • Push your fix to your fork
  • Submit a pull request

How to submit a pull request

For any new PRs related to gitflow-cjs you can use one of the keywords from Linking a pull request to an issue to automatically close the related issue.

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.

Screencast git flow init

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

Sync feature/bugfix branches (LBEM Edition)

To synchronize your feature branch with the latest changes from the develop branch, use:

git flow feature sync [<name>]

This command (inspired by git-town sync):

  • Stashes any uncommitted changes
  • Fetches from the remote
  • Rebases (or merges, depending on config) your branch onto the latest develop
  • Restores your stashed changes

You can configure the sync strategy:

git flow config set syncstrategy rebase   # default
git flow config set syncstrategy merge

Create pull requests (LBEM Edition)

Instead of merging locally with finish, you can create a pull request:

git flow feature propose [<name>]

This will:

  • Push your branch to the remote (if not already pushed)
  • Create a pull request using gh CLI (if available)
  • Fall back to opening the PR URL in your browser

You can also configure finish to always create a PR instead of merging:

git flow config set finishmode propose   # always create PR
git flow config set finishmode classic   # traditional merge (default)
git flow config set finishmode ask       # prompt each time

Export/Import configuration (LBEM Edition)

To share gitflow configuration with your team, export settings to a .gitflow file:

git flow config export

This creates a .gitflow file in your repository root that can be committed. When another developer clones the repo and runs git flow init, the settings are automatically imported.

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:

Donate

About

LBEM Edition of the git extensions to provide high-level repository operations for Vincent Driessen's branching model

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 98.5%
  • Other 1.5%