我们有一个包含N个文件夹的git存储库。
Repo
|-Folder1
|-Folder2
|- ...
|-FolderN
对于不同的协作者,我们希望分享不同的文件夹。每个协作者只能访问其允许的文件夹子集。使用git实现这一目标的“好”方法是什么?
答案是使用git submodules
。但在我读完这篇文章之后:
https://codingkilledthecat.wordpress.com/2012/04/28/why-your-company-shouldnt-use-git-submodules/
我知道你需要掌握git(我们的合作者不是这样),以便在使用git submodules
时没有问题。
我读到了一些可能的替代方案,例如gitslave
和git subtree
。 gitslave
似乎是一个很好的解决方案,但在我看来仍然是一个复杂的解决方案。
这是我的简单解决方案,我想知道它是否有一些非常糟糕的缺点:
- 为每个文件夹和Repo存储库提供一个简单的存储库。然后在主Repo中添加Folder1,...,FolderN中的所有文件。
-globalpush脚本:
function globalpush(){
REPOS="$HOME/Repo/
$HOME/Repo/Folder1
$HOME/Repo/Folder2
$HOME/Repo/Folder3
# ...
$HOME/Repo/FolderN"
#do not show untracked files
git config status.showuntrackedfiles no
read -p "Commit description: " description
for repo in ${REPOS}
do
# if the repo folder exists
if [ -d $repo ]
then
# Go inside the repo
cd $repo
echo "-----PUSHING REPO : "$repo"-----"
#add all modified all deleted TRACKED files
git add -u .
git commit --allow-empty -m "$description"
git push
else
echo "-----COULD NOT FIND : "$repo"-----"
fi
done
#show untracked files again
git config status.showuntrackedfiles normal
}
-globalpull script:
function globalpull(){
REPOS="$HOME/Repo/
$HOME/Repo/Folder1
$HOME/Repo/Folder2
$HOME/Repo/Folder3
# ...
$HOME/Repo/FolderN"
for repo in ${REPOS}
do
# if the repo folder exists
if [ -d $repo ]
then
# Go inside the repo
cd $repo
# pull the modifs.
echo "-----PULLING REPO : "$repo"-----"
git pull
else
echo "-----COULD NOT FIND : "$repo"-----"
fi
done
}
此解决方案的优点是:
1 - 每个人都能理解的简单解决方案。
2 - 可以独立授予每个文件夹的访问权限。
3 - 对于主要开发人员(可以访问Repo),存储库Repo是自包含的,包含所有历史记录(如果Folder1,...,FolderN的存储库出现问题)。
4 - 当主开发人员使用给定描述进行提交时,将为所有文件夹存储库创建具有相同描述的提交,即使是那些没有修改的文件夹( - allow-empty),当然也不是完美但有助于跟踪主要开发者提交的版本。
编辑:
似乎有一个新的命令,我不知道git subrepo
...
答案 0 :(得分:3)
git-subtree是获胜的解决方案,实际上它以我更好的“git-native”方式完成了我用脚本做的事情。
以下是我们为设置环境所遵循的教程的链接。