zoukankan      html  css  js  c++  java
  • linux下gitflow辅助工具安装和使用

    gitflow是一个确保nvie推荐的git branch分支策略最佳模型得到有效实施的辅助工具。它作为git的一个子命令而存在。 http://nvie.com/posts/a-successful-git-branching-model/

    linux下安装非常简单 https://github.com/nvie/gitflow/wiki/Linux

    $ yum install gitflow

    安装完成以后git flow xxx就可以使用了。

    git flow init [-d]

    list,start,finish一个feature:

    git flow feature
    git flow feature start <name> [<base>]
    git flow feature finish <name>

    注意,For feature branches, the <base> arg must be a commit on develop.

    push/pull一个feature branch到remote

    git flow feature publish <name>
    git flow feature pull <remote> <name>

    list,start,finish一个release branch:

    git flow release
    git flow release start <release> [<base>]
    git flow release finish <release>

    对于release branch来说,base一定是一个develop上的commit

    list,start,finish一个hotfix:

    git flow hotfix
    git flow hotfix start <release> [<base>]
    git flow hotfix finish <release>

    对于hotfix branch来说,base需要是一个master上的commit

    list,start support branch:

    git flow support
    git flow support start <release> <base>

    git flow中feature start/feature finish对应的底层操作log:

    $ git fs myawesomefeature
    git config --local gitflow.branch.feature/myawesomefeature.base dev
    Branches 'dev' and 'origin/dev' have diverged.
    And local branch 'dev' is ahead of 'origin/dev'.
    git checkout -b feature/myawesomefeature dev
    Switched to a new branch 'feature/myawesomefeature'
    
    Summary of actions:
    - A new branch 'feature/myawesomefeature' was created, based on 'dev'
    - You are now on branch 'feature/myawesomefeature'
    
    Now, start committing on your feature. When done, use:
    
         git flow feature finish myawesomefeature
    
    $ git ff
    git fetch -q origin feature/myawesomefeature:refs/remotes/origin/feature/myawesomefeature
    git checkout dev
    Switched to branch 'dev'
    Your branch is up-to-date with 'origin/dev'.
    git merge --no-ff feature/myawesomefeature
      GNU nano 2.2.6                    File: /home/vagrant/Code/newkidsit/.git/MERGE_MSG                                      Modified  
    
    Merge branch 'feature/myawesomefeature' into dev  
    
    # Please enter a commit message to explain why this merge is necessary,
    # especially if it merges an updated upstream into a topic branch.
    #
    # Lines starting with '#' will be ignored, and an empty message aborts
    # the commit.
    
    
    Save modified buffer (ANSWERING "No" WILL DESTROY CHANGES) ?                                                                         
    
    Merge made by the 'recursive' strategy.
     app/Models/Skill/Skill.php                                                           |   5 ++
     database/migrations/2016_10_16_191716_create_file_skill_pivot_table.php              |  39 +++++++++
     public/prebuild/assets/css/style.css                                                 |   3 +
     resources/assets/js/vueapp/src/components/pages/adminfiles/assets-manager.vue        | 179 +++++++++++++++++++++++++++-------------
     .../assets/js/vueapp/src/components/pages/adminfiles/file-upload-job-wrapper.vue     | 169 +++++++++++++++++++++++++++++++++++++
    git push origin :feature/myawesomefeature
    To git@github.com:myaccount/myrepo.git
     - [deleted]         feature/myawesomefeature
    git branch -d feature/myawesomefeature
    Deleted branch feature/myawesomefeature (was bf56c2d).
    
    Summary of actions:
    - The feature branch 'feature/myawesomefeature' was merged into 'dev'
    - Feature branch 'feature/myawesomefeature' has been locally deleted; it has been remotely deleted from 'origin'
    - You are now on branch 'dev'
    
    $ 
  • 相关阅读:
    在windows上使用win2000资源工具
    Apache与Tomcat整合
    web服务器和应用服务器概念比较
    linux定时删除N天前的文件(文件夹)
    程序员如何自我学习和成长?
    20210708总结
    Docker 常用命令!还有谁不会?
    Redis常用命令set
    laravel与thinkphp之间的区别与优缺点
    2021年7月总结
  • 原文地址:https://www.cnblogs.com/kidsitcn/p/4548678.html
Copyright © 2011-2022 走看看