-
A1. 附录 A: 在其它环境中使用 Git
- A1.1 图形界面
- A1.2 Visual Studio 中的 Git
- A1.3 Visual Studio Code 中的 Git
- A1.4 IntelliJ / PyCharm / WebStorm / PhpStorm / RubyMine 中的 Git
- A1.5 Sublime Text 中的 Git
- A1.6 Bash 中的 Git
- A1.7 Zsh 中的 Git
- A1.8 Git 在 PowerShell 中使用 Git
- A1.9 总结
-
A2. 附录 B: 在你的应用中嵌入 Git
- A2.1 命令行 Git 方式
- A2.2 Libgit2
- A2.3 JGit
- A2.4 go-git
- A2.5 Dulwich
-
A3. 附录 C: Git 命令
A3.5 附录 C: Git 命令 - 项目分享与更新
项目分享与更新
在 Git 中没有多少访问网络的命令,几乎所以的命令都是在操作本地的数据库。 当你想要分享你的工作,或者从其他地方拉取变更时,这有几个处理远程仓库的命令。
git fetch
git fetch
命令与一个远程的仓库交互,并且将远程仓库中有但是在当前仓库的没有的所有信息拉取下来然后存储在你本地数据库中。
我们开始在 从远程仓库中抓取与拉取 一节中介绍了此命令,然后我们在 远程分支 中看到了几个使用示例。
我们在 向一个项目贡献 一节中有几个示例中也都有使用此命令。
在 引用规范 章节中我们设置了高度自定义的 refspec
以便 git fetch
可以做一些跟默认不同的事情。
git pull
git pull
命令基本上就是 git fetch
和 git merge
命令的组合体,Git 从你指定的远程仓库中抓取内容,然后马上尝试将其合并进你所在的分支中。
我们在 从远程仓库中抓取与拉取 一节中快速介绍了此命令,然后在 查看某个远程仓库 一节中了解了如果你运行此命令的话,什么将会合并。
我们也在 用变基解决变基 一节中了解了如何使用此命令来来处理变基的难题。
在 检出冲突 一节中我们展示了使用此命令如何通过一个 URL 来一次性的拉取变更。
最后,我们在 签署提交 一节中我们快速的介绍了你可以使用 --verify-signatures
选项来验证你正在拉取下来的经过 GPG 签名的提交。
git push
git push
命令用来与另一个仓库通信,计算你本地数据库与远程仓库的差异,然后将差异推送到另一个仓库中。
它需要有另一个仓库的写权限,因此这通常是需要验证的。
我们开始在 推送到远程仓库 一节中介绍了 git push
命令。
在这一节中主要介绍了推送一个分支到远程仓库的基本用法。
在 推送 一节中,我们深入了解了如何推送指定分支,在 跟踪分支 一节中我们了解了如何设置一个默认的推送的跟踪分支。
在 删除远程分支 一节中我们使用 --delete
标志和 git push
命令来在删除一个在服务器上的分支。
在 向一个项目贡献 一整节中,我们看到了几个使用 git push
在多个远程仓库分享分支中的工作的示例。
在 共享标签 一节中,我们知道了如何使用此命令加 --tags
选项来分享你打的标签。
在 发布子模块改动 一节中,我们使用 --recurse-submodules
选项来检查是否我们所有的子模块的工作都已经在推送子项目之前已经推送出去了,当使用子模块时这真的很有帮助。
在 其它客户端钩子 中我们简单的提到了 pre-push
挂钩(hook),它是一个可以用来设置成在一个推送完成之前运行的脚本,以检查推送是否被允许。
最后,在 引用规范推送 一节中,我们知道了使用完整的 refspec 来推送,而不是通常使用的简写形式。 这对我们精确的指定要分享出去的工作很有帮助。
git remote
git remote
命令是一个是你远程仓库记录的管理工具。
它允许你将一个长的 URL 保存成一个简写的句柄,例如 origin
,这样你就可以不用每次都输入他们了。
你可以有多个这样的句柄,git remote
可以用来添加,修改,及删除它们。
此命令在 远程仓库的使用 一节中做了详细的介绍,包括列举、添加、移除、重命名功能。
几乎在此书的后续章节中都有使用此命令,但是一般是以 git remote add <name> <url>
这样的标准格式。
git submodule
git submodule
命令用来管理一个仓库的其他外部仓库。
它可以被用在库或者其他类型的共享资源上。
submodule
命令有几个子命令, 如(add
、update
、sync
等等)用来管理这些资源。
只在 子模块 章节中提到和详细介绍了此命令。