`git flow release finish` non-interactively

2019-03-14 15:55发布

How I can use git flow release finish in a manner that doesn't ask for merge commit messages? The -m flag doesn't provide this, as I expected.

The goal of course is to be able to script this in such a way that doesn't require interaction.

6条回答
疯言疯语
2楼-- · 2019-03-14 16:20

git flow is (more or less) just a wrapper around git commands. Pop open the git-flow-*.sh of your choice, copy the git commands, and then mess with them. In this case, add --no-edit to git merge. This approach kills two birds with one stone: you can just copy these lines into your automation script.

查看更多
ゆ 、 Hurt°
3楼-- · 2019-03-14 16:23

Unfortunately there's no out-of-the-box way to achieve that with the current version of git-flow.

By looking at the source code, the git command used to merge is

git merge --no-ff

and there's no way to pass the --no-edit flag to it.

A couple of things you could do:

  • fork the project and insert this capability (possibly as an optional flag)
  • propose it as a feature and wait for the dev to implement it
查看更多
甜甜的少女心
4楼-- · 2019-03-14 16:25

You can set the environment variable

export GIT_MERGE_AUTOEDIT=no

git flow release -m 'Merge Message' release_branch_name

unset GIT_MERGE_AUTOEDIT

It won't invoke the editor for when you merge.

If you switch to my fork git-flow AVH Edition you can set this option to only work for when you use git-flow.

查看更多
forever°为你锁心
5楼-- · 2019-03-14 16:31

You can pass the -m flag to specify a tag message on the command line.

It is still possible for the merges to have conflicts, but the tag operation will not try to open an editor for the tag message.

git flow release finish -m "my awesome release" 1.2.3

https://github.com/nvie/gitflow/wiki/Command-Line-Arguments#git-flow-release-finish--fsumpkn-version

查看更多
够拽才男人
6楼-- · 2019-03-14 16:38

I had trouble with the -m flag. However if you give a message without spaces, it worked. Must be a bug.

git flow release finish -m 'my_message_with_no_spaces' 1.2.3
查看更多
女痞
7楼-- · 2019-03-14 16:38

I don't know about git flow, but if it supports standard git flags, you can use the --no-edit flag to avoid merge commit messages in an automated setting.

查看更多
登录 后发表回答