Git Fork 技巧

2020-02-13  本文已影响0人  sunnyaxin

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


Fork 的主要作用

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

常用场景

  1. 对 repoA 进行 Fork,然后就可以在自己的github下看到该工程了,名为 repoB
  2. 若直接 clone repoB
  1. 若直接 clone repoA
Tips
  1. 通常我们在分支上push代码时,会直接使用gp命令,这里其实是git push origin <branch_name> 的缩写,代表将当前分支push到origin远端分支上;
  2. 当我们在步骤3中为本地repo添加了第二个远端源之后,则当前repo有两个关联的远端repo,分别为originfork_repo,这时在分支上提交代码时不能再使用 gp, 需要使用 git push fork_repo <branch_name>来完成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 <remote_repo_name> <remote_repo_github_address>
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 <remote_repo_name> <branch_name>
上一篇 下一篇

猜你喜欢

热点阅读