Git Fork 技巧


日常工作中,经常会遇到一种情况,看到别人写的好的 repo 希望能够学习瞻仰,一番观摩之后发现一些问题,因而需要对代码做一波修改,修改之后希望能够贡献在源代码上,但是又因为没有权限无法提交,这时候就可以使用 Fork了。


Fork 的主要作用

  1. 对该项目提出改动意见。
  2. 使用其它的人的项目作为自己项目的起点。
    这样你就可以在遵守Open source license的前提下任意修改这个项目了。

常用场景

  1. 对 repoA 进行 Fork,然后就可以在自己的github下看到该工程了,名为 repoB
  2. 若直接 clone repoB
  • 进行浏览或修改,commit之后可以直接提交在自己的 repoB 中;
  • 若希望修改也发生在 repoA中,则通过提 PR 的方式,则原 repoA accept后即可修改;
  1. 若直接 clone repoA
  • 进行浏览或修改,commit之后没有代码 push 权限,因为此时本地的 repo 关联的是 repoA;git remote -v可以查看
  • 则需要将 repoB也设为本地 repo 的远端代码,并设置远端repo的名字
    git remote add
    之后则可以像步骤2 一样进行其他的操作。
Tips
  1. 通常我们在分支上push代码时,会直接使用gp命令,这里其实是git push origin 的缩写,代表将当前分支push到origin远端分支上;
  2. 当我们在步骤3中为本地repo添加了第二个远端源之后,则当前repo有两个关联的远端repo,分别为originfork_repo,这时在分支上提交代码时不能再使用 gp, 需要使用 git push fork_repo 来完成push;

涉及知识点

  1. 使用 git remote -v 查看远程状态
git remote -v
origin  https://github.com/YOUR_USERNAME/YOUR_FORK.git (fetch)
origin  https://github.com/YOUR_USERNAME/YOUR_FORK.git (push)

通常 fetch 和 push 的两个远端源是同一个,当然也可以设置成不同的远端源,如从A源进行fetch,而去B源push提交。

  1. 为本地repo添加一个远端repo
git remote add  
git remote -v
origin    https://github.com/YOUR_USERNAME/YOUR_FORK.git (fetch)
origin    https://github.com/YOUR_USERNAME/YOUR_FORK.git (push)
upstream  https://github.com/ORIGINAL_OWNER/ORIGINAL_REPOSITORY.git (fetch)
upstream  https://github.com/ORIGINAL_OWNER/ORIGINAL_REPOSITORY.git (push)
  1. Push 本地代码到远端repo
git push  

你可能感兴趣的:(Git Fork 技巧)