前言
開發(fā)的mac機(jī)器只有256G的硬盤,工程代碼倉庫 clone 下來后少的10幾G,大的有60多G, 所以在日常的使用中,經(jīng)常會遇到磁盤空間不足的問題,頭痛不已。
我們是跨平臺開發(fā),git倉庫中會保存mac/linux兩個(gè)平臺所需要的所有文件。 其中 *.so 等一些文件在開發(fā)mac工程時(shí)是不需要的,可以使用sparse checkout功能在同步遠(yuǎn)程倉庫時(shí)候,不拉取這些文件,給磁盤留出多一些的可用空間。
本地沒有還沒有clone倉庫
可以執(zhí)行如下命令,只拉取指定的目錄下內(nèi)容
$ git init <project>
$ cd <project>
$ git remote add origin https://*****.git // 你的git倉庫地址
$ git config core.sparsecheckout true
$ echo "path1/" >> .git/info/sparse-checkout
$ echo "path2/" >> .git/info/sparse-checkout
$ git pull origin [branch] // 你的分支名稱
-
git init <project>: 建立一個(gè)空的版本庫 -
git remote add origin https://*****.git: 添加遠(yuǎn)程庫的地址 -
git config core.sparsecheckout true: 打開sparse checkout功能 -
echo "path1/" >> .git/info/sparse-checkout: 添加目錄到checkout的列表 ,也可以使用文本編輯 -
git pull origin [branch]: 拉取遠(yuǎn)程的分支
本地已clone了倉庫
- 1、打開 sparse checkout 功能
進(jìn)入版本庫的目錄,執(zhí)行以下命令
$ git config core.sparsecheckout true
.git/config 配置文件中可以看到新增了 sparsecheckout = true 的配置
[core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
ignorecase = true
precomposeunicode = true
sparsecheckout = true
- 2、 添加 checkout 列表
使用文本編輯打開.git/info/sparse-checkout文件 (沒有這個(gè)文件可以手動創(chuàng)建一個(gè))
添加如下列表。
/*
!/add_on/native_addon/kylinv4_ft1500a/*
!/add_on/native_addon/neokylin_lib/*
!/add_on/native_addon/ubuntu_lib/*
!/add_on/native_addon/uos_arm_lib/*
!*.so
- 3、 重新checkout
$ git checkout [branch] // 你的分支名稱
or
$ git read-tree -mu HEAD
sparse-checkout 文件設(shè)置
- 子目錄的匹配
在 sparse-checkout 文件中,如果目錄名稱前帶斜杠,如/docs/,將只匹配項(xiàng)目根目錄下的docs目錄,如果目錄名稱前不帶斜杠,如docs/,其他目錄下如果也有這個(gè)名稱的目錄,如test/docs/也能被匹配。
而如果寫了多級目錄,如docs/05/,則不管前面是否帶有斜杠,都只匹配項(xiàng)目根目錄下的目錄,如test/docs/05/不能被匹配fd- 通配符 ““ (星號)匹配
在 sparse-checkout 文件中,支持通配符 ““,如可以寫成以下格式:
docs/
index.
*.so
- 排除項(xiàng) “!” (感嘆號)匹配
在 sparse-checkout 文件中,也支持排除項(xiàng) “!”,如只想排除排除項(xiàng)目下的 “docs” 目錄,可以按如下格式寫:
/*
!/docs/
關(guān)閉sparsecheckout
要注意一點(diǎn):關(guān)閉sparsecheckout功能,全取整個(gè)項(xiàng)目庫,可以寫一個(gè)”“號,但如果有排除項(xiàng),必須寫”/“,同時(shí)排除項(xiàng)要寫在通配符后面。