这个问题的后续:如果我有一个浅克隆,如何获取所有旧的提交,使它成为一个完整的克隆?
编辑:git fetch -unshallow现在是一个选项(感谢杰克·奥康纳)。
你可以运行git fetch——depth=2147483647
来自《shallow》的文档:
特殊深度2147483647(或0x7fffffff, 32位有符号整数可以包含的最大正数)表示无限深度。
下面的命令(git版本1.8.3)将把浅克隆转换为常规克隆
git fetch --unshallow
然后,访问所有分支的起源(感谢@Peter在评论中)
git config remote.origin.fetch "+refs/heads/*:refs/remotes/origin/*"
git fetch origin
我只需要将一个回购深化到一个特定的提交。
在阅读man git-fetch之后,我发现不能指定提交,但可以指定日期:
git fetch --shallow-since=15/11/2012
对于那些需要进一步深化的人,另一个人引用道:
——深化= <深度> 类似于——depth,只不过它指定了 从当前浅边界提交,而不是从尖端提交 每个远程分支历史的。
以上这些信息都没有起到作用。我试图从一个浅克隆开始与git标签工作。
首先我尝试了
git fetch --update-shallow
这种方法在中途起了作用。 然而,没有标签可用!
git fetch --depth=1000000
最后一个命令真的获取了标签,我终于可以执行了
git checkout -b master-v1.1.0 tags/v1.1.0
然后就完事了。
HTH
实现浅克隆到深克隆的两种方法。:
使用以下步骤下载分支:(下载分支的浅拷贝,然后将其转换为完整的克隆,即带来完整的分支及其历史)。 a. git clone -b branch http://git.repository/customSP01.git——深度1
这是一个浅克隆(使用depth-选项),只获取一个分支(在您所请求的深度)。
b. cd customSP01
c. git fetch --depth=100
d. get fetch --depth=500
....
e. git fetch --unshallow
//上面的命令将把浅克隆转换为普通克隆。 然而,这并没有带来所有的分支:
然后,访问所有的分支。
f. git remote set-branches origin '*'
[此步骤也可以通过编辑.git/config中的以下行手动完成。
Fetch = +refs/heads/master:refs/remotes/origin/master
To(用*替换master):
fetch = +refs/heads/*:refs/remotes/origin/* ]
g. git fetch -v
这将浅克隆转换为深克隆与所有的历史和分支细节。
你可以避免f和g步骤,如果你使用下面的命令代替步骤a中的命令来做浅克隆: git clone -b branch——no-single-branch http://git.repository/customSP01.git——深度1
推荐文章
- 如何在Visual Studio中删除未推送的外向提交?
- Git在两个不同的文件之间的差异
- 我如何使用vimdiff来解决git合并冲突?
- 如何将更改提交到另一个预先存在的分支
- 为什么使用'git rm'来删除文件而不是'rm'?
- 我如何安装imagemagick与自制?
- 致命:git-write-tree:错误构建树
- Git克隆远程存储库的特定版本
- git隐藏的意图用例是什么?
- 从远程Git存储库检索特定的提交
- 如何配置git bash命令行补全?
- 我如何迫使git拉覆盖每一个拉上的一切?
- 撤销“git add <dir>”?
- 是否可以在不先签出整个存储库的情况下进行稀疏签出?
- 如何移除SSH密钥?