最近新公司学习相应的代码逻辑,使用SVN作为项目的托管工具,实属不大习惯,尤其对于用惯了git的人来说。一度想尝试使用git-svn的组合拳的方式,间接通过git来实现git才有的本地仓库。反正最终没落实,也就这样,去熟悉SVN的那一套逻辑,其实也还OK,接受范围之内。
不过,今天有个同事来问我git是否可以像SVN那样单独拉下仓库里的某个文件夹或者某些文件呢,毕竟整个项目结构这么庞大,不一定每个项目文件都是需要的,只需要拉下开发需求的文件就行。自认为git知识还是相当熟透的我,觉得问题应该不大,但是实操却发现,这有点难受,好像git并没有留下对应的命令操作方式。如果使用SVN还比较简单点,大体实现如下:
# 先checkout空目录
svn co--depthempty svnLocation localDir
# 对需要的子目录递归checkout
svn update--set-depthinfinity localDir/data
svn update--set-depthinfinity localDir/block
后来谷歌研究了下实现方法,原来还是有方式可以去实现的,我就觉得嘛,万能的git哪有实现不了的东西。于是我尝试进行了这么些操作,只能说感谢先人。
因为SVN是基于文件方式存储的,而git是基于元数据方式分别式存储文件信息的,注定每次clone的时候都会将所有信息都取回至本地,并在本地生成一个克隆版的版本库。但是发现在Git 1.7.0之后,新加入了Sparse checkout模式,可以实现指定checkout指定文件或者文件夹到本地。具体实现我们可以尝试下:
1. 创建一个文件夹checkout_part_from_git
2. 打开git bash,进入文件夹对应路径,执行git init初始化仓库
3. git remote add -f origin <url> 将远程URL加入到git config中
4. git config core.sparsecheckout true 允许config中使用Sparse checkout模式
5. 需要指定checkout哪个文件夹或者哪个文件
echo "game/region" >> .git/info/sparse-checkout
6. 最后将远程分支上的项目拉下来: git pull origin master
大功告成!
过程展示如下: